



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

| Product Status             | Active                                                                |
|----------------------------|-----------------------------------------------------------------------|
| Core Processor             | S08                                                                   |
| Core Size                  | 8-Bit                                                                 |
| Speed                      | 48MHz                                                                 |
| Connectivity               | I <sup>2</sup> C, LINbus, SCI, SPI, USB                               |
| Peripherals                | LVD, POR, PWM, WDT                                                    |
| Number of I/O              | 33                                                                    |
| Program Memory Size        | 16KB (16K x 8)                                                        |
| Program Memory Type        | FLASH                                                                 |
| EEPROM Size                | -                                                                     |
| RAM Size                   | 1K x 8                                                                |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                           |
| Data Converters            | A/D 8x12b                                                             |
| Oscillator Type            | External                                                              |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                     |
| Mounting Type              | Surface Mount                                                         |
| Package / Case             | 44-LQFP                                                               |
| Supplier Device Package    | 44-LQFP (10x10)                                                       |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc9s08jm16cld |

Email: info@E-XFL.COM

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



| 18.4 | Register Definition                                         |  |
|------|-------------------------------------------------------------|--|
|      | 18.4.1 BDC Registers and Control Bits                       |  |
|      | 18.4.2 System Background Debug Force Reset Register (SBDFR) |  |
|      | 18.4.3 DBG Registers and Control Bits                       |  |

# Appendix A Electrical Characteristics

| A.1  | Introduction                               | .349 |
|------|--------------------------------------------|------|
| A.2  | Parameter Classification                   | .349 |
| A.3  | Absolute Maximum Ratings                   | .349 |
| A.4  | Thermal Characteristics.                   | .350 |
| A.5  | ESD Protection and Latch-up Immunity       | .351 |
| A.6  | DC Characteristics.                        | .352 |
| A.7  | Supply Current Characteristics             | .356 |
| A.8  | Analog Comparator (ACMP) Electricals       | .357 |
| A.9  | ADC Characteristics                        | .357 |
| A.10 | External Oscillator (XOSC) Characteristics | .361 |
| A.11 | MCG Specifications                         | .362 |
| A.12 | AC Characteristics                         | .363 |
|      | A.12.1 Control Timing                      | .363 |
|      | A.12.2 Timer/PWM (TPM) Module Timing       | .364 |
|      | A.12.3 SPI Characteristics                 | .365 |
| A.13 | Flash Specifications                       | .369 |
| A.14 | USB Electricals                            | .369 |
| 18.5 | EMC Performance                            | .370 |
|      | 18.5.1 Radiated Emissions                  | .370 |

# Appendix B

# Ordering Information and Mechanical Drawings

| <b>B</b> .1 | Ordering Information            | .373 |
|-------------|---------------------------------|------|
| B.2         | Orderable Part Numbering System | .373 |
| B.3         | Mechanical Drawings             | .373 |



**Chapter 4 Memory** 



Figure 4-1. MC9S08JM16 Series Memory Map



Chapter 5 Resets, Interrupts, and System Configuration

# 5.5.1 Interrupt Stack Frame

Figure 5-1 shows the contents and organization of a stack frame. Before the interrupt, the stack pointer (SP) points at the next available byte location on the stack. The current values of CPU registers are stored on the stack starting with the low-order byte of the program counter (PCL) and ending with the CCR. After stacking, the SP points at the next available location on the stack which is the address that is one less than the address where the CCR was saved. The PC value that is stacked is the address of the instruction in the main program that would have executed next if the interrupt had not occurred.



Figure 5-1. Interrupt Stack Frame

When an RTI instruction is executed, these values are recovered from the stack in reverse order. As part of the RTI sequence, the CPU fills the instruction pipeline by reading three bytes of program information, starting from the PC address recovered from the stack.

The status flag causing the interrupt must be acknowledged (cleared) before returning from the ISR. Typically, the flag must be cleared at the beginning of the ISR, so that if another interrupt is generated by this same source, it will be registered to be serviced after completion of the current ISR.

# 5.5.2 External Interrupt Request (IRQ) Pin

External interrupts are managed by the IRQSC status and control register. When the IRQ function is enabled, synchronous logic monitors the pin for edge-only or edge-and-level events. When the MCU is in stop mode and system clocks are shut down, a separate asynchronous path is used so the IRQ (if enabled) can wake the MCU.

## 5.5.2.1 Pin Configuration Options

The IRQ pin enable (IRQPE) control bit in IRQSC must be 1 for the IRQ pin to act as the interrupt request (IRQ) input. As an IRQ input, the user can choose the polarity of edges or levels detected (IRQEDG), whether the pin detects edges-only or edges and levels (IRQMOD), and whether an event causes an interrupt or only sets the IRQF flag which can be polled by software.



**Chapter 6 Parallel Input/Output** 



#### Figure 6-11. Output Drive Strength Selection for Port B (PTBDS)

#### Table 6-10. PTBDS Register Field Descriptions

| Field             | Description                                                                                                                                                                                                                                                                         |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0<br>PTBDS[5:0] | <ul> <li>Output Drive Strength Selection for Port B Bits — Each of these control bits selects between low and high output drive for the associated PTB pin.</li> <li>0 Low output drive enabled for port B bit n.</li> <li>1 High output drive enabled for port B bit n.</li> </ul> |

## 6.5.5 Port C I/O Registers (PTCD and PTCDD)

Port C parallel I/O function is controlled by the registers listed below.



Figure 6-12. Port C Data Register (PTCD)

#### Table 6-11. PTCD Register Field Descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0<br>PTCD[5:0] | Port C Data Register Bits — For port C pins that are inputs, reads return the logic level on the pin. For port C 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 C pins that are configured as outputs, the logic level is driven out the corresponding MCU pin. Reset forces PTCD 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.3 Addressing Modes

Addressing modes define the way the CPU accesses operands and data. In the HCS08, all memory, status and control registers, and input/output (I/O) ports share a single 64-Kbyte linear address space so a 16-bit binary address can uniquely identify any memory location. This arrangement means that the same instructions that access variables in RAM can also be used to access I/O and control registers or nonvolatile program space.

Some instructions use more than one addressing mode. For instance, move instructions use one addressing mode to specify the source operand and a second addressing mode to specify the destination address. Instructions such as BRCLR, BRSET, CBEQ, and DBNZ use one addressing mode to specify the location of an operand for a test and then use relative addressing mode to specify the branch destination address when the tested condition is true. For BRCLR, BRSET, CBEQ, and DBNZ, the addressing mode listed in the instruction set tables is the addressing mode needed to access the operand to be tested, and relative addressing mode is implied for the branch destination.

## 7.3.1 Inherent Addressing Mode (INH)

In this addressing mode, operands needed to complete the instruction (if any) are located within CPU registers so the CPU does not need to access memory to get any operands.

# 7.3.2 Relative Addressing Mode (REL)

Relative addressing mode is used to specify the destination location for branch instructions. A signed 8-bit offset value is located in the memory location immediately following the opcode. During execution, if the branch condition is true, the signed offset is sign-extended to a 16-bit value and is added to the current contents of the program counter, which causes program execution to continue at the branch destination address.

## 7.3.3 Immediate Addressing Mode (IMM)

In immediate addressing mode, the operand needed to complete the instruction is included in the object code immediately following the instruction opcode in memory. In the case of a 16-bit immediate operand, the high-order byte is located in the next memory location after the opcode, and the low-order byte is located in the next memory location after that.

# 7.3.4 Direct Addressing Mode (DIR)

In direct addressing mode, the instruction includes the low-order eight bits of an address in the direct page (0x0000-0x00FF). During execution a 16-bit address is formed by concatenating an implied 0x00 for the high-order half of the address and the direct address from the instruction to get the 16-bit address where the desired operand is located. This is faster and more memory efficient than specifying a complete 16-bit address for the operand.



| Source                                                                                                          | Operation                                                                                                                                                                                                                                                                                                                                                                                          | dress<br>ode                                        | Object Code                                                                      | /cles                           | Cyc-by-Cyc                                       | Affect<br>on CCR |           |  |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------|--------------------------------------------------|------------------|-----------|--|
|                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                    | Ρq<br>Mq                                            |                                                                                  | Су                              | Details                                          | VH               | INZC      |  |
| SUB #opr8i<br>SUB opr8a<br>SUB opr16a<br>SUB oprx16,X<br>SUB oprx8,X<br>SUB ,X<br>SUB oprx16,SP<br>SUB oprx8,SP | Subtract<br>A $\leftarrow$ (A) – (M)                                                                                                                                                                                                                                                                                                                                                               | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 | A0 ii<br>B0 dd<br>C0 hh ll<br>D0 ee ff<br>E0 ff<br>F0<br>9E D0 ee ff<br>9E E0 ff | 2<br>3<br>4<br>3<br>3<br>5<br>4 | pp<br>rpp<br>prpp<br>rpp<br>rfp<br>pprpp<br>prpp | ↓-               | -\$\$\$   |  |
| SWI                                                                                                             | Software Interrupt<br>PC $\leftarrow$ (PC) + \$0001<br>Push (PCL); SP $\leftarrow$ (SP) - \$0001<br>Push (PCH); SP $\leftarrow$ (SP) - \$0001<br>Push (X); SP $\leftarrow$ (SP) - \$0001<br>Push (A); SP $\leftarrow$ (SP) - \$0001<br>Push (CCR); SP $\leftarrow$ (SP) - \$0001<br>I $\leftarrow$ 1;<br>PCH $\leftarrow$ Interrupt Vector High Byte<br>PCL $\leftarrow$ Interrupt Vector Low Byte | INH                                                 | 83                                                                               | 11                              | sssssvvfppp                                      |                  | 1         |  |
| ТАР                                                                                                             | Transfer Accumulator to CCR $CCR \leftarrow (A)$                                                                                                                                                                                                                                                                                                                                                   | INH                                                 | 84                                                                               | 1                               | р                                                | ¢¢               | ¢¢¢¢      |  |
| ТАХ                                                                                                             | Transfer Accumulator to X (Index Register Low) $X \leftarrow (A)$                                                                                                                                                                                                                                                                                                                                  | INH                                                 | 97                                                                               | 1                               | р                                                |                  |           |  |
| ТРА                                                                                                             | Transfer CCR to Accumulator $A \leftarrow (CCR)$                                                                                                                                                                                                                                                                                                                                                   | INH                                                 | 85                                                                               | 1                               | q                                                |                  |           |  |
| TST opr8a<br>TSTA<br>TSTX<br>TST oprx8,X<br>TST ,X<br>TST oprx8,SP                                              | Test for Negative or Zero (M) - \$00<br>(A) - \$00<br>(X) - \$00<br>(M) - \$00<br>(M) - \$00<br>(M) - \$00                                                                                                                                                                                                                                                                                         | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3D dd<br>4D<br>5D<br>6D ff<br>7D<br>9E 6D ff                                     | 4<br>1<br>4<br>3<br>5           | rfpp<br>p<br>rfpp<br>rfp<br>prfpp                | 0 —              | - \$ \$ - |  |
| тѕх                                                                                                             | Transfer SP to Index Reg.<br>H:X $\leftarrow$ (SP) + \$0001                                                                                                                                                                                                                                                                                                                                        | INH                                                 | 95                                                                               | 2                               | fp                                               |                  |           |  |
| ТХА                                                                                                             | Transfer X (Index Reg. Low) to Accumulator $A \leftarrow (X)$                                                                                                                                                                                                                                                                                                                                      | INH                                                 | 9F                                                                               | 1                               | q                                                |                  |           |  |

| Table 7-2 Instruction Set Summar | ry (Sheet 8 of 9) |
|----------------------------------|-------------------|
|----------------------------------|-------------------|



#### Chapter 7 Central Processor Unit (S08CPUV2)

| Source<br>Form | Operation                                                            | dress<br>lode | Object Code | /cles  | Cyc-by-Cyc<br>Details | Affect<br>on CCR |      |
|----------------|----------------------------------------------------------------------|---------------|-------------|--------|-----------------------|------------------|------|
|                |                                                                      | PA            |             | С<br>С |                       | VH               | INZC |
| тхѕ            | Transfer Index Reg. to SP SP $\leftarrow$ (H:X) – \$0001             | INH           | 94          | 2      | fp                    |                  |      |
| WAIT           | Enable Interrupts; Wait for Interrupt I bit $\leftarrow$ 0; Halt CPU | INH           | 8F          | 2+     | fp                    |                  | 0    |

Source Form: Everything in the source forms columns, *except expressions in italic characters*, is literal information which must appear in the assembly source file exactly as shown. The initial 3- to 5-letter mnemonic and the characters (# , () and +) are always a 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 direct-page address (\$00xx).

opr16a Any label or expression that evaluates to a 16-bit address.

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, used for indexed addressing.

rel Any label or expression that refers to an address that is within -128 to +127 locations from the start of the next instruction.

#### **Operation Symbols:**

| A | Accumulator |
|---|-------------|
|   |             |

- CCR Condition code register
- H Index register high byte
- M Memory location
- n Any bit
- opr Operand (one or two bytes)
- PC Program counter
- PCH Program counter high byte
- PCL Program counter low byte
- rel Relative program counter offset byte
- SP Stack pointer
- SPL Stack pointer low byte
- X Index register low byte
- & Logical AND
- Logical OR
- Logical EXCLUSIVE OR
- () Contents of
- + Add
- Subtract, Negation (two's complement)
- × Multiply
- ÷ Divide
- # Immediate value
- $\leftarrow \qquad \text{Loaded with} \qquad$
- : Concatenated with

#### CCR Bits:

- V Overflow bit
- H Half-carry bit
- I Interrupt mask
- N Negative bit
- Z Zero bit
- C Carry/borrow bit

#### Addressing Modes:

- DIR Direct addressing mode
- EXT Extended addressing mode
- IMM Immediate addressing mode
- INH Inherent addressing mode
- IX Indexed, no offset addressing mode
- IX1 Indexed, 8-bit offset addressing mode
- IX2 Indexed, 16-bit offset addressing mode
- IX+ Indexed, no offset, post increment addressing mode
- IX1+ Indexed, 8-bit offset, post increment addressing mode
- REL Relative addressing mode
- SP1 Stack pointer, 8-bit offset addressing mode
- SP2 Stack pointer 16-bit offset addressing mode

#### Cycle-by-Cycle Codes:

- f Free cycle. This indicates a cycle where the CPU does not require use of the system buses. An f cycle is always one cycle of the system bus clock and is always a read cycle.
- p Progryam fetch; read from next consecutive location in program memory
- r Read 8-bit operand
- s Push (write) one byte onto stack
- u Pop (read) one byte from stack
- v Read vector from \$FFxx (high byte first)
- w Write 8-bit operand

#### CCR Effects:

- \$\$ Set or cleared
- Not affected
- U Undefined



| Bit-Mani | nulation      | Branch                         |                     | Rea          | d-Modify-V | Vrite                         |                                | Cor   | ntrol                          | · /              |                                 | Register         | /Memory                       |                                 |                                |
|----------|---------------|--------------------------------|---------------------|--------------|------------|-------------------------------|--------------------------------|-------|--------------------------------|------------------|---------------------------------|------------------|-------------------------------|---------------------------------|--------------------------------|
| 00 5     | 10 5          | 20 2                           | 20 5                | 40 1         | 50 1       | 60 5                          | 70 4                           | 80 0  | 00 2                           | A0 2             | B0 2                            |                  |                               | E0 2                            | E0 2                           |
| BRSETO   | BSETO         |                                | NEG                 |              | NEGY       | NEG                           | NEG                            | BTI   | BGE                            | SUB              | SUB                             | SUB              | SUB                           | SUB                             | SUB                            |
| 3 DIB    | 2 DIR         | 2 BEI                          |                     |              |            | 2 111                         |                                | 1 INH | 2 BEI                          | 2 IMM            | 2 DIB                           | 3 EXT            | 3 122                         | 2 111                           | 1 1                            |
| 0 5      | 11 5          | 21 2                           | 21 5                | 41 4         | 51 4       | 61 5                          | 71 5                           | 91 6  | 01 2                           | A1 2             | E DIIT                          |                  |                               | E1 2                            | F1 2                           |
|          |               | BBN                            |                     |              |            | CBEO                          |                                | °'ets | BIT                            |                  |                                 | CMP <sup>4</sup> | CMP <sup>4</sup>              |                                 | CMP                            |
| 3 DIR    |               | 2 BEI                          | 3 DIR               | 3 IMM        | 3 IMM      | 3 181+                        |                                | 1 INH | 2 BEI                          | 2 IMM            |                                 | 3 EXT            | 3 122                         | 2 181                           | 1 1                            |
| 02 5     | 10 5          | 2 1122                         | 30 DIT              | 40 5         | 5 11/11/1  | 60 1                          | Z 1/(+<br>70 1                 | 00 E. | 00 0                           | A0 0             |                                 |                  | D2 4                          | E0 0                            | E0 0                           |
| DOCET1   | DOET1         |                                |                     | 42 5<br>MUII |            |                               |                                |       | <sup>92</sup> PGT              |                  |                                 |                  |                               | <sup>6</sup> 680°               | ີ ອຸ <u>ມ</u> ດັ່              |
|          |               |                                |                     |              |            |                               |                                |       | 2 001                          | 2 100            | 2 00                            | 2 EVT            | 3 172                         | 2 111                           | 1 1                            |
| 02 5     | 10 5          | 2 1122                         | 22 E                | 42 1         | EQ 1       | 62 5                          | 70 4                           | 00 11 | 02 2                           | A2 0             |                                 | C2 4             | D2 4                          | E2 2                            | E2 2                           |
|          |               | 23 3                           | 33 COM              |              |            | °COM <sup>°</sup>             | $^{\prime 3}$ $^{\prime 4}$    | °3 11 | 93 B E                         |                  | <sup>D3</sup> CPV <sup>3</sup>  |                  |                               | <sup>E3</sup> CDV <sup>3</sup>  | <sup>r3</sup> CPV <sup>3</sup> |
|          |               | 2 DE3                          |                     |              |            | 2 111                         |                                |       |                                |                  |                                 |                  |                               |                                 |                                |
| 04 5     | 14 5          | 2 1122                         | 2 011               | 44 4         | F 4 1      | 2 1/1                         | 74 4                           | 0.4 1 | 2 1122                         | 2 1101101        |                                 |                  | 5 IX2                         |                                 | T 1A                           |
| BDSET2   | 14 5<br>BOETO | <sup>24</sup> BCC <sup>3</sup> | <sup>34</sup> 1 C D |              |            |                               | <sup>4</sup> 100 <sup>4</sup>  |       | <sup>94</sup> TVC <sup>2</sup> |                  |                                 |                  |                               |                                 |                                |
|          |               |                                |                     |              |            | 2 171                         |                                |       | 1 111                          |                  |                                 |                  |                               | 2 111                           |                                |
| 05 5     | 15 E          | 2 1122                         | 2 011               | 45 2         | EE 4       | 65 2                          | 75 5                           | 05 1  | 05 0                           | AE 0             |                                 |                  |                               | E 2                             | EE 2                           |
|          |               |                                |                     |              |            | CDUY                          | CDUY                           |       | <sup>95</sup> Tev <sup>2</sup> |                  |                                 |                  |                               |                                 |                                |
| 3 DIR    |               | 2 BEI                          | 2 DIR               | 3 100        |            | 3 1MM                         |                                | 1 101 | 1 INH                          | 2 1MM            |                                 | 3 FYT            | 3 182                         | 2 181                           | 1 1                            |
|          | 16 E          | 2 1122                         | 2 011               | 46 1         | EG 1       | 66 5                          | 76 4                           | 06 0  | 06 5                           | AG 0             |                                 |                  |                               | E6 2                            | FG 2                           |
| BBSET3   | BSET3         | BNE                            | <sup>30</sup> BOB   | BOBA         | BOBY       | <sup>°</sup> BOB              | <sup>(°</sup> BOB <sup>4</sup> |       | STHY                           |                  |                                 |                  |                               |                                 |                                |
| 3 DIR    |               | 2 BEI                          | 2 DIR               |              |            | 2 181                         | 1 18                           |       | 3 FXT                          | 2 IMM            |                                 | 3 FYT            | 3 122                         | 2 181                           |                                |
| 07 5     | 17 5          | 27 2                           | 27 5                | 47 1         | 57 1       | 67 5                          | 77 4                           | 97 2  | 07 1                           | A7 2             | E DIII                          |                  | D7 4                          | E7 2                            | F7 2                           |
|          |               |                                | 3/ ASB              |              | ASBY       | °′ ^ CR                       | ″^SR                           | °/    | "TAY                           |                  | <sup>р</sup> ′ ста <sup>3</sup> | С/ STA 4         | <sup>0</sup> ста <sup>4</sup> | <sup>с</sup> ′ 9та <sup>3</sup> | Г′ <u>ста</u> <sup>2</sup>     |
| 3 DIR    | 2 DIR         | 2 BEI                          | 2 DIR               | 1 INH        |            | 2 111                         |                                |       | 1 INH                          | 2 IMM            | 2 DIR                           | 3 FXT            | 3 122                         | 2 111                           |                                |
| 09 5     | 19 5          | 29 2                           | 29 5                | 49 1         | 59 1       | 69 5                          | 79 /                           | 99 3  | 09 1                           | A9 2             | E 0111                          |                  |                               | E9 2                            | E9 2                           |
| BBSET4   | BSET4         | BHCC                           |                     |              | ับราม      | i si j                        | (° I SI <sup>-</sup>           |       | ິດເດ່                          | <sup>C</sup> EOR | FOR                             | FOR              | FOR                           | FOR                             | FOR                            |
| 3 DIR    | 2 DIB         | 2 BEI                          | 2 DIB               | 1 INH        | 1 INH      | 2 IX1                         |                                | 1 INH | 1 INH                          | 2 IMM            | 2 DIB                           | 3 FXT            | 3 IX2                         | 2 IX1                           |                                |
| 09 5     | 19 5          | 20 3                           | 39 5                | /0 1         | 59 1       | 69 5                          | 79 /                           | 80 2  | 00 1                           | Δ <u>Ω</u> 2     | B9 3                            | C9 /             |                               | E9 3                            | F9 3                           |
| BRCI B4  | BCI B4        | BHCS                           | <sup>3</sup> ΒΟΙ 3  |              | BOI X      | <sup>°</sup> ΒΟΙ <sup>°</sup> | Í BOI                          | PSHY  | SEC                            |                  | _<br>⊃DU                        |                  |                               |                                 | `⊿⊓Cັ                          |
| 3 DIR    | 2 DIR         | 2 BEI                          | 2 DIB               | 1 INH        | 1 INH      | 2 111                         |                                | 1 INH | 1 INH                          | 2 IMM            | 2 DIB                           | 3 FXT            | 3 IX2                         | 2 IX1                           | 1 IX                           |
| 04 5     | 14 5          | 24 3                           | 34 5                | <i>1</i> Δ 1 | 54 1       | 64 5                          | 74 /                           | 84 3  | QA 1                           |                  | BA 3                            |                  |                               | EA 3                            | FA 3                           |
| BBSET5   | BSETS         | <sup>2</sup> RPI               | DEC                 | DECA         | DECX       | DEC                           | "DEC                           | PIIIH | ° cu '                         |                  | _<br>OB⊅                        | OBA T            | OBA                           | Γ́ORΔŬ                          | OBA                            |
| 3 DIB    | 2 DIR         | 2 BEI                          | 2 DIR               | 1 INH        | 1 INH      | 2 IX1                         | 1 IX                           | 1 INH | 1 INH                          | 2 IMM            | 2 DIB                           | 3 FXT            | 3 IX2                         | 2 IX1                           | 1 IX                           |
| 0B 5     | 1B 5          | 2B 3                           | 3B 7                | 4B 4         | 5B /       | 6B 7                          | 7B 6                           | 8B 2  | 9B 1                           | ΔR 2             | BB 3                            | CB 4             |                               | FB 3                            | FB 3                           |
| BBCI B5  | BCI BS        | BMI                            |                     |              |            |                               |                                | PSHH  | SEL                            |                  | _<br>ADD _                      |                  |                               | _<br>AUD _                      |                                |
| 3 DIR    | 2 DIB         | 2 BEI                          | 3 DIB               | 2 INH        | 2 INH      | 3 IX1                         | 2 1X                           | 1 INH | 1 INH                          | 2 IMM            | 2 DIB                           | 3 FXT            | 3 IX2                         | 2 IX1                           | 1 IX                           |
| 00 5     | 10 5          | 20 3                           | 30 5                | 40 1         | 50 1       | 60 5                          | 70 /                           | 80 1  | 90 1                           |                  | BC 3                            | CC 4             |                               | FC 3                            | FC 3                           |
| BRSET    | BSET          | BMC                            | INC                 | INCA         | INCX       | INC                           | Í INC                          | CLBH  | BSP                            |                  | .IMP                            | IMP              | IMP                           | IMP                             | IMP                            |
| 3 DIR    | 2 DIR         | 2 BEL                          | 2 DIR               | 1 INH        | 1 INH      | 2 IX1                         | 1 IX                           | 1 INH | 1 INH                          |                  | 2 DIR                           | 3 EXT            | 3 IX2                         | 2 IX1                           | 1 IX                           |
| 0D 5     | 1D 5          | 2D 3                           | 3D 4                | 4D 1         | 5D 1       | 6D 4                          | 7D 3                           |       | 9D 1                           | AD 5             | BD 5                            | CD 6             |                               | ED 5                            | FD 5                           |
| BRCI B6  | BCI B6        | BMS                            | TST                 | TSTA         | TSTX       | TST                           | TST                            |       | NOP                            | BSB              | <b>JSB</b>                      | <b>JSB</b>       | <b>JSB</b>                    | <b>JSB</b>                      | . JSB                          |
| 3 DIR    | 2 DIR         | 2 REL                          | 2 DIR               | 1 INH        | 1 INH      | 2 IX1                         | 1 IX                           |       | 1 INH                          | 2 REL            | 2 DIR                           | 3 EXT            | 3 IX2                         | 2 IX1                           | 1 IX                           |
| 0F 5     | 1E 5          | 2F 3                           | 3E 6                | 4F 5         | 5E 5       | 6F 4                          | 7E 5                           | 8F 2+ | 9F                             | AF 2             | BE 3                            | CF 4             | DF 4                          | FF 3                            | FF 3                           |
| BRSET7   | BSET7         | BIL                            | CPHX                | MOV          | тмол       | MOV                           | MOV                            | STOP  | Page 2                         |                  | LDX                             | LDX              |                               | LDX                             | LDX                            |
| 3 DIR    | 2 DIR         | 2 REL                          | 3 EXT               | 3 DD         | 2 DIX+     | 3 IMD                         | 2 IX+D                         | 1 INH | ·                              | 2 IMM            | 2 DIR                           | 3 EXT            | 3 IX2                         | 2 IX1                           | 1 IX                           |
| 0F 5     | 1F 5          | 2F 3                           | 3F 5                | 4F 1         | 5F 1       | 6F 5                          | 7F 4                           | 8F 2+ | 9F 1                           | AF 2             | BF 3                            | CF 4             | DF 4                          | EF 3                            | FF 2                           |
| BRCLR7   | BCLR7         | BIH                            | CLR                 | CLRA         | CLRX       | CLR                           | CLR                            | WAIT  | TXA                            | AIX              | STX                             | STX              | STX                           | STX                             | STX                            |
| 3 DIR    | 2 DIR         | 2 REL                          | 2 DIR               | 1 INH        | 1 INH      | 2 IX1                         | 1 IX                           | 1 INH | 1 INH                          | 2 IMM            | 2 DIR                           | 3 EXT            | 3 IX2                         | 2 IX1                           | 1 IX                           |
|          |               |                                |                     |              |            |                               |                                |       |                                |                  |                                 |                  |                               |                                 |                                |

#### Table 7-3. Opcode Map (Sheet 1 of 2)

| Inherent   |
|------------|
| Immediate  |
| Direct     |
| Extended   |
| DIR to DIR |
| IX+ to DIR |
|            |

Relative Indexed, No Offset Indexed, 8-Bit Offset Indexed, 16-Bit Offset IMM to DIR DIR to IX+ REL IX IX1 IX2 IMD DIX+

SP1 SP2 IX+

Stack Pointer, 8-Bit Offset Stack Pointer, 16-Bit Offset Indexed, No Offset with Post Increment Indexed, 1-Byte Offset with Post Increment IX1+

MC9S08JM16 Series Data Sheet, Rev. 2

Opcode in Hexadecimal F0 3 SUB Instruction Mnemonic 1 IX Addressing Mode Number of Bytes



#### Keyboard Interrupt (KBI) ModuleChapter 8 Keyboard Interrupt (S08KBIV2)



4. Pin contains integrated pullup device.

5. When pin functions as KBI (KBIPEn = 1) and associated pin is configured to enable the pullup device, KBEDGn can be used to reconfigure the pullup as a pulldown device.

#### Figure 8-1. MC9S08JM16 Series Block Diagram Highlighting KBI Block and Pins

MC9S08JM16 Series Data Sheet, Rev. 2



## 9.1.3 Features

The ACMP has the following features:

- Full rail to rail supply operation.
- Selectable interrupt on rising edge, falling edge, or either rising or falling edges of comparator output.
- Option to compare to fixed internal bandgap reference voltage.
- Option to allow comparator output to be visible on a pin, ACMPO.
- Can operate in stop3 mode

## 9.1.4 Modes of Operation

This section defines the ACMP operation in wait, stop and background debug modes.

### 9.1.4.1 ACMP in Wait Mode

The ACMP continues to run in wait mode if enabled before executing the WAIT instruction. Therefore, the ACMP can be used to bring the MCU out of wait mode if the ACMP interrupt, ACIE is enabled. For lowest possible current consumption, the ACMP must be disabled by software if not required as an interrupt source during wait mode.

## 9.1.4.2 ACMP in Stop Modes

### 9.1.4.2.1 Stop3 Mode Operation

The ACMP continues to operate in stop3 mode if enabled and compare operation remains active. If ACOPE is enabled, comparator output operates as in the normal operating mode and comparator output is placed onto the external pin. The MCU is brought out of stop when a compare event occurs and ACIE is enabled; ACF flag sets accordingly.

If stop is exited with a reset, the ACMP will be put into its reset state.

### 9.1.4.2.2 Stop2 and Stop1 Mode Operation

During either stop2 and stop1 mode, the ACMP module will be fully powered down. Upon wake-up from stop2 or stop1 mode, the ACMP module will be in the reset state.

## 9.1.4.3 ACMP in Active Background Mode

When the microcontroller is in active background mode, the ACMP will continue to operate normally.

## 9.1.5 Block Diagram

The block diagram for the Analog Comparator module is shown Figure 9-2.

MC9S08JM16 Series Data Sheet, Rev. 2



Chapter 10 Analog-to-Digital Converter (S08ADC12V1)

| ADCH  | Channel | Input             | Pin Control | ADCH  | Channel            | Input | Pin Control |
|-------|---------|-------------------|-------------|-------|--------------------|-------|-------------|
| 01111 | AD15    | V <sub>REFL</sub> | ADPC15      | 11111 | module<br>disabled | None  | N/A         |

| Table 10-1. Al | DC Channel | Assignment | (continued) | ) |
|----------------|------------|------------|-------------|---|
|                |            | /.ee.g     |             | / |

<sup>1</sup> For more information, see Section 10.1.1.5, "Temperature Sensor."

### NOTE

Selecting the internal bandgap channel requires BGBE =1 in SPMSC1, see Section 5.7.7, "System Power Management Status and Control 1 Register (SPMSC1)." For value of bandgap voltage reference see Appendix A.8, "Analog Comparator (ACMP) Electricals."

## 10.1.1.2 Alternate Clock

The ADC module is capable of performing conversions using the MCU bus clock, the bus clock divided by two, the local asynchronous clock (ADACK) within the module, or the alternate clock (ALTCLK). The ALTCLK on this device is MCGERCLK.

The selected clock source must run at a frequency such that the ADC conversion clock (ADCK) runs at a frequency within its specified range ( $f_{ADCK}$ ) after being divided down from the ALTCLK input as determined by the ADIV bits.

ALTCLK is active while the MCU is in wait mode provided the conditions described above are met. This allows ALTCLK to be used as the conversion clock source for the ADC while the MCU is in wait mode.

ALTCLK cannot be used as the ADC conversion clock source while the MCU is in stop3.

### 10.1.1.3 Hardware Trigger

The RTC on this device can be enabled as a hardware trigger for the ADC module by setting the ADCSC2[ADTRG] bit. When enabled, the ADC will be triggered every time RTCINT matches RTCMOD. The RTC interrupt does not have to be enabled to trigger the ADC.

The RTC can be configured to cause a hardware trigger in MCU run, wait, and stop3.

## 10.1.1.4 Analog Pin Enables

The ADC on MC9S08JM16 series contain only two analog pin enable registers, APCTL1 and APCTL2.

## 10.1.1.5 Temperature Sensor

The ADC module includes a temperature sensor whose output is connected to one of the ADC analog channel inputs. Equation 10-1 provides an approximate transfer function of the temperature sensor.

Temp = 
$$25 - ((V_{TEMP} - V_{TEMP25}) \div m)$$
 Eqn. 10-1

where:

- V<sub>TEMP</sub> is the voltage of the temperature sensor channel at the ambient temperature.



# 10.2.1 Analog Power (V<sub>DDAD</sub>)

The ADC analog portion uses  $V_{DDAD}$  as its power connection. In some packages,  $V_{DDAD}$  is connected internally to  $V_{DD}$ . If externally available, connect the  $V_{DDAD}$  pin to the same voltage potential as  $V_{DD}$ . External filtering may be necessary to ensure clean  $V_{DDAD}$  for good results.

## 10.2.2 Analog Ground (V<sub>SSAD</sub>)

The ADC analog portion uses  $V_{SSAD}$  as its ground connection. In some packages,  $V_{SSAD}$  is connected internally to  $V_{SS}$ . If externally available, connect the  $V_{SSAD}$  pin to the same voltage potential as  $V_{SS}$ .

## 10.2.3 Voltage Reference High (V<sub>REFH</sub>)

 $V_{REFH}$  is the high reference voltage for the converter. In some packages,  $V_{REFH}$  is connected internally to  $V_{DDAD}$ . If externally available,  $V_{REFH}$  may be connected to the same potential as  $V_{DDAD}$  or may be driven by an external source between the minimum  $V_{DDAD}$  spec and the  $V_{DDAD}$  potential ( $V_{REFH}$  must never exceed  $V_{DDAD}$ ).

## 10.2.4 Voltage Reference Low (V<sub>REFL</sub>)

 $V_{REFL}$  is the low-reference voltage for the converter. In some packages,  $V_{REFL}$  is connected internally to  $V_{SSAD}$ . If externally available, connect the  $V_{REFL}$  pin to the same voltage potential as  $V_{SSAD}$ .

## 10.2.5 Analog Channel Inputs (ADx)

The ADC module supports up to 28 separate analog inputs. An input is selected for conversion through the ADCH channel select bits.

# **10.3 Register Definition**

These memory-mapped registers control and monitor operation of the ADC:

- Status and control register, ADCSC1
- Status and control register, ADCSC2
- Data result registers, ADCRH and ADCRL
- Compare value registers, ADCCVH and ADCCVL
- Configuration register, ADCCFG
- Pin control registers, APCTL1, APCTL2, APCTL3

## 10.3.1 Status and Control Register 1 (ADCSC1)

This section describes the function of the ADC status and control register (ADCSC1). Writing ADCSC1 aborts the current conversion and initiates a new conversion (if the ADCH bits are equal to a value other than all 1s).



| Field       | Description                                                                                                                                    |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 3<br>ADPC19 | ADC Pin Control 19. ADPC19 controls the pin associated with channel AD19.<br>0 AD19 pin I/O control enabled<br>1 AD19 pin I/O control disabled |
| 2<br>ADPC18 | ADC Pin Control 18. ADPC18 controls the pin associated with channel AD18.<br>0 AD18 pin I/O control enabled<br>1 AD18 pin I/O control disabled |
| 1<br>ADPC17 | ADC Pin Control 17. ADPC17 controls the pin associated with channel AD17.<br>0 AD17 pin I/O control enabled<br>1 AD17 pin I/O control disabled |
| 0<br>ADPC16 | ADC Pin Control 16. ADPC16 controls the pin associated with channel AD16.<br>0 AD16 pin I/O control enabled<br>1 AD16 pin I/O control disabled |

Table 10-12. APCTL3 Register Field Descriptions (continued)

# 10.4 Functional Description

The ADC module is disabled during reset or when the ADCH bits are all high. The module is idle when a conversion has completed and another conversion has not been initiated. When idle, the module is in its lowest power state.

The ADC can perform an analog-to-digital conversion on any of the software selectable channels. In 12-bit and 10-bit mode, the selected channel voltage is converted by a successive approximation algorithm into a 12-bit digital result. In 8-bit mode, the selected channel voltage is converted by a successive approximation algorithm into a 9-bit digital result.

When the conversion is completed, the result is placed in the data registers (ADCRH and ADCRL). In 10-bit mode, the result is rounded to 10 bits and placed in the data registers (ADCRH and ADCRL). In 8-bit mode, the result is rounded to 8 bits and placed in ADCRL. The conversion complete flag (COCO) is then set and an interrupt is generated if the conversion complete interrupt has been enabled (AIEN = 1).

The ADC module has the capability of automatically comparing the result of a conversion with the contents of its compare registers. The compare function is enabled by setting the ACFE bit and operates with any of the conversion modes and configurations.

# 10.4.1 Clock Select and Divide Control

One of four clock sources can be selected as the clock source for the ADC module. This clock source is then divided by a configurable value to generate the input clock to the converter (ADCK). The clock is selected from one of the following sources by means of the ADICLK bits.

- The bus clock, which is equal to the frequency at which software is executed. This is the default selection following reset.
- The bus clock divided by two. For higher bus clock rates, this allows a maximum divide by 16 of the bus clock.
- ALTCLK, as defined for this MCU (See module section introduction).

MC9S08JM16 Series Data Sheet, Rev. 2



message characters. At the end of a message, or at the beginning of the next message, all receivers automatically force RWU to 0 so all receivers wake up in time to look at the first character(s) of the next message.

### 14.3.3.2.1 Idle-Line Wakeup

When WAKE = 0, the receiver is configured for idle-line wakeup. In this mode, RWU is cleared automatically when the receiver detects a full character time of the idle-line level. The M control bit selects 8-bit or 9-bit data mode that determines how many bit times of idle are needed to constitute a full character time (10 or 11 bit times because of the start and stop bits).

When RWU is one and RWUID is zero, the idle condition that wakes up the receiver does not set the IDLE flag. The receiver wakes up and waits for the first data character of the next message which will set the RDRF flag and generate an interrupt if enabled. When RWUID is one, any idle condition sets the IDLE flag and generates an interrupt if enabled, regardless of whether RWU is zero or one.

The idle-line type (ILT) control bit selects one of two ways to detect an idle line. When ILT = 0, the idle bit counter starts after the start bit so the stop bit and any logic 1s at the end of a character count toward the full character time of idle. When ILT = 1, the idle bit counter does not start until after a stop bit time, so the idle detection is not affected by the data in the last character of the previous message.

## 14.3.3.2.2 Address-Mark Wakeup

When WAKE = 1, the receiver is configured for address-mark wakeup. In this mode, RWU is cleared automatically when the receiver detects a logic 1 in the most significant bit of a received character (eighth bit in M = 0 mode and ninth bit in M = 1 mode).

Address-mark wakeup allows messages to contain idle characters but requires that the MSB be reserved for use in address frames. The logic 1 MSB of an address frame clears the RWU bit before the stop bit is received and sets the RDRF flag. In this case the character with the MSB set is received even though the receiver was sleeping during most of this character time.

# 14.3.4 Interrupts and Status Flags

The SCI system has three separate interrupt vectors to reduce the amount of software needed to isolate the cause of the interrupt. One interrupt vector is associated with the transmitter for TDRE and TC events. Another interrupt vector is associated with the receiver for RDRF, IDLE, RXEDGIF and LBKDIF events, and a third vector is used for OR, NF, FE, and PF error conditions. Each of these ten interrupt sources can be separately masked by local interrupt enable masks. The flags can still be polled by software when the local masks are cleared to disable generation of hardware interrupt requests.

The SCI transmitter has two status flags that optionally can generate hardware interrupt requests. Transmit data register empty (TDRE) indicates when there is room in the transmit data buffer to write another transmit character to SCIxD. If the transmit interrupt enable (TIE) bit is set, a hardware interrupt will be requested whenever TDRE = 1. Transmit complete (TC) indicates that the transmitter is finished transmitting all data, preamble, and break characters and is idle with TxD at the inactive level. This flag is often used in systems with modems to determine when it is safe to turn off the modem. If the transmit complete interrupt will be requested whenever TC = 1.





#### Figure 15-6. SPI Control Register 2 (SPIxC2)

#### Table 15-3. SPIxC2 Register Field Descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>SPMIE   | <ul> <li>SPI Match Interrupt Enable — This is the interrupt enable for the SPI receive data buffer hardware match (SPMF) function.</li> <li>Interrupts from SPMF inhibited (use polling).</li> <li>When SPMF = 1, requests a hardware interrupt.</li> </ul>                                                                                                                                                                                                                                                                                                  |
| 6<br>SPIMODE | <ul> <li>SPI 8- or 16-bit Mode — This bit allows the user to select either an 8-bit or 16-bit SPI data transmission length.</li> <li>In master mode, a change of this bit will abort a transmission in progress, force the SPI system into idle state, and reset all status bits in the SPIxS register. Refer to section Section 15.4.4, "Data Transmission Length," for details.</li> <li>8-bit SPI shift register, match register, and buffers.</li> <li>16-bit SPI shift register, match register, and buffers.</li> </ul>                                |
| 4<br>MODFEN  | Master Mode-Fault Function EnableWhen the SPI is configured for slave mode, this bit has no meaning or<br>effect. (The SS pin is the slave select input.) In master mode, this bit determines how the SS pin is used (refer to<br>Table 15-2 for details)0Mode fault function disabled, master SS pin reverts to general-purpose I/O not controlled by SPI<br>11Mode fault function enabled, master SS pin acts as the mode fault input or the slave select output                                                                                           |
| 3<br>BIDIROE | <b>Bidirectional Mode Output Enable</b> — When bidirectional mode is enabled by SPI pin control 0 (SPC0) = 1,<br>BIDIROE determines whether the SPI data output driver is enabled to the single bidirectional SPI I/O pin.<br>Depending on whether the SPI is configured as a master or a slave, it uses either the MOSI (MOMI) or MISO<br>(SISO) pin, respectively, as the single SPI data I/O pin. When SPC0 = 0, BIDIROE has no meaning or effect.<br>0 Output driver disabled so SPI data I/O pin acts as an input<br>1 SPI I/O pin enabled as an output |
| 1<br>SPISWAI | <ul> <li>SPI Stop in Wait Mode — This bit is used for power conservation while in wait.</li> <li>0 SPI clocks continue to operate in wait mode</li> <li>1 SPI clocks stop when the MCU enters wait mode</li> </ul>                                                                                                                                                                                                                                                                                                                                           |
| 0<br>SPC0    | <ul> <li>SPI Pin Control 0 — This bit enables bidirectional pin configurations as shown in Table 15-4.</li> <li>0 SPI uses separate pins for data input and data output.</li> <li>1 SPI configured for single-wire bidirectional operation.</li> </ul>                                                                                                                                                                                                                                                                                                       |



# Chapter 17 Universal Serial Bus Device Controller (S08USBV1)

# 17.1 Introduction

This chapter describes an universal serial bus device controller (S08USBV1) module that is based on the Universal Serial Bus Specification Rev 2.0. The USB bus is designed to replace existing bus interfaces such as RS-232, PS/2, and IEEE 1284 for PC peripherals.

The S08USBV1 module provides a single-chip solution for full-speed (12 Mbps) USB device applications, and integrates the required transceiver with Serial Interface Engine (SIE), 3.3 V regulator, Endpoint RAM and other control logics.

## 17.1.1 Clocking Requirements

The S08USBV1 requires two clock sources, the 24 MHz bus clock and a 48 MHz reference clock. The 48 MHz clock is sourced directly from MCGOUT. To achieve the 48 MHz clock rate, the MCG must be configured properly for PLL engaged external (PEE) mode with an external crystal.

For USB operation, examples of MCG configuration using PEE mode include:

- 2 MHz crystal RDIV = 000 and VDIV = 0110
- 4 MHz crystal RDIV = 001 and VDIV = 0110

## 17.1.2 Current Consumption in USB Suspend

In USB suspend mode, the S08USBV1 current consumption is limited to 500  $\mu$ A. When the USB device goes into suspend mode, the firmware typically enters stop3 to meet the USB suspend requirements on current consumption.

### NOTE

Enabling LVD increases current consumption in stop3. Consequently, when trying to satisfy USB suspend requirements, disabling LVD before entering stop3.

# 17.1.3 3.3 V Regulator

If using an external 3.3 V regulator as an input to  $V_{USB33}$  (only when USBVREN = 0), the supply voltage,  $V_{DD}$ , must not fall below the input voltage at the  $V_{USB33}$  pin. If using the internal 3.3 V regulator (USBVREN = 1), do not connect an external supply to the  $V_{USB33}$  pin. In this case,  $V_{DD}$  must fall between 3.9 V and 5.5 V for the internal 3.3 V regulator to operate correctly.



Chapter 17 Universal Serial Bus Device Controller (S08USBV1)



4. Pin contains integrated pullup device.

5. When pin functions as KBI (KBIPEn = 1) and associated pin is configured to enable the pullup device, KBEDGn can be used to reconfigure the pullup as a pulldown device.

#### Figure 17-1. MC9S08JM16 Series Block Diagram Highlighting USB Blocks and Pins

MC9S08JM16 Series Data Sheet, Rev. 2



## 17.1.4 Features

Features of the USB module include:

- USB 2.0 compliant
  - 12 Mbps full-speed (FS) data rate
  - USB data control logic:
    - Packet identification and decoding/generation
    - CRC generation and checking
    - NRZI (non-return-to-zero inverted) encoding/decoding
    - Bit-stuffing
    - Sync detection
    - End-of-packet detection
- Seven USB endpoints
  - Bidirectional endpoint 0
  - Six unidirectional data endpoints configurable as interrupt, bulk, or isochronous
  - Endpoints 5 and 6 support double-buffering
- USB RAM
  - 256 bytes of buffer RAM shared between system and USB module
  - RAM may be allocated as buffers for USB controller or extra system RAM resource
- USB reset options
  - USB module reset generated by MCU
  - Bus reset generated by the host, which triggers a CPU interrupt
- Suspend and resume operations with remote wakeup support
- Transceiver features
  - Converts USB differential voltages to digital logic signal levels
- On-chip USB pullup resistor
- On-chip 3.3 V regulator

## 17.1.5 Modes of Operation

#### Table 17-2. Operating Modes

| Mode  | Description                                                                                                                                                                                                             |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stop1 | USB module is not functional. Before entering stop1, the internal USB voltage regulator and USB transceiver enter shutdown mode; therefore, the USB voltage regulator and USB transceiver must be disabled by firmware. |
| Stop2 | USB module is not functional. Before entering stop2, the internal USB voltage regulator and USB transceiver enter shutdown mode; therefore, the USB voltage regulator and USB transceiver must be disabled by firmware. |

| USB RAM<br>Offset | USB RAM Description of Contents        |                         |  |
|-------------------|----------------------------------------|-------------------------|--|
| 0x00              |                                        | Endpoint 0 IN           |  |
|                   |                                        | Endpoint 0, OUT         |  |
|                   | BDT                                    | Endpoint 1              |  |
|                   |                                        | Endpoint 2              |  |
|                   |                                        | Endpoint 3              |  |
|                   |                                        | Endpoint 4              |  |
|                   |                                        | Endpoint 5, Buffer EVEN |  |
|                   |                                        | Endpoint 5, Buffer ODD  |  |
|                   |                                        | Endpoint 6, Buffer EVEN |  |
| 0x1D              |                                        | Endpoint 6, Buffer ODD  |  |
| 0x1E              | RESERVED                               |                         |  |
| 0x1F              | RESERVED                               |                         |  |
| 0x20              | USB RAM available for endpoint buffers |                         |  |
| 0xFF              |                                        |                         |  |

#### Table 17-21. USB RAM Organization

When the USB module receives a USB token on an enabled endpoint, it interrogates the BDT. The USB module reads the corresponding endpoint BD entry and determines if it owns the BD and corresponding data buffer.

## 17.4.2.3 Buffer Descriptor Formats

The buffer descriptors (BDs) are groups of registers that provide endpoint buffer control information for the USB module and the MCU. The BDs have different meanings based on who is reading the BD in memory.

The USB module uses the data stored in the BDs to determine:

- Who owns the buffer in system memory
- Data0 or Data1 PID
- Release Own upon packet completion
- Data toggle synchronization enable
- How much data to be transmitted or received
- Where the buffer resides in the buffer RAM.

The microcontroller uses the data stored in the BDs to determine:

- Who owns the buffer in system memory
- Data0 or Data1 PID
- The received TOKEN PID



#### **Development Support**

the host must perform ((8 - CNT) - 1) dummy reads of the FIFO to advance it to the first significant entry in the FIFO.

In most trigger modes, the information stored in the FIFO consists of 16-bit change-of-flow addresses. In these cases, read DBGFH then DBGFL to get one coherent word of information out of the FIFO. Reading DBGFL (the low-order byte of the FIFO data port) causes the FIFO to shift so the next word of information is available at the FIFO data port. In the event-only trigger modes (see Section 18.3.5, "Trigger Modes"), 8-bit data information is stored into the FIFO. In these cases, the high-order half of the FIFO (DBGFH) is not used and data is read out of the FIFO by simply reading DBGFL. Each time DBGFL is read, the FIFO is shifted so the next data value is available through the FIFO data port at DBGFL.

In trigger modes where the FIFO is storing change-of-flow addresses, there is a delay between CPU addresses and the input side of the FIFO. Because of this delay, if the trigger event itself is a change-of-flow address or a change-of-flow address appears during the next two bus cycles after a trigger event starts the FIFO, it will not be saved into the FIFO. In the case of an end-trace, if the trigger event is a change-of-flow, it will be saved as the last change-of-flow entry for that debug run.

The FIFO can also be used to generate a profile of executed instruction addresses when the debugger is not armed. When ARM = 0, reading DBGFL causes the address of the most-recently fetched opcode to be saved in the FIFO. To use the profiling feature, a host debugger would read addresses out of the FIFO by reading DBGFH then DBGFL at regular periodic intervals. The first eight values would be discarded because they correspond to the eight DBGFL reads needed to initially fill the FIFO. Additional periodic reads of DBGFH and DBGFL return delayed information about executed instructions so the host debugger can develop a profile of executed instruction addresses.

## 18.3.3 Change-of-Flow Information

To minimize the amount of information stored in the FIFO, only information related to instructions that cause a change to the normal sequential execution of instructions is stored. With knowledge of the source and object code program stored in the target system, an external debugger system can reconstruct the path of execution through many instructions from the change-of-flow information stored in the FIFO.

For conditional branch instructions where the branch is taken (branch condition was true), the source address is stored (the address of the conditional branch opcode). Because BRA and BRN instructions are not conditional, these events do not cause change-of-flow information to be stored in the FIFO.

Indirect JMP and JSR instructions use the current contents of the H:X index register pair to determine the destination address, so the debug system stores the run-time destination address for any indirect JMP or JSR. For interrupts, RTI, or RTS, the destination address is stored in the FIFO as change-of-flow information.

# 18.3.4 Tag vs. Force Breakpoints and Triggers

Tagging is a term that refers to identifying an instruction opcode as it is fetched into the instruction queue, but not taking any other action until and unless that instruction is actually executed by the CPU. This distinction is important because any change-of-flow from a jump, branch, subroutine call, or interrupt causes some instructions that have been fetched into the instruction queue to be thrown away without being executed.