# E·XFL

### NXP USA Inc. - MC908GR32AMFUE Datasheet



#### 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             | Not For New Designs                                                    |
|----------------------------|------------------------------------------------------------------------|
| Core Processor             | HC08                                                                   |
| Core Size                  | 8-Bit                                                                  |
| Speed                      | 8MHz                                                                   |
| Connectivity               | SCI, SPI                                                               |
| Peripherals                | LVD, POR, PWM                                                          |
| Number of I/O              | 53                                                                     |
| Program Memory Size        | 32KB (32K x 8)                                                         |
| Program Memory Type        | FLASH                                                                  |
| EEPROM Size                | -                                                                      |
| RAM Size                   | 1.5K x 8                                                               |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                                              |
| Data Converters            | A/D 24x10b                                                             |
| Oscillator Type            | Internal                                                               |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                     |
| Mounting Type              | Surface Mount                                                          |
| Package / Case             | 64-QFP                                                                 |
| Supplier Device Package    | 64-QFP (14x14)                                                         |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc908gr32amfue |

Email: info@E-XFL.COM

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



#### Input/Output (I/O) Section

| Addr.                                                      | Register Name                                        |                 | Bit 7       | 6                   | 5            | 4           | 3                    | 2              | 1                | Bit 0    |  |  |  |
|------------------------------------------------------------|------------------------------------------------------|-----------------|-------------|---------------------|--------------|-------------|----------------------|----------------|------------------|----------|--|--|--|
|                                                            | ESCI Data Register                                   | Read:           | R7          | R6                  | R5           | R4          | R3                   | R2             | R1               | R0       |  |  |  |
| \$0018                                                     | (SCDR)                                               | Write:          | T7          | T6                  | T5           | T4          | T3                   | T2             | T1               | T0       |  |  |  |
|                                                            | See page 173.                                        | Reset:          |             | Unaffected by reset |              |             |                      |                |                  |          |  |  |  |
| \$0019                                                     | ESCI Baud Rate Register<br>(SCBR)                    | Read:<br>Write: | LINT        | LINR                | SCP1         | SCP0        | R                    | SCR2           | SCR1             | SCR0     |  |  |  |
|                                                            | See page 174.                                        | Reset:          | 0           | 0                   | 0            | 0           | 0                    | 0              | 0                | 0        |  |  |  |
|                                                            | Keyboard Status and Control                          | Read:           | 0           | 0                   | 0            | 0           | KEYF                 | 0              |                  |          |  |  |  |
| \$001A                                                     | Register (INTKBSCR)                                  | Write:          |             |                     |              |             |                      | ACKK           | INIASKK          | MODEK    |  |  |  |
|                                                            | See page 118.                                        | Reset:          | 0           | 0                   | 0            | 0           | 0                    | 0              | 0                | 0        |  |  |  |
| \$001B                                                     | Keyboard Interrupt Enable<br>Register (INTKBIER)     | Read:<br>Write: | KBIE7       | KBIE6               | KBIE5        | KBIE4       | KBIE3                | KBIE2          | KBIE1            | KBIE0    |  |  |  |
|                                                            | See page 119.                                        | Reset:          | 0           | 0                   | 0            | 0           | 0                    | 0              | 0                | 0        |  |  |  |
|                                                            | Timebase Module Control                              | Read:           | TBIF        | TBB2                | TBB1         | TBB0        | 0                    | TRIE           |                  | в        |  |  |  |
| \$001C                                                     | Register (TBCR)                                      | Write:          |             | TONE                | IBIII        | TEHO        | TACK                 | IDIL           | IBON             |          |  |  |  |
|                                                            | See page 224.                                        | Reset:          | 0           | 0                   | 0            | 0           | 0                    | 0              | 0                | 0        |  |  |  |
|                                                            | IRQ Status and Control                               | Read:           | 0           | 0                   | 0            | 0           | IRQF                 | 0              | IMASK            | MODE     |  |  |  |
| \$001D                                                     | Register (INTSCR)                                    | Write:          |             |                     |              |             |                      | ACK            |                  | MODE     |  |  |  |
|                                                            | See page 112.                                        | Reset:          | 0           | 0                   | 0            | 0           | 0                    | 0              | 0                | 0        |  |  |  |
| Configuration Register 2<br>\$001E (CONFIG2) <sup>(1</sup> | Configuration Register 2<br>(CONFIG2) <sup>(1)</sup> | Read:<br>Write: | 0           | MCLKSEL             | MCLK1        | MCLK0       | R                    | TMBCLK-<br>SEL | OSCENIN-<br>STOP | SCIBDSRC |  |  |  |
|                                                            | See page 90.                                         | Reset:          | 0           | 0                   | 0            | 0           | 0                    | 0              | 0                | 1        |  |  |  |
| \$001F                                                     | Configuration Register 1<br>(CONFIG1) <sup>(1)</sup> | Read:<br>Write: | COPRS       | LVISTOP             | LVIRSTD      | LVIPWRD     | LVI50R3 <sup>†</sup> | SSREC          | STOP             | COPD     |  |  |  |
|                                                            | See page 91.                                         | Reset:          | 0           | 0                   | 0            | 0           | 0                    | 0              | 0                | 0        |  |  |  |
| 1. On                                                      | e-time writable register af                          | ter eac         | h reset, ex | cept LVI5C          | 0R3 bit. LVI | 50R3 bit is | only reset           | via POR (j     | power-on r       | eset).   |  |  |  |
|                                                            | TIM1 Status and Control                              | Read:           | TOF         | TOIE                | TSTOP        | 0           | 0                    | PS2            | PS1              | PS0      |  |  |  |
| \$0020                                                     | Register (T1SC)                                      | Write:          | 0           |                     |              | TRST        |                      |                |                  |          |  |  |  |
|                                                            | See page 234.                                        | Reset:          | 0           | 0                   | 1            | 0           | 0                    | 0              | 0                | 0        |  |  |  |
|                                                            | TIM1 Counter                                         | Read:           | Bit 15      | 14                  | 13           | 12          | 11                   | 10             | 9                | Bit 8    |  |  |  |
| \$0021                                                     | Register High (T1CNTH)                               | Write:          |             |                     |              |             |                      |                |                  |          |  |  |  |
|                                                            | See page 235.                                        | Reset:          | 0           | 0                   | 0            | 0           | 0                    | 0              | 0                | 0        |  |  |  |
|                                                            | TIM1 Counter                                         | Read:           | Bit 7       | 6                   | 5            | 4           | 3                    | 2              | 1                | Bit 0    |  |  |  |
| \$0022                                                     | Register Low (T1CNTL)                                | Write:          |             |                     |              |             |                      |                |                  |          |  |  |  |
|                                                            | See page 235.                                        | Reset:          | 0           | 0                   | 0            | 0           | 0                    | 0              | 0                | 0        |  |  |  |
| \$0023                                                     | TIM1 Counter Modulo<br>Register High (T1MODH)        | Read:<br>Write: | Bit 15      | 14                  | 13           | 12          | 11                   | 10             | 9                | Bit 8    |  |  |  |
|                                                            | See page 236.                                        | Docot.          | - 1         | 1                   | 1            | 1           | 4                    | 1              | 4                | 1        |  |  |  |

Figure 2-2. Control, Status, and Data Registers (Sheet 3 of 9)

1 = Unimplemented

1

1

R = Reserved

1

1

U = Unaffected

MC68HC908GR60A • MC68HC908GR48A • MC68HC908GR32A Data Sheet, Rev. 5

See page 236. Reset:

1

1

1



#### Memory

- *E.* The time between each FLASH address change (step 7 to step 7), or the time between the last FLASH address programmed to clearing the PGM bit (step 7 to step 10) must not exceed the maximum programming time, t<sub>PROG</sub> maximum.
- **F.** Be cautious when programming the FLASH-1 array to ensure that non-FLASH locations are not used as the address that is written to when selecting either the desired row address range in step 3 of the algorithm or the byte to be programmed in step 7 of the algorithm.

## 2.6.7 Low-Power Modes

The WAIT and STOP instructions will place the MCU in low power-consumption standby modes.

### 2.6.7.1 Wait Mode

Putting the MCU into wait mode while the FLASH is in read mode does not affect the operation of the FLASH memory directly; however, no memory activity will take place since the CPU is inactive.

The WAIT instruction should not be executed while performing a program or erase operation on the FLASH. Wait mode will suspend any FLASH program/erase operations and leave the memory in a standby mode.

#### 2.6.7.2 Stop Mode

Putting the MCU into stop mode while the FLASH is in read mode does not affect the operation of the FLASH memory directly; however, no memory activity will take place since the CPU is inactive.

The STOP instruction should not be executed while performing a program or erase operation on the FLASH. Stop mode will suspend any FLASH program/erase operations and leave the memory in a standby mode.

#### NOTE

Standby mode is the power saving mode of the FLASH module, in which all internal control signals to the FLASH are inactive and the current consumption of the FLASH is minimum.



| ADCH4       | ADCH3       | ADCH2       | ADCH1       | ADCH0       | Input Select      |
|-------------|-------------|-------------|-------------|-------------|-------------------|
| 1           | 0           | 0           | 0           | 0           | PTG0/AD16         |
| 1           | 0           | 0           | 0           | 1           | PTG1/AD17         |
| 1           | 0           | 0           | 1           | 0           | PTG2/AD18         |
| 1           | 0           | 0           | 1           | 1           | PTG3/AD19         |
| 1           | 0           | 1           | 0           | 0           | PTG4/AD20         |
| 1           | 0           | 1           | 0           | 1           | PTG5/AD21         |
| 1           | 0           | 1           | 1           | 0           | PTG6/AD22         |
| 1           | 0           | 1           | 1           | 1           | PTG7/AD23         |
| 1<br>↓<br>1 | 1<br>↓<br>1 | 0<br>↓<br>1 | 0<br>↓<br>0 | 0<br>↓<br>0 | Unused            |
| 1           | 1           | 1           | 0           | 1           | V <sub>REFH</sub> |
| 1           | 1           | 1           | 1           | 0           | V <sub>REFL</sub> |
| 1           | 1           | 1           | 1           | 1           | ADC power off     |

## Table 3-1. Mux Channel Select<sup>(1)</sup> (Continued)

1. If any unused channels are selected, the resulting ADC conversion will be unknown or reserved.

## 3.8.2 ADC Data Register High and Data Register Low

## 3.8.2.1 Left Justified Mode

In left justified mode, the ADRH register holds the eight MSBs of the 10-bit result. The ADRL register holds the two LSBs of the 10-bit result. All other bits read as 0. ADRH and ADRL are updated each time an ADC single channel conversion completes. Reading ADRH latches the contents of ADRL until ADRL is read. All subsequent results will be lost until the ADRH and ADRL reads are completed.



Figure 3-5. ADC Data Register High (ADRH) and Low (ADRL)



**Clock Generator Module (CGM)** 

## 4.4.9 CGM Base Clock Output (CGMOUT)

CGMOUT is the clock output of the CGM. This signal goes to the SIM, which generates the MCU clocks. CGMOUT is a 50 percent duty cycle clock running at twice the bus frequency. CGMOUT is software programmable to be either the oscillator output, CGMXCLK, divided by two or the VCO clock, CGMVCLK, divided by two.

## 4.4.10 CGM CPU Interrupt (CGMINT)

CGMINT is the interrupt signal generated by the PLL lock detector.

## 4.5 CGM Registers

These registers control and monitor operation of the CGM:

- PLL control register (PCTL) see 4.5.1 PLL Control Register
- PLL bandwidth control register (PBWC) see 4.5.2 PLL Bandwidth Control Register
- PLL multiplier select register high (PMSH) see 4.5.3 PLL Multiplier Select Register High
- PLL multiplier select register low (PMSL) see 4.5.4 PLL Multiplier Select Register Low
- PLL VCO range select register (PMRS) see 4.5.5 PLL VCO Range Select Register

Figure 4-3 is a summary of the CGM registers.

| Addr.  | Register Name                   |                                               | Bit 7 | 6               | 5     | 4      | 3          | 2      | 1     | Bit 0 |
|--------|---------------------------------|-----------------------------------------------|-------|-----------------|-------|--------|------------|--------|-------|-------|
|        | PLL Control Register            | Read:                                         | PLLIE | PLLF            | PLLON | BCS    | R          | В      | VPR1  | VPR0  |
| \$0036 | (PCTL)                          | Write:                                        |       |                 |       |        |            |        |       |       |
|        | See page 81.                    | Reset:                                        | 0     | 0               | 1     | 0      | 0          | 0      | 0     | 0     |
|        | PLL Bandwidth Control           | Read:                                         | AUTO  | LOCK            | ACO   | 0      | 0          | 0      | 0     | в     |
| \$0037 | Register (PBWC)                 | Write:                                        | 71010 |                 | nod   |        |            |        |       |       |
|        | See page 82.                    | Reset:                                        | 0     | 0               | 0     | 0      | 0          | 0      | 0     | 0     |
|        | PLL Multiplier Select High      | Read:                                         | 0     | 0               | 0     | 0      | MUL 11     | MUL 10 | MUL9  | MUL8  |
| \$0038 | Register (PMSH)<br>See page 83. | Write:                                        |       |                 |       |        | MOLTI      | WOLTO  |       |       |
|        |                                 | Reset:                                        | 0     | 0               | 0     | 0      | 0          | 0      | 0     | 0     |
|        | PLL Multiplier Select Low       | elect Low Read: MUL7<br>er (PMSL) Write: MUL7 | MUU 7 | МШС             | MULE  |        | MULIO      | MULO   | MUL 1 | MULO  |
| \$0039 | Register (PMSL)                 |                                               | WUL/  | MOLO            | WULD  | WUL4   | WOL3       | IVIULZ | NUCLI | NIOLU |
|        | See page 84.                    | Reset:                                        | 0     | 1               | 0     | 0      | 0          | 0      | 0     | 0     |
|        | PLL VCO Select Range            | Read:                                         | VDC7  | VDS6            | VDSE  |        | VDS2       | VDCO   |       | VBS0  |
| \$003A | Register (PMRS)                 | Write:                                        | VN3/  | VN30            | VICOD | V N 04 | VNOO       | VNGZ   | VNOI  | VIGU  |
|        | See page 84.                    | Reset:                                        | 0     | 1               | 0     | 0      | 0          | 0      | 0     | 0     |
|        |                                 | Read:                                         | 0     | 0               | 0     | 0      | <b>D</b>   | Б      | D     | D     |
| \$003B | Reserved Register               | Write:                                        |       |                 |       |        | п          | К      | К     | К     |
|        |                                 | Reset:                                        | 0     | 0               | 0     | 0      | 0          | 0      | 0     | 1     |
|        |                                 | [                                             |       | = Unimplemented |       | R      | = Reserved |        |       |       |

NOTES:

- 1. When AUTO = 0, PLLIE is forced clear and is read-only.
- 2. When AUTO = 0, PLLF and LOCK read as clear.
- 3. When AUTO = 1,  $\overline{ACQ}$  is read-only.
- 4. When PLLON = 0 or VRS7:VRS0 = \$0, BCS is forced clear and is read-only.
- 5. When PLLON = 1, the PLL programming register is read-only.
- 6. When BCS = 1, PLLON is forced set and is read-only.

### Figure 4-3. CGM I/O Register Summary





## 8.4 IRQ Pin

A falling edge on the IRQ pin can latch an interrupt request into the IRQ latch. A vector fetch, software clear, or reset clears the IRQ latch.

If the MODE bit is set, the IRQ pin is both falling-edge-sensitive and low-level-sensitive. With MODE set, both of the following actions must occur to clear IRQ:

- Vector fetch or software clear A vector fetch generates an interrupt acknowledge signal to clear the latch. Software may generate the interrupt acknowledge signal by writing a 1 to the ACK bit in the interrupt status and control register (INTSCR). The ACK bit is useful in applications that poll the IRQ pin and require software to clear the IRQ latch. Writing to the ACK bit prior to leaving an interrupt service routine can also prevent spurious interrupts due to noise. Setting ACK does not affect subsequent transitions on the IRQ pin. A falling edge that occurs after writing to the ACK bit latches another interrupt request. If the IRQ mask bit, IMASK, is clear, the CPU loads the program counter with the vector address at locations \$FFFA and \$FFFB.
- Return of the  $\overline{IRQ}$  pin to a high level As long as the  $\overline{IRQ}$  pin is low, IRQ remains active.

The vector fetch or software clear and the return of the  $\overline{IRQ}$  pin to a high level may occur in any order. The interrupt request remains pending as long as the  $\overline{IRQ}$  pin is low. A reset will clear the latch and the MODE control bit, thereby clearing the interrupt even if the pin stays low.

If the MODE bit is clear, the IRQ pin is falling-edge-sensitive only. With MODE clear, a vector fetch or software clear immediately clears the IRQ latch.

The IRQF bit in the INTSCR register can be used to check for pending interrupts. The IRQF bit is not affected by the IMASK bit, which makes it useful in applications where polling is preferred.

Use the BIH or BIL instruction to read the logic level on the  $\overline{IRQ}$  pin.

NOTE

When using the level-sensitive interrupt trigger, avoid false interrupts by masking interrupt requests in the interrupt routine.

## 8.5 IRQ Module During Break Interrupts

The BCFE bit in the SIM break flag control register (SBFCR) enables software to clear the latch during the break state. See Chapter 19 Development Support.

To allow software to clear the IRQ latch during a break interrupt, write a 1 to the BCFE bit. If a latch is cleared during the break state, it remains cleared when the MCU exits the break state.

To protect CPU interrupt flags during the break state, write a 0 to the BCFE bit. With BCFE at 0 (its default state), writing to the ACK bit in the IRQ status and control register during the break state has no effect on the IRQ interrupt flags.



#### Input/Output (I/O) Ports

| Addr.                                    | Register Name                                   |                 | Bit 7               | 6                   | 5       | 4             | 3       | 2       | 1       | Bit 0   |  |  |  |
|------------------------------------------|-------------------------------------------------|-----------------|---------------------|---------------------|---------|---------------|---------|---------|---------|---------|--|--|--|
| \$0003                                   | Port D Data Register<br>(PTD)                   | Read:<br>Write: | PTD7                | PTD6                | PTD5    | PTD4          | PTD3    | PTD2    | PTD1    | PTD0    |  |  |  |
|                                          | See page 142.                                   | Reset:          |                     | Unaffected by reset |         |               |         |         |         |         |  |  |  |
| \$0004                                   | Data Direction Register A<br>(DDRA)             | Read:<br>Write: | DDRA7               | DDRA6               | DDRA5   | DDRA4         | DDRA3   | DDRA2   | DDRA1   | DDRA0   |  |  |  |
|                                          | See page 136.                                   | Reset:          | 0                   | 0                   | 0       | 0             | 0       | 0       | 0       | 0       |  |  |  |
| \$0005                                   | Data Direction Register B<br>(DDRB)             | Read:<br>Write: | DDRB7               | DDRB6               | DDRB5   | DDRB4         | DDRB3   | DDRB2   | DDRB1   | DDRB0   |  |  |  |
|                                          | See page 138.                                   | Reset:          | 0                   | 0                   | 0       | 0             | 0       | 0       | 0       | 0       |  |  |  |
| \$0006                                   | Data Direction Register C<br>(DDRC)             | Read:<br>Write: | 0                   | DDRC6               | DDRC5   | DDRC4         | DDRC3   | DDRC2   | DDRC1   | DDRC0   |  |  |  |
|                                          | See page 140.                                   | Reset:          | 0                   | 0                   | 0       | 0             | 0       | 0       | 0       | 0       |  |  |  |
| \$0007                                   | Data Direction Register D<br>\$0007 (DDRD)      | Read:<br>Write: | DDRD7               | DDRD6               | DDRD5   | DDRD4         | DDRD3   | DDRD2   | DDRD1   | DDRD0   |  |  |  |
|                                          | See page 143.                                   | Reset:          | 0                   | 0                   | 0       | 0             | 0       | 0       | 0       | 0       |  |  |  |
|                                          | Port E Data Begister                            | Read:           | 0                   | 0                   | DTCC    |               | DTEO    | DTEO    | DTC1    | DTEO    |  |  |  |
| \$0008                                   | (PTE)                                           | Write:          |                     |                     | PIES    | F1 <b>L</b> 4 | PIE3    | PIEZ    | PIEI    | PIEU    |  |  |  |
|                                          | See page 145.                                   | Reset:          | Unaffected by reset |                     |         |               |         |         |         |         |  |  |  |
| \$000C                                   | Data Direction Register E                       | Read:<br>Write: | 0                   | 0                   | DDRE5   | DDRE4         | DDRE3   | DDRE2   | DDRE1   | DDRE0   |  |  |  |
|                                          | See page 146.                                   | Reset:          | 0                   | 0                   | 0       | 0             | 0       | 0       | 0       | 0       |  |  |  |
| \$000D                                   | Port A Input Pullup Enable<br>Register (PTAPUE) | Read:<br>Write: | PTAPUE7             | PTAPUE6             | PTAPUE5 | PTAPUE4       | PTAPUE3 | PTAPUE2 | PTAPUE1 | PTAPUE0 |  |  |  |
|                                          | See page 137.                                   | Reset:          | 0                   | 0                   | 0       | 0             | 0       | 0       | 0       | 0       |  |  |  |
|                                          | Port C Input Pullup Enable                      | Read:           | 0                   |                     |         |               |         |         |         |         |  |  |  |
| \$000E                                   | Register (PTCPUE)                               | Write:          |                     | FICFUED             | FICFUED | FIGFUE4       | FICFUES | FIGFUEZ | FICFUEI | FICFUEU |  |  |  |
|                                          | See page 142.                                   | Reset:          | 0                   | 0                   | 0       | 0             | 0       | 0       | 0       | 0       |  |  |  |
| Port D Input Pullu<br>\$000F Register (F | Port D Input Pullup Enable<br>Register (PTDPUE) | Read:<br>Write: | PTDPUE7             | PTDPUE6             | PTDPUE5 | PTDPUE4       | PTDPUE3 | PTDPUE2 | PTDPUE1 | PTDPUE0 |  |  |  |
|                                          | See page 145.                                   | Reset:          | 0                   | 0                   | 0       | 0             | 0       | 0       | 0       | 0       |  |  |  |
|                                          |                                                 |                 |                     | = Unimplemented     |         |               |         |         |         |         |  |  |  |





Input/Output (I/O) Ports

## 12.3.2 Data Direction Register A

Data direction register A (DDRA) determines whether each port A pin is an input or an output. Writing a 1 to a DDRA bit enables the output buffer for the corresponding port A pin; a 0 disables the output buffer.



Figure 12-3. Data Direction Register A (DDRA)

## DDRA7–DDRA0 — Data Direction Register A Bits

These read/write bits control port A data direction. Reset clears DDRA7–DDRA0, configuring all port A pins as inputs.

1 = Corresponding port A pin configured as output

0 = Corresponding port A pin configured as input

#### NOTE

Avoid glitches on port A pins by writing to the port A data register before changing data direction register A bits from 0 to 1.

Figure 12-4 shows the port A I/O logic.

When bit DDRAx is a 1, reading address \$0000 reads the PTAx data latch. When bit DDRAx is a 0, reading address \$0000 reads the voltage level on the pin. The data latch can always be written, regardless of the state of its data direction bit. Table 12-2 summarizes the operation of the port A pins.



Figure 12-4. Port A I/O Circuit



#### Enhanced Serial Communications Interface (ESCI) Module



SL = 1 -> SCI\_CLK = BUSCLK SL = 0 -> SCI\_CLK = CGMXCLK

Figure 13-3. ESCI Module Block Diagram



#### Enhanced Serial Communications Interface (ESCI) Module

#### PDS2–PDS0 — Prescaler Divisor Select Bits

These read/write bits select the prescaler divisor as shown in Table 13-9. Reset clears PDS2–PDS0.

NOTE

The setting of '000' will bypass this prescaler. It is not recommended to bypass the prescaler while ENSCI is set, because the switching is not glitch free.

| PDS[2:1:0] | Prescaler Divisor (PD) |
|------------|------------------------|
| 0 0 0      | Bypass this prescaler  |
| 001        | 2                      |
| 010        | 3                      |
| 0 1 1      | 4                      |
| 100        | 5                      |
| 101        | 6                      |
| 1 1 0      | 7                      |
| 1 1 1      | 8                      |

#### Table 13-9. ESCI Prescaler Division Ratio

#### PSSB4–PSSB0 — Clock Insertion Select Bits

These read/write bits select the number of clocks inserted in each 32 output cycle frame to achieve more timing resolution on the **average** prescaler frequency as shown in Table 13-10. Reset clears PSSB4–PSSB0.

| PSSB[4:3:2:1:0] | Prescaler Divisor Fine Adjust (PDFA) |
|-----------------|--------------------------------------|
| 00000           | 0/32 = 0                             |
| 00001           | 1/32 = 0.03125                       |
| 00010           | 2/32 = 0.0625                        |
| 00011           | 3/32 = 0.09375                       |
| 00100           | 4/32 = 0.125                         |
| 00101           | 5/32 = 0.15625                       |
| 00110           | 6/32 = 0.1875                        |
| 00111           | 7/32 = 0.21875                       |
| 01000           | 8/32 = 0.25                          |
| 01001           | 9/32 = 0.28125                       |
| 01010           | 10/32 = 0.3125                       |
| 01011           | 11/32 = 0.34375                      |
| 01100           | 12/32 = 0.375                        |
| 01101           | 13/32 = 0.40625                      |
| 01110           | 14/32 = 0.4375                       |
| 0 1 1 1 1       | 15/32 = 0.46875                      |

Table 13-10. ESCI Prescaler Divisor Fine Adjust

Continued on next page



#### System Integration Module (SIM)



Figure 14-1. SIM Block Diagram



#### Serial Peripheral Interface (SPI) Module

#### **CPOL** — Clock Polarity Bit

This read/write bit determines the logic state of the SPSCK pin between transmissions. (See Figure 15-5 and Figure 15-7.) To transmit data between SPI modules, the SPI modules must have identical CPOL values. Reset clears the CPOL bit.

#### CPHA — Clock Phase Bit

This read/write bit controls the timing relationship between the serial clock and SPI data. (See Figure 15-5 and Figure 15-7.) To transmit data between SPI modules, the SPI modules must have identical CPHA values. When CPHA = 0, the  $\overline{SS}$  pin of the slave SPI module must be high between bytes. (See Figure 15-13.) Reset sets the CPHA bit.

#### SPWOM — SPI Wired-OR Mode Bit

This read/write bit disables the pullup devices on pins SPSCK, MOSI, and MISO so that those pins become open-drain outputs.

1 = Wired-OR SPSCK, MOSI, and MISO pins

0 = Normal push-pull SPSCK, MOSI, and MISO pins

#### SPE — SPI Enable

This read/write bit enables the SPI module. Clearing SPE causes a partial reset of the SPI. (See 15.8 Resetting the SPI.) Reset clears the SPE bit.

1 = SPI module enabled

0 = SPI module disabled

#### **SPTIE**— SPI Transmit Interrupt Enable

This read/write bit enables CPU interrupt requests generated by the SPTE bit. SPTE is set when a byte transfers from the transmit data register to the shift register. Reset clears the SPTIE bit.

- 1 = SPTE CPU interrupt requests enabled
- 0 = SPTE CPU interrupt requests disabled

## 15.12.2 SPI Status and Control Register

The SPI status and control register contains flags to signal these conditions:

- Receive data register full
- Failure to clear SPRF bit before next byte is received (overflow error)
- Inconsistent logic level on SS pin (mode fault error)
- Transmit data register empty

The SPI status and control register also contains bits that perform these functions:

- Enable error interrupts
- Enable mode fault error detection
- Select master SPI baud rate







#### Serial Peripheral Interface (SPI) Module

If the MODFEN bit is 0, the level of the  $\overline{SS}$  pin does not affect the operation of an enabled SPI configured as a master. For an enabled SPI configured as a slave, having MODFEN low only prevents the MODF flag from being set. It does not affect any other part of SPI operation. See 15.6.2 Mode Fault Error.

#### SPR1 and SPR0 — SPI Baud Rate Select Bits

In master mode, these read/write bits select one of four baud rates as shown in Table 15-3. SPR1 and SPR0 have no effect in slave mode. Reset clears SPR1 and SPR0.

| SPR1 and SPR0 | Baud Rate Divisor (BD) |  |  |  |  |  |
|---------------|------------------------|--|--|--|--|--|
| 00            | 2                      |  |  |  |  |  |
| 01            | 8                      |  |  |  |  |  |
| 10            | 32                     |  |  |  |  |  |
| 11            | 128                    |  |  |  |  |  |

Table 15-3. SPI Master Baud Rate Selection

Use this formula to calculate the SPI baud rate:

Baud rate = 
$$\frac{BUSCLK}{BD}$$

### 15.12.3 SPI Data Register

The SPI data register consists of the read-only receive data register and the write-only transmit data register. Writing to the SPI data register writes data into the transmit data register. Reading the SPI data register reads data from the receive data register. The transmit data and receive data registers are separate registers that can contain different values. See Figure 15-2.

| Address: | \$0012              |    |    |    |    |    |    |       |  |
|----------|---------------------|----|----|----|----|----|----|-------|--|
|          | Bit 7               | 6  | 5  | 4  | 3  | 2  | 1  | Bit 0 |  |
| Read:    | R7                  | R6 | R5 | R4 | R3 | R2 | R1 | R0    |  |
| Write:   | T7                  | T6 | T5 | T4 | T3 | T2 | T1 | Т0    |  |
| Reset:   | Unaffected by reset |    |    |    |    |    |    |       |  |

Figure 15-16. SPI Data Register (SPDR)

#### R7–R0/T7–T0 — Receive/Transmit Data Bits

NOTE

Do not use read-modify-write instructions on the SPI data register since the register read is not the same as the register written.



## Chapter 17 Timer Interface Module (TIM1)

## **17.1 Introduction**

This section describes the timer interface module (TIM1). TIM1 is a two-channel timer that provides a timing reference with input capture, output compare, and pulse-width-modulation functions. Figure 17-2 is a block diagram of the TIM1.

## 17.2 Features

Features of the TIM1 include the following:

- Two input capture/output compare channels
  - Rising-edge, falling-edge, or any-edge input capture trigger
  - Set, clear, or toggle output compare action
- Buffered and unbuffered pulse width modulation (PWM) signal generation
- Programmable TIM1 clock input with 7-frequency internal bus clock prescaler selection
- Free-running or modulo up-count operation
- Toggle any channel pin on overflow
- TIM1 counter stop and reset bits

## **17.3 Functional Description**

Figure 17-2 shows the structure of the TIM1. The central component of the TIM1 is the 16-bit TIM1 counter that can operate as a free-running counter or a modulo up-counter. The TIM1 counter provides the timing reference for the input capture and output compare functions. The TIM1 counter modulo registers, T1MODH:T1MODL, control the modulo value of the TIM1 counter. Software can read the TIM1 counter value at any time without affecting the counting sequence.

The two TIM1 channels are programmable independently as input capture or output compare channels.



#### **Functional Description**

Use the following methods to synchronize unbuffered changes in the PWM pulse width on channel x:

- When changing to a shorter pulse width, enable channel x output compare interrupts and write the new value in the output compare interrupt routine. The output compare interrupt occurs at the end of the current pulse. The interrupt routine has until the end of the PWM period to write the new value.
- When changing to a longer pulse width, enable TIM1 overflow interrupts and write the new value in the TIM1 overflow interrupt routine. The TIM1 overflow interrupt occurs at the end of the current PWM period. Writing a larger value in an output compare interrupt routine (at the end of the current pulse) could cause two output compares to occur in the same PWM period.

#### NOTE

In PWM signal generation, do not program the PWM channel to toggle on output compare. Toggling on output compare prevents reliable 0% duty cycle generation and removes the ability of the channel to self-correct in the event of software error or noise. Toggling on output compare also can cause incorrect PWM signal generation when changing the PWM pulse width to a new, much larger value.

#### 17.3.4.2 Buffered PWM Signal Generation

Channels 0 and 1 can be linked to form a buffered PWM channel whose output appears on the T1CH0 pin. The TIM1 channel registers of the linked pair alternately control the pulse width of the output.

Setting the MS0B bit in TIM1 channel 0 status and control register (T1SC0) links channel 0 and channel 1. The TIM1 channel 0 registers initially control the pulse width on the T1CH0 pin. Writing to the TIM1 channel 1 registers enables the TIM1 channel 1 registers to synchronously control the pulse width at the beginning of the next PWM period. At each subsequent overflow, the TIM1 channel registers (0 or 1) that control the pulse width are the ones written to last. T1SC0 controls and monitors the buffered PWM function, and TIM1 channel 1 status and control register (T1SC1) is unused. While the MS0B bit is set, the channel 1 pin, T1CH1, is available as a general-purpose I/O pin.

#### NOTE

In buffered PWM signal generation, do not write new pulse width values to the currently active channel registers. User software should track the currently active channel to prevent writing a new value to the active channel. Writing to the active channel registers is the same as generating unbuffered PWM signals.

#### 17.3.4.3 PWM Initialization

To ensure correct operation when generating unbuffered or buffered PWM signals, use the following initialization procedure:

- 1. In the TIM1 status and control register (T1SC):
  - a. Stop the TIM1 counter by setting the TIM1 stop bit, TSTOP.
  - b. Reset the TIM1 counter and prescaler by setting the TIM1 reset bit, TRST.
- 2. In the TIM1 counter modulo registers (T1MODH:T1MODL), write the value for the required PWM period.
- 3. In the TIM1 channel x registers (T1CHxH:T1CHxL), write the value for the required pulse width.



#### Timer Interface Module (TIM2)

#### CHxMAX — Channel x Maximum Duty Cycle Bit

When the TOVx bit is at a 1 and clear output on compare is selected, setting the CHxMAX bit forces the duty cycle of buffered and unbuffered PWM signals to 100%. As Figure 18-9 shows, the CHxMAX bit takes effect in the cycle after it is set or cleared. The output stays at 100% duty cycle level until the cycle after CHxMAX is cleared.

#### NOTE

The 100% PWM duty cycle is defined as a continuous high level if the PWM polarity is 1 and a continuous low level if the PWM polarity is 0. Conversely, a 0% PWM duty cycle is defined as a continuous low level if the PWM polarity is 1 and a continuous high level if the PWM polarity is 0.



Figure 18-9. CHxMAX Latency

### 18.8.5 TIM2 Channel Registers

These read/write registers contain the captured TIM2 counter value of the input capture function or the output compare value of the output compare function. The state of the TIM2 channel registers after reset is unknown.

In input capture mode (MSxB:MSxA = 0:0), reading the high byte of the TIM2 channel x registers (T2CHxH) inhibits input captures until the low byte (T2CHxL) is read.

In output compare mode (MSxB:MSxA  $\neq$  0:0), writing to the high byte of the TIM2 channel x registers (T2CHxH) inhibits output compares until the low byte (T2CHxL) is written.



Figure 18-10. TIM2 Channel Registers (T2CH0H/L:T2CH5H/L) (Sheet 1 of 3)



## Chapter 19 Development Support

## **19.1 Introduction**

This section describes the break module, the monitor module (MON), and the monitor mode entry methods.

## 19.2 Break Module (BRK)

The break module can generate a break interrupt that stops normal program flow at a defined address to enter a background program.

Features of the break module include:

- Accessible input/output (I/O) registers during the break Interrupt
- Central processor unit (CPU) generated break interrupts
- Software-generated break interrupts
- Computer operating properly (COP) disabling during break interrupts

## 19.2.1 Functional Description

When the internal address bus matches the value written in the break address registers, the break module issues a breakpoint signal (BKPT) to the system integration module (SIM). The SIM then causes the CPU to load the instruction register with a software interrupt instruction (SWI). The program counter vectors to \$FFFC and \$FFFD (\$FEFC and \$FEFD in monitor mode).

The following events can cause a break interrupt to occur:

- A CPU generated address (the address in the program counter) matches the contents of the break address registers.
- Software writes a 1 to the BRKA bit in the break status and control register.

When a CPU generated address matches the contents of the break address registers, the break interrupt is generated. A return-from-interrupt instruction (RTI) in the break routine ends the break interrupt and returns the microcontroller unit (MCU) to normal operation.

Figure 19-2 shows the structure of the break module.

Figure 19-3 provides a summary of the I/O registers.



#### Development Support



Figure 19-9. Simplified Monitor Mode Entry Flowchart



#### **Electrical Specifications**

| Characteristic <sup>(1)</sup>                                                                                               | Symbol                              | Min                   | Typ <sup>(2)</sup> | Max                   | Unit |
|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------|-----------------------|--------------------|-----------------------|------|
| Pullup/pulldown resistors (as input only)<br>Ports PTA7/KBD7–PTA0/KBD0, PTC6–PTC0/CAN <sub>TX</sub> ,<br>PTD7/T2CH1–PTD0/SS | R <sub>PU</sub>                     | 20                    | 45                 | 65                    | kΩ   |
| Capacitance<br>Ports (as input or output)                                                                                   | C <sub>Out</sub><br>C <sub>In</sub> |                       |                    | 12<br>8               | pF   |
| Monitor mode entry voltage                                                                                                  | V <sub>TST</sub>                    | V <sub>DD</sub> + 2.5 |                    | V <sub>DD</sub> + 4.0 | V    |
| Low-voltage inhibit, trip falling voltage                                                                                   | V <sub>TRIPF</sub>                  | 3.90                  | 4.25               | 4.50                  | V    |
| Low-voltage inhibit, trip rising voltage                                                                                    | V <sub>TRIPR</sub>                  | 4.0                   | 4.35               | 4.60                  | V    |
| Low-voltage inhibit reset/recover hysteresis<br>(V <sub>TRIPF</sub> + V <sub>HYS</sub> = V <sub>TRIPR</sub> )               | V <sub>HYS</sub>                    | _                     | 100                | _                     | mV   |
| POR rearm voltage <sup>(12)</sup>                                                                                           | V <sub>POR</sub>                    | 0                     | _                  | 100                   | mV   |
| POR reset voltage <sup>(13)</sup>                                                                                           | V <sub>PORRST</sub>                 | 0                     | 700                | 800                   | mV   |
| POR rise time ramp rate <sup>(14)</sup>                                                                                     | R <sub>POR</sub>                    | 0.035                 | _                  | _                     | V/ms |

1.  $V_{DD}$  = 5.0 Vdc ± 10%,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_A$  (min) to  $T_A$  (max), unless otherwise noted

2. Typical values reflect average measurements at midpoint of voltage range, 25°C only.

3. Run (operating)  $I_{DD}$  measured using external square wave clock source ( $f_{OSC}$  = 32 MHz). All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs.  $C_L$  = 20 pF on OSC2. All ports configured as inputs. OSC2 capacitance linearly affects run  $I_{DD}$ . Measured with all modules enabled.

- 4. Wait I<sub>DD</sub> measured using external square wave clock source (f<sub>OSC</sub> = 32 MHz). All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs. C<sub>L</sub> = 20 pF on OSC2. All ports configured as inputs. OSC2 capacitance linearly affects wait I<sub>DD</sub>. Measured with CGM and LVI enabled.
- 5. Stop I<sub>DD</sub> is measured with OSC1 = V<sub>SS</sub>. All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs. All ports configured as inputs. Typical values at midpoint of voltage range, 25°C only.
- Stop I<sub>DD</sub> with TBM enabled is measured using an external square wave clock source (f<sub>OSC</sub> = 8 MHz). All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs. All inputs configured as inputs.
- 7. This parameter is characterized and not tested on each device.
- 8. All functional non-supply pins are internally clamped to  $V_{SS}$  and  $V_{DD}$ .
- 9. Input must be current limited to the value specified. To determine the value of the required current-limiting resistor, calculate resistance values for positive and negative clamp voltages, then use the larger of the two values.
- 10. Power supply must maintain regulation within operating V<sub>DD</sub> range during instantaneous and operating maximum current conditions. If positive injection current (V<sub>in</sub> > V<sub>DD</sub>) is greater than I<sub>DD</sub>, the injection current may flow out of V<sub>DD</sub> and could result in external power supply going out of regulation. Ensure external V<sub>DD</sub> load will shunt current greater than maximum injection current. This will be the greatest risk when the MCU is not consuming power. Examples are: if no system clock is present, or if clock rate is very low (which would reduce overall power consumption).
- 11. Pullups and pulldowns are disabled. Port B leakage is specified in 20.10 5.0-Volt ADC Characteristics.
- 12. Maximum is highest voltage that POR is guaranteed.
- 13. Maximum is highest voltage that POR is possible.

14. If minimum  $V_{DD}$  is not reached before the internal POR reset is released,  $\overline{RST}$  must be driven low externally until minimum  $V_{DD}$  is reached.



## 20.11 3.3-Volt ADC Characteristics

| Characteristic <sup>(1)</sup>                 | Symbol            | Min               | Мах               | Unit                    | Comments                                                                         |
|-----------------------------------------------|-------------------|-------------------|-------------------|-------------------------|----------------------------------------------------------------------------------|
| Supply voltage                                | V <sub>DDAD</sub> | 3.0               | 3.6               | V                       | $V_{DDAD}$ should be tied to the same potential as $V_{DD}$ via separate traces. |
| Input voltages                                | V <sub>ADIN</sub> | 0                 | V <sub>DDAD</sub> | V                       | V <sub>ADIN</sub> <= V <sub>DDAD</sub>                                           |
| Resolution                                    | B <sub>AD</sub>   | 10                | 10                | Bits                    |                                                                                  |
| Absolute accuracy                             | A <sub>AD</sub>   | -6                | +6                | LSB                     | Includes quantization                                                            |
| ADC internal clock                            | f <sub>ADIC</sub> | 500 k             | 1.048 M           | Hz                      | $t_{AIC} = 1/f_{ADIC}$                                                           |
| Conversion range                              | R <sub>AD</sub>   | V <sub>SSAD</sub> | V <sub>DDAD</sub> | V                       |                                                                                  |
| Power-up time                                 | t <sub>ADPU</sub> | 16                | —                 | t <sub>AIC</sub> cycles |                                                                                  |
| Conversion time                               | t <sub>ADC</sub>  | 16                | 17                | t <sub>AIC</sub> cycles |                                                                                  |
| Sample time                                   | t <sub>ADS</sub>  | 5                 | —                 | t <sub>AIC</sub> cycles |                                                                                  |
| Monotonicity                                  | M <sub>AD</sub>   |                   |                   | Guaranteed              |                                                                                  |
| Zero input reading                            | Z <sub>ADI</sub>  | 000               | 005               | Hex                     | $V_{ADIN} = V_{SSA}$                                                             |
| Full-scale reading                            | F <sub>ADI</sub>  | 3FA               | 3FF               | Hex                     | $V_{ADIN} = V_{DDA}$                                                             |
| Input capacitance                             | C <sub>ADI</sub>  | —                 | 30                | pF                      | Not tested                                                                       |
| V <sub>DDAD</sub> /V <sub>REFH</sub> current  | I <sub>VREF</sub> | —                 | 1.2               | mA                      |                                                                                  |
| Absolute accuracy<br>(8-bit truncation mode)  | A <sub>AD</sub>   | -1                | +1                | LSB                     | Includes quantization                                                            |
| Quantization error<br>(8-bit truncation mode) | _                 | -1/8              | +7/8              | LSB                     |                                                                                  |

1.  $V_{DD}$  = 3.3 Vdc  $\pm$  10%,  $V_{SS}$  = 0 Vdc,  $V_{DDAD/}V_{REFH}$  = 3.3 Vdc  $\pm$  10%,  $V_{SSAD/}V_{REFL}$  = 0 Vdc





1. Pin contains integrated pullup device.

2. Ports are software configurable with pullup device if input port or pullup/pulldown device for keyboard input.

3. Higher current drive port pins

### Figure B-1. MC68HC908GR32A Block Diagram