



# CEG3136 Final Exam Annex Fall 2009

Computer Architecture II (University of Ottawa)

**CEG3136 – Computer Architecture II / CEG3536 Achitecture d'ordinateur II**  
**Final Exam Annex / Annex d'examen final**  
**Fall 2009 / Automne 2009**

68HCS12 INSTRUCTION LIST (reduced)

**Loads, Stores, and Transfers**

| Function                                | Mnemonic   | IMM | DIR | EXT | IDX | [IDX] | INH | Operation                              |
|-----------------------------------------|------------|-----|-----|-----|-----|-------|-----|----------------------------------------|
| Clear Memory Byte                       | CLR        |     |     | X   | X   | X     |     | $m(ea) \leq 0$                         |
| Clear Accumulator A (B)                 | CLRA (B)   |     |     |     |     |       | X   | $A \leq 0$                             |
| Load Accumulator A (B)                  | LDAA (B)   | X   | X   | X   | X   | X     |     | $A \leftarrow [m(ea)]$                 |
| Load Double Accumulator D               | LDL        | X   | X   | X   | X   | X     |     | $D \leftarrow [m(ea), m(ea+1)]$        |
| Load Effective Address into SP (X or Y) | LEAS (A,B) |     |     |     |     |       |     | $SP \leq ea$                           |
| Store Accumulator A (B)                 | STAA (B)   | X   | X   | X   | X   | X     |     | $m(ea) \leq (A)$                       |
| Store Double Accumulator D              | STD        | X   | X   | X   | X   | X     |     | $m(ea, ea+1) \leq D$                   |
| Transfer A to B                         | TAB        |     |     |     |     |       | X   | $B \leq (A)$                           |
| Transfer A to CCR                       | TAP        |     |     |     |     |       | X   | $CCR \leq (A)$                         |
| Transfer B to A                         | TBA        |     |     |     |     |       | X   | $A \leq B$                             |
| Transfer CCR to A                       | TPA        |     |     |     |     |       | X   | $A \leq (CCR)$                         |
| Exchange D with X (Y)                   | XGDX       |     |     |     |     |       | X   | $D \leftrightarrow (X)$                |
| Pull A (B) from Stack                   | PULA(B)    |     |     |     |     |       | X   | $A \leftarrow [m(SP)], SP \leq (SP)+1$ |
| Push A (B) onto Stack                   | PSHA(B)    |     |     |     |     |       | X   | $SP \leq (SP)-1, m(SP) \leq A$         |

**Arithmetic Operations**

| Function                          | Mnemonic | IMM | DIR | EXT | IDX | [IDX] | INH | Operation                                                                   |
|-----------------------------------|----------|-----|-----|-----|-----|-------|-----|-----------------------------------------------------------------------------|
| Add Accumulators                  | ABA      |     |     |     |     |       | X   | $A \leftarrow (A) + (B)$                                                    |
| Add with Carry to A (B)           | ADCA (B) | X   | X   | X   | X   | X     |     | $A \leftarrow (A) + [m(ea)] + (C)$                                          |
| Add Memory to A (B)               | ADDA (B) | X   | X   | X   | X   | X     |     | $A \leftarrow (A) + [m(ea)]$                                                |
| Add Memory to D (16 Bit)          | ADDD     | X   | X   | X   | X   | X     |     | $D \leftarrow (D) + [m(ea, ea+1)]$                                          |
| Decrement Memory Byte             | DEC      |     |     | X   | X   | X     |     | $m(ea) \leftarrow [m(ea)] - 1$                                              |
| Decrement Accumulator A (B)       | DECA (B) |     |     |     |     |       | X   | $A \leftarrow (A) - 1$                                                      |
| Increment Memory Byte             | INC      |     |     | X   | X   | X     |     | $m(ea) \leftarrow [m(ea)] + 1$                                              |
| Increment Accumulator A (B)       | INCA (B) |     |     |     |     |       | X   | $A \leftarrow (A) + 1$                                                      |
| Subtract with Carry from A (B)    | SBCA (B) | X   | X   | X   | X   | X     |     | $A \leftarrow (A) - [m(ea)] - C$                                            |
| Subtract Memory from A (B)        | SUBA (B) | X   | X   | X   | X   | X     |     | $A \leftarrow (A) - [m(ea)]$                                                |
| Subtract Memory from D (16 Bit)   | SUBD     | X   | X   | X   | X   | X     |     | $D \leftarrow (D) - [m(ea, ea+1)]$                                          |
| Multiply (byte, unsigned)         | MUL      |     |     |     |     |       | X   | $D \leftarrow (A) \times (B)$                                               |
| Multiply word, unsigned (signed)  | EMUL(S)  |     |     |     |     |       | X   | $Y:D \leftarrow (D) \times (Y)$                                             |
| Unsigned (signed) 32 by 16 divide | EDIV(S)  |     |     |     |     |       | X   | $X \leftarrow (Y:D) /.(X), Y \leq \text{quotient}, D \leq \text{remainder}$ |
| Fractional Divide (D < X)         | FDIV     |     |     |     |     |       | X   | $X \leftarrow (D) /.(X), D \leq \text{remainder}$                           |
| Integer Divide (unsigned)         | IDIV     |     |     |     |     |       | X   | $X \leftarrow (D) /.(X), D \leq \text{remainder}$                           |

**Logical Operations**

| Function                         | Mnemonic | IMM | DIR | EXT | IDX | [IDX] | INH | Operation                         |
|----------------------------------|----------|-----|-----|-----|-----|-------|-----|-----------------------------------|
| AND A (B) with Memory            | ANDA (B) | X   | X   | X   | X   | X     |     | $A \leftarrow A \bullet [m(ea)]$  |
| Bit(s) Test A (B) with Memory    | BITA (B) | X   | X   | X   | X   | X     |     | $A \bullet [m(ea)]$               |
| One's Complement Memory Byte     | COM      |     |     | X   | X   | X     |     | $m(ea) \leftarrow [/\bar{m}(ea)]$ |
| One's Complement A (B)           | COMA (B) |     |     |     |     |       | X   | $A \leftarrow /A$                 |
| OR A (B) with Memory (Exclusive) | EORA (B) | X   | X   | X   | X   | X     |     | $A \leftarrow A \oplus [m(ea)]$   |
| OR A (B) with Memory (Inclusive) | ORAA (B) | X   | X   | X   | X   | X     |     | $A \leftarrow A + [m(ea)]$        |

**Shift and Rotate**

| Function                             | Mnemonic  | IMM | DIR | EXT | [IDX] | [IDX] | [INH] | Operation |
|--------------------------------------|-----------|-----|-----|-----|-------|-------|-------|-----------|
| Arithmetic/Logical Shift Left Memory | ASL/LSL   |     |     | X   | X     | X     |       |           |
| Arithmetic/Logical Shift Left A (B)  | ASLA(B)   |     |     |     |       |       | X     |           |
| Arithmetic/Logical Shift Left Double | ASLD/LSLD |     |     |     |       |       | X     |           |
| Arithmetic Shift Right Memory        | ASR       |     |     | X   | X     | X     |       |           |
| Arithmetic Shift Right A (B)         | ASRA(B)   |     |     |     |       |       | X     |           |
| Logical Shift Right A (B)            | LSRA(B)   |     |     |     |       |       | X     |           |
| Logical Shift Right Memory           | LSR       |     |     | X   | X     | X     |       |           |
| Logical Shift Right D                | LSRD      |     |     |     |       |       | X     |           |
| Rotate Left Memory                   | ROL       |     |     | X   | X     | X     |       |           |
| Rotate Left A (B)                    | ROLA(B)   |     |     |     |       |       | X     |           |
| Rotate Right A (B)                   | RORA(B)   |     |     |     |       |       | X     |           |
| Rotate Right Memory                  | ROR       |     |     | X   | X     | X     |       |           |

**Compare & Test**

| Function                         | Mnemonic | IMM | DIR | EXT | [IDX] | [IDX] | [INH] | Operation           |
|----------------------------------|----------|-----|-----|-----|-------|-------|-------|---------------------|
| Compare A to B                   | CBA      |     |     |     |       |       | X     | (A)-(B)             |
| Compare A (B) to Memory          | CMPA (B) | X   | X   | X   | X     | X     |       | (A) - [m(ea)]       |
| Compare D to Memory (16 Bit)     | CPD      | X   | X   | X   | X     | X     |       | (D) - [m(ea,ea+1)]  |
| Compare SP to Memory (16 Bit)    | CPS      | X   | X   | X   | X     | X     |       | (SP) - [m(ea,ea+1)] |
| Compare X (Y) to Memory (16 Bit) | CPX      | X   | X   | X   | X     | X     |       | (X) - [m(ea,ea+1)]  |
| Test memory for 0 or minus       | TST      |     |     | X   | X     | X     |       | m(ea) - 0           |
| Test A (B) for 0 or minus        | TSTA (B) |     |     |     |       |       | X     | (A)-0               |

**Short Branches**

| Function                               | Mnemonic | REL | DIR | [IDX] | [IDX] | PC <= ea if       |
|----------------------------------------|----------|-----|-----|-------|-------|-------------------|
| Branch ALWAYS                          | BRA      | X   |     |       |       |                   |
| Branch if Carry Clear                  | BCC      | X   |     |       |       | C = 0 ?           |
| Branch if Carry Set                    | BCS      | X   |     |       |       | C = 1 ?           |
| Branch if Equal Zero                   | BEQ      | X   |     |       |       | Z = 1 ?           |
| Branch if Not Equal                    | BNE      | X   |     |       |       | Z = 0 ?           |
| Branch if Minus                        | BMI      | X   |     |       |       | N = 1 ?           |
| Branch if Plus                         | BPL      | X   |     |       |       | N = 0 ?           |
| Branch if Bit(s) Clear in Memory Byte  | BRCLR    |     | X   | X     |       | [m(ea)] • mask=0  |
| Branch if Bit(s) Set in Memory Byte    | BRSET    |     | X   | X     |       | [/m(ea)] • mask=0 |
| Branch if Overflow Clear               | BVC      | X   |     |       |       | V = 0 ?           |
| Branch if Overflow Set                 | BVS      | X   |     |       |       | V = 1 ?           |
| Branch if Greater Than                 | BGT      | X   |     |       |       | Signed >          |
| Branch if Greater Than or Equal        | BGE      | X   |     |       |       | Signed ≥          |
| Branch if Less Than or Equal           | BLE      | X   |     |       |       | Signed ≤          |
| Branch if Less Than                    | BLT      | X   |     |       |       | Signed <          |
| Branch if Higher                       | BHI      | X   |     |       |       | Unsigned >        |
| Branch if Higher or Same (same as BCC) | BHS      | X   |     |       |       | Unsigned ≥        |
| Branch if Lower or Same                | BLS      | X   |     |       |       | Unsigned ≤        |
| Branch if Lower (same as BCS)          | BLO      | X   |     |       |       | Unsigned <        |
| Branch Never                           | BRN      | X   |     |       |       | 3-cycle NOP       |

Long branch mnemonic = L + Short branch mnemonic, e.g.: BRA → LBRA

**Loop Primitive Instructions** (counter ctr = A, B, or D)

| Function                         | Mnemonic | REL | DIR | EXT | IDX | [IDX] | INH | Operation                               |
|----------------------------------|----------|-----|-----|-----|-----|-------|-----|-----------------------------------------|
| Decrement counter & branch if =0 | DBEQ     | X   |     |     |     |       |     | ctr <= (ctr)-1, if (ctr)=0 => PC <= ea  |
| Decrement counter & branch if ≠0 | DBNE     | X   |     |     |     |       |     | ctr <= (ctr)-1, if (ctr) ≠0 => PC <= ea |
| Increment counter & branch if =0 | IBEQ     | X   |     |     |     |       |     | ctr <= (ctr)+1, if (ctr)=0 => PC <= ea  |
| Increment counter & branch if ≠0 | IBNE     | X   |     |     |     |       |     | ctr <= (ctr)+1, if (ctr) ≠0 => PC <= ea |
| Test counter & branch if =0      | DBEQ     | X   |     |     |     |       |     | if (ctr)=0 => PC <= ea                  |

**Subroutine Calls and Returns**

| Function                               | Mnemonic | REL | DIR | EXT | IDX | [IDX] | INH | Operation                                                                       |
|----------------------------------------|----------|-----|-----|-----|-----|-------|-----|---------------------------------------------------------------------------------|
| Branch to Subroutine                   | BSR      | X   |     |     |     |       |     | SP <= (SP)-2, m(SP) <= (PC), PC <= ea                                           |
| Jump to Subroutine                     | JSR      |     | X   | X   | X   | X     |     | SP <= (SP)-2, m(SP) <= (PC), PC <= ea                                           |
| CALL a Subroutine<br>(expanded memory) | CALL     |     | X   | X   | X   | X     |     | SP <= (SP)-2, m(SP) <= (PC), PC <= ea<br>SP <= (SP)-1, m(SP) <= (PPG), PC <= pg |
| Return from Subroutine                 | RTS      |     |     |     |     |       | X   | PC <= [m(SP)], SP <= (SP)+2                                                     |
| Return from call                       | RTC      |     |     |     |     |       | X   | PPG <= [m(SP)], SP <= (SP)+1,<br>PC <= [m(SP)], SP <= (SP)+2                    |

| Function | Mnemonic | DIR | EXT | IDX | [IDX] | INH | Operation |
|----------|----------|-----|-----|-----|-------|-----|-----------|
| Jump     | JMP      | X   | X   | X   | X     |     | PC <= ea  |

The **jump** instruction allows control to be passed to any address in the 64-Kbyte memory map.

**Stack and Index Register Instructions**

| Function                       | Mnemonic | IMM | DIR | EXT | IDX | [IDX] | INH | Operation                           |
|--------------------------------|----------|-----|-----|-----|-----|-------|-----|-------------------------------------|
| Decrement Index Register X (Y) | DEX (Y)  |     |     |     |     |       | X   | X <= (X) - 1                        |
| Increment Index Register X (Y) | INX (Y)  |     |     |     |     |       | X   | X <= (X) + 1                        |
| Load Index Register X (Y)      | LDX(Y)   | X   | X   | X   | X   | X     |     | X <= [m(ea,ea+1)]                   |
| Pull X (Y) from Stack          | PULX     |     |     |     |     |       | X   | X <= [m(SP,SP+1)]<br>SP <= (SP) + 2 |
| Push X (Y) onto Stack          | PSHX (Y) |     |     |     |     |       | X   | m(SP,SP+1) <= (X)<br>SP <= (SP) - 2 |
| Store Index Register X (Y)     | STX (X)  | X   | X   | X   | X   | X     |     | m(ea,ea+1) <= X                     |
| Add Accumulator B to X (Y)     | ABX (Y)  |     |     |     |     |       | X   | X <= (X) + (B)                      |
| Decrement Stack Pointer        | DES      |     |     |     |     |       | X   | SP <= (SP) - 1                      |
| Increment Stack Pointer        | INS      |     |     |     |     |       | X   | SP <= (SP) + 1                      |
| Load Stack Pointer             | LDS      | X   | X   | X   | X   | X     |     | SP <= [m(ea,ea+1)]                  |
| Store Stack Pointer            | STS      | X   | X   | X   | X   | X     |     | m(ea,ea+1) <= (SP)                  |
| Transfer SP to X (Y)           | TSX (Y)  |     |     |     |     |       | X   | X <= (SP)                           |
| Transfer X (Y) to SP           | TXS (Y)  |     |     |     |     |       | X   | SP <= (X)                           |
| Exchange D with X (Y)          | XGDX (Y) |     |     |     |     |       | X   | (D) <=> (X)                         |

| Function              | Mnemonic | INH | Operation                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Return from Interrupt | RTI      | X   | $(M_{(SP)}) \Rightarrow CCR; (SP) + \$0001 \Rightarrow SP$<br>$(M_{(SP)} : M_{(SP+1)}) \Rightarrow B : A; (SP) + \$0002 \Rightarrow S$<br>$(M_{(SP)} : M_{(SP+1)}) \Rightarrow X_H : X_L; (SP) + \$0004 \Rightarrow S$<br>$(M_{(SP)} : M_{(SP+1)}) \Rightarrow PC_H : PC_L; (SP) + \$0002 \Rightarrow [M_{(SP)} : M_{(SP+1)}]$<br>$(M_{(SP)} : M_{(SP+1)}) \Rightarrow Y_H : Y_L; (SP) + \$0004 \Rightarrow S$ |
| Software Interrupt    | SWI      | X   |                                                                                                                                                                                                                                                                                                                                                                                                                |
| Wait for Interrupt    | WAI      | X   |                                                                                                                                                                                                                                                                                                                                                                                                                |

**Interrupt Handling**

The software interrupt (SWI) instruction is similar to a JSR instruction, except the contents of all working CPU registers are saved on the stack rather than just the return address. SWI is unusual in that it is requested by the software program as opposed to other interrupts that are requested asynchronously to the executing program.

## Register and Bit Definitions for 9S12DG256 Peripheral Modules

| DATA REGISTERS                                                      |              |              |            |        |        |       |       | CONTROL REGISTERS                                            |                                      |         |         |         |        |         |        | STATUS REGISTERS |                       |                                      |                                 |                                       |                        |              |                        |                                              |                            |              |                        |        |        |   |   |   |
|---------------------------------------------------------------------|--------------|--------------|------------|--------|--------|-------|-------|--------------------------------------------------------------|--------------------------------------|---------|---------|---------|--------|---------|--------|------------------|-----------------------|--------------------------------------|---------------------------------|---------------------------------------|------------------------|--------------|------------------------|----------------------------------------------|----------------------------|--------------|------------------------|--------|--------|---|---|---|
| <b>PARALLEL PORTS</b>                                               |              |              |            |        |        |       |       |                                                              |                                      |         |         |         |        |         |        |                  |                       |                                      |                                 |                                       |                        |              |                        |                                              |                            |              |                        |        |        |   |   |   |
| PORTA \$0000                                                        | PORTB \$0001 | PORTE \$0008 | PORTh \$32 | PA7    | PA6    | PA5   | PA4   | PA3                                                          | PA2                                  | PA1     | PA0     | DDR4    | \$0002 | DDR5    | \$0003 | DDR6             | \$0009                | DDR7                                 | \$0033                          | DDR8                                  | \$0034                 | DDR9         | \$0035                 | DDR10                                        | \$0036                     |              |                        |        |        |   |   |   |
| PB7                                                                 | PB6          | PB5          | PB4        | PB3    | PB2    | PB1   | PB0   | DDR5                                                         | DDR6                                 | DDR7    | DDR8    | DDR11   | DDR12  | DDR13   | DDR14  | DDR15            | DDR16                 | DDR17                                | DDR18                           | DDR19                                 | DDR20                  | DDR21        | DDR22                  | DDR23                                        | DDR24                      |              |                        |        |        |   |   |   |
| PE7                                                                 | PE6          | PE5          | PE4        | PE3    | PE2    | PE1   | PE0   | DDR11                                                        | DDR12                                | DDR13   | DDR14   | DDR15   | DDR16  | DDR17   | DDR18  | DDR19            | DDR20                 | DDR21                                | DDR22                           | DDR23                                 | DDR24                  | DDR25        | DDR26                  | DDR27                                        | DDR28                      |              |                        |        |        |   |   |   |
| PK7                                                                 | PK6          | PK5          | PK4        | PK3    | PK2    | PK1   | PK0   | PUCR \$000C                                                  | PUPKE 0                              | PUPEE 0 | PUPBE 0 | PUPAE 0 |        |         |        |                  |                       |                                      |                                 |                                       |                        |              |                        |                                              |                            |              |                        |        |        |   |   |   |
| <b>TIMER</b>                                                        |              |              |            |        |        |       |       | TIOS \$0040                                                  | Timer                                |         |         |         |        |         |        |                  |                       |                                      |                                 |                                       |                        |              |                        |                                              |                            |              |                        |        |        |   |   |   |
| TCNT \$0044 \$0045 Timer Count Register                             |              |              |            |        |        |       |       | Input-Capture (IOS=0)/Output-Compare (IOS=1) Select Register |                                      |         |         |         |        |         |        |                  |                       |                                      |                                 |                                       |                        |              |                        | TFLG1 \$004E Timer Interrupt Flag Register 1 |                            |              |                        |        |        |   |   |   |
| Bit 15                                                              | Bit 14       | Bit 13       | Bit 12     | Bit 11 | Bit 10 | Bit 9 | Bit 8 | IOS7                                                         | IOS6                                 | IOS5    | IOS4    | IOS3    | IOS2   | IOS1    | IOS0   | C7F              | C6F                   | C5F                                  | C4F                             | C3F                                   | C2F                    | C1F          | C0F                    | TFLG2 \$004F Timer Interrupt Flag 2          |                            |              |                        |        |        |   |   |   |
| Bit 7                                                               | Bit 6        | Bit 5        | Bit 4      | Bit 3  | Bit 2  | Bit 1 | Bit 0 | CFORC \$0041                                                 | Timer Compare Force Register         | FOC7    | FOC6    | FOC5    | FOC4   | FOC3    | FOC2   | FOC1             | FOC0                  | TOF 0                                | 0                               | 0                                     | 0                      | 0            | 0                      | 0                                            | 0                          |              |                        |        |        |   |   |   |
| TC0 \$0050 \$0051 Timer Input-Capture/<br>Output-Compare Register 0 |              |              |            |        |        |       |       | OC7M \$0042                                                  | Timer Output Compare 7 Mask          | OC7M7   | OC7M6   | OC7M5   | OC7M4  | OC7M3   | OC7M2  | OC7M1            | OC7M0                 |                                      |                                 |                                       |                        |              |                        |                                              |                            |              |                        |        |        |   |   |   |
| Bit 15                                                              | Bit 14       | Bit 13       | Bit 12     | Bit 11 | Bit 10 | Bit 9 | Bit 8 | OC7D \$0043                                                  | Timer Output Compare 7 Data Register | OC7D7   | OC7D6   | OC7D5   | OC7D4  | OC7D3   | OC7D2  | OC7D1            | OC7D0                 |                                      |                                 |                                       |                        |              |                        |                                              |                            |              |                        |        |        |   |   |   |
| Bit 7                                                               | Bit 6        | Bit 5        | Bit 4      | Bit 3  | Bit 2  | Bit 1 | Bit 0 | TCTL1/TCTL2 \$0048/49                                        | Timer Control Register 1/2           | OM7     | OL7     | OM6     | OL6    | OM5     | OL5    | OM4              | OL4                   | OM3                                  | OL3                             | OM2                                   | OL2                    | OM1          | OL1                    | OM0                                          | OL0                        |              |                        |        |        |   |   |   |
| TCx x=0...7 \$0050+2*x                                              |              |              |            |        |        |       |       | TCTL3/TCTL4 \$004A/4B                                        | Timer Control Register 4             | EDG7B   | EDG7A   | EDG6B   | EDG6A  | EDG5B   | EDG5A  | EDG4B            | EDG4A                 | EDG3B                                | EDG3A                           | EDG2B                                 | EDG2A                  | EDG1B        | EDG1A                  | EDG0B                                        | EDG0A                      |              |                        |        |        |   |   |   |
|                                                                     |              |              |            |        |        |       |       | TSCR1 \$0046                                                 | Timer System Control Register 1      | TEN     | TSWAI   | TSFRZ   | TFCCA  | 0       | 0      | 0                | 0                     | TSCR2 \$004D                         | Timer System Control Register 1 | TOI 0                                 | 0                      | 0            | TCRE                   | PR2                                          | PR1                        | PR0          |                        |        |        |   |   |   |
|                                                                     |              |              |            |        |        |       |       | TIE \$004C                                                   | Timer Interrupt Enable Register      | C7I     | C6I     | C5I     | C4I    | C3I     | C2I    | C1I              | C0I                   |                                      |                                 |                                       |                        |              |                        |                                              |                            |              |                        |        |        |   |   |   |
| <b>SERIAL INTERFACE-SCI</b>                                         |              |              |            |        |        |       |       | SC0BDH,\$00C8 \$00C9                                         | SCI Baud Rate Control Register       | 0       | 0       | 0       | SBR12  | SBR11   | SBR10  | SBR9             | SBR8                  | SBR7                                 | SBR6                            | SBR5                                  | SBR4                   | SBR3         | SBR2                   | SBR1                                         | SBR0                       |              |                        |        |        |   |   |   |
| SC0DRH \$00CE SCI Data Register High                                |              |              |            |        |        |       |       | SC0CR1 \$00CA                                                | SCI Control Register 1               | LOOPS   | SCISWAI | RSRC    | M      | WAKE    | ILT    | PE               | PT                    | SC0CR2 \$00CB                        | SCI Control Register 2          | TDRE 0                                | TC 0                   | RDRF 0       | IDLE 0                 | OR 0                                         | NF 0                       | FE 0         | PF 0                   |        |        |   |   |   |
| SC0DRL \$00CF SCI Data Register Low                                 |              |              |            |        |        |       |       | TIE                                                          | TCIE                                 | RIE     | ILIE    | TE      | RE     | RWU     | SBK    | SC0SR1 \$00CC    | SCI Status Register 1 | SC0SR2 \$00CD                        | SCI Status Register 2           | TDRE 0                                | TC 0                   | RDRF 0       | IDLE 0                 | OR 0                                         | NF 0                       | FE 0         | PF 0                   |        |        |   |   |   |
|                                                                     |              |              |            |        |        |       |       | SP0BR \$00DA                                                 | SPI Baud Rate Control Register       | 0       | SPPR2   | SPPR1   | SPPR1  | 0       | SPR2   | SPR1             | SPR0                  | SP0CR1 \$00D8                        | SPI Control Register 1          | SCF 0                                 | ETORF 0                | FIFOR 0      | CC2 0                  | CC1 0                                        | CC0 0                      |              |                        |        |        |   |   |   |
|                                                                     |              |              |            |        |        |       |       | SP0CR2 \$00D9                                                | SPI Control Register 2               | SPIE    | SPE     | SPTIE   | MSTR   | CPOL    | CPHA   | SSOE             | LSBF                  | ATDSTAT0 \$86                        | ATD Status Register 0           | ATDSTAT1 \$86                         | ATD Status Register 1  | CCF7 0       | CCF6 0                 | CCF5 0                                       | CCF4 0                     | CCF3 0       | CCF2 0                 | CCF1 0 | CCF0 0 |   |   |   |
| <b>SERIAL INTERFACE-SPI</b>                                         |              |              |            |        |        |       |       | SP0PR \$00D0                                                 | SPI Status Register                  | 0       | 0       | 0       | MODFEN | BIDRIOE | 0      | SPISWAI          | SPCO                  | ATDCTL2 \$82                         | ATD Control Register 2          | ADPU                                  | AFFC                   | AWAI         | ETRIGLE                | ETRIGP                                       | ETRIG                      | ASCIIE       | ASCIIF                 |        |        |   |   |   |
| SP0DR \$00Dd SPI Data Register                                      |              |              |            |        |        |       |       | SP0CR3 \$00D9                                                | SPI Control Register 3               | 0       | S8C     | S4C     | S2C    | S1C     | FIFO   | FRZ1             | FRZ2                  | ATDCTL3 \$83                         | ATD Control Register 3          | ATDCTL4 \$84                          | ATD Control Register 4 | ATDCTL5 \$85 | ATD Control Register 5 | ATDCTL6 \$86                                 | ATD Control Register 6     | ATDCTL7 \$87 | ATD Control Register 7 |        |        |   |   |   |
| Bit 7                                                               | Bit 6        | Bit 5        | Bit 4      | Bit 3  | Bit 2  | Bit 1 | Bit 0 | SRES8                                                        | SMP1                                 | SMP0    | PRS4    | PRS3    | PRS2   | PRS1    | PRS0   | DJM              | DSGN                  | SCAN                                 | MULT                            | 0                                     | CC                     | CB           | CA                     | INTCR \$001E                                 | Interrupt Control Register | IRQE         | IRQEN                  | DLY    | 0      | 0 | 0 | 0 |
| ANALOG-TO-DIGITAL SUBSYSTEM                                         |              |              |            |        |        |       |       | INTCR \$001E                                                 | Interrupt Control Register           | IRQE    | IRQEN   | DLY     | 0      | 0       | 0      | 0                | 0                     | SampleDuration = 2^(SMP+1) ATD clock | HPRI0 \$001F                    | Highest Priority I Interrupt Register | PSEL7                  | PSEL6        | PSEL5                  | PSEL4                                        | PSEL3                      | PSEL2        | PSEL1 0                |        |        |   |   |   |
| ADRXL: \$91+2x ATD Result Registers Low                             |              |              |            |        |        |       |       | x=0...7                                                      |                                      |         |         |         |        |         |        |                  |                       |                                      |                                 |                                       |                        |              |                        |                                              |                            |              |                        |        |        |   |   |   |

## Timer Module

- TEN - Activate (=1) and deactivate (=0) timer
- AFFC - allows automatic clear of flags (=1)
- TOI enable (=1) overflow interrupt (from \$FFFF to \$0000) of the TCNT
- PR2, PR1, PR0 prescale bits ( $= 2^{PR}$ ) applied to system clock for incrementing timer
- IOS0 to IOS7 – Configure channel as output compare (=1) or input-capture (=0)
- FOC0-FOC1 – Force output-compare event on channel
- OC7M0-OC7M7 – Allow channel 7 to affect channel pin (=1)
- OC7D0-OC7D7 – Value of level for channel 7 to output to channel pin
- C0I-C7I – Enable a channel interrupt
- C0F-C7F – Channel flag set when event occurs
- TOF – Counter Overflow flag

## ATD Module

- ADPU enable (=1) converter
- AFFC enable (=1) fast clear
- ASCIE enable (=1) interruption at the completion of a conversion sequence
- ASCFI flags (=1) a sequence conversion
- S8C,S4C,S2C,S1C defines number of conversions per sequence (when set to 0, or S8C=1,8 conversions in a sequence)
- FIFO – Use FIFO discipline to fill registers when set to 1 (otherwise fill in starting at register ADR0).
- SRES8 selects resolution (1 = 8 bits, 0 = 10 bits)
- SMP1, SMP2 – sample time ( $= 2^{SMP+1}$ )
- PRS4, PRS3,PRS2,PRS1,PRS0 – prescaler of system bus clock (of frequency BUS = typically 24 MHz) to generate ATD clock (of frequency CC):  
$$CC = (BUS/(2*(PRS+1))),$$
 where PRS is value represented by PRS4 to PRS0.
- DJM – Right justify (=1) or left justify (=0) results
- DSGN – Used signed (=1) or unsigned numbers (=0) (significant only if DJM=0)
- SCAN – single conversion (=0) or scan mode (=1)
- MULT – single pin (=0) or multiple pins (=1)
- CC, CB, CA – Selects pin for single conversion or first pin in the case of multiple conversion.

ATD Cycles per conversion  
2 (initial sample time) + 2 to 16 (final sample time) + 8 or 10 (conversion time for 8 bits or 10 bits).

## Serial Interface Module – SCI subsystem

- M: Two modes 8 data bits or 9 data bits (with 1 start bit and 1 stop bit)
- PE, PT: Enable parity (PE) and type of parity (PT)
- TIE, TCIE, RIE: Bits for enabling interruptions for reception and transmission
- TE, RE: Enable transmission (TE) and reception (RE)
- TDRE: 1 indicates that more data can be written into the data register
- TC: 1 indicates that transmission of data is complete
- RDRF: 1 indicates that reception data register is full
- OR, NF, FE, PF: error bits, equal 1 when an error is detected during reception (overrun, noise, framing, parity)
- RAF: 1 indicates that reception of a character is underway.
- MODF – Set when SS configured in Master for error detection (input)

## Port H

**Address Offset:\$\_\_20**

|        | Bit 7                                                                             | 6    | 5     | 4     | 3    | 2    | 1     | Bit 0                       |
|--------|-----------------------------------------------------------------------------------|------|-------|-------|------|------|-------|-----------------------------|
| Read:  | PTH7                                                                              | PTH6 | PTH5  | PTH4  | PTH3 | PTH2 | PTH1  | PTH0                        |
| Write: | SS2                                                                               | SCK2 | MOSI2 | MISO2 | SS1  | SCK1 | MOSI1 | MISO1                       |
| Reset: | 0                                                                                 | 0    | 0     | 0     | 0    | 0    | 0     | 0                           |
|        |  |      |       |       |      |      |       | = Reserved or unimplemented |

**Figure 3-30 Port H I/O Register (PTH)**

Read:Anytime.

Write:Anytime.

If the data direction bits of the associated I/O pins are set to 1, a read returns the value of the port register, otherwise the value at the pins is read.

The SPI function takes precedence over the general purpose I/O function associated with if enabled. *Refer to SPI Block Guide for details.*

**Address Offset: \$\_\_22**

|        | Bit 7                                                                               | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0                       |
|--------|-------------------------------------------------------------------------------------|-------|-------|-------|-------|-------|-------|-----------------------------|
| Read:  | DDRH7                                                                               | DDRH6 | DDRH5 | DDRH4 | DDRH3 | DDRH2 | DDRH1 | DDRH0                       |
| Write: | 0                                                                                   | 0     | 0     | 0     | 0     | 0     | 0     | 0                           |
| Reset: | 0                                                                                   | 0     | 0     | 0     | 0     | 0     | 0     | 0                           |
|        |  |       |       |       |       |       |       | = Reserved or unimplemented |

**Figure 3-32 Port H Data Direction Register (DDRH)**

Read:Anytime.

Write:Anytime.

This register configures each port H pin as either input or output.

DDRH[7:0] — Data Direction Port H

1 = Associated pin is configured as output.

0 = Associated pin is configured as input.

## CodeWarrior Definitions

```
***** interrupt vector numbers *****/
#define VectorNumber_Vatd1          23
#define VectorNumber_Vatd0          22
#define VectorNumber_Vsc11          21
#define VectorNumber_Vsc10          20
#define VectorNumber_Vtimovf         16
#define VectorNumber_Vtimch7         15
#define VectorNumber_Vtimch6         14
#define VectorNumber_Vtimch5         13
#define VectorNumber_Vtimch4         12
#define VectorNumber_Vtimch3         11
#define VectorNumber_Vtimch2         10
#define VectorNumber_Vtimch1          9
#define VectorNumber_Vtimch0          8
#define VectorNumber_Virq            6
#define VectorNumber_Vxirq            5
#define VectorNumber_Vswi             4

// Peripheral registers
#define PORTA _PORTAB.Overlap_STR.PORTASTR.Byte // PORT A Data Register
#define DDRA _DDRAB.Overlap_STR.DDRASTR.Byte // PORT A Data Direction Register
#define PORTB _PORTAB.Overlap_STR.PORTBSTR.Byte // PORT B Data Register
#define DDRB _DDRAB.Overlap_STR.DDRBSTR.Byte // PORT B Data Direction Register
#define PORTK _PORTK.Byte // PORT K Data Register
#define DDRK _DDRK.Byte // PORT K Data Direction Register
#define PUCR _PUCR.Byte // Pullup Control Register
#define INTCR _INTCR.Byte // Interrupt Control Register
#define PTH _PTH.Byte // Port H Data Register
#define DDRH _DDRH.Byte // Port H Data Direction Register

// Timer Registers
#define TSCR1 _TSCR1.Byte // Timer System Control Register 1
#define TSCR2 _TSCR2.Byte // Timer System Control Register 2
#define TIOS _TIOS.Byte // Timer Input Capture/Output Compare Select
#define CFORC _CFORC.Byte // Timer Compare Force Register
#define OC7M _OC7M.Byte // Output Compare 7 Mask Register
#define OC7D _OC7D.Byte // Output Compare 7 Data Register
#define TCNT _TCNT.Word // Timer Count Register
#define TCTL1 _TCTL1.Byte // Timer Control Register 1
#define TCTL2 _TCTL2.Byte // Timer Control Register 2
#define TCTL3 _TCTL3.Byte // Timer Control Register 3
#define TCTL4 _TCTL4.Byte // Timer Control Register 4
#define TIE _TIE.Byte // Timer Interrupt Enable Register;
#define TFLG1 _TFLG1.Byte // Main Timer Interrupt Flag 1
#define TFLG2 _TFLG2.Byte // Main Timer Interrupt Flag 2
#define TC0 _TC0.Word // Timer Data Register 0
#define TC1 _TC1.Word // Timer Data Register 1
#define TC2 _TC2.Word // Timer Data Register 2
#define TC3 _TC3.Word // Timer Data Register 3
#define TC4 _TC4.Word // Timer Data Register 4
#define TC5 _TC5.Word // Timer Data Register 5
#define TC6 _TC6.Word // Timer Data Register 6
#define TC7 _TC7.Word // Timer Data Register 7
```