MCF5204

NXP MCF5204 Reference guide

  • Hello! I am an AI chatbot trained to assist you with the NXP MCF5204 Reference guide. I’ve already reviewed the document and can help you find the information you need or explain it in simple terms. Just ask your questions, and providing more details will help me assist you more effectively!
ColdFire
®
Family
Programmer’s Reference Manual
Document Number: CFPRM
Rev. 3
03/2005
Information in this document is provided solely to enable system and
software implementers to use Freescale Semiconductor products. There are
no express or implied copyright licenses granted hereunder to design or
fabricate any integrated circuits or integrated circuits based on the
information in this document.
Freescale Semiconductor reserves the right to make changes without further
notice to any products herein. Freescale Semiconductor makes no warranty,
representation or guarantee regarding the suitability of its products for any
particular purpose, nor does Freescale Semiconductor assume any liability
arising out of the application or use of any product or circuit, and specifically
disclaims any and all liability, including without limitation consequential or
incidental damages. “Typical” parameters that may be provided in Freescale
Semiconductor data sheets and/or specifications can and do vary in different
applications and actual performance may vary over time. All operating
parameters, including “Typicals”, must be validated for each customer
application by customer’s technical experts. Freescale Semiconductor does
not convey any license under its patent rights nor the rights of others.
Freescale Semiconductor products are not designed, intended, or authorized
for use as components in systems intended for surgical implant into the body,
or other applications intended to support or sustain life, or for any other
application in which the failure of the Freescale Semiconductor product could
create a situation where personal injury or death may occur. Should Buyer
purchase or use Freescale Semiconductor products for any such unintended
or unauthorized application, Buyer shall indemnify and hold Freescale
Semiconductor and its officers, employees, subsidiaries, affiliates, and
distributors harmless against all claims, costs, damages, and expenses, and
reasonable attorney fees arising out of, directly or indirectly, any claim of
personal injury or death associated with such unintended or unauthorized
use, even if such claim alleges that Freescale Semiconductor was negligent
regarding the design or manufacture of the part.
Freescale™ and the Freescale logo are trademarks of Freescale
Semiconductor, Inc. All other product or service names are the property
of their respective owners.© Freescale Semiconductor, Inc. 2004. All rights
reserved.
Document Number: CFPRM
Rev. 3
03/2005
How to Reach Us:
Home Page:
www.freescale.com
E-mail:
USA/Europe or Locations Not Listed:
Freescale Semiconductor
Technical Information Center, CH370
1300 N. Alma School Road
Chandler, Arizona 85224
+1-800-521-6274 or +1-480-768-2130
Europe, Middle East, and Africa:
Freescale Halbleiter Deutschland GmbH
Technical Information Center
Schatzbogen 7
81829 Muenchen, Germany
+44 1296 380 456 (English)
+46 8 52200080 (English)
+49 89 92103 559 (German)
+33 1 69 35 48 48 (French)
Japan:
Freescale Semiconductor Japan Ltd.
Headquarters
ARCO Tower 15F
1-8-1, Shimo-Meguro, Meguro-ku,
Tokyo 153-0064, Japan
0120 191014 or +81 3 5437 9125
Asia/Pacific:
Freescale Semiconductor Hong Kong Ltd.
Technical Information Center
2 Dai King Street
Tai Po Industrial Estate
Tai Po, N.T., Hong Kong
+800 2666 8080
For Literature Requests Only:
Freescale Semiconductor Literature Distribution Center
P.O. Box 5405
Denver, Colorado 80217
1-800-441-2447 or 303-675-2140
Fax: 303-675-2150
LDCForFreescaleSemiconductor@hibbertgroup.com
1
2
3
4
5
7
8
10
11
6
IND
Introduction
Addressing Capabilities
Instruction Set Summary
Integer User Instructions
MAC User Instructions
EMAC User Instructions
FPU User Instructions
Supervisor Instructions
Exception Processing
PST/DDATA Encodings
Index
A
S-Record Output Format
9
Instruction Format Summary
Introduction
Addressing Capabilities
Instruction Set Summary
Integer User Instructions
MAC User Instructions
EMAC User Instructions
FPU User Instructions
Supervisor Instructions
Exception Processing
PST/DDATA Encodings
Index
S-Record Output Format
Instruction Format Summary
1
2
3
4
5
7
8
10
11
6
IND
A
9
ColdFire Family Programmer’s Reference Manual, Rev. 3
Freescale Semiconductor iii
Contents
Paragraph
Number
Title
Page
Number
Chapter 1
Introduction
1.1 Integer Unit User Programming Model .......................................................................... 1-2
1.1.1 Data Registers (D0–D7) .............................................................................................. 1-2
1.1.2 Address Registers (A0–A7) ........................................................................................ 1-2
1.1.3 Program Counter (PC) ................................................................................................ 1-2
1.1.4 Condition Code Register (CCR) ................................................................................. 1-2
1.2 Floating-Point Unit User Programming Model .............................................................. 1-3
1.2.1 Floating-Point Data Registers (FP0–FP7) .................................................................. 1-4
1.2.1.1 Floating-Point Control Register (FPCR) ................................................................ 1-4
1.2.2 Floating-Point Status Register (FPSR) ....................................................................... 1-5
1.2.3 Floating-Point Instruction Address Register (FPIAR) ................................................ 1-6
1.3 MAC User Programming Model .................................................................................... 1-6
1.3.1 MAC Status Register (MACSR) ................................................................................. 1-7
1.3.2 MAC Accumulator (ACC) .......................................................................................... 1-7
1.3.3 MAC Mask Register (MASK) .................................................................................... 1-7
1.4 EMAC User Programming Model .................................................................................. 1-8
1.4.1 MAC Status Register (MACSR) ................................................................................. 1-8
1.4.2 MAC Accumulators (ACC[0:3]) ................................................................................ 1-9
1.4.3 Accumulator Extensions (ACCext01, ACCext23) ................................................... 1-10
1.4.4 MAC Mask Register (MASK) .................................................................................. 1-10
1.5 Supervisor Programming Model ................................................................................... 1-11
1.5.1 Status Register (SR) .................................................................................................. 1-12
1.5.2 Supervisor/User Stack Pointers (A7 and OTHER_A7) ............................................ 1-13
1.5.3 Vector Base Register (VBR) ..................................................................................... 1-13
1.5.4 Cache Control Register (CACR) .............................................................................. 1-13
1.5.5 Address Space Identifier (ASID) .............................................................................. 1-13
1.5.6 Access Control Registers (ACR0–ACR3) ................................................................ 1-14
1.5.7 MMU Base Address Register (MMUBAR) ............................................................. 1-14
1.5.8 RAM Base Address Registers (RAMBAR0/RAMBAR1) ....................................... 1-14
1.5.9 ROM Base Address Registers (ROMBAR0/ROMBAR1) ....................................... 1-14
1.5.10 Module Base Address Register (MBAR) ................................................................. 1-15
1.6 Integer Data Formats .................................................................................................... 1-15
1.7 Floating-Point Data Formats ......................................................................................... 1-16
1.7.1 Floating-Point Data Types ........................................................................................ 1-16
1.7.1.1 Normalized Numbers ............................................................................................ 1-16
1.7.1.2 Zeros ..................................................................................................................... 1-16
1.7.1.3 Infinities ................................................................................................................ 1-16
ColdFire Family Programmer’s Reference Manual, Rev. 3
iv Freescale Semiconductor
Contents
Paragraph
Number
Title
Page
Number
1.7.1.4 Not-A-Number ...................................................................................................... 1-17
1.7.1.5 Denormalized Numbers ........................................................................................ 1-17
1.7.2 FPU Data Format and Type Summary ..................................................................... 1-17
1.8 Multiply Accumulate Data Formats ............................................................................. 1-19
1.9 Organization of Data in Registers ................................................................................. 1-19
1.9.1 Organization of Integer Data Formats in Registers .................................................. 1-19
1.9.2 Organization of Integer Data Formats in Memory ................................................... 1-20
1.10 Hardware Configuration Information ........................................................................... 1-21
Chapter 2
Addressing Capabilities
2.1 Instruction Format ........................................................................................................... 2-1
2.2 Effective Addressing Modes ........................................................................................... 2-2
2.2.1 Data Register Direct Mode ......................................................................................... 2-3
2.2.2 Address Register Direct Mode .................................................................................... 2-3
2.2.3 Address Register Indirect Mode ................................................................................. 2-3
2.2.4 Address Register Indirect with Postincrement Mode ................................................. 2-4
2.2.5 Address Register Indirect with Predecrement Mode .................................................. 2-4
2.2.6 Address Register Indirect with Displacement Mode .................................................. 2-5
2.2.7 Address Register Indirect with Scaled Index and 8-Bit Displacement Mode ............ 2-6
2.2.8 Program Counter Indirect with Displacement Mode .................................................. 2-6
2.2.9 Program Counter Indirect with Scaled Index and 8-Bit Displacement Mode ............ 2-7
2.2.10 Absolute Short Addressing Mode ............................................................................... 2-8
2.2.11 Absolute Long Addressing Mode ............................................................................... 2-9
2.2.12 Immediate Data ...........................................................................................................2-9
2.2.13 Effective Addressing Mode Summary ...................................................................... 2-10
2.3 Stack .............................................................................................................................. 2-10
Chapter 3
Instruction Set Summary
3.1 Instruction Summary ....................................................................................................... 3-1
3.1.1 Data Movement Instructions ....................................................................................... 3-4
3.1.2 Program Control Instructions ...................................................................................... 3-5
3.1.3 Integer Arithmetic Instructions ................................................................................... 3-6
3.1.4 Floating-Point Arithmetic Instructions ....................................................................... 3-8
3.1.5 Logical Instructions .................................................................................................... 3-9
3.1.6 Shift Instructions ......................................................................................................... 3-9
3.1.7 Bit Manipulation Instructions ................................................................................... 3-10
ColdFire Family Programmer’s Reference Manual, Rev. 3
Freescale Semiconductor v
Contents
Paragraph
Number
Title
Page
Number
3.1.8 System Control Instructions ...................................................................................... 3-11
3.1.9 Cache Maintenance Instructions ............................................................................... 3-12
3.2 Instruction Set Summary .............................................................................................. 3-12
3.3 ColdFire Core Summary ............................................................................................... 3-19
Chapter 4
Integer User Instructions
Chapter 5
Multiply-Accumulate Unit (MAC) User Instructions
Chapter 6
Enhanced Multiply-Accumulate Unit (EMAC) User Instructions
Chapter 7
Floating-Point Unit (FPU)
User Instructions
7.1 Floating-Point Status Register (FPSR) ........................................................................... 7-1
7.2 Conditional Testing .........................................................................................................7-3
7.3 Instruction Results when Exceptions Occur ................................................................... 7-6
7.4 Key Differences between ColdFire and MC680x0 FPU Programming Models ........... 7-7
7.5 Instruction Descriptions .................................................................................................. 7-9
Chapter 8
Supervisor (Privileged) Instructions
Chapter 9
Instruction Format Summary
9.1 Operation Code Map ....................................................................................................... 9-1
Chapter 10
PST/DDATA Encodings
10.1 User Instruction Set ...................................................................................................... 10-1
10.2 Supervisor Instruction Set ............................................................................................. 10-7
ColdFire Family Programmer’s Reference Manual, Rev. 3
vi Freescale Semiconductor
Contents
Paragraph
Number
Title
Page
Number
Chapter 11
Exception Processing
11.1 Overview ....................................................................................................................... 11-1
11.1.1 Supervisor/User Stack Pointers (A7 and OTHER_A7) ............................................ 11-3
11.1.2 Exception Stack Frame Definition ............................................................................ 11-4
11.1.3 Processor Exceptions ................................................................................................ 11-5
11.1.4 Floating-Point Arithmetic Exceptions ...................................................................... 11-5
11.1.5 Branch/Set on Unordered (BSUN) ........................................................................... 11-7
11.1.6 Input Not-A-Number (INAN) ................................................................................... 11-7
11.1.7 Input Denormalized Number (IDE) .......................................................................... 11-8
11.1.8 Operand Error (OPERR) ........................................................................................... 11-8
11.1.9 Overflow (OVFL) ..................................................................................................... 11-9
11.1.10 Underflow (UNFL) ................................................................................................... 11-9
11.1.11 Divide-by-Zero (DZ) .............................................................................................. 11-10
11.1.12 Inexact Result (INEX) ............................................................................................ 11-10
11.1.13 MMU Changes to the Exception Processing Model ............................................... 11-11
Appendix A
S-Record Output Format
A.1 S-Record Content 1
A.2 S-Record Types 1
A.3 S-Record Creation 2
ColdFire Family Programmer’s Reference Manual, Rev. 3
Freescale Semiconductor vii
Figures
Figure
Number
Title
Page
Number
1-1 ColdFire Family User Programming Model............................................................................. 1-2
1-2 Condition Code Register (CCR) ............................................................................................... 1-3
1-3 ColdFire Family Floating-Point Unit User Programming Model............................................. 1-4
1-4 Floating-Point Control Register (FPCR) .................................................................................. 1-4
1-5 Floating-Point Status Register (FPSR) ..................................................................................... 1-5
1-6 MAC Unit Programming Model............................................................................................... 1-7
1-7 MAC Status Register (MACSR)............................................................................................... 1-7
1-8 EMAC Programming Model .................................................................................................... 1-8
1-9 MAC Status Register (MACSR)............................................................................................... 1-8
1-10 EMAC Fractional Alignment.................................................................................................... 1-9
1-11 EMAC Signed and Unsigned Integer Alignment ................................................................... 1-10
1-12 Accumulator 0 and 1 Extensions (ACCext01) ....................................................................... 1-10
1-13 Accumulator 2 and 3 Extensions (ACCext01) ....................................................................... 1-10
1-14 Supervisor Programming Model............................................................................................. 1-11
1-15 Status Register (SR)................................................................................................................ 1-12
1-16 Vector Base Register (VBR)................................................................................................... 1-13
1-17 MMU Base Address Register ................................................................................................. 1-14
1-18 Module Base Address Register (MBAR) ............................................................................... 1-15
1-19 Normalized Number Format................................................................................................... 1-16
1-20 Zero Format ............................................................................................................................ 1-16
1-21 Infinity Format........................................................................................................................ 1-17
1-22 Not-a-Number Format ............................................................................................................ 1-17
1-23 Denormalized Number Format ............................................................................................... 1-17
1-24 Two’s Complement, Signed Fractional Equation................................................................... 1-19
1-25 Organization of Integer Data Format in Data Registers ......................................................... 1-20
1-26 Organization of Addresses in Address Registers.................................................................... 1-20
1-27 Memory Operand Addressing................................................................................................. 1-21
1-28 Memory Organization for Integer Operands........................................................................... 1-21
1-29 D0 Processor Configuration.................................................................................................... 1-22
1-30 D1 Local Memory Configuration ........................................................................................... 1-24
2-1 Instruction Word General Format............................................................................................. 2-1
2-2 Instruction Word Specification Formats................................................................................... 2-2
2-3 Data Register Direct.................................................................................................................. 2-3
2-4 Address Register Direct .....................................................................................................
....... 2-3
2-5 Address Register Indirect.......................................................................................................... 2-3
2-6 Address Register Indirect with Postincrement.......................................................................... 2-4
2-7 Address Register Indirect with Predecrement .......................................................................... 2-5
2-8 Address Register Indirect with Displacement .......................................................................... 2-5
2-9 Address Register Indirect with Scaled Index and 8-Bit Displacement..................................... 2-6
ColdFire Family Programmer’s Reference Manual, Rev. 3
viii Freescale Semiconductor
Figures
Figure
Number
Title
Page
Number
2-10 Program Counter Indirect with Displacement .......................................................................... 2-7
2-11 Program Counter Indirect with Scaled Index and 8-Bit Displacement .................................... 2-8
2-12 Absolute Short Addressing ....................................................................................................... 2-8
2-13 Absolute Long Addressing ....................................................................................................... 2-9
2-14 Immediate Data Addressing...................................................................................................... 2-9
2-15 Stack Growth from High Memory to Low Memory............................................................... 2-11
2-16 Stack Growth from Low Memory to High Memory............................................................... 2-11
7-1 Floating-Point Status Register (FPSR) ..................................................................................... 7-1
11-1 Exception Stack Frame ........................................................................................................... 11-4
ColdFire Family Programmer’s Reference Manual, Rev. 3
Freescale Semiconductor ix
Tables
Table
Number
Title
Page
Number
1-1 CCR Bit Descriptions ............................................................................................................... 1-3
1-2 FPCR Field Descriptions .......................................................................................................... 1-4
1-3 FPSR Field Descriptions........................................................................................................... 1-5
1-4 MACSR Field Descriptions ...................................................................................................... 1-7
1-5 MACSR Field Descriptions ...................................................................................................... 1-8
1-6 Implemented Supervisor Registers by Device........................................................................ 1-11
1-7 Status Field Descriptions ........................................................................................................ 1-12
1-8 MMU Base Address Register Field Descriptions................................................................... 1-14
1-9 MBAR Field Descriptions ......................................................................................................1-15
1-10 Integer Data Formats .............................................................................................................. 1-15
1-11 Real Format Summary ............................................................................................................ 1-18
1-12 D0 Processor Configuration Field Descriptions ..................................................................... 1-22
1-13 D1 Local Memory Field Descriptions .................................................................................... 1-24
2-1 Instruction Word Format Field Definitions .............................................................................. 2-2
2-2 Immediate Operand Location ...................................................................................................2-9
2-3 Effective Addressing Modes and Categories.......................................................................... 2-10
3-1 Notational Conventions ............................................................................................................ 3-1
3-2 Data Movement Operation Format ........................................................................................... 3-4
3-3 Program Control Operation Format .......................................................................................... 3-5
3-4 Integer Arithmetic Operation Format ....................................................................................... 3-6
3-5 Dyadic Floating-Point Operation Format ................................................................................. 3-8
3-6 Dyadic Floating-Point Operations ............................................................................................ 3-8
3-7 Monadic Floating-Point Operation Format............................................................................... 3-8
3-8 Monadic Floating-Point Operations.......................................................................................... 3-8
3-9 Logical Operation Format......................................................................................................... 3-9
3-10 Shift Operation Format ........................................................................................................... 3-10
3-11 Bit Manipulation Operation Format ....................................................................................... 3-10
3-12 System Control Operation Format .......................................................................................... 3-11
3-13 Cache Maintenance Operation Format ................................................................................... 3-12
3-14 ColdFire User Instruction Set Summary................................................................................. 3-13
3-15 ColdFire Supervisor Instruction Set Summary....................................................................... 3-18
3-16 ColdFire Instruction Set and Processor Cross-Reference....................................................... 3-19
7-1 FPSR Field Descriptions........................................................................................................... 7-1
7-2 FPSR EXC Bits......................................................................................................................... 7-3
7-3 FPCC Encodings....................................................................................................................... 7-4
7-4 Floating-Point Conditional Tests .............................................................................................. 7-5
7-5 FPCR EXC Byte Exception Enabled/Disabled Results............................................................ 7-6
7-6 Key Programming Model Differences...................................................................................... 7-8
7-7 68K/ColdFire Operation Sequence 1........................................................................................ 7-8
Tables
Table
Number
Title
Page
Number
ColdFire Family Programmer’s Reference Manual, Rev. 3
x Freescale Semiconductor
7-8 68K/ColdFire Operation Sequence 2........................................................................................ 7-8
7-9 68K/ColdFire Operation Sequence 3........................................................................................ 7-9
7-10 Data Format Encoding ........................................................................................................... 7-10
8-1 State Frames.............................................................................................................................. 8-3
8-2 State Frames.............................................................................................................................. 8-5
8-3 ColdFire CPU Space Assignments ......................................................................................... 8-13
9-1 Operation Code Map................................................................................................................. 9-1
10-1 PST/DDATA Specification for User-Mode Instructions........................................................ 10-1
10-2 PST/DDATA Values for User-Mode Multiply-Accumulate Instructions .............................. 10-5
10-3 PST/DDATA Values for User-Mode Floating-Point Instructions ......................................... 10-6
10-4 Data Markers and FPU Operand Format Specifiers ............................................................... 10-7
10-5 PST/DDATA Specifications for Supervisor-Mode Instructions ............................................ 10-7
11-1 Exception Vector Assignments............................................................................................... 11-2
11-2 Format/Vector Word............................................................................................................... 11-4
11-3 Exception Priorities................................................................................................................. 11-5
11-4 BSUN Exception Enabled/Disabled Results .......................................................................... 11-7
11-5 INAN Exception Enabled/Disabled Results ........................................................................... 11-7
11-6 IDE Exception Enabled/Disabled Results .............................................................................. 11-8
11-7 Possible Operand Errors ......................................................................................................... 11-8
11-8 OPERR Exception Enabled/Disabled Results ........................................................................ 11-9
11-9 OVFL Exception Enabled/Disabled Results........................................................................... 11-9
11-10 UNFL Exception Enabled/Disabled Results......................................................................... 11-10
11-11 DZ Exception Enabled/Disabled Results.............................................................................. 11-10
11-12 Inexact Rounding Mode Values ........................................................................................... 11-11
11-13 INEX Exception Enabled/Disabled Results ......................................................................... 11-11
11-14 OEP EX Cycle Operations.................................................................................................... 11-12
ColdFire Family Programmer’s Reference Manual, Rev. 3
Freescale Semiconductor 1-1
Chapter 1
Introduction
This manual contains detailed information about the instruction set architecture (ISA) for all versions of
ColdFire® microprocessors. Within the ColdFire Family, each generation of hardware microarchitecture
is known as a Version, beginning with the original Version 2 (V2) core implementation, the first native
ColdFire processor implementation. Within the instruction set architectures, each definition is known as
an ISA_Revision and labeled as ISA_Revision_A, ISA_Revision_B, etc. These ISA revisions are
commonly described using a short-form nomenclature as ISA_A, ISA_B, etc.
The original ColdFire ISA was developed from a reduced version of the M68000 instruction set that was
targeted to hit a “sweet-spot” representing the minimum of both code expansion (both static and dynamic)
and hardware gate count. The original instruction set architecture (the ISA_A specification) supported a
proper subset of the M68000 opcodes along with selected enhancements from the M68020, and provided
an acceptable trade-off between minimization of code expansion and core gate count, while fully retaining
the user-mode programming model from the M68K Family.
As the ColdFire Family grew, input from users and tool developers as well as internal performance analysis
suggested a number of ISA enhancements could improve performance and code density. Accordingly,
different revisions to the baseline instruction set architecture have been defined and implemented in the
various ColdFire processor cores. In addition, optional hardware execution engines targeted for specific
application areas required the creation of new ISA extensions. Examples of these extensions are the
hardware floating-point unit (FPU) and varieties of multiply-accumulate (MAC) units.
ColdFire legacy had a correspondence between the processor microarchitecture generation and a
instruction set architecture revision. As newer instructions have been implemented on earlier core
versions, that association has blurred over time. This manual defines the instruction set in terms of the
specific ISA revision rather than an association with any given processor version.
The available ISA revisions are:
ISA_A: The original ColdFire instruction set architecture
ISA_B: Added improved data movement instructions, byte- and word-sized compares,
miscellaneous enhancements
ISA_C: Added instructions for improved bit manipulation
FPU: Original ColdFire instruction set architecture for floating-point unit (FPU)
MAC: Original ColdFire instruction set architecture for multiply-accumulate unit (MAC)
EMAC: Revised ISA for enhanced multiply-accumulate unit (EMAC)
EMAC_B: Added instructions for dual-accumulation operations
These represent the major revisions of the instruction set architecture. In addition, there are expanded ISA
revisions, e.g., ISA_A+, created by combining a major revision with selected instructions from other
revisions.
Information on the processor configuration is generally loaded into 2 program-visible registers at system
reset. This information defines the ColdFire core version as well as the implemented ISA revision. See
Section 1.1, “Integer Unit User Programming Model.
The ColdFire Family programming model consists of two register groups: user and supervisor. Programs
executing in the user mode use only the registers in the user group. System software executing in the
supervisor mode can access all registers and use the control registers in the supervisor group to perform
supervisor functions. The following paragraphs provide a brief description of the registers in the user and
supervisor models as well as the data organization in the registers.
ColdFire Family Programmer’s Reference Manual, Rev. 3
1-2 Freescale Semiconductor
1.1 Integer Unit User Programming Model
Figure 1-1 illustrates the integer portion of the user programming model. It consists of the following
registers:
16 general-purpose 32-bit registers (D0–D7, A0–A7)
32-bit program counter (PC)
8-bit condition code register (CCR)
Figure 1-1. ColdFire Family User Programming Model
1.1.1 Data Registers (D0–D7)
These registers are for bit, byte (8 bits), word (16 bits), and longword (32 bits) operations. They can also
be used as index registers.
1.1.2 Address Registers (A0–A7)
These registers serve as software stack pointers, index registers, or base address registers. The base address
registers can be used for word and longword operations. Register A7 functions as a hardware stack pointer
during stacking for subroutine calls and exception handling.
1.1.3 Program Counter (PC)
The program counter (PC) contains the address of the instruction currently executing. During instruction
execution and exception processing, the processor automatically increments the contents or places a new
value in the PC. For some addressing modes, the PC can serve as a pointer for PC relative addressing.
1.1.4 Condition Code Register (CCR)
Consisting of 5 bits, the condition code register (CCR)—the status registers lower byte—is the only
portion of the SR available in the user mode. Many integer instructions affect the CCR and indicate the
31 0
D0 Data registers
D1
D2
D3
D4
D5
D6
D7
31 0
A0 Address registers
A1
A2
A3
A4
A5
A6
A7 Stack pointer
PC Program counter
CCR Condition code register
Floating-Point Unit User Programming Model
ColdFire Family Programmer’s Reference Manual, Rev. 3
Freescale Semiconductor 1-3
instruction’s result. Program and system control instructions also use certain combinations of these bits to
control program and system flow.
The condition codes meet two criteria:
1. Consistency across:
Instructions, meaning that all instructions that are special cases of more general instructions
affect the condition codes in the same way;
Uses, meaning that conditional instructions test the condition codes similarly and provide the
same results whether a compare, test, or move instruction sets the condition codes; and
Instances, meaning that all instances of an instruction affect the condition codes in the same
way.
2. Meaningful results with no change unless it provides useful information.
Bits [3:0] represent a condition of the result generated by an operation. Bit 5, the extend bit, is an operand
for multiprecision computations. Version 3 processors have an additional bit in the CCR: bit 7, the branch
prediction bit.
The CCR is illustrated in Figure 1-2.
Figure 1-2. Condition Code Register (CCR)
Table 1-1 describes CCR bits.
1.2 Floating-Point Unit User Programming Model
The following paragraphs describe the registers for the optional ColdFire floating-point unit. Figure 1-3
illustrates the user programming model for the floating-point unit. It contains the following registers:
76543210
P
1
—XNZVC
1
The P bit is implemented only on the V3 core.
Table 1-1. CCR Bit Descriptions
Bits Field Description
7 P Branch prediction (Version 3 only). Alters the static prediction algorithm used by the
branch acceleration logic in the instruction fetch pipeline on forward conditional
branches. Refer to a V3 core or device user’s manual for further information on this bit.
Reserved; should be cleared (all other versions).
6–5 Reserved, should be cleared.
4 X Extend. Set to the value of the C-bit for arithmetic operations; otherwise not affected or
set to a specified result.
3 N Negative. Set if the most significant bit of the result is set; otherwise cleared.
2 Z Zero. Set if the result equals zero; otherwise cleared.
1 V Overflow. Set if an arithmetic overflow occurs implying that the result cannot be
represented in the operand size; otherwise cleared.
0 C Carry. Set if a carry out of the most significant bit of the operand occurs for an addition,
or if a borrow occurs in a subtraction; otherwise cleared.
ColdFire Family Programmer’s Reference Manual, Rev. 3
1-4 Freescale Semiconductor
8 64-bit floating-point data registers (FP0–FP7)
32-bit floating-point control register (FPCR)
32-bit floating-point status register (FPSR)
32-bit floating-point instruction address register (FPIAR)
Figure 1-3. ColdFire Family Floating-Point Unit User Programming Model
1.2.1 Floating-Point Data Registers (FP0–FP7)
Floating-point data registers are analogous to the integer data registers for the 68K/ColdFire family. The
64-bit floating-point data registers always contain numbers in double-precision format. All external
operands, regardless of the source data format, are converted to double-precision values before being used
in any calculation or being stored in a floating-point data register. A reset or a null-restore operation sets
FP0–FP7 to positive, nonsignaling not-a-numbers (NANs).
1.2.1.1 Floating-Point Control Register (FPCR)
The FPCR, Figure 1-4, contains an exception enable byte (EE) and a mode control byte (MC). The user
can read or write to FPCR using FMOVE or FRESTORE. A processor reset or a restore operation of the
null state clears the FPCR. When this register is cleared, the FPU never generates exceptions.
Figure 1-4. Floating-Point Control Register (FPCR)
Table 1-2 describes FPCR fields.
31 16 15 14 13 12 11 10 9 8 7 6 5 4 3 0
BSUN INAN OPERR OVFL UNFL DZ INEX IDE PREC RND
Table 1-2. FPCR Field Descriptions
Bits Field Description
31–16 Reserved, should be cleared.
15–8 EE Exception enable byte. Each EE bit corresponds to a floating-point exception class. The user can
separately enable traps for each class of floating-point exceptions.
15 BSUN Branch set on unordered
14 INAN Input not-a-number
13 OPERR Operand error
12 OVFL Overflow
11 UNFL Underflow
10 DZ Divide by zero
9 INEX Inexact operation
8 IDE Input denormalized
Exception Enable Byte (EE) Mode Control Byte (MC)
Floating-Point Unit User Programming Model
ColdFire Family Programmer’s Reference Manual, Rev. 3
Freescale Semiconductor 1-5
1.2.2 Floating-Point Status Register (FPSR)
The FPSR, Figure 1-5, contains a floating-point condition code byte (FPCC), a floating-point exception
status byte (EXC), and a floating-point accrued exception byte (AEXC). The user can read or write all
FPSR bits. Execution of most floating-point instructions modifies FPSR. FPSR is loaded by using
FMOVE or FRESTORE. A processor reset or a restore operation of the null state clears the FPSR.
Figure 1-5. Floating-Point Status Register (FPSR)
Table 1-3 describes FPSR fields.
7–0 MC Mode control byte. Controls FPU operating modes.
7 Reserved, should be cleared.
6 PREC Rounding precision
5–4 RND Rounding mode
3–0 Reserved, should be cleared.
31 28 27 26 25 24 23 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 0
NZ INAN
BSUN INAN OPERR OVFL UNFL DZ INEX IDE IOP OVFL UNFL DZ INEX
Table 1-3. FPSR Field Descriptions
Bits Field Description
31–24 FPCC Floating-point condition code byte. Contains four condition code bits that are set after completion
of all arithmetic instructions involving the floating-point data registers.
31–28 Reserved, should be cleared.
27 N Negative
26 FPPC
(cont.)
ZZero
25 I Infinity
24 NAN Not-a-number
23–16 Reserved, should be cleared.
Table 1-2. FPCR Field Descriptions (Continued)
Bits Field Description
FPCC Exception Status Byte (EXC) AEXC Byte
ColdFire Family Programmer’s Reference Manual, Rev. 3
1-6 Freescale Semiconductor
1.2.3 Floating-Point Instruction Address Register (FPIAR)
The ColdFire operand execution pipeline can execute integer and floating-point instructions
simultaneously. As a result, the PC value stacked by the processor in response to a floating-point exception
trap may not point to the instruction that caused the exception.
For those FPU instructions that can generate exception traps, the 32-bit FPIAR is loaded with the
instruction PC address before the FPU begins execution. In case of an FPU exception, the trap handler can
use the FPIAR contents to determine the instruction that generated the exception. FMOVE to/from the
FPCR, FPSR, or FPIAR and FMOVEM instructions cannot generate floating-point exceptions and so do
not modify FPIAR. A reset or a null-restore operation clears FPIAR.
1.3 MAC User Programming Model
The following paragraphs describe the registers for the optional ColdFire MAC unit. Figure 1-6 illustrates
the user programming model for the MAC unit. It contains the following registers:
32-bit MAC status register (MACSR)
32-bit accumulator register (ACC)
32-bit MAC mask register (MASK)
15–8 EXC Exception status byte. Contains a bit for each floating-point exception that might have occurred
during the most recent arithmetic instruction or move operation.
15 BSUN Branch/set on unordered
14 INAN Input not-a-number
13 OPERR Operand error
12 OVFL Overflow
11 UNFL Underflow
10 DZ Divide by zero
9 INEX Inexact operation
8 IDE Input denormalization
7–0 AEXC Accrued exception byte. Contains 5 exception bits the IEEE 754 standard requires for
exception-disabled operations. These exceptions are logical combinations of bits in the EXC byte.
AEXC records all floating-point exceptions since the user last cleared AEXC.
7 IOP Invalid operation
6 OVFL Underflow
5 UNFL Divide By Zero
4 DZ Inexact Operation
3 INEX Input Denormalization
2–0 Reserved, should be cleared.
Table 1-3. FPSR Field Descriptions (Continued)
Bits Field Description
MAC User Programming Model
ColdFire Family Programmer’s Reference Manual, Rev. 3
Freescale Semiconductor 1-7
Figure 1-6. MAC Unit Programming Model
1.3.1 MAC Status Register (MACSR)
The MACSR, shown in Figure 1-7, contains an operational mode field and a set of flags.
Figure 1-7. MAC Status Register (MACSR)
Table 1-4 describes MACSR fields.
1.3.2 MAC Accumulator (ACC)
This 32-bit register contains the results of MAC operations.
1.3.3 MAC Mask Register (MASK)
The mask register (MASK) is 32 bits of which only the low-order 16 bits are implemented. When MASK
is loaded, the low-order 16 bits of the source operand are loaded into the register. When it is stored, the
upper 16 bits are forced to all ones.
31 0
MACSR MAC status register
ACC MAC accumulator
MASK MAC mask register
3
1
87 43 0
Operational Mode Flags
—OM
C
S/U F/I R/T N Z V C
Table 1-4. MACSR Field Descriptions
Bits Field Description
31-8 Reserved, should be cleared.
7-4 OMF Operational mode field. Defines the operating configuration of the MAC unit.
7 OMC Overflow/saturation mode
6 S/U Signed/unsigned operations
5 F/I Fraction/integer mode
4 R/T Round/truncate mode
3–0 Flags Flags. Contains indicator flags from the last MAC instruction execution.
3 N Negative
2ZZero
1 V Overflow
0 C Carry. This field is always zero.
ColdFire Family Programmer’s Reference Manual, Rev. 3
1-8 Freescale Semiconductor
When used by an instruction, this register is ANDed with the specified operand address. Thus, MASK
allows an operand address to be effectively constrained within a certain range defined by the 16-bit value.
This feature minimizes the addressing support required for filtering, convolution, or any routine that
implements a data array as a circular queue using the (Ay)+ addressing mode.
For MAC with load operations, the MASK contents can optionally be included in all memory effective
address calculations.
1.4 EMAC User Programming Model
The following paragraphs describe the registers for the optional ColdFire EMAC unit. Figure 1-8
illustrates the user programming model for the EMAC unit. It contains the following registers:
One 32-bit MAC status register (MACSR) including four indicator bits signaling product or
accumulation overflow (one for each accumulator: PAV0–PAV3)
Four 32-bit accumulators (ACCx = ACC0, ACC1, ACC2, ACC3)
Eight 8-bit accumulator extensions (two per accumulator), packaged as two 32-bit values for load
and store operations (ACCext01, ACCext23)
One 32-bit mask register (MASK)
Figure 1-8. EMAC Programming Model
1.4.1 MAC Status Register (MACSR)
Figure 1-9 shows the EMAC MACSR, which contains an operational mode field and two sets of flags.
Table 1-5 describes EMAC MACSR fields.
31 0
MACSR MAC status register
ACC0 MAC accumulator 0
ACC1 MAC accumulator 1
ACC2 MAC accumulator 2
ACC3 MAC accumulator 3
ACCext01 Extensions for ACC0 and ACC1
ACCext23 Extensions for ACC2 and ACC3
MASK MAC mask register
3
1
1
2
11109 8 76543210
Prod/acc overflow flags Operational Mode Flags
—PAV
3
PAV
2
PAV
1
PAV
0
OM
C
S/U F/I R/T N Z V EV
Figure 1-9. MAC Status Register (MACSR)
Table 1-5. MACSR Field Descriptions
Bits Field Description
31-12 Reserved, should be cleared.
11-8 PAVx Product/accumulation overflow flags, one per accumulator
/