Reference Guide M68HC11ERG/AD Rev. 2, 10/2003 M68HC11E Series Programming Reference Gui<u>de</u> # **Block Diagram** # **Devices Covered in This Reference Guide** | Device | RAM | ROM | EPROM | EEPROM | |--------------|-----|-----|-------|--------| | MC68HC11E0 | 512 | _ | _ | _ | | MC68HC11E1 | 512 | _ | _ | 512 | | MC68HC11E9 | 512 | 12K | _ | 512 | | MC68HC711E9 | 512 | _ | 12K | 512 | | MC68HC11E20 | 768 | 20K | _ | 512 | | MC68HC711E20 | 768 | _ | 10K | 512 | | MC68HC811E2 | 256 | _ | _ | 2048 | # M68HC11E Series Programming Model # **Crystal Dependent Timer Summary** | | Selected | Comr | mon XTAL Freque | ncies | |----------------------------------------------------------------------------------------------|--------------------------------------|-------------------------------------------------|------------------------------------------------|--------------------------------------------------| | | Crystal | 4.0 MHz | 8.0 MHz | 12.0 MHz | | CPU Clock | (E) | 1.0 MHz | 2.0 MHz | 3.0 MHz | | Cycle Time | (1/E) | 1000 ns | 500 ns | 333 ns | | | | Pulse Accumulate | or (in Gated Mode) | | | (E/2 <sup>6</sup> )<br>(E/2 <sup>14</sup> ) | 1 count —<br>overflow — | 64.0 μs<br>16.384 ms | 32.0 μs<br>8.192 ms | 21.330 μs<br>5.491 ms | | | PR[1:0] | Mai | in Timer Count Ra | tes | | (E/1)<br>(E/2 <sup>16</sup> ) | 0 0<br>1 count—<br>overflow — | 1.0 μs<br>65.536 ms | 500 ns<br>32.768 ms | 333 ns<br>21.845 ms | | (E/4)<br>(E/2 <sup>18</sup> ) | 0 1<br>1 count—<br>overflow — | 4.0 μs<br>262.14 ms | 2.0 μs<br>131.07 ms | 1.333 μs<br>87.381 ms | | (E/8)<br>(E/2 <sup>19</sup> ) | 1 0<br>1 count—<br>overflow — | 8.0 μs<br>524.29 ms | 4.0 μs<br>262.14 ms | 2.667 μs<br>174.76 ms | | (E/16)<br>(E/2 <sup>20</sup> ) | 1 1<br>1 count—<br>overflow — | 16.0 μs<br>1.049 s | 8.0 μs<br>524.29 ms | 5.333 μs<br>349.52 ms | | | RTR[1:0] | Period | dic (RTI) Interrupt | Rates | | (E/2 <sup>13</sup> )<br>(E/2 <sup>14</sup> )<br>(E/2 <sup>15</sup> )<br>(E/2 <sup>16</sup> ) | 0 0<br>0 1<br>1 0<br>1 1 | 8.192 ms<br>16.384 ms<br>32.768 ms<br>65.536 ms | 4.096 ms<br>8.192 ms<br>16.384 ms<br>32.768 ms | 2.731 ms<br>5.461 ms<br>10.923 ms<br>21.845 ms | | | CR[1:0] | COP V | Vatchdog Timeout | Rates | | (E/2 <sup>15</sup> )<br>(E/2 <sup>17</sup> )<br>(E/2 <sup>19</sup> )<br>(E/2 <sup>21</sup> ) | 7) 0 1 131.072 m<br>P) 1 0 524.288 m | | 16.384 ms<br>65.536 ms<br>262.14 ms<br>1.049 s | 10.923 ms<br>43.691 ms<br>174.76 ms<br>699.05 ms | | (E/2 <sup>15</sup> ) | Timeout<br>tolerance<br>(-0 ms/+) | 32.8 ms | 16.4 ms | 10.9 ms | # **Interrupt Vector Assignments** | Vector<br>Address | Interrupt<br>Source | CCR<br>Mask Bit | Local<br>Mask | |---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------| | FFC0, C1 – FFD4, D5 | Reserved | _ | _ | | FFD6, D7 | SCI serial system <sup>(1)</sup> • SCI receive data register full • SCI receiver overrun • SCI transmit data register empty • SCI transmit complete • SCI idle line detect | ı | RIE<br>RIE<br>TIE<br>TCIE<br>ILIE | | FFD8, D9 | SPI serial transfer complete | I | SPIE | | FFDA, DB | Pulse accumulator input edge | I | PAII | | FFDC, DD | Pulse accumulator overflow | 1 | PAOVI | | FFDE, DF | Timer overflow | I | TOI | | FFE0, E1 | Timer input capture 4/output compare 5 | I | I4/O5I | | FFE2, E3 | Timer output compare 4 | I | OC4I | | FFE4, E5 | Timer output compare 3 | I | OC3I | | FFE6, E7 | Timer output compare 2 | I | OC2I | | FFE8, E9 | Timer output compare 1 | I | OC1I | | FFEA, EB | Timer input capture 3 | I | IC3I | | FFEC, ED | Timer input capture 2 | I | IC2I | | FFEE, EF | Timer input capture 1 | I | IC1I | | FFF0, F1 | Real-time interrupt | I | RTII | | FFF2, F3 | IRQ (external pin) | I | None | | FFF4, F5 | XIRQ pin | Х | None | | FFF6, F7 | Software interrupt | None | None | | FFF8, F9 | Illegal opcode trap | None | None | | FFFA, FB | COP failure | None | NOCOP | | FFFC, FD | Clock monitor fail | None | CME | | FFFE, FF | RESET | None | None | <sup>1.</sup> Interrupts generated by SCI; read SCSR to determine source. Refer to HPRIO register to determine priority of interrupt. # M68HC11E Series Memory Maps Figure 1. Memory Map for MC68HC11E0 Figure 2. Memory Map for MC68HC11E1 Figure 3. Memory Map for MC68HC(7)11E9 <sup>\* 20</sup> Kbytes ROM/EPROM are contained in two segments of 8 Kbytes and 12 Kbytes each. Figure 4. Memory Map for MC68HC(7)11E20 Figure 5. Memory Map for MC68HC811E2 # **Opcode Maps** # Page 1 | | | | D | IR<br><b>L</b> | | | | | | | | | | | | | | | |------|----|------|--------|----------------|------|------|------|-------|------|------|------|-------|------|--------|------|-------|------|---| | | | | | | | | | | | | AC | CA | | | AC | СВ | | | | | | INH | INH | REL | INH | ACCA | ACCB | IND,X | EXT | IMM | DIR | IND,X | EXT | IMM | DIR | IND,X | EXT | | | M | SB | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 | | | LSB | \ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | | | 0000 | 0 | TEST | SBA | BRA | TSX | | NE | EG | | | | | S | UB | | | | 0 | | 0001 | 1 | NOP | СВА | BRN | INS | | | | | | | | С | MP | | | | 1 | | 0010 | 2 | IDIV | BRSET | BHI | PULA | | | | | | | | S | вс | | | | 2 | | 0011 | 3 | EDIV | BRCLR | BLS | PULB | | CC | OM | | | SU | BD | | | AD | DD | | 3 | | 0100 | 4 | LSRD | BSET | BCC | DES | | LSR | | | | | | Α | ND | | | | 4 | | 0101 | 5 | ASLD | BCLR | BCS | TXS | | | | | BIT | | | | | | | | 5 | | 0110 | 6 | TAP | TAB | BNE | PSHA | | ROR | | | | | | L | DA | | | | 6 | | 0111 | 7 | TPA | TBA | BEQ | PSHB | | AS | SR | | | | STA | | | | STA | | 7 | | 1000 | 8 | INX | PAGE 2 | BVC | PULX | | AS | SL. | | | | | E | OR | | | | 8 | | 1001 | 9 | DEX | DAA | BVS | RTS | | RO | OL | | | | | Α | DC | | | | 9 | | 1010 | Α | CLV | PAGE 3 | BPL | ABX | | DE | €C | | | | | 0 | RA | | | | A | | 1011 | В | SEV | ABA | BMI | RTI | | | | | | | | А | DD | | | | В | | 1100 | С | CLC | BSET | BGE | PSHX | | IN | IC | | | CI | PΧ | | | Lſ | DD | | С | | 1101 | D | SEC | BCLR | BLT | MUL | | TS | ST | | BSR | | JSR | | PAGE 4 | | STD | | D | | 1110 | Ε | CLI | BRSET | BGT | WAI | | | JN | ЛР | | L | os | | | L[ | ΟX | | Е | | 1111 | F | SEI | BRCLR | BLE | SWI | | | XGDX | | STS | | STOP | | STX | | F | | | | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | | | | • | | INI | ),X | | | | | | | | | | | | | | | Page 2 (18XX) BRSET **BRCLR** 1 IND,Y 2 3 4 5 1110 1111 Ε F Ε F LDY D STY Ε F LDS STS Α В С 9 #### ACCA ACCB IND,Y IND,X IND,X EXT INH INH IMM DIR EXT IMM DIR 1110 1111 0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 MSB LSB 0 1 2 3 4 5 6 7 8 9 Α В С D Ε F 0000 SUB SUB 0 TSY NEG 0 CMP CMP 0001 1 1 SBC SBC 2 2 0010 3 COM SUBD ADDD 0011 3 LSR 4 0100 AND AND 4 5 TYS 5 BIT BIT 0101 ROR LDA LDA 0110 6 6 7 ASR STA 7 STA 0111 8 INY **PULY** ASL **EOR EOR** 8 1000 9 DEY RDL ADC ADC 1001 9 1010 ORA Α ABY DEC ORA Α 1011 В ADD ADD В CPY 1100 С **BSET PSHY** INC LDD С 1101 D **BCLR** TST **JSR** STD D XGDY JMP CLR 6 7 | | | | | | | | | | | | AC | CCA | | | AC | СВ | | | |------|----|------|------|------|------|------|------|------|------|------|------|-------|------|------|------|-------|------|---| | | | | | | | | | | | IMM | DIR | IND,X | EXT | | | IND,X | | | | MS | SB | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 | | | LSB | \ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | | | 0000 | 0 | | | | | | | | | | | | | | | | | 0 | | 0001 | 1 | | | | | | | | | | | | | | | | | 1 | | 0010 | 2 | | | | | | | | | | | | | | | | | 2 | | 0011 | 3 | | | | | | | | | | Cl | PD | | | | | | 3 | | 0100 | 4 | | | | | | | | | | | | | | | | | 4 | | 0101 | 5 | | | | | | | | | | | | | | | | | 5 | | 0110 | 6 | | | | | | | | | | | | | | | | | 6 | | 0111 | 7 | | | | | | | | | | | | | | | | | 7 | | 1000 | 8 | | | | | | | | | | | | | | | | | 8 | | 1001 | 9 | | | | | | | | | | | | | | | | | 9 | | 1010 | Α | | | | | | | | | | | | | | | | | Α | | 1011 | В | | | | | | | | | | | | | | | | | В | | 1100 | С | | | | | | | | | | | CPY | | | | | | С | | 1101 | D | | | | | | | | | | | | | | | | | D | | 1110 | Е | | | | | | | | | | | | | | | LDY | | E | | 1111 | F | | | | | | | | | | | | | | | STY | | F | | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | В | С | D | E | F | | Page 4 (CDXX) | | | | | | | | | | | | AC | CA | | | AC | СВ | | ] | |------|-----|------|------|------|------|------|------|------|------|------|------|-------|------|------|------|-------|------|---| | | | | | | | | | | | | | IND,Y | | | | IND,Y | | | | N | ISB | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 | | | LSB | \ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | | | 0000 | 0 | | | | | | | | | | | | | | | | | 0 | | 0001 | 1 | | | | | | | | | | | | | | | | | 1 | | 0010 | 2 | | | | | | | | | | | | | | | | | 2 | | 0011 | 3 | | | | | | | | | | | CPD | | | | | | 3 | | 0100 | 4 | | | | | | | | | | | | | | | | | 4 | | 0101 | 5 | | | | | | | | | | | | | | | | | 5 | | 0110 | 6 | | | | | | | | | | | | | | | | | 6 | | 0111 | 7 | | | | | | | | | | | | | | | | | 7 | | 1000 | 8 | | | | | | | | | | | | | | | | | 8 | | 1001 | 9 | | | | | | | | | | | | | | | | | 9 | | 1010 | Α | | | | | | | | | | | | | | | | | A | | 1011 | В | | | | | | | | | | | | | | | | | В | | 1100 | С | | | | | | | | | | | CPX | | | | | | С | | 1101 | D | | | | | | | | | | | | | | | | | D | | 1110 | Ε | | | | | | | | | | | | | | | LDX | | E | | 1111 | F | | | | | | | | | | | | | | | STX | | F | | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | | # **Simple Branches** | Mnemonic | Opcode | Cycles | |----------|--------|--------| | BRA | 20 | 3 | | BRN | 21 | 3 | | BSR | 8D | 7 | # **Simple Conditional Branches** | Test | Tr | ue | Fa | lse | |-------|-------------|--------|-------------|--------| | Test | Instruction | Opcode | Instruction | Opcode | | N = 1 | BMI | 2B | BPL | 2A | | Z = 1 | BEQ | 27 | BNE | 26 | | V = 1 | BVS | 29 | BVC | 28 | | C = 1 | BCS | 25 | BCC | 24 | # **Signed Conditional Branches** | Test | Tr | ue | False | | | | | | |-----------|-------------|--------|-------------|--------|--|--|--|--| | 1621 | Instruction | Opcode | Instruction | Opcode | | | | | | r > m | BGT | 2E | BLE | 2F | | | | | | $r \ge m$ | BGE | 2C | BLT | 2D | | | | | | r = m | BEQ | 27 | BNE | 26 | | | | | | $r \le m$ | BLE | 2F | BGT | 2E | | | | | | r < m | BLT | 2D | BGE | 2C | | | | | # **Unsigned Conditional Branches** | Test | Tr | ue | False | | | | | | |-------|-------------|--------|-------------|--------|--|--|--|--| | rest | Instruction | Opcode | Instruction | Opcode | | | | | | r > m | BHI | 22 | BLS | 23 | | | | | | r ≥ m | BHS/BCC | 24 | BL0/BCS | 25 | | | | | | r = m | BEQ | 27 | BNE | 26 | | | | | | r ≤ m | BLS | 23 | BHI | 22 | | | | | | r < m | BLO/BCS | 25 | BHS/BCC | 24 | | | | | # **Bit Manipulation Branches** **BRCLR** Branch if all selected bits are clear (opcode) (operand addr) (mask) (rel offset) M • mm = 0? M = operand in memory; mm = mask BRSET Branch if all selected bits are set (opcode) (operand addr) (rel offset) $(\overline{M}) \bullet mm = 0$ ? M = operand in memory; <math>mm = mask # **Instruction Set** Refer to **Table 1**, which shows all the M68HC11 instructions in all possible addressing modes. For each instruction, the table shows the operand construction, the number of machine code bytes, and execution time in CPU E-clock cycles. Table 1. Instruction Set (Sheet 1 of 8) | Mnemonic | Operation | Description | Addressing | | | | | | Co | nditio | n Coc | les | | | |------------|----------------------------|---------------------------------|-----------------------------------------------|-------------------------------|----------------------------|-----------------------|---|---|----|--------|-------|-----|---|---| | winemonic | Operation | Description | Mode | Opcode | Operand | Cycles | s | Х | Н | ı | N | Z | ٧ | С | | ABA | Add<br>Accumulators | $A + B \Rightarrow A$ | INH | 1B | _ | 2 | _ | _ | Δ | _ | Δ | Δ | Δ | Δ | | ABX | Add B to X | IX + (00 : B) ⇒ IX | INH | 3A | _ | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | ABY | Add B to Y | IY + (00 : B) ⇒ IY | INH | 18 3A | _ | 4 | _ | _ | _ | _ | _ | _ | _ | _ | | ADCA (opr) | Add with Carry<br>to A | $A + M + C \Rightarrow A$ | A IMM A DIR A EXT A IND,X A IND,Y | 89<br>99<br>B9<br>A9<br>18 A9 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | Δ | _ | Δ | Δ | Δ | Δ | | ADCB (opr) | Add with Carry<br>to B | $B + M + C \Rightarrow B$ | B IMM B DIR B EXT B IND,X B IND,Y | C9<br>D9<br>F9<br>E9<br>18 E9 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | | _ | Δ | _ | Δ | Δ | Δ | Δ | | ADDA (opr) | Add Memory to<br>A | $A + M \Rightarrow A$ | A IMM A DIR A EXT A IND,X A IND,Y | 8B<br>9B<br>BB<br>AB<br>18 AB | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | Δ | _ | Δ | Δ | Δ | Δ | | ADDB (opr) | Add Memory to<br>B | $B + M \Rightarrow B$ | B IMM B DIR B EXT B IND,X B IND,Y | CB<br>DB<br>FB<br>EB<br>18 EB | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | Δ | _ | Δ | Δ | Δ | Δ | | ADDD (opr) | Add 16-Bit to D | $D + (M : M + 1) \Rightarrow D$ | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | C3<br>D3<br>F3<br>E3<br>18 E3 | jj kk<br>dd<br>hh II<br>ff | 4<br>5<br>6<br>6<br>7 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | ANDA (opr) | AND A with<br>Memory | $A \bullet M \Rightarrow A$ | A IMM<br>A DIR<br>A EXT<br>A IND,X<br>A IND,Y | 84<br>94<br>B4<br>A4<br>18 A4 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | ANDB (opr) | AND B with<br>Memory | $B \bullet M \Rightarrow B$ | B IMM B DIR B EXT B IND,X B IND,Y | C4<br>D4<br>F4<br>E4 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | ASL (opr) | Arithmetic Shift<br>Left | 0 C b7 b0 | EXT<br>IND,X<br>IND,Y | 78<br>68<br>18 68 | hh II<br>ff<br>ff | 6<br>6<br>7 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | ASLA | Arithmetic Shift<br>Left A | C b7 b0 | A INH | 48 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | ASLB | Arithmetic Shift<br>Left B | C b7 b0 | B INH | 58 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | ASLD | Arithmetic Shift<br>Left D | C b7 A b0 b7 B b0 | INH | 05 | _ | 3 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | Table 1. Instruction Set (Sheet 2 of 8) | | | | Addressing | g Instruction | | | | Condition Codes | | | | | | | | | |---------------------|-----------------------------|-------------------------------------------|------------------|---------------|----------|----------------------|--------|-----------------|---|---|----------|----|---|---|---|--| | Mnemonic | Operation | Description | Mode | Opp | ode | Operand | Cycles | s | Х | Н | I | N | Z | ٧ | С | | | ASR | Arithmetic Shift | | EXT | 900 | 77 | hh II | 6 | _ | _ | | <u> </u> | Δ | Δ | Δ | Δ | | | | Right | | IND,X<br>IND,Y | 18 | 67<br>67 | ff<br>ff | 6<br>7 | | | | | | | | | | | ASRA | Arithmetic Shift | b7 b0 C | A INH | 10 | 47 | | 2 | | | | | Δ | Δ | Δ | Δ | | | AOIVA | Right A | b7 b0 C | A INII | | 47 | | | | | | | Δ | Δ | Δ | Δ | | | 4000 | A ::1 :: Ol :fr | b7 b0 C | D 15111 | | | | | | | | | | | | | | | ASRB | Arithmetic Shift<br>Right B | | B INH | | 57 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | | | 3 | b7 b0 C | | | | | | | | | | | | | | | | BCC (rel) | Branch if Carry<br>Clear | ? C = 0 | REL | | 24 | rr | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | | BCLR (opr) | Clear Bit(s) | $M \bullet (\overline{mm}) \Rightarrow M$ | DIR | | 15 | dd mm | 6 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | | (msk) | | | IND,X<br>IND,Y | 18 | 1D<br>1D | ff mm<br>ff mm | 7<br>8 | | | | | | | | | | | BCS (rel) | Branch if Carry | ? C = 1 | REL | - | 25 | rr | 3 | _ | | | | _ | | _ | | | | | Set | | | | | | | | | | | | | | | | | BEQ (rel) | Branch if = Zero | ? Z = 1 | REL | | 27 | rr | 3 | _ | _ | _ | | _ | _ | _ | | | | BGE (rel) | Branch if ∆ Zero | ? N ⊕ V = 0 | REL | | 2C | rr | 3 | _ | | | _ | _ | | | _ | | | BGT (rel) | Branch if > Zero | $? Z + (N \oplus V) = 0$ | REL | | 2E | rr | 3 | _ | | | | _ | | _ | | | | BHI (rel) | Branch if<br>Higher | ? C + Z = 0 | REL | | 22 | rr | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | | BHS (rel) | Branch if<br>Higher or Same | ? C = 0 | REL | | 24 | rr | 3 | _ | _ | - | _ | _ | - | _ | _ | | | BITA (opr) | Bit(s) Test A | A • M | A IMM | | 85 | ii | 2 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | | | with Memory | | A DIR<br>A EXT | | 95<br>B5 | dd<br>hh II | 3<br>4 | | | | | | | | | | | | | | A IND,X | 40 | A5 | ff | 4 | | | | | | | | | | | BITB (opr) | Bit(s) Test B | B • M | A IND,Y B IMM | 18 | A5<br>C5 | ff | 5<br>2 | | | | | Δ | Δ | 0 | | | | БПБ (орг) | with Memory | D - W | B DIR | | D5 | dd | 3 | | | | | Δ. | Δ | U | | | | | | | B EXT<br>B IND,X | | F5<br>E5 | hh II<br>ff | 4 | | | | | | | | | | | | | | B IND,Y | 18 | E5 | ff | 5 | | | | | | | | | | | BLE (rel) | Branch if $\Delta$ Zero | ? Z + (N ⊕ V) = 1 | REL | | 2F | rr | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | | BLO (rel) | Branch if Lower | ? C = 1 | REL | | 25 | rr | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | | BLS (rel) | Branch if Lower or Same | ? C + Z = 1 | REL | | 23 | rr | 3 | _ | _ | _ | _ | _ | _ | - | _ | | | BLT (rel) | Branch if < Zero | ? N ⊕ V = 1 | REL | | 2D | rr | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | | BMI (rel) | Branch if Minus | ? N = 1 | REL | | 2B | rr | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | | BNE (rel) | Branch if not = Zero | ? Z = 0 | REL | | 26 | rr | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | | BPL (rel) | Branch if Plus | ? N = 0 | REL | | 2A | rr | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | | BRA (rel) | Branch Always | ? 1 = 1 | REL | | 20 | rr | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | | BRCLR(opr)<br>(msk) | Branch if<br>Bit(s) Clear | ? M • mm = 0 | DIR<br>IND,X | | 13<br>1F | dd mm rr<br>ff mm rr | 6<br>7 | _ | _ | _ | _ | _ | _ | _ | _ | | | (rel) | Dit(3) Olcai | | IND,Y | 18 | 1F | ff mm rr | 8 | | | | | | | | | | | BRN (rel) | Branch Never | ? 1 = 0 | REL | | 21 | rr | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | | BRSET(opr) | Branch if Bit(s) | ? ( <del>M</del> ) • mm = 0 | DIR | | 12 | dd mm rr | 6 | _ | _ | _ | _ | _ | _ | _ | _ | | | (msk)<br>(rel) | Set | | IND,X<br>IND,Y | 18 | 1E<br>1E | ff mm rr<br>ff mm rr | 7<br>8 | | | | | | | | | | | BSET (opr) | Set Bit(s) | $M + mm \Rightarrow M$ | DIR | | 14 | dd mm | 6 | _ | _ | _ | | Δ | Δ | 0 | | | | (msk) | | | IND,X<br>IND,Y | 18 | 1C<br>1C | ff mm<br>ff mm | 7<br>8 | | | | | | | | | | | BSR (rel) | Branch to<br>Subroutine | See Figure 3–2 | REL | | 8D | rr | 6 | _ | _ | _ | _ | _ | _ | _ | _ | | | BVC (rel) | Branch if<br>Overflow Clear | ? V = 0 | REL | | 28 | rr | 3 | _ | _ | _ | _ | _ | _ | - | _ | | Table 1. Instruction Set (Sheet 3 of 8) | | | | Addressir | g | I | nstruction | | | | C | onditio | n Co | des | | | |------------|-----------------------------------|---------------------|---------------------------------------------|---|----------------------------|----------------------------------|-----------------------|---|---|---|---------|------|-----|---|---| | Mnemonic | Operation | Description | Mode | _ | Opcode | Operand | Cycles | s | Х | Н | ı | N | Z | ٧ | С | | BVS (rel) | Branch if<br>Overflow Set | ? V = 1 | REL | | 29 | rr | 3 | _ | _ | _ | _ | - | _ | - | _ | | СВА | Compare A to B | A – B | INH | | 11 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | CLC | Clear Carry Bit | $0\RightarrowC$ | INH | | 0C | _ | 2 | _ | _ | _ | _ | _ | _ | _ | 0 | | CLI | Clear Interrupt<br>Mask | 0 ⇒ I | INH | | 0E | _ | 2 | - | _ | _ | 0 | - | _ | _ | _ | | CLR (opr) | Clear Memory<br>Byte | $0 \Rightarrow M$ | EXT<br>IND,<br>IND, | | 7F<br>6F<br>6F | hh II<br>ff<br>ff | 6<br>6<br>7 | _ | _ | _ | _ | 0 | 1 | 0 | 0 | | CLRA | Clear<br>Accumulator A | 0 ⇒ A | A INH | | 4F | _ | 2 | _ | _ | _ | _ | 0 | 1 | 0 | 0 | | CLRB | Clear<br>Accumulator B | 0 ⇒ B | B INH | | 5F | _ | 2 | _ | _ | _ | _ | 0 | 1 | 0 | 0 | | CLV | Clear Overflow<br>Flag | $0 \Rightarrow V$ | INH | | 0A | _ | 2 | _ | _ | _ | _ | _ | - | 0 | _ | | CMPA (opr) | Compare A to<br>Memory | A – M | A IMM<br>A DIR<br>A EXT<br>A IND,<br>A IND, | | 81<br>91<br>B1<br>A1<br>A1 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | | - | _ | _ | Δ | Δ | Δ | Δ | | CMPB (opr) | Compare B to<br>Memory | B – M | B IMM B DIR B EXT B IND,3 B IND, | | C1<br>D1<br>F1<br>E1 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | | _ | _ | _ | Δ | Δ | Δ | Δ | | COM (opr) | Ones<br>Complement<br>Memory Byte | \$FF − M ⇒ M | EXT<br>IND,<br>IND, | | 73<br>63<br>63 | hh II<br>ff<br>ff | 6<br>6<br>7 | _ | _ | _ | _ | Δ | Δ | 0 | 1 | | COMA | Ones<br>Complement<br>A | \$FF − A ⇒ A | A INH | | 43 | _ | 2 | _ | _ | _ | _ | Δ | Δ | 0 | 1 | | COMB | Ones<br>Complement<br>B | \$FF – B ⇒ B | B INH | | 53 | _ | 2 | _ | _ | _ | _ | Δ | Δ | 0 | 1 | | CPD (opr) | Compare D to<br>Memory 16-Bit | D-M:M +1 | IMM<br>DIR<br>EXT<br>IND,<br>IND, | | 93<br>B3<br>A A3 | jj kk<br>dd<br>hh II<br>ff<br>ff | 5<br>6<br>7<br>7<br>7 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | CPX (opr) | Compare X to<br>Memory 16-Bit | IX – M : M + 1 | IMM<br>DIR<br>EXT<br>IND,<br>IND, | | 8C<br>9C<br>BC<br>AC<br>AC | jj kk<br>dd<br>hh II<br>ff | 4<br>5<br>6<br>6<br>7 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | CPY (opr) | Compare Y to<br>Memory 16-Bit | IY – M : M + 1 | IMM<br>DIR<br>EXT<br>IND,<br>IND, | | 9C<br>BC<br>AC | jj kk<br>dd<br>hh II<br>ff | 5<br>6<br>7<br>7<br>7 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | DAA | Decimal Adjust<br>A | Adjust Sum to BCD | INH | | 19 | _ | 2 | _ | - | _ | - | Δ | Δ | Δ | Δ | | DEC (opr) | Decrement<br>Memory Byte | $M-1 \Rightarrow M$ | EXT<br>IND,<br>IND, | | 7A<br>6A<br>6A | hh II<br>ff<br>ff | 6<br>6<br>7 | _ | _ | _ | _ | Δ | Δ | Δ | _ | | DECA | Decrement<br>Accumulator<br>A | $A-1 \Rightarrow A$ | A INH | | 4A | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | _ | | DECB | Decrement<br>Accumulator<br>B | B − 1 ⇒ B | B INH | | 5A | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | _ | Table 1. Instruction Set (Sheet 4 of 8) | Mnemonic | Operation | Description | Addressing | I | nstruction | | | | Co | onditio | on Co | des | | | |------------|----------------------------------|---------------------------------------------|-----------------------------------------------|-------------------------------|----------------------------|-----------------------|---|---|----|---------|-------|-----|---|---| | Winemonic | Operation | Description | Mode | Opcode | Operand | Cycles | S | Х | Н | I | N | Z | ٧ | С | | DES | Decrement<br>Stack Pointer | SP − 1 ⇒ SP | INH | 34 | _ | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | DEX | Decrement<br>Index Register<br>X | IX − 1 ⇒ IX | INH | 09 | _ | 3 | _ | _ | _ | _ | _ | Δ | _ | _ | | DEY | Decrement<br>Index Register<br>Y | IY − 1 ⇒ IY | INH | 18 09 | _ | 4 | _ | _ | _ | _ | _ | Δ | _ | _ | | EORA (opr) | Exclusive OR A with Memory | $A \oplus M \Rightarrow A$ | A IMM<br>A DIR<br>A EXT<br>A IND,X<br>A IND,Y | 88<br>98<br>B8<br>A8<br>18 A8 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | EORB (opr) | Exclusive OR B with Memory | $B \oplus M \Rightarrow B$ | B IMM<br>B DIR<br>B EXT<br>B IND,X<br>B IND,Y | C8<br>D8<br>F8<br>E8<br>18 E8 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | FDIV | Fractional<br>Divide 16 by 16 | $D / IX \Rightarrow IX; r \Rightarrow D$ | INH | 03 | _ | 41 | _ | _ | _ | _ | _ | Δ | Δ | Δ | | IDIV | Integer Divide<br>16 by 16 | $D / IX \Rightarrow IX; r \Rightarrow D$ | INH | 02 | _ | 41 | _ | _ | _ | _ | _ | Δ | 0 | Δ | | INC (opr) | Increment<br>Memory Byte | M + 1 ⇒ M | EXT<br>IND,X<br>IND,Y | 7C<br>6C<br>18 6C | hh II<br>ff<br>ff | 6<br>6<br>7 | _ | _ | _ | _ | Δ | Δ | Δ | _ | | INCA | Increment<br>Accumulator<br>A | A + 1 ⇒ A | A INH | 4C | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | _ | | INCB | Increment<br>Accumulator<br>B | B + 1 ⇒ B | B INH | 5C | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | _ | | INS | Increment<br>Stack Pointer | $SP + 1 \Rightarrow SP$ | INH | 31 | _ | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | INX | Increment<br>Index Register<br>X | IX + 1 ⇒ IX | INH | 08 | _ | 3 | _ | _ | _ | _ | _ | Δ | _ | _ | | INY | Increment<br>Index Register<br>Y | IY + 1 ⇒ IY | INH | 18 08 | _ | 4 | _ | _ | _ | _ | _ | Δ | _ | _ | | JMP (opr) | Jump | See Figure 3–2 | EXT<br>IND,X<br>IND,Y | 7E<br>6E<br>18 6E | hh II<br>ff<br>ff | 3<br>3<br>4 | _ | _ | _ | _ | _ | _ | _ | _ | | JSR (opr) | Jump to<br>Subroutine | See Figure 3–2 | DIR<br>EXT<br>IND,X<br>IND,Y | 9D<br>BD<br>AD<br>18 AD | dd<br>hh II<br>ff | 5<br>6<br>6<br>7 | _ | _ | _ | _ | _ | _ | _ | _ | | LDAA (opr) | Load<br>Accumulator<br>A | $M \Rightarrow A$ | A IMM<br>A DIR<br>A EXT<br>A IND,X<br>A IND,Y | 86<br>96<br>B6<br>A6<br>18 A6 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | LDAB (opr) | Load<br>Accumulator<br>B | $M\RightarrowB$ | B IMM B DIR B EXT B IND,X B IND,Y | C6<br>D6<br>F6<br>E6 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | LDD (opr) | Load Double<br>Accumulator<br>D | $M \Rightarrow A, M+1 \Rightarrow B$ | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | CC<br>DC<br>FC<br>EC<br>18 EC | jj kk<br>dd<br>hh II<br>ff | 3<br>4<br>5<br>5<br>6 | _ | _ | _ | _ | Δ | Δ | 0 | _ | Table 1. Instruction Set (Sheet 5 of 8) | Mmau: -:-!- | Operation | Decertation | Addressing | ı | nstruction | | | | Co | onditio | on Co | des | | | |-------------|------------------------------------|---------------------------------------|-------------------------------------|-------------------------------------------|----------------------------|-----------------------|---|---|----|---------|-------|-----|---|---| | Mnemonic | Operation | Description | Mode | Opcode | Operand | Cycles | S | Х | Н | I | N | Z | ٧ | С | | LDS (opr) | Load Stack<br>Pointer | M:M+1⇒SP | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 8E<br>9E<br>BE<br>AE<br>18 AE | jj kk<br>dd<br>hh II<br>ff | 3<br>4<br>5<br>5<br>6 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | LDX (opr) | Load Index<br>Register<br>X | M : M + 1 ⇒ IX | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | CE<br>DE<br>FE<br>EE<br>CD EE | jj kk<br>dd<br>hh II<br>ff | 3<br>4<br>5<br>5<br>6 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | LDY (opr) | Load Index<br>Register<br>Y | M : M + 1 ⇒ IY | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 CE<br>18 DE<br>18 FE<br>1A EE<br>18 EE | jj kk<br>dd<br>hh II<br>ff | 4<br>5<br>6<br>6<br>6 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | LSL (opr) | Logical Shift<br>Left | ————————————————————————————————————— | EXT<br>IND,X<br>IND,Y | 78<br>68<br>18 68 | hh II<br>ff<br>ff | 6<br>6<br>7 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | LSLA | Logical Shift<br>Left A | ← 0<br>C b7 b0 | A INH | 48 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | LSLB | Logical Shift<br>Left B | ————————————————————————————————————— | B INH | 58 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | LSLD | Logical Shift<br>Left Double | C b7 A b0 b7 B b0 | INH | 05 | _ | 3 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | LSR (opr) | Logical Shift<br>Right | 0 | EXT<br>IND,X<br>IND,Y | 74<br>64<br>18 64 | hh II<br>ff<br>ff | 6<br>6<br>7 | _ | _ | _ | _ | 0 | Δ | Δ | Δ | | LSRA | Logical Shift<br>Right A | 0 | A INH | 44 | _ | 2 | _ | _ | _ | _ | 0 | Δ | Δ | Δ | | LSRB | Logical Shift<br>Right B | 0 | B INH | 54 | _ | 2 | _ | _ | _ | _ | 0 | Δ | Δ | Δ | | LSRD | Logical Shift<br>Right Double | 0+ | INH | 04 | _ | 3 | _ | _ | _ | _ | 0 | Δ | Δ | Δ | | MUL | Multiply 8 by 8 | $A * B \Rightarrow D$ | INH | 3D | _ | 10 | _ | _ | _ | _ | _ | _ | _ | Δ | | NEG (opr) | Two's<br>Complement<br>Memory Byte | 0 − M ⇒ M | EXT<br>IND,X<br>IND,Y | 70<br>60<br>18 60 | hh II<br>ff<br>ff | 6<br>6<br>7 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | NEGA | Two's<br>Complement<br>A | 0 − A ⇒ A | A INH | 40 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | NEGB | Two's<br>Complement<br>B | 0 − B ⇒ B | B INH | 50 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | NOP | No operation | No Operation | INH | 01 | _ | 2 | _ | _ | _ | _ | _ | _ | _ | _ | | ORAA (opr) | OR<br>Accumulator<br>A (Inclusive) | $A + M \Rightarrow A$ | A IMM A DIR A EXT A IND,X A IND,Y | 8A<br>9A<br>BA<br>AA<br>18 AA | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | ORAB (opr) | OR<br>Accumulator<br>B (Inclusive) | B + M ⇒ B | B IMM B DIR B EXT B IND,X B IND,Y | CA<br>DA<br>FA<br>EA<br>18 EA | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | _ | _ | Δ | Δ | 0 | _ | Table 1. Instruction Set (Sheet 6 of 8) | | | | Address | ing | lı | nstruction | | | | Co | onditio | on Cod | des | | | |------------|------------------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------|---------------|------------------------------|-------------------------|-----------------------|---|----------|----|---------|--------|-----|---|---| | Mnemonic | Operation | Description | Mode | | Opcode | Operand | Cycles | s | Х | Н | ı | N | Z | ٧ | С | | PSHA | Push A onto<br>Stack | $A \Rightarrow Stk,SP = SP - 1$ | A INF | I | 36 | _ | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | PSHB | Push B onto<br>Stack | $B \Rightarrow Stk, SP = SP - 1$ | B INH | ł | 37 | _ | 3 | _ | _ | _ | _ | - | - | _ | _ | | PSHX | Push X onto<br>Stack (Lo<br>First) | $IX \Rightarrow Stk, SP = SP - 2$ | INF | I | 3C | _ | 4 | _ | _ | _ | _ | _ | _ | _ | _ | | PSHY | Push Y onto<br>Stack (Lo<br>First) | $IY \Rightarrow Stk, SP = SP - 2$ | INH | i 1 | 8 3C | _ | 5 | _ | _ | _ | _ | _ | _ | _ | _ | | PULA | Pull A from<br>Stack | SP = SP + 1, A ← Stk | A INH | ł | 32 | _ | 4 | _ | _ | _ | _ | - | - | _ | _ | | PULB | Pull B from<br>Stack | SP = SP + 1, B ← Stk | B INH | ł | 33 | _ | 4 | _ | _ | - | - | - | - | _ | _ | | PULX | Pull X From<br>Stack (Hi<br>First) | SP = SP + 2, IX ← Stk | INF | I | 38 | _ | 5 | _ | _ | _ | _ | _ | _ | _ | _ | | PULY | Pull Y from<br>Stack (Hi<br>First) | SP = SP + 2, IY ← Stk | INF | 1 1 | 8 38 | _ | 6 | _ | _ | _ | _ | _ | _ | _ | _ | | ROL (opr) | Rotate Left | <b>←□←□□−</b> □ <b>−</b> | EX <sup>-</sup><br>IND<br>IND | ),X | 79<br>69<br>8 69 | hh II<br>ff<br>ff | 6<br>6<br>7 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | ROLA | Rotate Left A | C b7 b0 | A INF | I | 49 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | ROLB | Rotate Left B | C b7 b0 | B INF | I | 59 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | ROR (opr) | Rotate Right | b7 b0 C | EX <sup>-</sup><br>INC<br>INC | ),X | 76<br>66<br>8 66 | hh II<br>ff<br>ff | 6<br>6<br>7 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | RORA | Rotate Right A | b7 b0 C | A INF | I | 46 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | RORB | Rotate Right B | b7 b0 C | B INF | I | 56 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | RTI | Return from<br>Interrupt | See Figure 3–2 | INH | I | 3B | _ | 12 | Δ | <b>\</b> | Δ | Δ | Δ | Δ | Δ | Δ | | RTS | Return from<br>Subroutine | See Figure 3–2 | INH | ł | 39 | _ | 5 | _ | _ | - | - | - | - | _ | _ | | SBA | Subtract B from<br>A | $A - B \Rightarrow A$ | INH | I | 10 | _ | 2 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | SBCA (opr) | Subtract with<br>Carry from A | $A - M - C \Rightarrow A$ | A IMM<br>A DIR<br>A EXT<br>A IND<br>A IND | R<br>T<br>D,X | 82<br>92<br>B2<br>A2<br>8 A2 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | | _ | _ | _ | Δ | Δ | Δ | Δ | | SBCB (opr) | Subtract with<br>Carry from B | $B-M-C\RightarrowB$ | B IMM<br>B DIR<br>B EXT<br>B IND<br>B IND | R<br>T<br>D,X | C2<br>D2<br>F2<br>E2<br>E2 | ii<br>dd<br>hh II<br>ff | 2<br>3<br>4<br>4<br>5 | _ | _ | _ | _ | Δ | Δ | Δ | Δ | | SEC | Set Carry | 1 ⇒ C | INH | ı | 0D | _ | 2 | _ | _ | _ | _ | _ | _ | _ | 1 | | SEI | Set Interrupt<br>Mask | 1 ⇒ I | INF | 1 | 0F | | 2 | | | | 1 | | | | | | SEV | Set Overflow<br>Flag | 1 ⇒ V | INH | I | 0B | _ | 2 | _ | _ | - | _ | - | - | 1 | _ | Table 1. Instruction Set (Sheet 7 of 8) | | 5 | Α | ddressing | | li | nstructio | n | | | | Co | onditio | n Cod | les | | | | |------------|--------------------------------|----------------------------------------|------------------|-------------------------------------|----------------------|----------------------------|----------------------------|------|-----------------------|---|----------|---------|-------|-----|---|---|---| | Mnemonic | Operation | Description | | Mode | O | pcode | Opera | nd ( | Cycles | S | Х | Н | ı | N | Z | ٧ | С | | STAA (opr) | Store<br>Accumulator<br>A | $A\RightarrowM$ | A<br>A<br>A | DIR<br>EXT<br>IND,X<br>IND,Y | 18 | 97<br>B7<br>A7<br>A7 | dd<br>hh II<br>ff | | 3<br>4<br>4<br>5 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | STAB (opr) | Store<br>Accumulator<br>B | $B\RightarrowM$ | B<br>B<br>B | DIR<br>EXT<br>IND,X<br>IND,Y | 18 | D7<br>F7<br>E7<br>E7 | dd<br>hh II<br>ff | | 3<br>4<br>4<br>5 | | _ | _ | _ | Δ | Δ | 0 | _ | | STD (opr) | Store<br>Accumulator<br>D | $A \Rightarrow M, B \Rightarrow M + 1$ | | DIR<br>EXT<br>IND,X<br>IND,Y | 18 | DD<br>FD<br>ED<br>ED | dd<br>hh II<br>ff | | 4<br>5<br>5<br>6 | 1 | _ | _ | _ | Δ | Δ | 0 | _ | | STOP | Stop Internal<br>Clocks | _ | | INH | | CF | _ | | 2 | | _ | _ | _ | _ | - | _ | _ | | STS (opr) | Store Stack<br>Pointer | SP ⇒ M : M + 1 | | DIR<br>EXT<br>IND,X<br>IND,Y | 18 | 9F<br>BF<br>AF<br>AF | dd<br>hh II<br>ff | | 4<br>5<br>5<br>6 | | _ | _ | _ | Δ | Δ | 0 | _ | | STX (opr) | Store Index<br>Register X | IX ⇒ M : M + 1 | | DIR<br>EXT<br>IND,X<br>IND,Y | CD | DF<br>FF<br>EF<br>EF | dd<br>hh II<br>ff | | 4<br>5<br>5<br>6 | | _ | _ | _ | Δ | Δ | 0 | _ | | STY (opr) | Store Index<br>Register Y | IY ⇒ M : M + 1 | | DIR<br>EXT<br>IND,X<br>IND,Y | 18<br>18<br>1A<br>18 | DF<br>FF<br>EF<br>EF | dd<br>hh II<br>ff | | 5<br>6<br>6 | | _ | _ | _ | Δ | Δ | 0 | _ | | SUBA (opr) | Subtract<br>Memory from<br>A | A − M ⇒ A | A<br>A<br>A<br>A | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 | 80<br>90<br>B0<br>A0<br>A0 | ii<br>dd<br>hh II<br>ff | | 2<br>3<br>4<br>4<br>5 | | _ | _ | _ | Δ | Δ | Δ | Δ | | SUBB (opr) | Subtract<br>Memory from<br>B | $B - M \Rightarrow B$ | A<br>A<br>A<br>A | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 | C0<br>D0<br>F0<br>E0 | ii<br>dd<br>hh II<br>ff | | 2<br>3<br>4<br>4<br>5 | - | _ | _ | _ | Δ | Δ | Δ | Δ | | SUBD (opr) | Subtract<br>Memory from<br>D | D − M : M + 1 ⇒ D | | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 | 83<br>93<br>B3<br>A3<br>A3 | jj kk<br>dd<br>hh II<br>ff | | 4<br>5<br>6<br>6<br>7 | 1 | _ | _ | _ | Δ | Δ | Δ | Δ | | SWI | Software<br>Interrupt | See Figure 3–2 | | INH | | 3F | _ | | 14 | _ | _ | _ | 1 | _ | - | _ | _ | | TAB | Transfer A to B | $A \Rightarrow B$ | | INH | | 16 | _ | | 2 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | TAP | Transfer A to CC Register | $A \Rightarrow CCR$ | | INH | | 06 | _ | | 2 | Δ | <b>\</b> | Δ | Δ | Δ | Δ | Δ | Δ | | TBA | Transfer B to A | $B \Rightarrow A$ | | INH | | 17 | _ | | 2 | _ | _ | _ | _ | Δ | Δ | 0 | _ | | TEST | TEST (Only in<br>Test Modes) | Address Bus Counts | | INH | | 00 | _ | | * | - | _ | _ | _ | _ | _ | - | _ | | TPA | Transfer CC<br>Register to A | $CCR \Rightarrow A$ | | INH | | 07 | _ | | 2 | - | _ | _ | _ | _ | _ | - | _ | | TST (opr) | Test for Zero or<br>Minus | M – 0 | | EXT<br>IND,X<br>IND,Y | 18 | 7D<br>6D<br>6D | hh II<br>ff<br>ff | | 6<br>6<br>7 | _ | _ | _ | _ | Δ | Δ | 0 | 0 | | TSTA | Test A for Zero or Minus | A – 0 | A | INH | | 4D | _ | | 2 | - | - | _ | - | Δ | Δ | 0 | 0 | | TSTB | Test B for Zero or Minus | B – 0 | В | INH | | 5D | _ | | 2 | _ | _ | _ | _ | Δ | Δ | 0 | 0 | | TSX | Transfer Stack<br>Pointer to X | SP + 1 ⇒ IX | | INH | | 30 | _ | | 3 | _ | _ | _ | _ | _ | _ | _ | _ | # Table 1. Instruction Set (Sheet 8 of 8) | Mnemonic | Operation | Description | Addressing | | In | struction | • | | | Co | nditio | n Coc | les | | | |--------------|--------------------------------|---------------------------------|------------|----|------|-----------|--------|---|---|----|--------|-------|-----|---|---| | Willellionic | Operation | Description | Mode | Op | code | Operand | Cycles | S | Х | Н | I | N | Z | ٧ | С | | TSY | Transfer Stack<br>Pointer to Y | SP + 1 ⇒ IY | INH | 18 | 30 | _ | 4 | _ | _ | _ | _ | _ | _ | _ | _ | | TXS | Transfer X to<br>Stack Pointer | IX − 1 ⇒ SP | INH | | 35 | _ | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | TYS | Transfer Y to<br>Stack Pointer | IY − 1 ⇒ SP | INH | 18 | 35 | _ | 4 | _ | _ | _ | _ | _ | _ | _ | _ | | WAI | Wait for<br>Interrupt | Stack Regs & WAIT | INH | | 3E | _ | ** | _ | _ | _ | _ | _ | _ | _ | _ | | XGDX | Exchange D with X | $IX\RightarrowD,D\RightarrowIX$ | INH | | 8F | _ | 3 | _ | _ | _ | _ | _ | _ | _ | _ | | XGDY | Exchange D with Y | $IY\RightarrowD,D\RightarrowIY$ | INH | 18 | 8F | _ | 4 | _ | _ | _ | _ | _ | _ | _ | _ | #### Cycle - \* Infinity or until reset occurs - \*\* 12 cycles are used beginning with the opcode fetch. A wait state is entered which remains in effect for an integer number of MPU E-clock cycles (n) until an interrupt is recognized. Finally, two additional cycles are used to fetch the appropriate interrupt vector (14 + n total). #### Operands - dd = 8-bit direct address (\$0000-\$00FF) (high byte assumed to be \$00) - ff = 8-bit positive offset \$00 (0) to \$FF (255) (is added to index) - hh = High-order byte of 16-bit extended address - ii = One byte of immediate data - jj = High-order byte of 16-bit immediate data - kk = Low-order byte of 16-bit immediate data - II = Low-order byte of 16-bit extended address - mm = 8-bit mask (set bits to be affected) - rr = Signed relative offset \$80 (-128) to \$7F (+127) (offset relative to address following machine code offset byte)) #### Operators - () Contents of register shown inside parentheses - $\downarrow\downarrow$ Is pushed onto stack - Boolean AND - Arithmetic addition symbol except where used as inclusive-OR symbol in Boolean formula - ⊕ Exclusive-OR - \* Multiply - : Concatenation - Arithmetic subtraction symbol or negation symbol (two's complement) #### **Condition Codes** - Bit not changed - 0 Bit always cleared - 1 Bit always set - $\Delta$ Bit cleared or set, depending on operation $\downarrow$ Bit can be cleared, cannot become set # **Special Operations** #### JSR, JUMP TO SUBROUTINE #### **BSR, BRANCH TO SUBROUTINE** #### RTS, RETURN FROM SUBROUTINE #### RTI, RETURN FROM INTERRUPT #### SWI, SOFTWARE INTERRUPT #### LEGEND: - RTN = ADDRESS OF NEXT INSTRUCTION IN MAIN PROGRAM TO - BE EXECUTED UPON RETURN FROM SUBROUTINE - RTN<sub>H</sub> = MOST SIGNIFICANT BYTE OF RETURN ADDRESS - RTN<sub>L</sub> = LEAST SIGNIFICANT BYTE OF RETURN ADDRESS - = STACK POINTER POSITION AFTER OPERATION IS COMPLETE dd = 8-BIT DIRECT ADDRESS (\$0000-\$00FF) (HIGH BYTE ASSUMED TO BE \$00) - ff = 8-BIT POSITIVE OFFSET \$00 (0) TO \$FF (255) IS ADDED TO INDEX - hh = HIGH-ORDER BYTE OF 16-BIT EXTENDED ADDRESS II = LOW-ORDER BYTE OF 16-BIT EXTENDED ADDRESS - rr = SIGNED RELATIVE OFFSET \$80 (–128) TO \$7F (+127) (OFFSET RELATIVE TO THE ADDRESS FOLLOWING THE MACHINE CODE OFFSET BYTE) # M68HC11E Series Registers **Figure 6** provides a summary of the M68HC11E registers. Note that the 128-byte register block can be remapped to any 4K boundary. Figure 6. Register and Control Bit Assignments (Sheet 1 of 6) Figure 6. Register and Control Bit Assignments (Sheet 2 of 6) | Addr. | Register Name | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | |---------|---------------------------------------------------------|-----------------|-------------|--------------|--------|--------|------------|-----------|-------|-------| | \$1017 | Timer Output Compare 1 Register<br>Low (TOC1L) | Read:<br>Write: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | 2011 (10012) | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | \$1018 | Timer Output Compare 2 Register<br>High (TOC2H) | Read:<br>Write: | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | | Tilgit (100211) | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | \$1019 | Timer Output Compare 2 Register<br>Low (TOC2L) | Read:<br>Write: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | \$101A | Timer Output Compare 3 Register<br>High (TOC3H) | Read:<br>Write: | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | \$101B | Timer Output Compare 3 Register<br>Low (TOC3L) | Read:<br>Write: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | ···(····-) | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | \$101C | Timer Output Compare 4 Register<br>High (TOC4H) | Read:<br>Write: | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | | nigii (1004n, | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | \$101D | Timer Output Compare 4 Register<br>Low (TOC4L) | Read:<br>Write: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | 2011 (10012) | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | \$101E | Timer Input Capture 4/Output<br>Compare 5 Register High | Read:<br>Write: | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | | (TI4/O5) | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | \$101F | Timer Input Capture 4/Output<br>Compare 5 Register Low | Read:<br>Write: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | (TI4/O5) | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | \$1020 | Timer Control Register 1<br>(TCTL1) | Read:<br>Write: | OM2 | OL2 | ОМЗ | OL3 | OM4 | OL4 | OM5 | OL5 | | | (10121) | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | \$1021 | Timer Control Register 2<br>(TCTL2) | Read:<br>Write: | EDG4B | EDG4A | EDG1B | EDG1A | EDG2B | EDG2A | EDG3B | EDG3A | | | (TOTLE) | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | \$1022 | Timer Interrupt Mask 1 Register<br>(TMSK1) | Read:<br>Write: | OC1I | OC2I | OC3I | OC4I | I4/O5I | IC1I | IC2I | IC3I | | (IMSKI) | | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | = Unimplem | nented | R | = Reserved | U = Unaff | ected | | | | | | I = Indeter | minate after | reset | | | | | | Figure 6. Register and Control Bit Assignments (Sheet 3 of 6) Figure 6. Register and Control Bit Assignments (Sheet 4 of 6) Figure 6. Register and Control Bit Assignments (Sheet 5 of 6) <sup>1.</sup> Can be written only once in first 64 cycles out of reset in normal modes or at any time during special modes. = Unimplemented R = Reserved U = Unaffected I = Indeterminate after reset Figure 6. Register and Control Bit Assignments (Sheet 6 of 6) #### A/D Control/Status Register (ADCTL) CCF — Conversion Complete Flag This bit is set after an A/D conversion cycle and cleared when ADCTL is written. Bit 6 — Unimplemented Always reads 0 SCAN — Continuous Scan Control 0 = Do four conversions and stop 1 = Convert four channels in selected group continuously MULT — Multiple Channel/Single Channel Control 0 = Convert single channel selected 1 = Convert four channels in selected group <sup>2.</sup> MC68HC711E9 only <sup>3.</sup> MC68HC811E2 only CD:CA — Channel Selects D:A Refer to the following table. | Channel Select<br>Control Bits | Channel Signal | Result in ADRx if MULT = 1 | Result in ADRx<br>if MULT = 0 | |--------------------------------|-------------------------------------|----------------------------|-------------------------------| | CD:CC:CB:CA | | II WOLT - I | II WOLI - 0 | | 0000 | AN0 | ADR1 | ADR[4:1] | | 0001 | AN1 | ADR2 | ADR[4:1] | | 0010 | AN2 | ADR3 | ADR[4:1] | | 0011 | AN3 | ADR4 | ADR[4:1] | | 0100 | AN4 | ADR1 | ADR[4:1] | | 0101 | AN5 | ADR2 | ADR[4:1] | | 0110 | AN6 | ADR3 | ADR[4:1] | | 0111 | AN7 | ADR4 | ADR[4:1] | | 10XX | Reserved | _ | _ | | 1100 | V <sub>RH</sub> <sup>(1)</sup> | ADR1 | ADR[4:1] | | 1101 | V <sub>RL</sub> <sup>(1)</sup> | ADR2 | ADR[4:1] | | 1110 | (V <sub>RH</sub> )/2 <sup>(1)</sup> | ADR3 | ADR[4:1] | | 1111 | Reserved <sup>(1)</sup> | ADR4 | ADR[4:1] | <sup>1.</sup> Used for factory testing # A/D Results (ADR1-ADR4) | <b>ADR1</b> — Address: \$1031 | | | | | | | | | | | | | | |-------------------------------|--------------|------------|--------|------------|--------------|-----|---|-------|--|--|--|--|--| | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | | | | Read: | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | | | | Write: | | | | | | | | | | | | | | | Reset: | | | Ind | determinat | te after res | set | | | | | | | | | <b>ADR2</b> — Ad | ddress: \$10 | 32 | | | | | | | | | | | | | _ | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | | | | Read: | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | | | | Write: | | | | | | | | | | | | | | | Reset: | | | Ind | determinat | te after res | set | | | | | | | | | <b>ADR3</b> — Ad | ddress: \$10 | 33 | | | | | | | | | | | | | _ | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | | | | Read: | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | | | | Write: | | | | | | | | | | | | | | | Reset: | | | Ind | determinat | te after res | set | | | | | | | | | ADR4 — Ad | ddress: \$10 | 34 | | | | | | | | | | | | | _ | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | | | | Read: | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | | | | Write: | | | | | | | | | | | | | | | Reset: | | | Inc | determinat | te after res | set | | | | | | | | | | | = Unimplen | nented | | | | | | | | | | | # **Analog Input to 8-Bit Result Translation Table** | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | |----------------------|-------|-------|--------|--------|--------|--------|--------|--------| | %(1) | 50% | 25% | 12.5% | 6.25% | 3.12% | 1.56% | 0.78% | 0.39% | | Volts <sup>(2)</sup> | 2.500 | 1.250 | 0.625 | 0.3125 | 0.1562 | 0.0781 | 0.0391 | 0.0195 | | Volts <sup>(3)</sup> | 1.65 | 8.25 | 0.4125 | 0.2063 | 0.1031 | 0.0516 | 0.0258 | 0.0129 | - 1. % of $V_{RH}$ – $V_{RL}$ 2. Voltages for $V_{RL}$ = 0; $V_{RH}$ = 5.0 V 3. Voltages for $V_{RL}$ = 0; $V_{RH}$ = 3.3 V ## **Baud Rate Control Register (BAUD)** \$102B Address: Bit 7 6 5 4 3 2 1 Bit 0 Read: **TCLR** SCP2 SCP1 SCP0 **RCKB** SCR2 SCR1 SCR0 Write: 0 0 U U U 0 0 Reset: U = Unaffected TCLR — Clear Baud Rate Counter (Test) SCP[2:0] — SCI Baud Rate Prescaler Select SCP2 applies to the MC68HC(7)11E20 only. When SCP2 = 1, SCP[1:0] must equal 0. Any other values for SCP[1:0] are not decoded in the prescaler and the results are unpredictable. | S | CP | | Divide | | Cryst | tal Frequenc | y (MHz) | | |------------------|----|---|----------------------|-------|--------|--------------|---------|--------| | 2 <sup>(1)</sup> | 1 | 0 | Internal<br>Clock By | 4.0 | 4.9152 | 8.0 | 8.3886 | 12.0 | | 0 | 0 | 0 | 1 | 62500 | 76800 | 125000 | 131072 | 187500 | | 0 | 0 | 1 | 3 | 20833 | 25600 | 41667 | 43691 | 62500 | | 0 | 1 | 0 | 4 | 15625 | 19200 | 31250 | 32768 | 46875 | | 0 | 1 | 1 | 13 | 4800 | 5907 | 9600 | 10082 | 14423 | | 1 | 0 | 0 | 39 | 1602 | 1969 | 3205 | 3361 | 4808 | <sup>1.</sup> Shaded areas apply to MC68HC(7)11E20 only. RCKB — SCI Baud Rate Clock Check (TEST) # SCR[2:0] — SCI Baud Rate Selects Selects receiver and transmitter bit rate based on output from baud rate prescaler stage. Refer to SCI baud rate generator block diagram. | | SCR | | Divide<br>Prescaler | (Pre | Highe<br>Scaler Outp | est Baud Ra<br>out from Pre | | e | |---|-----|---|---------------------|--------|----------------------|-----------------------------|-------|------| | 2 | 1 | 0 | Ву | 131072 | 76800 | 32768 | 19200 | 4800 | | 0 | 0 | 0 | 1 | 131072 | 76800 | 32768 | 19200 | 4800 | | 0 | 0 | 1 | 2 | 65536 | 38400 | 16384 | 9600 | 2400 | | 0 | 1 | 0 | 4 | 32768 | 19200 | 8192 | 4800 | 1200 | | 0 | 1 | 1 | 8 | 16384 | 9600 | 4096 | 2400 | 600 | | 1 | 0 | 0 | 16 | 8192 | 480 | 2048 | 1200 | 300 | | 1 | 0 | 1 | 32 | 4096 | 2400 | 1024 | 600 | 150 | | 1 | 1 | 0 | 64 | 2048 | 1200 | 512 | 300 | 75 | | 1 | 1 | 1 | 128 | 1024 | 600 | 256 | 150 | 37.5 | ## **Block Protect Register (BPROT)** Bits [7:5] — Unimplemented Always read 0 PTCON — Protect CONFIG Register 0 = CONFIG register can be programmed or erased normally. 1 = CONFIG register cannot be programmed or erased. BPRT[3:0] — Block Protect for EEPROM Block protect register bits can be written to 0 (protection disabled) only once within 64 cycles of a reset in normal modes, or at any time in special modes. Block protect register bits can be written to 1 (protection enabled) at any time. - 0 = Protection disabled for associated block - 1 = Protection enabled for associated block | Bit Name | Block Protected | Block Size | |----------|-----------------|------------| | BPRT0 | \$B600-\$B61F | 32 bytes | | BPRT1 | \$B620-\$B65F | 64 bytes | | BPRT2 | \$B660-\$B6DF | 128 bytes | | BPRT3 | \$B6E0-\$B7FF | 288 bytes | #### MC68HC811E2 Only | BPRT0 | \$x800-\$x9FF <sup>(1)</sup> | 512 bytes | |-------|------------------------------|-----------| | BPRT1 | \$xA00-\$xBFF <sup>(1)</sup> | 512 bytes | | BPRT2 | \$xC00-\$xDFF <sup>(1)</sup> | 512 bytes | | BPRT3 | \$xE00-\$xFFF <sup>(1)</sup> | 512 bytes | <sup>1.</sup> x is determined by the value of EE[3:0] in CONFIG (MC68HC811E2 only). Refer to the MC68HC811E2 CONFIG register. # **Timer Compare Force Register (CFORC)** FOC[1:5] — Force Output Comparison Write 1s to force compare(s). 0 = Not affected 1 = Output x action occurs Bits [2:0] — Unimplemented Always read 0 ## **Configuration Register (CONFIG)** ## Security disable, COP, ROM mapping, and EEPROM enables | Address: | \$103F | | | | | | | | |--------------|--------|------------|-------|---|-------|-------|--------|-------| | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | Read: | | | | | NOSEC | NOCOP | ROMON | EEON | | Write: | | | | | NOSLO | 10001 | TIONON | LLON | | Resets: | | | | | | | | | | Single chip: | 0 | 0 | 0 | 0 | U | U | 1 | U | | Bootstrap: | 0 | 0 | 0 | 0 | U | U(L) | U | U | | Expanded: | 0 | 0 | 0 | 0 | 1 | U | U | U | | Test: | 0 | 0 | 0 | 0 | 1 | U(L) | U | U | | | | = Unimplem | ented | | | | | | U indicates a previously programmed bit. U(L) indicates that the bit resets to the logic level held in the latch prior to reset, but the function of COP is controlled by the DISR bit in TEST1 register. #### The following register description applies to the MC68HC11E2 only. | Address: | \$103F | | | | | | | | |--------------|--------|------------|-------|-----|-------|-------|---|-------| | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | Read: | EE3 | EE2 | EE1 | EE0 | NOSEC | NOCOP | | EEON | | Write: | EES | CC2 | EEI | EEU | NOSEC | NOCOP | | EEON | | Resets: | | | | • | | | | | | Single chip: | 1 | 1 | 1 | 1 | U | U | 1 | 1 | | Bootstrap: | 1 | 1 | 1 | 1 | U | U(L) | 1 | 1 | | Expanded: | U | U | U | U | 1 | U | 1 | U | | Test: | U | U | U | U | 1 | U(L) | 1 | 0 | | | | = Unimplem | ented | | | | | | U indicates a previously programmed bit. U(L) indicates that the bit resets to the logic level held in the latch prior to reset, but the function of COP is controlled by the DISR bit in TEST1 register. EE[3:0] — EEPROM Map Position (MC68HC811E2 only) EE[3:0] determine the upper four bits of EEPROM address, positioning EEPROM at the selected 4-Kbyte boundary. In single-chip and boot modes, these bits are set to 1s during reset and EEPROM is mapped to top of memory. Not implemented in other E-series devices; always read 0. Refer to the following table. | EE3 | EE1 | EE2 | EE0 | EEPROM Location | |-----|-----|-----|-----|-----------------| | 0 | 0 | 0 | 0 | \$0800-\$0FFF | | 0 | 0 | 0 | 1 | \$1800–\$1FFF | | 0 | 0 | 1 | 0 | \$2800-\$2FFF | | 0 | 0 | 1 | 1 | \$3800-\$3FFF | | 0 | 1 | 0 | 0 | \$4800-\$4FFF | | 0 | 1 | 0 | 1 | \$5800-\$5FFF | | 0 | 1 | 1 | 0 | \$6800-\$6FFF | | 0 | 1 | 1 | 1 | \$7800–\$7FFF | | 1 | 0 | 0 | 0 | \$8800-\$8FFF | | 1 | 0 | 0 | 1 | \$9800-\$9FFF | | 1 | 0 | 1 | 0 | \$A800-\$AFFF | | 1 | 0 | 1 | 1 | \$B800-\$BFFF | | 1 | 1 | 0 | 0 | \$C800-\$CFFF | | 1 | 1 | 0 | 1 | \$D800-\$DFFF | | 1 | 1 | 1 | 0 | \$E800-\$EFFF | | 1 | 1 | 1 | 1 | \$F800-\$FFFF | ### NOSEC — Security Disable NOSEC is invalid unless the security mask option is specified before the MCU is manufactured. If the security mask option is omitted NOSEC always reads 1. The enhanced security feature is available in the MC68S711E9 MCU. The enhancement to the standard security feature protects the EPROM as well as RAM and EEPROM. - 0 = RAM/EEPROM security mode enabled - 1 = RAM/EEPROM security mode disabled NOCOP — COP System Disable Resets to programmed value. - 0 = COP enabled (forces reset on timeout) - 1 = COP disabled (does not force reset on timeout) ## ROMON — ROM/EPROM Enable In single-chip mode, ROMON is forced to 1 out of reset. ROMON does not apply to the MC68HC811E2. For devices with disabled ROM arrays (the MC68HC11E0, MC68HC11E1, MC68L11E0, or MC68L11E1) ROMON must never be set to 1. - 0 = ROM/EPROM removed from the memory map - 1 = ROM/EPROM present in the memory map EEON — EEPROM Enable - 0 = EEPROM removed from the memory map - 1 = EEPROM present in the memory map # **Arm/Reset COP Timer Circuitry Register (COPRST)** | Address: | \$103A | | | | | | | | |-----------------|--------|---|---|---|---|---|---|-------| | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | Read:<br>Write: | BIT 7 | 6 | 5 | 4 | 3 | 2 | 1 | BIT 0 | | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Write \$55 to COPRST to arm COP watchdog clearing mechanism. Write \$AA to COPRST to reset COP watchdog. # **Data Direction Register for Port C (DDRC)** DDC[7:0] — Data Direction for Port C In handshake output mode, DDRC bits selected the three-stated output option (DDCx = 1). 0 = Input 1 = Output ## **Data Direction Register for Port D (DDRD)** Bits [7:6] — Unimplemented Always read 0 DDD[5:0] — Data Direction for Port D 0 = Input 1 = Output # **EPROM Programming Control Register (EPROG)** # **NOTE:** EPROG is present only on the MC68HC711E20. ## MBE — Multiple-Byte Programming Enable When multiple-byte programming is enabled, address bit 5 is considered a don't care so that bytes with address bit 5 = 0 and address bit 5 = 1 both get programmed. MBE can be read in any mode and always reads 0 in normal modes. MBE can be written only in special modes. - 0 = EPROM array configured for normal programming - 1 = Program two bytes with the same data Bit 6 — Unimplemented Always reads 0 #### ELAT — EPROM/OTPROM Latch Control When ELAT = 1, writes to EPROM cause address and data to be latched and the EPROM/OTPROM cannot be read. ELAT can be read any time. ELAT can be written any time except when PGM = 1; then the write to ELAT is disabled. - 0 = EPROM/OTPROM address and data bus configured for normal reads - 1 = EPROM/OTPROM address and data bus configured for programming #### EXCOL — Select Extra Columns - 0 = User array selected - 1 = User array is disabled and extra columns are accessed at bits [7:0]. Addresses use bits [13:5] and bits [4:0] are don't care. EXCOL can be read and written only in special modes and always returns 0 in normal modes. #### EXROW — Select Extra Rows - 0 = User array selected - 1 = User array is disabled and two extra rows are available. Addresses use bits [7:0] and bits [13:8] are don't care. EXROW can be read and written only in special modes and always returns 0 in normal modes. #### T[1:0] — EPROM Test Mode Select These bits allow selection of either gate stress or drain stress test modes. They can be read and written only in special modes and always read 0 in normal modes. | T1 | T0 | Function Selected | |----|----|-------------------| | 0 | 0 | Normal mode | | 0 | 1 | Reserved | | 1 | 0 | Gate stress | | 1 | 1 | Drain stress | #### PGM — EPROM Programming Voltage Enable PGM can be read any time and can be written only when ELAT = 1. - 0 = Programming voltage to EPROM array disconnected - 1 = Programming voltage to EPROM array connected # **Highest Priority I Bit Interrupt and Miscellaneous (HPRIO)** Address: \$103C | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | |-----------------|----------------------|---------------------|--------------------|-------|-------|-------|-------|-------| | Read:<br>Write: | RBOOT <sup>(1)</sup> | SMOD <sup>(1)</sup> | MDA <sup>(1)</sup> | IRVNE | PSEL3 | PSEL2 | PSEL1 | PSEL0 | | Reset: | | | | | | | | | | Single chip: | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | | Expanded: | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | | Bootstrap: | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | | Special test: | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | <sup>1.</sup> The values of the RBOOT, SMOD, and MDA reset bits depend on the mode selected at the RESET pin rising edge. ### RBOOT — Read Bootstrap ROM Valid only when SMOD is set to 1 (bootstrap or special test mode). Can only be written in special modes. - 0 = Bootloader ROM disabled and not in map - 1 = Bootloader ROM enabled and in map at \$BE00-\$BFFF #### SMOD and MDA — Special Mode Select and Mode Select A The initial value of SMOD is in the **inverse** of the logic level present on the MODB pin at the rising edge of reset. The initial value of MDA equals the logic level present on the MODA pin at the rising edge of reset. These two bits can be read at any time. They can be written anytime in special modes. MDA can only be written once in normal modes. SMOD cannot be set once it has been cleared. Refer to the following table. | Inp | outs | Mode | Latched at Reset | | | |------|------|--------------|------------------|-----|--| | MODB | MODA | Wiode | SMOD | MDA | | | 1 | 0 | Single chip | 0 | 0 | | | 1 | 1 | Expanded | 0 | 1 | | | 0 | 0 | Bootstrap | 1 | 0 | | | 0 | 1 | Special test | 1 | 1 | | #### IRVNE — Internal Read Visibility/Not E (IRV in MC68HC811E2) IRVNE can be written once in any mode. In expanded modes, IRVNE determines whether IRV is on or off. In special test mode, IRVNE is reset to 1. For the MC68HC811E2, this bit controls only internal read visibility function and has no meaning or effect in single-chip modes. - 0 = No internal read visibility on external bus - 1 = Data from internal reads is driven out the external data bus In single-chip modes this bit determines whether the E clock drives out from the chip. - 0 = E is driven out from the chip. - 1 = E pin is driven low. Refer to the following table. | Mode | IRVNE Out of Reset | E Clock Out of Reset | IRV Out of Reset | IRVNE<br>Affects Only | IRVNE Can<br>Be Written | |--------------|--------------------|----------------------|------------------|-----------------------|-------------------------| | Single chip | 0 | On | Off | Е | Once | | Expanded | 0 | On | Off | IRV | Once | | Bootstrap | 0 | On | Off | E | Once | | Special test | 1 | On | On | IRV | Once | ## **NOTE:** When IRV function is used, care must be taken to ensure that bus conflicts do not occur. Data can be driven onto the bus even though the $R\overline{/W}$ line indicates a high-impedance state on data bus pins. # PSEL[3:0] — Priority Select Can be written only while bit I in the CCR is set (interrupts disabled). These bits select one interrupt source to be elevated above all other I bit related sources. Refer to the following table. | PSEL3 | PSEL2 | PSEL1 | PSEL0 | Interrupt Source Promoted | |-------|-------|-------|-------|----------------------------------------| | 0 | 0 | 0 | 0 | Timer overflow | | 0 | 0 | 0 | 1 | Pulse accumulator overflow | | 0 | 0 | 1 | 0 | Pulse accumulator input edge | | 0 | 0 | 1 | 1 | SPI serial transfer complete | | 0 | 1 | 0 | 0 | SCI serial system | | 0 | 1 | 0 | 1 | Reserved (default to IRQ) | | 0 | 1 | 1 | 0 | IRQ (external pin or parallel I/O) | | 0 | 1 | 1 | 1 | Real-time interrupt | | 1 | 0 | 0 | 0 | Timer input capture 1 | | 1 | 0 | 0 | 1 | Timer input capture 2 | | 1 | 0 | 1 | 0 | Timer input capture 3 | | 1 | 0 | 1 | 1 | Timer output compare 1 | | 1 | 1 | 0 | 0 | Timer output compare 2 | | 1 | 1 | 0 | 1 | Timer output compare 3 | | 1 | 1 | 1 | 0 | Timer output compare 4 | | 1 | 1 | 1 | 1 | Timer input capture 4/output compare 5 | # **RAM and Register Mapping (INIT)** Address: \$103D Bit 7 6 5 3 2 Bit 0 4 1 Read: RAM3 RAM2 RAM1 RAM0 REG3 REG2 REG1 REG0 Write: Reset: 0 0 0 RAM[3:0] — Internal RAM Map Position Determine the upper four bits of RAM address. At reset, RAM is mapped to \$0000. | RAM[3:0] | Address | |----------|---------------| | 0000 | \$0000-\$0xFF | | 0001 | \$1000-\$1xFF | | 0010 | \$2000-\$2xFF | | 0011 | \$3000-\$3xFF | | 0100 | \$4000-\$4xFF | | 0101 | \$5000-\$5xFF | | 0110 | \$6000-\$6xFF | | 0111 | \$7000-\$7xFF | | RAM[3:0] | Address | |----------|---------------| | 1000 | \$8000-\$8xFF | | 1001 | \$9000-\$9xFF | | 1010 | \$A000-\$AxFF | | 1011 | \$B000-\$BxFF | | 1100 | \$C000-\$CxFF | | 1101 | \$D000-\$DxFF | | 1110 | \$E000-\$ExFF | | 1111 | \$F000-\$FxFF | | | | REG[3:0] — 64-Byte Register Block Map Position Determine upper four bits of register space address. At reset, registers are mapped to \$1000. | REG[3:0] | Address | |----------|---------------| | 0000 | \$0000-\$003F | | 0001 | \$1000–\$103F | | 0010 | \$2000-\$203F | | 0011 | \$3000-\$303F | | 0100 | \$4000-\$403F | | 0101 | \$5000-\$503F | | 0110 | \$6000-\$603F | | 0111 | \$7000-\$703F | | REG[3:0] | Address | |----------|---------------| | 1000 | \$8000-\$803F | | 1001 | \$9000-\$903F | | 1010 | \$A000-\$A03F | | 1011 | \$B000-\$B03F | | 1100 | \$C000-\$C03F | | 1101 | \$D000-\$D03F | | 1110 | \$E000-\$E03F | | 1111 | \$F000-\$F03F | **NOTE:** Can be written only once in first 64 cycles out of reset in normal modes or at any time in special modes. ### **Output Compare 1 Data Register (OC1D)** If OC1Mx is set, data in OC1Dx is output to port A bit x on successful OC1 compares. Bits [2:0]— Unimplemented Always reads 0 #### **Output Compare 1 Mask Register (OC1M)** OC1M[7:3] — Output Compare Masks 0 = OC1 disabled 1 = OC1 enabled to control the corresponding pin of port A Bits [2:0]— Unimplemented Always reads 0 ### **System Configuration Options (OPTION)** Can be written only once in first 64 cycles out of reset in normal modes or at any time during special modes. = Unimplemented ADPU — Analog-to-Digital (A/D) Converter Power-Up 0 = A/D powered down 1 = A/D powered up CSEL — Clock Select 0 = A/D and EEPROM charge pumps use system E clock 1 = A/D and EEPROM charge pumps use internal RC oscillator IRQE — IRQ Select Edge-Sensitive Only 0 = Low level recognition 1 = Falling edge recognition DLY — Enable Oscillator Startup Delay on Exit from Stop Mode 0 = No stabilization delay on exit from stop mode 1 = Stabilization delay enabled on exit from stop mode CME — Clock Monitor Enable 0 = Clock monitor disabled; slow clocks can be used 1 = Slow or stopped clocks cause clock failure reset Bit 2 — Not implemented Always reads 0 CR[1:0] — COP Timer Rate Select Refer to the following table. | CR[1:0] | Divide<br>E/2 <sup>15</sup> By | XTAL = 4.0 MHz<br>Timeout<br>– 0 ms, + 32.8 ms | XTAL = 8.0 MHz<br>Timeout<br>– 0 ms, + 16.4 ms | XTAL = 12.0 MHz<br>Timeout<br>– 0 ms, + 10.9 ms | XTAL = 16.0 MHz<br>Timeout<br>– 0 ms, + 8.2 ms | |---------|--------------------------------|------------------------------------------------|------------------------------------------------|-------------------------------------------------|------------------------------------------------| | 0 0 | 1 | 32.768 ms | 16.384 ms | 10.923 ms | 8.19 ms | | 0 1 | 4 | 131.072 ms | 65.536 ms | 43.691 ms | 32.8 ms | | 1 0 | 16 | 524.28 ms | 262.14 ms | 174.76 ms | 131 ms | | 11 | 64 | 2.098 s | 1.049 s | 699.05 ms | 524 ms | | | E = | 1.0 MHz | 2.0 MHz | 3.0 MHz | 4.0 MHz | #### **Pulse Accumulator Counter (PACNT)** Reset: Unaffected by reset ### **Pulse Accumulator Control (PACTL)** Address: \$1026 Bit 7 6 5 3 2 Bit 0 4 1 Read: DDRA7 PAEN PAMOD PEDGE DDRA3 14/05 RTR1 RTR0 Write: 0 0 0 Reset: 0 0 0 0 DDRA7 — Data Direction for Port A Bit 7 0 = Input only 1 = Output PAEN — Pulse Accumulator System Enable 0 = Pulse accumulator disabled 1 = Pulse accumulator enabled PAMOD — Pulse Accumulator Mode 0 = Event counter 1 = Gated time accumulation PEDGE — Pulse Accumulator Edge Control Refer to the following table. | PAMOD | PEDGE Action on Clock | | |--------------------------------------------|--------------------------------------|-----------------------------------------| | 0 PAI falling edge increments the counter. | | | | 0 | 1 | PAI rising edge increments the counter. | | 1 | 1 0 A zero on PAI inhibits counting. | | | 1 | 1 | A one on PAI inhibits counting. | #### DDRA3 — Data Direction for Port A Bit 3 Overridden if an output compare function is configured to control the PA3 pin. 0 = Input 1 = Output 14/O5 — Input Capture 4/Output Compare 5 Configure TI4/O5 for input capture or output compare 0 = OC5 enabled 1 = IC4 enabled RTR[1:0] — Real-Time Interrupt (RTI) Rate Refer to the following table. | RTR1 | RTR0 | E = 3 MHz | E = 2 MHz | E = 1 MHz | E = X MHz | |------|------|-----------|-----------|-----------|----------------------| | 0 | 0 | 2.731 ms | 4.096 ms | 8.192 ms | (E/2 <sup>13</sup> ) | | 0 | 1 | 5.461 ms | 8.192 ms | 16.384 ms | (E/2 <sup>14</sup> ) | | 1 | 0 | 10.923 ms | 16.384 ms | 32.768 ms | (E/2 <sup>15</sup> ) | | 1 | 1 | 21.845 ms | 32.768 ms | 65.536 ms | (E/2 <sup>16</sup> ) | #### Parallel I/O Control (PIOC) #### STAF — Strobe A Interrupt Status Flag STAF is set when the selected edge occurs on strobe A. This bit can be cleared by a read of PIOC with STAF set followed by a read of PORTCL (simple strobed or full input handshake mode) or a write to PORTCL (output handshake mode). - 0 = No active edge detected - 1 = Selected active edge detected - STAI Strobe A Interrupt Enable Mask - 0 = STAF does not request interrupt - 1 = STAF requests interrupt - CWOM Port C Wired-OR Mode (affects all eight port C pins) - 0 = Port C outputs are normal CMOS outputs. - 1 = Port C outputs are open-drain outputs. - HNDS Handshake Mode Bit - 0 = Simple strobe mode - 1 = Full input or output handshake mode - OIN Output or Input Handshake Select HNDS must be set to 1 for this bit to have meaning. - 0 = Input handshake - 1 = Output handshake - PLS Pulsed/Interlocked Handshake Operation HNDS must be set to 1 for this bit to have meaning. When interlocked handshake is selected, strobe B is active until the selected edge of strobe A is detected. - 0 = Interlocked handshake - 1 = Pulsed handshake (Strobe B pulses high for two E-clock cycles.) - EGA Active Edge for Strobe A - 0 = STRA falling edge selected - 1 = STRA rising edge selected - INVB Invert Strobe B - 0 = Active level is logic 0. - 1 = Active level is logic 1. | | STAF<br>Clearing<br>Sequence | HNDS | OIN | PLS | EGA | Port B | Port C | |-------------------------------------------|----------------------------------------------------|------|-----|------------------------------------------------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------|------------------------------------------------------------| | Simple<br>strobed<br>mode | Read PIOC<br>with STAF = 1<br>then read<br>PORTCL | 0 | Х | Х | 1 1 | Inputs latched into<br>PORTCL on any<br>active edge on<br>STRA | STRB pulses<br>on writes<br>to PORTB | | Full-input<br>hand-<br>shake<br>mode | Read<br>PIOC with<br>STAF = 1 then<br>read PORTCL | 1 | 0 | 0 = STRB<br>active level<br>1 = STRB<br>active pulse | 0 | Inputs latched into<br>PORTCL on any<br>active edge on<br>STRA | Normal output<br>port, unaffected<br>in handshake<br>modes | | Full-<br>output<br>hand-<br>shake<br>mode | Read<br>PIOC with<br>STAF = 1 then<br>write PORTCL | 1 | 1 | 0 = STRB active level 1 = STRB active pulse | Port C Driven STRA Follow Active Edge Follow DDRC | Driven as outputs if<br>STRA at active level;<br>follows DDRC if<br>STRA not at active<br>level | Normal output<br>port, unaffected<br>in handshake<br>modes | ### Port A Data Register (PORTA) **NOTE:** I/O pins configured as high-impedance inputs have port data that is indeterminate. The contents of the corresponding latches are dependent upon the electrical state of the pins during reset. This is indicated by an "I" in the port description. ## Port B Data Register (PORTB) ### Port C Data Register (PORTC) #### Port C Latched Data Register (PORTCL) #### Port D Data Register (PORTD) #### Port E Data Register (PORTE) ### **EEPROM Programming Control Register (PPROG)** ODD — Program Odd Rows in Half of EEPROM (TEST) EVEN — Program Even Rows in Half of EEPROM (Test) Bit ELAT — EPROM/OTPROM Latch Control Implemented on MC68HC711E9 only - 0 = EPROM/OTPROM address and data bus configured for normal reads and cannot be programmed - 1 = EPROM/OTPROM address and data bus configured for programming and cannot be read - BYTE Byte/Other EEPROM Erase Mode - 0 = Row or bulk erase mode used - 1 = Erase only one byte of EEPROM ROW — Row/All EEPROM Erase Mode Only valid when BYTE = 0 0 = Erase all of EEPROM 1 = Erase only one 16-byte row of EEPROM | BYTE | ROW | Action | |------|-----|------------------------| | 0 | 0 | Bulk erase (all bytes) | | 0 | 1 | Row erase (16 bytes) | | 1 | 0 | Byte erase | | 1 | 1 | Byte erase | ERASE — Erase/Normal Control for EEPROM - 0 = Normal read or program mode - 1 = Erase mode EELAT — EEPROM Latch Control - 0 = EEPROM address and data bus configured for normal reads - 1 = EEPROM address and data bus configured for programming or erasing EPGM — EPROM/EEPROM Programming Voltage Enable - 0 = Programming voltage to array disconnected (EEPROM only on MC68HC(7)11E20) - 1 = Programming voltage to array connected (EEPROM only on MC68HC(7)11E20) #### **Serial Communication Interface Control Register 1 (SCCR1)** R8 — Receive Data Bit 8 - 0 = SCI receiver configured for 8-bit data characters. - 1 = If M bit is set, R8 stores the ninth data bit in the receive data character. - T8 Transmit Data Bit 8 - 0 = SCI transmitter configured for 8-bit data characters. - 1 = If M bit is set, R8 stores the ninth data bit in the transmit data character. - Bit 5 Unimplemented Always reads 0 - M Mode Bit (select character format) - 0 = Start bit, 8 data bits, 1 stop bit - 1 = Start bit, 9 data bits, 1 stop bit - WAKE Wakeup by Address Mark/Idle - 0 = Wakeup by IDLE line recognition - 1 = Wakeup by address mark (most significant data bit set) Bits [2:0] — Unimplemented Always read 0 ### **Serial Communications Interface Control Register 2 (SCCR2)** | Address: | \$102D | | | | | | | | |-----------------|--------|------|-----|------|----|----|-----|-------| | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | Read:<br>Write: | TIE | TCIE | RIE | ILIE | TE | RE | RWU | SBK | | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - TIE Transmit Interrupt Enable - 0 = TDRE interrupts disabled - 1 = SCI interrupt requested when TDRE status flag is set - TCIE Transmit Complete Interrupt Enable - 0 = TC interrupts disabled - 1 = SCI interrupt requested when TC status flag is set - RIE Receiver Interrupt Enable - 0 = RDRF and OR interrupts disabled - 1 = SCI interrupt requested when RDRF flag or the OR status flag is set - ILIE Idle-Line Interrupt Enable - 0 = IDLE interrupts disabled - 1 = SCI interrupt requested when IDLE status flag is set - TE Transmitter Enable - 0 = Transmitter disabled - 1 = Transmitter enabled - RE Receiver Enable - 0 = Receiver disabled - 1 = Receiver enabled - RWU Receiver Wakeup Control - 0 = Normal SCI receiver - 1 = Wakeup enabled and receiver interrupts inhibited - SBK Send Break - 0 = Break generator off - 1 = Break codes generated as long as SBK = 1 ### **Serial Communications Interface Data Register (SCDR)** R[7:0]/T[7:0] — Receiver/Transmitter Data Bits [7:0] Receive and transmit are double buffered. Reads access the receive data buffer, and writes access the transmit data buffer. When the M bit in SCCR1 is set, R8 and T8 in SCCR1 store the ninth bit in receive and transmit data characters. #### Serial Communications Interface Status Register (SCSR) TDRE — Transmit Data Register Empty Flag This flag is set when SCDR is empty. Clear the TDRE flag by reading SCSR with TDRE set and then writing to SCDR. 0 = SCDR busy 1 = SCDR empty #### TC — Transmit Complete Flag This flag is set when the transmitter is idle (no data, preamble, or break transmission in progress). Clear the TC flag by reading SCSR with TC set and then writing to SCDR. 0 = Transmitter busy 1 = Transmitter idle #### RDRF — Receive Data Register Full Flag This flag is set if a received character is ready to be read from SCDR. Clear the RDRF flag by reading SCSR with RDRF set and then reading SCDR. 0 = SCDR emptv 1 = SCDR full #### IDLE — Idle Line Detected Flag This flag is set if the RxD line is idle. Once cleared, IDLE is not set again until the RxD line has been active and becomes idle again. The IDLE flag is inhibited when RWU = 1. Clear IDLE by reading SCSR with IDLE set and then reading SCDR. 0 = RxD line active 1 = RxD line idle #### OR — Overrun Error Flag OR is set if a new character is received before a previously received character is read from SCDR. Clear the OR flag by reading SCSR with OR set and then reading SCDR. 0 = No overrun 1 = Overrun detected NF — Noise Error Flag NF is set if majority sample logic detects anything other than a unanimous decision. Clear NF by reading SCSR with NF set and then reading SCDR. 0 = Unanimous decision 1 = Noise detected FE — Framing Error Flag FE is set when a 0 is detected where a stop bit was expected. Clear the FE flag by reading SCSR with FE set and then reading SCDR. 0 = Stop bit detected 1 = Zero detected Bit 0 — Unimplemented Always reads 0 #### Serial Peripheral Interface Control Register (SPCR) | Address: | \$1028 | | | | | | | | |-----------------|--------|-----|------|------|------|------|------|-------| | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | Read:<br>Write: | SPIE | SPE | DWOM | MSTR | CPOL | СРНА | SPR1 | SPR0 | | Reset: | 0 | 0 | 0 | 0 | 0 | 1 | U | U | SPIE — Serial Peripheral Interrupt Enable 0 = SPI interrupts disabled 1 = SPI interrupts enabled SPE — Serial Peripheral System Enable 0 = SPI off 1 = SPI on DWOM — Port D Wired-OR Mode Option for Port D Pins PD[5:0] 0 = Normal CMOS outputs 1 = Open-drain outputs MSTR — Master Mode Select 0 = Slave mode 1 = Master mode CPOL, CPHA — Clock Polarity, Clock Phase Refer to Figure 7 SPR[1:0] — SPI Clock Rate Select See the following table. | SPR1 | SPR0 | Divide<br>E Clock By | | | Frequency at E = 3 MHz (Baud) | Frequency at<br>E = 4 MHz (Baud) | |------|------|----------------------|----------|----------|-------------------------------|----------------------------------| | 0 | 0 | 2 | 500 kHz | 1.0 MHz | 1.5 MHz | 2 MHz | | 0 | 1 | 4 | 250 kHz | 500 kHz | 750 kHz | 1 MHz | | 1 | 0 | 16 | 62.5 kHz | 125 kHz | 187.5 kHz | 250 kHz | | 1 | 1 | 32 | 31.3 kHz | 62.5 kHz | 93.8 kHz | 125 kHz | - 1. SS ASSERTED - 2. MASTER WRITES TO SPDR - 3. FIRST SCK EDGE - 4. SPIF SET - 5. SS NEGATED Figure 7. Serial Peripheral Interface Transfer Format ## Serial Peripheral Interface Data Register (SPDR) SPI is double buffered in, single buffered out. #### Serial Peripheral Interface Status Register (SPSR) SPIF — SPI Transfer Complete Flag This flag is set when an SPI transfer is complete (after eight SCK cycles in a data transfer). Clear this flag by reading SPSR (with SPIF = 1), then access SPDR. - 0 = No SPI transfer complete or SPI transfer still in progress - 1 = SPI transfer complete WCOL — Write Collision This flag is set if the MCU tries to write data into SPDR while an SPI data transfer is in progress. Clear this flag by reading SPSR (with WCOL = 1), then access SPDR. - 0 = No write collision error - 1 = SPDR written while SPI transfer in progress Bit 5 — Unimplemented Always reads 0 MODF — Mode Fault (Mode fault terminates SPI operation) MODF is set when $\overline{SS}$ is pulled low while MSTR = 1. Clear this flag by reading SPCR with MODF set, then write to SPCR. - 0 = No mode fault error - $1 = \overline{SS}$ pulled low in master mode Bits [3:0] — Unimplemented Always reads 0 ### **Timer Count Register (TCNT)** In normal modes, TCNT is a read-only register. ## **Timer Control Register 1 (TCTL1)** Address: \$1020 | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | |-----------------|-------|-----|-----|-----|-----|-----|-----|-------| | Read:<br>Write: | OM2 | OL2 | OM3 | OL3 | OM4 | OL4 | OM5 | OL5 | | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | OM[2:5] — Output Mode OL[2:5] — Output Level | OMx | OLx | Action Taken on Successful Compare | |-----|-----|------------------------------------------| | 0 | 0 | Timer disconnected from output pin logic | | 0 | 1 | Toggle OCx output line | | 1 | 0 | Clear OCx output line to 0 | | 1 | 1 | Set OCx output line to 1 | ### **Timer Control Register 2 (TCTL2)** Address: \$1021 | EDGxB | EDGxA | Configuration | | | | | |-------|-------|-------------------------------|--|--|--|--| | 0 | 0 | Capture disabled | | | | | | 0 | 1 | Capture on rising edges only | | | | | | 1 | 0 | Capture on falling edges only | | | | | | 1 | 1 | Capture on any edge | | | | | #### **Factory Test Register (TEST1)** TILOP — Test Illegal Opcode (Test modes only) Bit 6 — Unimplemented Always reads 0 OCCR — Output Condition Code Register to Timer Port (Test modes only) CBYP — Timer Divider Chain Bypass (Test modes only) DISR — Disable Reset from COP and Clock Monitor (Special modes only (SMOD = 1)) FCM — Force Clock Monitor Failure (Test modes only) FCOP — Force COP Watchdog Failure (Test modes only) TCON — Test Configuration (Test modes only) #### Timer Interrupt Flag 1 Register (TFLG1) Clear flags by writing a 1 to the corresponding bit position(s). OC1F-OC4F — Output Compare x Flag Set each time the counter matches output compare x value. 14/O5F — Input Capture 4/Output Compare 5 Flag Set by IC4 or OC5, depending on which function was enabled by I4/O5 of PACTL. IC1F-IC3F — Input Capture x Flag Set each time a selected active edge is detected on the ICx input line. #### **Timer Interrupt Flag 2 Register (TFLG2)** Clear flags by writing a 1 to the corresponding bit position(s). TOF — Timer Overflow Flag Set when TCNT changes from \$FFFF to \$0000 RTIF — Real-Time (Periodic) Interrupt Flag The RTIF status bit is automatically set to 1 at the end of every RTI period. To clear RTIF, write a byte to TFLG2 with bit 6 set. PAOVF — Pulse Accumulator Overflow Flag Set when PACNT changes from \$FF to \$00 PAIF — Pulse Accumulator Input Edge Flag Set each time a selected active edge is detected on the PAI input line. Bits [3:0] — Unimplemented Always reads 0 # **Timer Input Capture 4/Output Compare 5 Register (TI4/O5)** | Address: | : \$101E — High | | | | | | | | | | |-----------------|-----------------------|--------|--------|--------|--------|--------|-------|-------|--|--| | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | Read:<br>Write: | BIT 15 | BIT 14 | BIT 13 | BIT 12 | BIT 11 | BIT 10 | BIT 9 | BIT 8 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | Address: | Address: \$101F — Low | | | | | | | | | | | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | Read:<br>Write: | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | # **Timer Input Capture Registers (TIC1-TIC3)** | TIC1 — Address: \$1010 — High | | | | | | | | | | |-------------------------------|-----------------------|--------|--------|-----------|------------|--------|-------|----------|--| | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | Read:<br>Write: | BIT 15 | BIT 14 | BIT 13 | BIT 12 | BIT 11 | BIT 10 | BIT 9 | BIT 8 | | | Reset: | | | | Unaffecte | d by reset | | | <u> </u> | | | Address: | \$1011 — Low | | | | | | | | | | _ | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | Read:<br>Write: | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | | | Reset: | | | | Unaffecte | d by reset | | | | | | TIC2 — Addre | ess: \$1012 - | — High | | | | | | | | | - | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | Read:<br>Write: | BIT 15 | BIT 14 | BIT 13 | BIT 12 | BIT 11 | BIT 10 | BIT 9 | BIT 8 | | | Reset: | | | | Unaffecte | d by reset | | | | | | Address: | \$1013 — Lo | W | | | | | | | | | _ | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | Read:<br>Write: | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | | | Reset: | | | | Unaffecte | d by reset | | | | | | TIC3 — Addre | ess: \$1014 - | — High | | | | | | | | | - | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | Read:<br>Write: | BIT 15 | BIT 14 | BIT 13 | BIT 12 | BIT 11 | BIT 10 | BIT 9 | BIT 8 | | | Reset: | : Unaffected by reset | | | | | | | | | | Address: \$1015 — Low | | | | | | | | | | | - | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | Read:<br>Write: | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | | | Reset: | : Unaffected by reset | | | | | | | | | #### **Timer Interrupt Mask Register 1 (TMSK1)** Address: \$1022 Bit 7 6 3 Bit 0 5 4 1 Read: OC4I OC1I OC2I OC3I 14/051 IC1I IC2I IC3I Write: 0 0 n 0 0 0 0 Reset: 0 OC1I-OC4I — Output Compare x Interrupt Enable If the OCxI enable bit is set when the OCxF flag bit is set, a hardware interrupt sequence is requested. 14/O5I — Input Capture 4/Output Compare 5 Interrupt Enable When I4/O5 in PACTL is 1, I4/O5I is the input capture 4 interrupt enable bit. When I4/O5 in PACTL is 0, I4/O5I is the output compare 5 interrupt enable bit. IC1I-IC3I — Input Capture x Interrupt Enable If the ICxI enable bit is set when the ICxF flag bit is set, a hardware interrupt sequence is requested. #### **Timer Interrupt Mask Register 2 (TMSK2)** TOI — Timer Overflow Interrupt Enable 0 = TOF interrupts disabled 1 = Interrupt requested when TOF is set to 1 RTII — Real-Time Interrupt Enable 0 = RTIF interrupts disabled 1 = Interrupt requested when RTIF is set to 1 PAOVI — Pulse Accumulator Input Edge Interrupt Enable 0 = PAOVF interrupts disabled 1 = Interrupt requested when PAOVF is set to 1 PAII — Pulse Accumulator Input Edge Interrupt Enable 0 = PAIF interrupts disabled 1 = Interrupt requested when PAIF is set to 1 Bits [3:2] — Unimplemented Always reads 0 PR[1:0] — Timer Prescaler Select In normal modes, PR1 and PR0 can only be written once, and the write must occur within 64 cycles after reset. | PR1 | PR0 | Prescaler | |-----|-----|-----------| | 0 | 0 | ÷ 1 | | 0 | 1 | ÷ 4 | | 1 | 0 | ÷ 8 | | 1 | 1 | ÷ 16 | # **Timer Output Compare Registers (TOC1-TOC4)** | TOC1 — Address: \$1016 — High | | | | | | | | | | | |-------------------------------|----------------|--------|--------|--------|--------|--------|-------|-------|--|--| | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | Read:<br>Write: | BIT 15 | BIT 14 | BIT 13 | BIT 12 | BIT 11 | BIT 10 | BIT 9 | BIT 8 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | Address: \$1017 — Low | | | | | | | | | | | | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | Read:<br>Write: | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | TOC2 — Add | ress: \$1018 - | — High | | | | | | | | | | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | Read:<br>Write: | BIT 15 | BIT 14 | BIT 13 | BIT 12 | BIT 11 | BIT 10 | BIT 9 | BIT 8 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | Address: | \$1019 — Lo | W | | | | | | | | | | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | Read:<br>Write: | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | TOC3 — Add | ress: \$101A - | — High | | | | | | | | | | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | Read:<br>Write: | BIT 15 | BIT 14 | BIT 13 | BIT 12 | BIT 11 | BIT 10 | BIT 9 | BIT 8 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | Address: | \$101B — Lo | )W | | | | | | | | | | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | Read:<br>Write: | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | TOC4 — Add | ress: \$101C | — High | | | | | | | | | | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | Read:<br>Write: | BIT 15 | BIT 14 | BIT 13 | BIT 12 | BIT 11 | BIT 10 | BIT 9 | BIT 8 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | Read:<br>Write: | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | ## M68HC11 E Series Pin Assignments Figure 8. Pin Assignments for 52-Pin PLCC and CLCC Figure 9. Pin Assignments for 52-Pin TQFP Figure 10. Pin Assignments for 64-Pin QFP $<sup>^{\</sup>star}$ $V_{\mbox{\footnotesize{PPE}}}$ applies only to devices with EPROM/OTPROM. Figure 11. Pin Assignments for 56-Pin SDIP Figure 12. Pin Assignments for 48-Pin DIP (MC68HC811E2) ## **Hexadecimal to ASCII Conversion** **Table 2. Hexadecimal to ASCII Conversion** | Hex | ASCII | Hex | ASCII | Hex | ASCII | Hex | ASCII | |------|----------------|------|----------|------|---------|------|---------------| | \$00 | NUL | \$20 | SP space | \$40 | @ | \$60 | ` grave | | \$01 | SOH | \$21 | ! | \$41 | Α | \$61 | а | | \$02 | STX | \$22 | " quote | \$42 | В | \$62 | b | | \$03 | ETX | \$23 | # | \$43 | С | \$63 | С | | \$04 | EOT | \$24 | \$ | \$44 | D | \$64 | d | | \$05 | ENQ | \$25 | % | \$45 | Е | \$65 | е | | \$06 | ACK | \$26 | & | \$46 | F | \$66 | f | | \$07 | BEL beep | \$27 | ʻapost. | \$47 | G | \$67 | g | | \$08 | BS back<br>sp | \$28 | ( | \$48 | Н | \$68 | h | | \$09 | HT tab | \$29 | ) | \$49 | I | \$69 | İ | | \$0A | LF<br>linefeed | \$2A | * | \$4A | J | \$6A | j | | \$0B | VT | \$2B | + | \$4B | K | \$6B | k | | \$0C | FF | \$2C | , comma | \$4C | L | \$6C | 1 | | \$0D | CR return | \$2D | - dash | \$4D | M | \$6D | m | | \$0E | SO | \$2E | . period | \$4E | N | \$6E | n | | \$0F | SI | \$2F | / | \$4F | 0 | \$6F | 0 | | \$10 | DLE | \$30 | 0 | \$50 | Р | \$70 | р | | \$11 | DC1 | \$31 | 1 | \$51 | Q | \$71 | q | | \$12 | DC2 | \$32 | 2 | \$52 | R | \$72 | r | | \$13 | DC3 | \$33 | 3 | \$53 | S | \$73 | s | | \$14 | DC4 | \$34 | 4 | \$54 | Т | \$74 | t | | \$15 | NAK | \$35 | 5 | \$55 | U | \$75 | u | | \$16 | SYN | \$36 | 6 | \$56 | V | \$76 | V | | \$17 | ETB | \$37 | 7 | \$57 | W | \$77 | W | | \$18 | CAN | \$38 | 8 | \$58 | Χ | \$78 | х | | \$19 | EM | \$39 | 9 | \$59 | Υ | \$79 | у | | \$1A | SUB | \$3A | : | \$5A | Z | \$7A | Z | | \$1B | ESCAPE | \$3B | , | \$5B | [ | \$7B | { | | \$1C | FS | \$3C | < | \$5C | \ | \$7C | 1 | | \$1D | GS | \$3D | = | \$5D | ] | \$7D | } | | \$1E | RS | \$3E | > | \$5E | ۸ | \$7E | ~ | | \$1F | US | \$3F | ? | \$5F | _ under | \$7F | DEL<br>delete | #### **Hexadecimal to Decimal Conversion** To convert a hexadecimal number (up to four hexadecimal digits) to decimal, look up the decimal equivalent of each hexadecimal digit in **Table 3**. The decimal equivalent of the original hexadecimal number is the sum of the weights found in the table for all hexadecimal digits. Bit Bit 15 8 0 15 12 11 8 7 4 3 4th Hex Digit 3rd Hex Digit 2nd Hex Digit 1st Hex Digit Hex **Decimal** Hex **Decimal** Hex **Decimal** Hex **Decimal** 0 0 0 0 0 0 1 4,096 1 256 1 16 1 1 2 2 512 2 2 2 8,192 32 3 3 12.288 3 768 3 48 3 4 4 4 4 4 16,384 1.024 64 5 5 5 5 20,480 1,280 80 5 6 6 6 6 6 24,576 1,536 96 7 7 7 7 7 28,672 1,792 112 8 32,768 8 2,048 8 128 8 8 9 36,864 9 2.304 9 144 9 9 2,560 Α 40,960 Α 10 Α Α 160 В В 45,056 В 2,816 В 176 11 С 49,152 С 3,072 С 192 C 12 D 53.248 D 3.328 D 208 D 13 Е Ε 57,344 Ε 3,484 Ε 224 14 F F F 240 F 61.440 3.840 15 Table 3. Hexadecimal to/from Decimal Conversion #### **Decimal to Hexadecimal Conversion** To convert a decimal number (up to 65,535<sub>10</sub>) to hexadecimal, find the largest decimal number in **Table 3** that is less than or equal to the number you are converting. The corresponding hexadecimal digit is the most significant hexadecimal digit of the result. Subtract the decimal number found from the original decimal number to get the *remaining decimal value*. Repeat the procedure using the remaining decimal value for each subsequent hexadecimal digit. #### **HOW TO REACH US:** #### USA/EUROPE/LOCATIONS NOT LISTED: Motorola Literature Distribution P.O. Box 5405 Denver, Colorado 80217 1-800-521-6274 or 480-768-2130 #### JAPAN: Motorola Japan Ltd. SPS, Technical Information Center 3-20-1, Minami-Azabu, Minato-ku Tokyo 106-8573, Japan 81-3-3440-3569 #### ASIA/PACIFIC: Motorola Semiconductors H.K. Ltd. Silicon Harbour Centre 2 Dai King Street Tai Po Industrial Estate Tai Po, N.T., Hong Kong 852-26668334 #### **HOME PAGE:** http://motorola.com/semiconductors Information in this document is provided solely to enable system and software implementers to use Motorola 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. Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Motorola 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 Motorola 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. Motorola does not convey any license under its patent rights nor the rights of others. Motorola 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 Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola 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 Motorola was negligent regarding the design or manufacture of the part. MOTOROLA and the Stylized M Logo are registered in the US Patent and Trademark Office. All other product or service names are the property of their respective owners. Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer. © Motorola Inc. 2003