

Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

#### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

E·XFI

| Product Status             | Active                                                    |
|----------------------------|-----------------------------------------------------------|
| Core Processor             | S08                                                       |
| Core Size                  | 8-Bit                                                     |
| Speed                      | 8MHz                                                      |
| Connectivity               | SCI                                                       |
| Peripherals                | LVD, POR, PWM, WDT                                        |
| Number of I/O              | 23                                                        |
| Program Memory Size        | 32KB (32K x 8)                                            |
| Program Memory Type        | FLASH                                                     |
| EEPROM Size                | -                                                         |
| RAM Size                   | 2K x 8                                                    |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                               |
| Data Converters            | -                                                         |
| Oscillator Type            | Internal                                                  |
| Operating Temperature      | 0°C ~ 70°C (TA)                                           |
| Mounting Type              | Through Hole                                              |
| Package / Case             | 28-DIP (0.600", 15.24mm)                                  |
| Supplier Device Package    | 28-PDIP                                                   |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=mc9s08rd32pe |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong



\_\_\_\_\_

| Part Number   | Part Number Package Description |             | Current (copper wire)<br>package document number |  |
|---------------|---------------------------------|-------------|--------------------------------------------------|--|
| MC68HC908JW32 | 48 QFN                          | 98ARH99048A | 98ASA00466D                                      |  |
| MC9S08AC16    |                                 |             |                                                  |  |
| MC9S908AC60   |                                 |             |                                                  |  |
| MC9S08AC128   |                                 |             |                                                  |  |
| MC9S08AW60    |                                 |             |                                                  |  |
| MC9S08GB60A   |                                 |             |                                                  |  |
| MC9S08GT16A   |                                 |             |                                                  |  |
| MC9S08JM16    |                                 |             |                                                  |  |
| MC9S08JM60    |                                 |             |                                                  |  |
| MC9S08LL16    |                                 |             |                                                  |  |
| MC9S08QE128   |                                 |             |                                                  |  |
| MC9S08QE32    |                                 |             |                                                  |  |
| MC9S08RG60    |                                 |             |                                                  |  |
| MCF51CN128    |                                 |             |                                                  |  |
| MC9RS08LA8    | 48 QFN                          | 98ARL10606D | 98ASA00466D                                      |  |
| MC9S08GT16A   | 32 QFN                          | 98ARH99035A | 98ASA00473D                                      |  |
| MC9S908QE32   | 32 QFN                          | 98ARE10566D | 98ASA00473D                                      |  |
| MC9S908QE8    | 32 QFN                          | 98ASA00071D | 98ASA00736D                                      |  |
| MC9S08JS16    | 24 QFN                          | 98ARL10608D | 98ASA00734D                                      |  |
| MC9S08QB8     |                                 |             |                                                  |  |
| MC9S08QG8     | 24 QFN                          | 98ARL10605D | 98ASA00474D                                      |  |
| MC9S08SH8     | 24 QFN                          | 98ARE10714D | 98ASA00474D                                      |  |
| MC9RS08KB12   | 24 QFN                          | 98ASA00087D | 98ASA00602D                                      |  |
| MC9S08QG8     | 16 QFN                          | 98ARE10614D | 98ASA00671D                                      |  |
| MC9RS08KB12   | 8 DFN                           | 98ARL10557D | 98ASA00672D                                      |  |
| MC9S08QG8     | 1                               |             |                                                  |  |
| MC9RS08KA2    | 6 DFN                           | 98ARL10602D | 98ASA00735D                                      |  |



# MC9S08RC8/16/32/60 MC9S08RD8/16/32/60 MC9S08RE8/16/32/60 MC9S08RG32/60

**Data Sheet** 

HCS08 Microcontrollers

MC9S08RG60/D Rev. 1.11 06/2005



freescale.com

# NP

### **Section Number**

## Title

### Page

### Chapter 9 Keyboard Interrupt (S08KBIV1)

| 9.1 | Introduc                        | tion                                       |  |  |  |  |  |
|-----|---------------------------------|--------------------------------------------|--|--|--|--|--|
| 9.2 | KBI Block Diagram               |                                            |  |  |  |  |  |
| 9.3 | Keyboard Interrupt (KBI) Module |                                            |  |  |  |  |  |
|     | 9.3.1                           | Pin Enables                                |  |  |  |  |  |
|     | 9.3.2                           | Edge and Level Sensitivity                 |  |  |  |  |  |
|     | 9.3.3                           | KBI Interrupt Controls                     |  |  |  |  |  |
| 9.4 | KBI Reg                         | sisters and Control Bits                   |  |  |  |  |  |
|     | 9.4.1                           | KBI x Status and Control Register (KBIxSC) |  |  |  |  |  |
|     | 9.4.2                           | KBI x Pin Enable Register (KBIxPE)         |  |  |  |  |  |

# Chapter 10 Timer/PWM Module (S08TPMV1)

| 10.1 | Introduct | ion                                                    |     |
|------|-----------|--------------------------------------------------------|-----|
| 10.2 | Features  |                                                        |     |
| 10.3 | TPM Blo   | ck Diagram                                             |     |
| 10.4 | Pin Desc  | riptions                                               |     |
|      | 10.4.1    | External TPM Clock Sources                             |     |
|      | 10.4.2    | TPM1CHn — TPM1 Channel n I/O Pins                      |     |
| 10.5 | Function  | al Description                                         |     |
|      | 10.5.1    | Counter                                                |     |
|      | 10.5.2    | Channel Mode Selection                                 |     |
|      |           | 10.5.2.1 Input Capture Mode                            |     |
|      |           | 10.5.2.2 Output Compare Mode                           |     |
|      |           | 10.5.2.3 Edge-Aligned PWM Mode                         |     |
|      | 10.5.3    | Center-Aligned PWM Mode                                |     |
| 10.6 | TPM Inte  | errupts                                                |     |
|      | 10.6.1    | Clearing Timer Interrupt Flags                         |     |
|      | 10.6.2    | Timer Overflow Interrupt Description                   |     |
|      | 10.6.3    | Channel Event Interrupt Description                    |     |
|      | 10.6.4    | PWM End-of-Duty-Cycle Events                           |     |
| 10.7 | TPM Reg   | gisters and Control Bits                               |     |
|      | 10.7.1    | Timer Status and Control Register (TPM1SC)             |     |
|      | 10.7.2    | Timer Counter Registers (TPM1CNTH:TPM1CNTL)            |     |
|      | 10.7.3    | Timer Counter Modulo Registers (TPM1MODH:TPM1MODL)     | 141 |
|      | 10.7.4    | Timer Channel n Status and Control Register (TPM1CnSC) |     |
|      | 10.7.5    | Timer Channel Value Registers (TPM1CnVH:TPM1CnVL)      |     |



# Chapter 4 Memory

## 4.1 MC9S08RC/RD/RE/RG Memory Map

As shown in Figure 4-1, on-chip memory in the MC9S08RC/RD/RE/RG series of MCUs consists of RAM, FLASH program memory for nonvolatile data storage, and I/O and control/status registers. The registers are divided into three groups:

- Direct-page registers (\$0000 through \$0045 for 32K and 60K parts, and \$0000 through \$003F for 16K and 8K parts)
- High-page registers (\$1800 through \$182B)
- Nonvolatile registers (\$FFB0 through \$FFBF)



Figure 4-1. MC9S08RC/RD/RE/RG Memory Map

### 4.1.1 Reset and Interrupt Vector Assignments

Figure 4-2 shows address assignments for reset and interrupt vectors. The vector names shown in this table are the labels used in the Freescale-provided equate file for the MC9S08RC/RD/RE/RG. For more details about resets, interrupts, interrupt priority, and local interrupt mask controls, refer to the Chapter 5, "Resets, Interrupts, and System Configuration."



| Address           | Register Name | Bit 7  | 6      | 5      | 4       | 3     | 2      | 1     | Bit 0 |
|-------------------|---------------|--------|--------|--------|---------|-------|--------|-------|-------|
| \$1809            | SPMSC1        | LVDF   | LVDACK | LVDIE  | SAFE    | LVDRE | —      | —     | —     |
| \$180A            | SPMSC2        | LVWF   | LVWACK | 0      | 0       | PPDF  | PPDACK | PDC   | PPDC  |
| \$180B–<br>\$180F | Reserved      |        | _      | _      | _       | _     | _      | _     | _     |
| \$1810            | DBGCAH        | Bit 15 | 14     | 13     | 12      | 11    | 10     | 9     | Bit 8 |
| \$1811            | DBGCAL        | Bit 7  | 6      | 5      | 4       | 3     | 2      | 1     | Bit 0 |
| \$1812            | DBGCBH        | Bit 15 | 14     | 13     | 12      | 11    | 10     | 9     | Bit 8 |
| \$1813            | DBGCBL        | Bit 7  | 6      | 5      | 4       | 3     | 2      | 1     | Bit 0 |
| \$1814            | DBGFH         | Bit 15 | 14     | 13     | 12      | 11    | 10     | 9     | Bit 8 |
| \$1815            | DBGFL         | Bit 7  | 6      | 5      | 4       | 3     | 2      | 1     | Bit 0 |
| \$1816            | DBGC          | DBGEN  | ARM    | TAG    | BRKEN   | RWA   | RWAEN  | RWB   | RWBEN |
| \$1817            | DBGT          | TRGSEL | BEGIN  | 0      | 0       | TRG3  | TRG2   | TRG1  | TRG0  |
| \$1818            | DBGS          | AF     | BF     | ARMF   | 0       | CNT3  | CNT2   | CNT1  | CNT0  |
| \$1819–<br>\$181F | Reserved      |        |        |        | _       | _     |        |       |       |
| \$1820            | FCDIV         | DIVLD  | PRDIV8 | DIV5   | DIV4    | DIV3  | DIV2   | DIV1  | DIV0  |
| \$1821            | FOPT          | KEYEN  | FNORED | 0      | 0       | 0     | 0      | SEC01 | SEC00 |
| \$1822            | Reserved      |        | _      |        | —       | —     | —      | _     | _     |
| \$1823            | FCNFG         | 0      | 0      | KEYACC | 0       | 0     | 0      | 0     | 0     |
| \$1824            | FPROT         | FPOPEN | FPDIS  | FPS2   | FPS1    | FPS0  | 0      | 0     | 0     |
| \$1825            | FSTAT         | FCBEF  | FCCF   | FPVIOL | FACCERR | 0     | FBLANK | 0     | 0     |
| \$1826            | FCMD          | FCMD7  | FCMD6  | FCMD5  | FCMD4   | FCMD3 | FCMD2  | FCMD1 | FCMD0 |
| \$1827–<br>\$182B | Reserved      | _      | _      | _      | _       | _     | _      | _     | _     |

| Table 4-2. | High-Page  | Register   | Summarv  | (continued) |  |
|------------|------------|------------|----------|-------------|--|
|            | ingh i ugo | 1 logiotoi | Gainnary | (001101000) |  |

1. The ILAD bit is only present on 16K and 8K versions of the devices.

Nonvolatile FLASH registers, shown in Table 4-3, are located in the FLASH memory. These registers include an 8-byte backdoor key that optionally can be used to gain access to secure memory resources. During reset events, the contents of NVPROT and NVOPT in the nonvolatile register area of the FLASH memory are transferred into corresponding FPROT and FOPT working registers in the high-page registers to control security and block protection options.

| Address           | Register Name | Bit 7  | 6                     | 5    | 4    | 3    | 2 | 1     | Bit 0 |
|-------------------|---------------|--------|-----------------------|------|------|------|---|-------|-------|
| \$FFB0–<br>\$FFB7 | NVBACKKEY     |        | 8-Byte Comparison Key |      |      |      |   |       |       |
| \$FFB8–<br>\$FFBC | Reserved      | _      | _                     | _    | _    | _    | _ | _     | _     |
| \$FFBD            | NVPROT        | FPOPEN | FPDIS                 | FPS2 | FPS1 | FPS0 | 0 | 0     | 0     |
| \$FFBE            | Reserved      |        |                       | _    |      |      | _ | _     | _     |
| \$FFBF            | NVOPT         | KEYEN  | FNORED                | 0    | 0    | 0    | 0 | SEC01 | SEC00 |

#### Table 4-3. Nonvolatile Register Summary



- Writing to a FLASH address before the internal FLASH clock frequency has been set by writing to the FCDIV register
- Writing to a FLASH address while FCBEF is not set (A new command cannot be started until the command buffer is empty.)
- Writing a second time to a FLASH address before launching the previous command (There is only one write to FLASH for every command.)
- Writing a second time to FCMD before launching the previous command (There is only one write to FCMD for every command.)
- Writing to any FLASH control register other than FCMD after writing to a FLASH address
- Writing any command code other than the five allowed codes (\$05, \$20, \$25, \$40, or \$41) to FCMD
- Accessing (read or write) any FLASH control register other than the write to FSTAT (to clear FCBEF and launch the command) after writing the command to FCMD
- The MCU enters stop mode while a program or erase command is in progress (The command is aborted.)
- Writing the byte program, burst program, or page erase command code (\$20, \$25, or \$40) with a background debug command while the MCU is secured (The background debug controller can only do blank check and mass erase commands when the MCU is secure.)
- Writing 0 to FCBEF to cancel a partial command

### 4.4.6 FLASH Block Protection

Block protection prevents program or erase changes for FLASH memory locations in a designated address range. Mass erase is disabled when any block of FLASH is protected. The MC9S08RC/RD/RE/RG allows a block of memory at the end of FLASH, and/or the entire FLASH memory to be block protected. A disable control bit and a 3-bit control field, for each of the blocks, allows the user to independently set the size of these blocks. A separate control bit allows block protection of the entire FLASH memory array. All seven of these control bits are located in the FPROT register (see Section 4.6.4, "FLASH Protection Register (FPROT and NVPROT)").

At reset, the high-page register (FPROT) is loaded with the contents of the NVPROT location that is in the nonvolatile register block of the FLASH memory. The value in FPROT cannot be changed directly from application software so a runaway program cannot alter the block protection settings. If the last 512 bytes of FLASH (which includes the NVPROT register) is protected, the application program cannot alter the block protection settings (intentionally or unintentionally). The FPROT control bits can be written by background debug commands to allow a way to erase a protected FLASH memory.

One use for block protection is to block protect an area of FLASH memory for a bootloader program. This bootloader program then can be used to erase the rest of the FLASH memory and reprogram it. Because the bootloader is protected, it remains intact even if MCU power is lost during an erase and reprogram operation.



# Chapter 5 Resets, Interrupts, and System Configuration

# 5.1 Introduction

This section discusses basic reset and interrupt mechanisms and the various sources of reset and interrupts in the MC9S08RC/RD/RE/RG. Some interrupt sources from peripheral modules are discussed in greater detail within other sections of this data sheet. This section gathers basic information about all reset and interrupt sources in one place for easy reference. A few reset and interrupt sources, including the computer operating properly (COP) watchdog and real-time interrupt (RTI), are not part of on-chip peripheral systems having their own sections but are part of the system control logic.

# 5.2 Features

Reset and interrupt features include:

- Multiple sources of reset for flexible system configuration and reliable operation:
  - Power-on detection (POR)
  - Low voltage detection (LVD) with enable
  - External reset pin with enable  $(\overline{\text{RESET}})$
  - COP watchdog with enable and two timeout choices
  - Illegal opcode
  - Illegal address (on 16K and 8K devices)
  - Serial command from a background debug host
- Reset status register (SRS) to indicate source of most recent reset; flag to indicate stop2 (partial power down) mode recovery (PPDF)
- Separate interrupt vectors for each module (reduces polling overhead) (see Table 5-1)
- Safe state for protecting the MCU in low-voltage condition

# 5.3 MCU Reset

Resetting the MCU provides a way to start processing from a known set of initial conditions. During reset, most control and status registers are forced to initial values and the program counter is loaded from the reset vector (\$FFFE:\$FFFF). On-chip peripheral modules are disabled and I/O pins are initially configured as general-purpose high-impedance inputs with pullup devices disabled. The I bit in the condition code register (CCR) is set to block maskable interrupts until the user program has a chance to initialize the stack pointer (SP) and system control settings. SP is forced to \$00FF at reset.



Parallel Input/Output

### 6.6.1 Port A Registers (PTAD, PTAPE, and PTADD)

Port A pins used as general-purpose I/O pins are controlled by the port A data (PTAD), data direction (PTADD), and pullup enable (PTAPE) registers.



Figure 6-6. Port A Data Register (PTAD)

#### Table 6-1. PTAD Field Descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0<br>PTAD[7:0] | Port A Data Register Bits — For port A pins that are inputs, reads of this register return the logic level on the pin. For port A pins that are configured as outputs, reads of this register return the last value written to this register.<br>Writes are latched into all bits of this register. For port A pins that are configured as outputs, the logic level is driven out the corresponding MCU pin.<br>Reset forces PTAD to all 0s, but these 0s are not driven out the corresponding pins because reset also configures all port pins as high-impedance inputs with pullups disabled. |

| _      | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| R<br>W | PTAPE7 | PTAPE6 | PTAPE5 | PTAPE4 | PTAPE3 | PTAPE2 | PTAPE1 | PTAPE0 |
| Reset  | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Figure 6-7. Pullup Enable for Port A (PTAPE)

#### Table 6-2. PTAPE Field Descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0<br>PTAPE[7:0] | <ul> <li>Pullup Enable for Port A Bits — For port A pins that are inputs, these read/write control bits determine whether internal pullup devices are enabled provided the corresponding PTADDn is a logic 0. For port A pins that are configured as outputs, these bits are ignored and the internal pullup devices are disabled. When any of bits 7 through 4 of port A are enabled as KBI inputs and are configured to detect rising edges/high levels, the pullup enable bits enable pulldown rather than pullup devices.</li> <li>0 Internal pullup device enabled.</li> <li>1 Internal pullup device enabled.</li> </ul> |



Parallel Input/Output

## 6.6.5 Port E Registers (PTED, PTEPE, and PTEDD)

Port E pins used as general-purpose I/O pins are controlled by the port E data (PTED), data direction (PTEDD), and pullup enable (PTEPE) registers.



### Figure 6-18. Port E Data Register (PTED)

#### Table 6-13. PTED Field Descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0<br>PTED[7:0] | Port E Data Register Bits — For port E pins that are inputs, reads return the logic level on the pin. For port E pins that are configured as outputs, reads return the last value written to this register. Writes are latched into all bits of this register. For port E pins that are configured as outputs, the logic level is driven out the corresponding MCU pin. Reset forces PTED to all 0s, but these 0s are not driven out the corresponding pins because reset also configures all port pins as high-impedance inputs with pullups disabled. |

|        | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| R<br>W | PTEPE7 | PTEPE6 | PTEPE5 | PTEPE4 | PTEPE3 | PTEPE2 | PTEPE1 | PTEPE0 |
| Reset  | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

#### Figure 6-19. Pullup Enable for Port E (PTED)

#### Table 6-14. PTED Field Descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0<br>PTED[7:0] | <ul> <li>Pullup Enable for Port E Bits — For port E pins that are inputs, these read/write control bits determine whether internal pullup devices are enabled. For port E pins that are configured as outputs, these bits are ignored and the internal pullup devices are disabled.</li> <li>0 Internal pullup device disabled.</li> <li>1 Internal pullup device enabled.</li> </ul> |



#### Parallel Input/Output

|        | 7                                              | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|------------------------------------------------|--------|--------|--------|--------|--------|--------|--------|
| R<br>W | PTEDD7                                         | PTEDD6 | PTEDD5 | PTEDD4 | PTEDD3 | PTEDD2 | PTEDD1 | PTEDD0 |
| Reset  | 0                                              | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
|        | Figure 6-20. Data Direction for Port E (PTEDD) |        |        |        |        |        |        |        |

#### **5**

#### Table 6-15. PTEDD Field Descriptions

| Field      | Description                                                                                                      |
|------------|------------------------------------------------------------------------------------------------------------------|
| 7:0        | Data Direction for Port E Bits — These read/write bits control the direction of port E pins and what is read for |
| PTEDD[7:0] | PTED reads.                                                                                                      |
|            | 0 Input (output driver disabled) and reads return the pin value.                                                 |
|            | 1 Output driver enabled for port E bit n and PTED reads return the contents of PTEDn.                            |



#### Central Processor Unit (S08CPUV2)Central Processor Unit (S08CPUV2)

- 0 = Bit forced to 0
- 1 = Bit forced to 1
  - = Bit set or cleared according to results of operation
- U = Undefined after the operation

### Machine coding notation

- dd = Low-order 8 bits of a direct address 0x0000-0x00FF (high byte assumed to be 0x00)
- ee = Upper 8 bits of 16-bit offset
- ff = Lower 8 bits of 16-bit offset or 8-bit offset
- ii = One byte of immediate data
- jj = High-order byte of a 16-bit immediate data value
- kk = Low-order byte of a 16-bit immediate data value
- hh = High-order byte of 16-bit extended address
  - II = Low-order byte of 16-bit extended address
- rr = Relative offset

### Source form

Everything in the source forms columns, *except expressions in italic characters*, is literal information that must appear in the assembly source file exactly as shown. The initial 3- to 5-letter mnemonic is always a literal expression. All commas, pound signs (#), parentheses, and plus signs (+) are literal characters.

- n Any label or expression that evaluates to a single integer in the range 0–7
- opr8i Any label or expression that evaluates to an 8-bit immediate value
- opr16i Any label or expression that evaluates to a 16-bit immediate value
- opr8a Any label or expression that evaluates to an 8-bit value. The instruction treats this 8-bit value as the low order 8 bits of an address in the direct page of the 64-Kbyte address space (0x00xx).
- *opr16a* Any label or expression that evaluates to a 16-bit value. The instruction treats this value as an address in the 64-Kbyte address space.
- *oprx8* Any label or expression that evaluates to an unsigned 8-bit value, used for indexed addressing
- *oprx16* Any label or expression that evaluates to a 16-bit value. Because the HCS08 has a 16-bit address bus, this can be either a signed or an unsigned value.
  - *rel* Any label or expression that refers to an address that is within –128 to +127 locations from the next address after the last byte of object code for the current instruction. The assembler will calculate the 8-bit signed offset and include it in the object code for this instruction.

### Address modes

- INH = Inherent (no operands)
- IMM = 8-bit or 16-bit immediate
- DIR = 8-bit direct
- EXT = 16-bit extended



- IX = 16-bit indexed no offset
- IX+ = 16-bit indexed no offset, post increment (CBEQ and MOV only)
- IX1 = 16-bit indexed with 8-bit offset from H:X
- IX1+ = 16-bit indexed with 8-bit offset, post increment (CBEQ only)
- IX2 = 16-bit indexed with 16-bit offset from H:X
- REL = 8-bit relative offset
- SP1 = Stack pointer with 8-bit offset
- SP2 = Stack pointer with 16-bit offset

#### Table 7-2. HCS08 Instruction Set Summary (Sheet 1 of 7)

| Source                                                                                                               | Operation                                                  | Description                                                        |   |   | Effect<br>on CCR |   |   |   | ress<br>de                                          | ode                                              | and                                             | ycles <sup>1</sup>              |
|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|--------------------------------------------------------------------|---|---|------------------|---|---|---|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------------|---------------------------------|
| Form                                                                                                                 | Operation                                                  | Description                                                        | v | н | I                | N | z | с | Addi<br>Mo                                          | Opc                                              | Opei                                            | Bus C                           |
| ADC #opr8i<br>ADC opr8a<br>ADC opr16a<br>ADC oprx16,X<br>ADC oprx8,X<br>ADC oprx8,X<br>ADC oprx16,SP<br>ADC oprx8,SP | Add with Carry                                             | A ← (A) + (M) + (C)                                                |   |   | _                |   |   |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 | A9<br>B9<br>C9<br>D9<br>E9<br>F9<br>9ED9<br>9EE9 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff<br>ff | 2<br>3<br>4<br>3<br>3<br>5<br>4 |
| ADD #opr8i<br>ADD opr8a<br>ADD opr16a<br>ADD oprx16,X<br>ADD oprx8,X<br>ADD ,X<br>ADD oprx16,SP<br>ADD oprx8,SP      | Add without Carry                                          | A ← (A) + (M)                                                      |   |   | _                |   |   |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 | AB<br>BB<br>CB<br>DB<br>EB<br>FB<br>9EDB<br>9EEB | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff<br>ff | 23443354                        |
| AIS #opr8i                                                                                                           | Add Immediate Value<br>(Signed) to Stack Pointer           | $SP \leftarrow (SP) + (M)$<br>M is sign extended to a 16-bit value | - | - | -                | - | - | - | IMM                                                 | A7                                               | ii                                              | 2                               |
| AIX #opr8i                                                                                                           | Add Immediate Value<br>(Signed) to Index<br>Register (H:X) | H:X ← (H:X) + (M)<br>M is sign extended to a 16-bit value          | _ | - | -                | - | - | - | IMM                                                 | AF                                               | ii                                              | 2                               |
| AND #opr8i<br>AND opr8a<br>AND opr16a<br>AND oprx16,X<br>AND oprx8,X<br>AND ,X<br>AND oprx16,SP<br>AND oprx8,SP      | Logical AND                                                | A ← (A) & (M)                                                      | 0 | _ | _                |   |   | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 | A4<br>B4<br>C4<br>D4<br>E4<br>F4<br>9ED4<br>9EE4 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff<br>ff | 2<br>3<br>4<br>3<br>3<br>5<br>4 |
| ASL opr8a<br>ASLA<br>ASLX<br>ASL oprx8,X<br>ASL ,X<br>ASL ,X<br>ASL oprx8,SP                                         | Arithmetic Shift Left<br>(Same as LSL)                     | C 0 0 b7 b0                                                        |   | _ | _                |   |   |   | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 38<br>48<br>58<br>68<br>78<br>9E68               | dd<br>ff<br>ff                                  | 5<br>1<br>5<br>4<br>6           |
| ASR opr8a<br>ASRA<br>ASRX<br>ASR oprx8,X<br>ASR ,X<br>ASR oprx8,SP                                                   | Arithmetic Shift Right                                     |                                                                    |   | _ | _                |   |   |   | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 37<br>47<br>57<br>67<br>77<br>9E67               | dd<br>ff<br>ff                                  | 5<br>1<br>5<br>4<br>6           |
| BCC rel                                                                                                              | Branch if Carry Bit Clear                                  | Branch if $(C) = 0$                                                | - | - | -                | - | - | - | REL                                                 | 24                                               | rr                                              | 3                               |



| Source                                                                                                           |                                             |                                                                                                                                                                                                                                                                                          |   | c | Effect<br>on CCR |   |   |   | ess                                                                                                      | ode                                          | and                                                                           | cles                                                     |
|------------------------------------------------------------------------------------------------------------------|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|------------------|---|---|---|----------------------------------------------------------------------------------------------------------|----------------------------------------------|-------------------------------------------------------------------------------|----------------------------------------------------------|
| Form                                                                                                             | Operation                                   | Description V                                                                                                                                                                                                                                                                            |   | н | I                | N | z | с | Addre<br>Mod                                                                                             | Opco                                         | Opera                                                                         | Bus Cy                                                   |
| BRCLR n,opr8a,rel                                                                                                | Branch if Bit <i>n</i> in Memory<br>Clear   | Branch if (Mn) = 0                                                                                                                                                                                                                                                                       | _ | - | _                | - | - |   | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7)             | 01<br>03<br>05<br>07<br>09<br>0B<br>0D<br>0F | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 |
| BRN rel                                                                                                          | Branch Never                                | Uses 3 Bus Cycles                                                                                                                                                                                                                                                                        | - | - | -                | - | - | - | REL                                                                                                      | 21                                           | rr                                                                            | 3                                                        |
| BRSET n,opr8a,rel                                                                                                | Branch if Bit <i>n</i> in Memory<br>Set     | Branch if (Mn) = 1                                                                                                                                                                                                                                                                       | - | - | -                | - | - |   | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 00<br>02<br>04<br>06<br>08<br>0A<br>0C<br>0E | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 555555555                                                |
| BSET <i>n,opr8a</i>                                                                                              | Set Bit <i>n</i> in Memory                  | Mn ← 1                                                                                                                                                                                                                                                                                   | - | - | -                | - | - | - | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7)             | 10<br>12<br>14<br>16<br>18<br>1A<br>1C<br>1E | dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd                            | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5      |
| BSR rel                                                                                                          | Branch to Subroutine                        | $\begin{array}{l} PC \leftarrow (PC) + 0x0002\\ push\ (PCL); SP \leftarrow (SP) - 0x0001\\ push\ (PCH); SP \leftarrow (SP) - 0x0001\\ PC \leftarrow (PC) + \mathit{rel} \end{array}$                                                                                                     | - | - | -                | - | - | - | REL                                                                                                      | AD                                           | rr                                                                            | 5                                                        |
| CBEQ opr8a,rel<br>CBEQA #opr8i,rel<br>CBEQX #opr8i,rel<br>CBEQ oprx8,X+,rel<br>CBEQ ,X+,rel<br>CBEQ oprx8,SP,rel | Compare and Branch if<br>Equal              | Branch if $(A) = (M)$<br>Branch if $(A) = (M)$<br>Branch if $(X) = (M)$<br>Branch if $(A) = (M)$<br>Branch if $(A) = (M)$<br>Branch if $(A) = (M)$                                                                                                                                       | - | - | -                | - | - | - | DIR<br>IMM<br>IX1+<br>IX+<br>SP1                                                                         | 31<br>41<br>51<br>61<br>71<br>9E61           | dd rr<br>ii rr<br>ii rr<br>ff rr<br>rr<br>ff rr                               | 544<br>556                                               |
| CLC                                                                                                              | Clear Carry Bit                             | $C \leftarrow 0$                                                                                                                                                                                                                                                                         | - | - | -                | - | - | 0 | INH                                                                                                      | 98                                           |                                                                               | 1                                                        |
| CLI                                                                                                              | Clear Interrupt Mask Bit                    | $I \leftarrow 0$                                                                                                                                                                                                                                                                         | - | - | 0                | - | - | - | INH                                                                                                      | 9A                                           |                                                                               | 1                                                        |
| CLR opr8a<br>CLRA<br>CLRX<br>CLRH<br>CLR oprx8,X<br>CLR ,X<br>CLR oprx8,SP                                       | Clear                                       | $\begin{array}{l} M \leftarrow 0x00\\ A \leftarrow 0x00\\ X \leftarrow 0x00\\ H \leftarrow 0x00\\ M \leftarrow 0x00\\ M \leftarrow 0x00\\ M \leftarrow 0x00\\ M \leftarrow 0x00 \end{array}$                                                                                             | 0 | _ | _                | 0 | 1 | _ | DIR<br>INH<br>INH<br>INH<br>IX1<br>IX<br>SP1                                                             | 3F<br>4F<br>5F<br>8C<br>6F<br>7F<br>9E6F     | dd<br>ff<br>ff                                                                | 5<br>1<br>1<br>5<br>4<br>6                               |
| CMP #opr8i<br>CMP opr8a<br>CMP opr16a<br>CMP oprx16,X<br>CMP oprx8,X<br>CMP ,X<br>CMP oprx16,SP<br>CMP oprx8,SP  | Compare Accumulator<br>with Memory          | (A) – (M)<br>(CCR Updated But Operands Not<br>Changed)                                                                                                                                                                                                                                   |   | - | -                |   |   |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1                                                      | A1<br>B1<br>C1<br>E1<br>F1<br>9ED1<br>9EE1   | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff<br>ff                               | 2<br>3<br>4<br>3<br>3<br>5<br>4                          |
| COM opr8a<br>COMA<br>COMX<br>COM oprx8,X<br>COM ,X<br>COM oprx8,SP                                               | Complement<br>(One's Complement)            | $\begin{array}{c} M \leftarrow (\overline{M}) = 0xFF - (M) \\ A \leftarrow (\overline{A}) = 0xFF - (A) \\ X \leftarrow (\overline{X}) = 0xFF - (X) \\ M \leftarrow (\overline{M}) = 0xFF - (M) \\ M \leftarrow (\overline{M}) = 0xFF - (M) \\ M \leftarrow (M) = 0xFF - (M) \end{array}$ | 0 | - | -                |   |   | 1 | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1                                                                    | 33<br>43<br>53<br>63<br>73<br>9E63           | dd<br>ff<br>ff                                                                | 5<br>1<br>5<br>4<br>6                                    |
| CPHX opr16a<br>CPHX #opr16i<br>CPHX opr8a<br>CPHX oprx8,SP                                                       | Compare Index Register<br>(H:X) with Memory | (H:X) – (M:M + 0x0001)<br>(CCR Updated But Operands Not<br>Changed)                                                                                                                                                                                                                      |   | - | -                |   |   |   | EXT<br>IMM<br>DIR<br>SP1                                                                                 | 3E<br>65<br>75<br>9EF3                       | hh ll<br>jj kk<br>dd<br>ff                                                    | 6<br>3<br>5<br>6                                         |

#### Table 7-2. HCS08 Instruction Set Summary (Sheet 3 of 7)



#### Carrier Modulator Transmitter (CMT) Block Description



Figure 8-7. Extended Space Operation

### 8.5.3.2 EXSPC Operation in FSK Mode

In FSK mode, the modulator continues to count carrier out clocks, alternating between the primary and secondary registers at the end of each modulation period.

To calculate the length of an extended space in FSK mode, the user must know whether the EXSPC bit was set on a primary or secondary modulation period, as well as the total number of both primary and secondary modulation periods completed while the EXSPC bit is high. A status bit for the current modulation is not accessible to the CPU. If necessary, software should maintain tracking of the current modulation cycle (primary or secondary). The extended space period ends at the completion of the space period time of the modulation period during which the EXSPC bit is cleared.

If the EXSPC bit was set during a primary modulation cycle, use the equation:

$$t_{exspace} = (t_{space})_{p} + (t_{mark} + t_{space})_{s} + (t_{mark} + t_{space})_{p} + \dots \qquad Eqn. 8-10$$

Where the subscripts p and s refer to mark and space times for the primary and secondary modulation cycles.

If the EXSPC bit was set during a secondary modulation cycle, use the equation:

$$t_{exspace} = (t_{space})_{s} + (t_{mark} + t_{space})_{p} + (t_{mark} + t_{space})_{s} + \dots \qquad Eqn. 8-11$$

### 8.5.4 Transmitter

The transmitter output block controls the state of the infrared out pin (IRO). The modulator output is gated on to the IRO pin when the modulator/carrier generator is enabled. When the modulator/carrier generator is disabled, the IRO pin is controlled by the state of the IRO latch.

A polarity bit in the CMTOC register enables the IRO pin to be high true or low true.

MC9S08RC/RD/RE/RG Data Sheet, Rev. 1.11



#### Carrier Modulator Transmitter (CMT) Block Description

#### Table 8-8. CMTMSC Field Descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>EOCIE | <ul> <li>End of Cycle Interrupt Enable — A CPU interrupt will be requested when EOCF is set if EOCIE is high.</li> <li>0 CPU interrupt disabled</li> <li>1 CPU interrupt enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0<br>MCGEN | <ul> <li>Modulator and Carrier Generator Enable — Setting MCGEN will initialize the carrier generator and modulator and enable all clocks. After it is enabled, the carrier generator and modulator will function continuously. When MCGEN is cleared, the current modulator cycle will be allowed to expire before all carrier and modulator clocks are disabled (to save power) and the modulator output is forced low. To prevent spurious operation, the user should initialize all data and control registers before enabling the system.</li> <li>Modulator and carrier generator disabled</li> <li>Modulator and carrier generator enabled</li> </ul> |

# 8.6.4 CMT Modulator Data Registers (CMTCMD1, CMTCMD2, CMTCMD3, and CMTCMD4)

The modulator data registers control the mark and space periods of the modulator for all modes. The contents of these registers are transferred to the modulator down counter and space period register upon the completion of a modulation period.

| Name    |   | 7    | 6    | 5           | 4    | 3           | 2    | 1   | 0     |
|---------|---|------|------|-------------|------|-------------|------|-----|-------|
| CMTCMD1 | R | MB15 | MB14 | MB13        | MB12 | MB11        | MB10 | MBO | MB8   |
|         | W |      |      |             |      |             |      | MD9 | NIDO  |
| CMTCMD2 | R | MB7  | MB6  | MB5         | MB4  | MB3         | MB2  | MB1 | MBO   |
|         | W |      | NID0 |             | NID4 | MDS         | MDZ  |     | NID0  |
| CMTCMD3 | R | QD15 | QD1/ | <b>CD12</b> | SB10 | <b>QD11</b> | SB10 | SBO | C D O |
|         | W | 3013 | 3014 | 3013        | 3012 | 3011        | 3010 | 309 | 300   |
| CMTCMD4 | R | SB7  | SB6  | SB5         | SB4  | SB3         | SB2  | SB1 | SBO   |
|         | W | 667  | 560  | 665         | 564  | 666         | 002  | 561 | 360   |

 Table 8-9. Sample Register Summary



## 9.4.1 KBI x Status and Control Register (KBIxSC)



Figure 9-3. KBI x Status and Control Register (KBIxSC)

| Table 9-1 | . KBIxSC | Field | <b>Descriptions</b> |
|-----------|----------|-------|---------------------|
|-----------|----------|-------|---------------------|

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4<br>KBEDG[7:4] | <ul> <li>Keyboard Edge Select for KBI Port Bits — Each of these read/write bits selects the polarity of the edges and/or levels that are recognized as trigger events on the corresponding KBI port pin when it is configured as a keyboard interrupt input (KBIPEn = 1). Also see the KBIMOD control bit, which determines whether the pin is sensitive to edges-only or edges and levels.</li> <li>Falling edges/low levels.</li> <li>Rising edges/high levels.</li> </ul>                                                                                                                                                                   |
| 3<br>KBF          | <ul> <li>Keyboard Interrupt Flag — This read-only status flag is set whenever the selected edge event has been detected on any of the enabled KBI port pins. This flag is cleared by writing a logic 1 to the KBACK control bit. The flag will remain set if KBIMOD = 1 to select edge-and-level operation and any enabled KBI port pin remains at the asserted level.</li> <li>0 No KBI interrupt pending.</li> <li>1 KBI interrupt pending.</li> <li>KBF can be used as a software pollable flag (KBIE = 0) or it can generate a hardware interrupt request to the CPU (KBIE = 1). KBF must be cleared before entering stop mode.</li> </ul> |
| 2<br>KBACK        | <b>Keyboard Interrupt Acknowledge</b> — This write-only bit (reads always return 0) is used to clear the KBF status flag by writing a logic 1 to KBACK. When KBIMOD = 1 to select edge-and-level operation and any enabled KBI port pin remains at the asserted level, KBF is being continuously set so writing 1 to KBACK does not clear the KBF flag.                                                                                                                                                                                                                                                                                        |
| 1<br>KBIE         | <ul> <li>Keyboard Interrupt Enable — This read/write control bit determines whether hardware interrupts are generated when the KBF status flag equals 1. When KBIE = 0, no hardware interrupts are generated, but KBF can still be used for software polling.</li> <li>KBF does not generate hardware interrupts (use polling).</li> <li>KBI hardware interrupt requested when KBF = 1.</li> </ul>                                                                                                                                                                                                                                             |
| 0<br>KBIMOD       | <ul> <li>Keyboard Detection Mode — This read/write control bit selects either edge-only detection or edge-and-level detection. KBI port bits 3 through 0 can detect falling edges-only or falling edges and low levels.</li> <li>KBI port bits 7 through 4 can be configured to detect either: <ul> <li>Rising edges-only or rising edges and high levels (KBEDGn = 1)</li> <li>Falling edges-only or falling edges and low levels (KBEDGn = 0)</li> <li>Edge-only detection.</li> </ul> </li> <li>1 Edge-and-level detection.</li> </ul>                                                                                                      |





### 12.2.5 SCI Status Register 2 (SCI1S2)

This register has one read-only status flag. Writes have no effect.



### Figure 12-8. SCI Status Register 2 (SCI1S2)

#### Table 12-6. SCI1S2 Register Field Descriptions

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>RAF | <ul> <li>Receiver Active Flag — RAF is set when the SCI receiver detects the beginning of a valid start bit, and RAF is cleared automatically when the receiver detects an idle line. This status flag can be used to check whether an SCI character is being received before instructing the MCU to go to stop mode.</li> <li>0 SCI receiver idle waiting for a start bit.</li> <li>1 SCI receiver active (RxD input not idle).</li> </ul> |

### 12.2.6 SCI Control Register 3 (SCI1C3)



#### Figure 12-9. SCI Control Register 3 (SCI1C3)

#### Table 12-7. SCI1C3 Register Field Descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>R8    | <b>Ninth Data Bit for Receiver</b> — When the SCI is configured for 9-bit data ( $M = 1$ ), R8 can be thought of as a ninth receive data bit to the left of the MSB of the buffered data in the SCI1D register. When reading 9-bit data, read R8 before reading SCI1D because reading SCI1D completes automatic flag clearing sequences which could allow R8 and SCI1D to be overwritten with new data.                                                                                                                                                                                   |
| 6<br>T8    | <b>Ninth Data Bit for Transmitter</b> — When the SCI is configured for 9-bit data ( $M = 1$ ), T8 may be thought of as a ninth transmit data bit to the left of the MSB of the data in the SCI1D register. When writing 9-bit data, the entire 9-bit value is transferred to the SCI shift register after SCI1D is written so T8 should be written (if it needs to change from its previous value) before SCI1D is written. If T8 does not need to change in the new value (such as when it is used to generate mark or space parity), it need not be written each time SCI1D is written. |
| 5<br>TXDIR | <ul> <li>TxD Pin Direction in Single-Wire Mode — When the SCI is configured for single-wire half-duplex operation (LOOPS = RSRC = 1), this bit determines the direction of data at the TxD pin.</li> <li>0 TxD pin is an input in single-wire mode.</li> <li>1 TxD pin is an output in single-wire mode.</li> </ul>                                                                                                                                                                                                                                                                       |

#### MC9S08RC/RD/RE/RG Data Sheet, Rev. 1.11



### 13.4.5 SPI Data Register (SPI1D)



Reads of this register return the data read from the receive data buffer. Writes to this register write data to the transmit data buffer. When the SPI is configured as a master, writing data to the transmit data buffer initiates an SPI transfer.

Data should not be written to the transmit data buffer unless the SPI transmit buffer empty flag (SPTEF) is set, indicating there is room in the transmit buffer to queue a new transmit byte.

Data may be read from SPI1D any time after SPRF is set and before another transfer is finished. Failure to read the data out of the receive data buffer before a new transfer ends causes a receive overrun condition and the data from the new transfer is lost.



# Chapter 15 Development Support

# 15.1 Introduction

### 15.1.1 Features

Features of the background debug controller (BDC) include:

- Single pin for mode selection and background communications
- BDC registers are not located in the memory map
- SYNC command to determine target communications rate
- Non-intrusive commands for memory access
- Active background mode commands for CPU register access
- GO and TRACE1 commands
- BACKGROUND command can wake CPU from stop or wait modes
- One hardware address breakpoint built into BDC
- Oscillator runs in stop mode, if BDC enabled
- COP watchdog disabled while in active background mode

Features of the debug module (DBG) include:

- Two trigger comparators:
  - Two address + read/write (R/W) or
  - One full address + data + R/W
- Flexible 8-word by 16-bit FIFO (first-in, first-out) buffer for capture information:
  - Change-of-flow addresses or
  - Event-only data
- Two types of breakpoints:
  - Tag breakpoints for instruction opcodes
  - Force breakpoints for any address access
- Nine trigger modes:
  - A-only
  - A OR B
  - A then B
  - A AND B data (full mode)
  - A AND NOT B data (full mode)
  - Event-only B (store data)
  - A then event-only B (store data)