

Welcome to E-XFL.COM

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

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

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

#### Details

E·XFI

| Product Status             | Active                                                    |
|----------------------------|-----------------------------------------------------------|
| Core Processor             | HC08                                                      |
| Core Size                  | 8-Bit                                                     |
| Speed                      | 8MHz                                                      |
| Connectivity               | SCI, SPI                                                  |
| Peripherals                | LVD, POR, PWM                                             |
| Number of I/O              | 31                                                        |
| Program Memory Size        | 16KB (16K x 8)                                            |
| Program Memory Type        | FLASH                                                     |
| EEPROM Size                | -                                                         |
| RAM Size                   | 512 x 8                                                   |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                               |
| Data Converters            | A/D 8x8b                                                  |
| Oscillator Type            | Internal                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                         |
| Mounting Type              | Through Hole                                              |
| Package / Case             | 42-SDIP (0.600", 15.24mm)                                 |
| Supplier Device Package    | 42-PDIP                                                   |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=mc908gp16cbe |

Email: info@E-XFL.COM

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





# **List of Chapters**

\_\_\_\_\_

| Chapter 1 General Description                           |
|---------------------------------------------------------|
| Chapter 2 Memory                                        |
| Chapter 3 Low-Power Modes                               |
| Chapter 4 Analog-to-Digital Converter (ADC)             |
| Chapter 5 Clock Generator Module (CGM)61                |
| Chapter 6 Configuration Register (CONFIG)81             |
| Chapter 7 Computer Operating Properly (COP)85           |
| Chapter 8 Central Processor Unit (CPU)                  |
| Chapter 9 External Interrupt (IRQ)101                   |
| Chapter 10 Keyboard Interrupt (KBI) Module105           |
| Chapter 11 Low-Voltage Inhibit (LVI)                    |
| Chapter 12 Input/Output (I/O) Ports115                  |
| Chapter 13 Serial Communications Interface Module (SCI) |
| Chapter 14 System Integration Module (SIM)157           |
| Chapter 15 Serial Peripheral Interface Module (SPI)     |
| Chapter 16 Timebase Module (TBM)195                     |
| Chapter 17 Timer Interface Module (TIM)199              |
| Chapter 18 Development Support                          |
| Chapter 19 Electrical Specifications                    |
| Chapter 20 Mechanical Specifications255                 |
| Chapter 21 Ordering Information263                      |



# **Table of Contents**

# Chapter 1 General Description

| 1.1    | Introduction                                                                                                     |
|--------|------------------------------------------------------------------------------------------------------------------|
| 1.2    | Features                                                                                                         |
| 1.2.1  | Standard Features of the MC68HC908GP32 21                                                                        |
| 1.2.2  | Features of the CPU08                                                                                            |
| 1.3    | MCU Block Diagram                                                                                                |
| 1.4    | Pin Assignments                                                                                                  |
| 1.5    | Pin Functions                                                                                                    |
| 1.5.1  | Power Supply Pins (V <sub>DD</sub> and V <sub>SS</sub> )                                                         |
| 1.5.2  | Oscillator Pins (OSC1 and OSC2) 27                                                                               |
| 1.5.3  | External Reset Pin (RST)                                                                                         |
| 1.5.4  | External Interrupt Pin (IRQ) 27                                                                                  |
| 1.5.5  | CGM Power Supply Pins (V <sub>DDA</sub> and V <sub>SSA</sub> )                                                   |
| 1.5.6  | External Filter Capacitor Pin (CGMXFC) 27                                                                        |
| 1.5.7  | ADC Power Supply/Reference Pins (V <sub>DDAD</sub> /V <sub>REFH</sub> and V <sub>SSAD</sub> /V <sub>REFL</sub> ) |
| 1.5.8  | Port A Input/Output (I/O) Pins (PTA7/KBD7–PTA0/KBD0)                                                             |
| 1.5.9  | Port B I/O Pins (PTB7/AD7–PTB0/AD0)                                                                              |
| 1.5.10 | Port C I/O Pins (PTC6–PTC0)                                                                                      |
| 1.5.11 | Port D I/O Pins (PTD7/T2CH1–PTD0/SS)                                                                             |
| 1.5.12 | Port E I/O Pins (PTE1/RxD–PTE0/TxD)                                                                              |

# Chapter 2

# Memory

| 2.1     | Introduction                      |
|---------|-----------------------------------|
| 2.2     | Unimplemented Memory Locations 29 |
| 2.3     | Reserved Memory Locations         |
| 2.4     | Input/Output (I/O) Section        |
| 2.5     | Random-Access Memory (RAM) 38     |
| 2.6     | FLASH Memory                      |
| 2.6.1   | Functional Description            |
| 2.6.2   | FLASH Control Register            |
| 2.6.3   | FLASH Page Erase Operation        |
| 2.6.4   | FLASH Mass Erase Operation 40     |
| 2.6.5   | FLASH Program Operation 40        |
| 2.6.6   | FLASH Block Protection            |
| 2.6.6.1 | FLASH Block Protect Register 44   |
| 2.6.7   | Wait Mode                         |
| 2.6.8   | Stop Mode                         |



#### Memory

When the FLBPR is programmed with all 0's, the entire memory is protected from being programmed and erased. When all the bits are erased (all 1's), the entire memory is accessible for program and erase.

When bits within the FLBPR are programmed, they lock a block of memory, address ranges as shown in 2.6.6.1 FLASH Block Protect Register. Once the FLBPR is programmed with a value other than \$FF, any erase or program of the FLBPR or the protected block of FLASH memory is prohibited. Mass erase is disabled whenever any block is protected (FLBPR does not equal \$FF). The presence of a  $V_{TST}$  on the IRQ pin will bypass the block protection so that all of the memory included in the block protect register is open for program and erase operations.

#### NOTE

The FLASH block protect register is not protected with special hardware or software. Therefore, if this page is not protected by FLBPR the register is erased by either a page or mass erase operation.

## 2.6.6.1 FLASH Block Protect Register

The FLASH block protect register (FLBPR) is implemented as a byte within the FLASH memory, and therefore can only be written during a programming sequence of the FLASH memory. The value in this register determines the starting location of the protected range within the FLASH memory.



U = Unaffected by reset. Initial value from factory is 1.

Write to this register is by a programming sequence to the FLASH memory.

#### Figure 2-5. FLASH Block Protect Register (FLBPR)

#### BPR[7:0] — FLASH Block Protect Bits

These eight bits represent bits [14:7] of a 16-bit memory address.

Bit-15 is 1 and bits [6:0] are 0s.

The resultant 16-bit address is used for specifying the start address of the FLASH memory for block protection. The FLASH is protected from this start address to the end of FLASH memory, at \$FFFF. With this mechanism, the protect start address can be XX00 and XX80 (128 bytes page boundaries) within the FLASH memory.

|                                      |   |  |    |     | 16-   | bit r | nem | ory a | addr | ess |   |   |   |   |   |
|--------------------------------------|---|--|----|-----|-------|-------|-----|-------|------|-----|---|---|---|---|---|
| Start address of FLASH block protect | 1 |  | FI | BPF | R val | ue    |     |       | 0    | 0   | 0 | 0 | 0 | 0 | 0 |

Figure 2-6. FLASH Block Protect Start Address



Examples of protect start address:

| BPR[7:0]                  | Start of Address of Protect Range         |
|---------------------------|-------------------------------------------|
| \$00                      | The entire FLASH memory is protected.     |
| \$01 ( <b>0000 0001</b> ) | \$8080 (1 <b>000 0000 1</b> 000 0000)     |
| \$02 ( <b>0000 0010</b> ) | \$8100 (1 <b>000 0001 0</b> 000 0000)     |
|                           | and so on                                 |
| \$FE (1111 1110)          | \$FF00 (1 <b>111 1111 0</b> 000 0000)     |
| \$FF                      | The entire FLASH memory is not protected. |

Note: The end address of the protected range is always \$FFFF.

#### 2.6.7 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, but there will not be any memory activity since the CPU is inactive.

The WAIT instruction should not be executed while performing a program or erase operation on the FLASH, otherwise the operation will discontinue, and the FLASH will be on Standby Mode.

#### 2.6.8 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, but there will not be any memory activity since the CPU is inactive.

The STOP instruction should not be executed while performing a program or erase operation on the FLASH, otherwise the operation will discontinue, and the FLASH will be on 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 at a minimum.



**Central Processor Unit (CPU)** 

| Source                                                                                         |                                                                   | <b>-</b>                                                                                                                                                                                                              |    | Effect<br>on CCR |   |    |    |    | ess                                                 | de                                               | and                                       | ŝ                                    |
|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------------------|---|----|----|----|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------|--------------------------------------|
| Form                                                                                           | Operation                                                         | Description                                                                                                                                                                                                           | v  | Н                | I | N  | z  | С  | Addr<br>Mode                                        | Opco                                             | Opera                                     | Cycle                                |
| PULA                                                                                           | Pull A from Stack                                                 | $SP \leftarrow (SP + 1); Pull (A)$                                                                                                                                                                                    | -  | -                | - | -  | -  | -  | INH                                                 | 86                                               |                                           | 2                                    |
| PULH                                                                                           | Pull H from Stack                                                 | $SP \leftarrow (SP + 1); Pull (H)$                                                                                                                                                                                    | -  | _                | _ | -  | -  | -  | INH                                                 | 8A                                               |                                           | 2                                    |
| PULX                                                                                           | Pull X from Stack                                                 | $SP \leftarrow (SP + 1); Pull (X)$                                                                                                                                                                                    | -  | -                | - | -  | -  | -  | INH                                                 | 88                                               |                                           | 2                                    |
| ROL <i>opr</i><br>ROLA<br>ROLX<br>ROL <i>opr</i> ,X<br>ROL ,X<br>ROL <i>opr</i> ,SP            | Rotate Left through Carry                                         | b7 b0                                                                                                                                                                                                                 | \$ | _                | _ | \$ | \$ | \$ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 39<br>49<br>59<br>69<br>79<br>9E69               | dd<br>ff<br>ff                            | 4<br>1<br>4<br>3<br>5                |
| ROR <i>opr</i><br>RORA<br>RORX<br>ROR <i>opr</i> ,X<br>ROR ,X<br>ROR <i>opr</i> ,SP            | Rotate Right through Carry                                        | b7 b0                                                                                                                                                                                                                 | \$ | _                | - | ↓  | ¢  | \$ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 36<br>46<br>56<br>66<br>76<br>9E66               | dd<br>ff<br>ff                            | 4 1 1 4 3 5                          |
| RSP                                                                                            | Reset Stack Pointer                                               | $SP \leftarrow \$FF$                                                                                                                                                                                                  | -  | -                | - | -  | -  | -  | INH                                                 | 9C                                               |                                           | 1                                    |
| RTI                                                                                            | Return from Interrupt                                             | $\begin{array}{c} SP \leftarrow (SP) + 1; Pull (CCR) \\ SP \leftarrow (SP) + 1; Pull (A) \\ SP \leftarrow (SP) + 1; Pull (X) \\ SP \leftarrow (SP) + 1; Pull (PCH) \\ SP \leftarrow (SP) + 1; Pull (PCL) \end{array}$ |    |                  |   | \$ | \$ | \$ | INH                                                 | 80                                               |                                           | 7                                    |
| RTS                                                                                            | Return from Subroutine                                            | $\begin{array}{l} SP \leftarrow SP + 1; Pull \ (PCH) \\ SP \leftarrow SP + 1; Pull \ (PCL) \end{array}$                                                                                                               | -  | -                | - | -  | -  | -  | INH                                                 | 81                                               |                                           | 4                                    |
| SBC #opr<br>SBC opr<br>SBC opr<br>SBC opr,X<br>SBC opr,X<br>SBC ,X<br>SBC opr,SP<br>SBC opr,SP | Subtract with Carry                                               | $A \gets (A) - (M) - (C)$                                                                                                                                                                                             | \$ | _                | - | €  | \$ | \$ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A2<br>B2<br>C2<br>D2<br>E2<br>F2<br>9EE2<br>9ED2 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff | 23443245                             |
| SEC                                                                                            | Set Carry Bit                                                     | $C \leftarrow 1$                                                                                                                                                                                                      | -  | -                | - | -  | -  | 1  | INH                                                 | 99                                               |                                           | 1                                    |
| SEI                                                                                            | Set Interrupt Mask                                                | I ← 1                                                                                                                                                                                                                 | -  | -                | 1 | -  | -  | -  | INH                                                 | 9B                                               |                                           | 2                                    |
| STA opr<br>STA opr,X<br>STA opr,X<br>STA opr,X<br>STA ,X<br>STA opr,SP<br>STA opr,SP           | Store A in M                                                      | M ← (A)                                                                                                                                                                                                               | 0  | _                | _ | \$ | \$ | _  | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2        | B7<br>C7<br>D7<br>E7<br>F7<br>9EE7<br>9ED7       | dd<br>hh II<br>ee ff<br>ff<br>ee ff       | 3443245                              |
| STHX opr                                                                                       | Store H:X in M                                                    | $(M{:}M+1) \gets (H{:}X)$                                                                                                                                                                                             | 0  | -                | - | \$ | \$ | -  | DIR                                                 | 35                                               | dd                                        | 4                                    |
| STOP                                                                                           | Enable Interrupts, Stop Processing,<br>Refer to MCU Documentation | $I \leftarrow 0$ ; Stop Processing                                                                                                                                                                                    | -  | -                | 0 | I  | -  | -  | INH                                                 | 8E                                               |                                           | 1                                    |
| STX opr<br>STX opr<br>STX opr,X<br>STX opr,X<br>STX ,X<br>STX opr,SP<br>STX opr,SP             | Store X in M                                                      | $M \gets (X)$                                                                                                                                                                                                         | 0  | _                | _ | €  | \$ | _  | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2        | BF<br>CF<br>DF<br>EF<br>FF<br>9EEF<br>9EDF       | dd<br>hh ll<br>ee ff<br>ff<br>ee ff       | 3<br>4<br>3<br>2<br>4<br>5           |
| SUB #opr<br>SUB opr<br>SUB opr<br>SUB opr,X<br>SUB opr,X<br>SUB opr,SP<br>SUB opr,SP           | Subtract                                                          | A ← (A) – (M)                                                                                                                                                                                                         | \$ | _                | _ | €  | \$ | \$ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A0<br>B0<br>C0<br>D0<br>E0<br>F0<br>9EE0<br>9ED0 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 |

## Table 8-1. Instruction Set Summary (Sheet 5 of 6)





## 10.4.3 Keyboard Initialization

When a keyboard interrupt pin is enabled, it takes time for the internal pullup to pull the pin to a high level. Therefore a false interrupt can occur as soon as the pin is enabled.

To prevent a false interrupt on keyboard initialization:

- 1. Mask keyboard interrupts by setting IMASKK in INTKBSCR.
- 2. Enable the KBI pins by setting the appropriate KBIEx bits in INTKBIER.
- 3. Write to ACKK in INTKBSCR to clear any false interrupts.
- 4. Clear IMASKK.

An interrupt signal on an edge sensitive pin can be acknowledged immediately after enabling the pin. An interrupt signal on an edge and level sensitive pin must be acknowledged after a delay that depends on the external load.

# 10.5 Interrupts

The following KBI source can generate interrupt requests:

 Keyboard flag (KEYF) — KEYF is set when any enabled KBI pin is asserted based on the KBI mode. The keyboard interrupt mask bit, IMASKK, is used to enable or disable KBI interrupt requests.

# 10.6 Low-Power Modes

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

## 10.6.1 Wait Mode

The KBI module remains active in wait mode. Clearing IMASKK in INTKBSCR enables keyboard interrupt requests to bring the MCU out of wait mode.

## 10.6.2 Stop Mode

The KBI module remains active in stop mode. Clearing IMASKK in INTKBSCR enables keyboard interrupt requests to bring the MCU out of stop mode.

# 10.7 KBI During Break Interrupts

The system integration module (SIM) controls whether status bits in other modules can be cleared during the break state. BCFE in the break flag control register (BFCR) enables software to clear status bits during the break state. See BFCR in the SIM section of this data sheet.

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

To protect status bits during the break state, write a 0 to BCFE. With BCFE cleared (its default state), software can read and write registers during the break state without affecting status bits. Some status bits have a two-step read/write clearing procedure. If software does the first step on such a bit before the break, the bit cannot change during the break state as long as BCFE is cleared. After the break, doing the second step clears the status bit.



Keyboard Interrupt (KBI) Module

\_\_\_\_\_

| Port | Bit     | DDR   | Modu        | le Control  | Pin        |
|------|---------|-------|-------------|-------------|------------|
|      | 0       | DDRA0 |             | KBIE0       | PTA0/KBD0  |
|      | 1       | DDRA1 |             | PTA1/KBD1   |            |
|      | 2       | DDRA2 |             | KBIE2       | PTA2/KBD2  |
|      | 3       | DDRA3 |             | KBIE3       | PTA3/KBD3  |
| A    | 4       | DDRA4 | KDU         | KBIE4       | PTA4/KBD4  |
|      | 5       | DDRA5 |             | KBIE5       | PTA5/KBD5  |
|      | 6       | DDRA6 |             | KBIE6       | PTA6/KBD6  |
|      | 7       | DDRA7 |             | KBIE7       | PTA7/KBD7  |
|      | 0       | DDRB0 |             |             | PTB0/AD0   |
|      | 1       | DDRB1 |             |             | PTB1/AD1   |
|      | 2       | DDRB2 |             |             | PTB2/AD2   |
| Б    | 3       | DDRB3 |             |             | PTB3/AD3   |
| Б    | 4       | DDRB4 | ADC         |             | PTB4/AD4   |
|      | 5       | DDRB5 |             |             | PTB5/AD5   |
|      | 6 DDRB6 | DDRB6 |             |             | PTB6/AD6   |
|      | 7       | DDRB7 |             |             | PTB7/AD7   |
|      | 0       | DDRC0 |             |             | PTC0       |
|      | 1       | DDRC1 |             |             | PTC1       |
|      | 2       | DDRC2 |             |             | PTC2       |
| С    | 3       | DDRC3 |             |             | PTC3       |
|      | 4       | DDRC4 |             |             | PTC4       |
|      | 5       | DDRC5 |             |             | PTC5       |
|      | 6       | DDRC6 |             |             | PTC6       |
|      | 0       | DDRD0 |             |             | PTD0/SS    |
|      | 1       | DDRD1 | <u>е</u> рі | ODE         | PTD1/MISO  |
|      | 2       | DDRD2 | 581         | SPE         | PTD2/MOSI  |
| P    | 3       | DDRD3 |             |             | PTD3/SPSCK |
| D    | 4       | DDRD4 | TINA        | ELS0B:ELS0A | PTD4/T1CH0 |
|      | 5       | DDRD5 |             | ELS1B:ELS1A | PTD5/T1CH1 |
|      | 6       | DDRD6 | TIMO        | ELS0B:ELS0A | PTD6/T2CH0 |
|      | 7       | DDRD7 |             | ELS1B:ELS1A | PTD7/T2CH1 |
|      | 0       | DDRE0 | 001         | ENICOL      | PTE0/TxD   |
| E    | 1       | DDRE1 | 501         | ENSCI       | PTE1/RxD   |



Figure 12-11 shows the port C I/O logic.

#### NOTE

For those devices packaged in a 40-pin dual in-line package and 42-pin shrink dual in-line package, PTC5 and PTC6 are connected to ground internally. DDRC5 and DDRC6 should be set to a 0 to configure PTC5 and PTC6 as inputs.



#### Figure 12-11. Port C I/O Circuit

When bit DDRCx is a logic 1, reading address \$0002 reads the PTCx data latch. When bit DDRCx is a logic 0, reading address \$0002 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-4 summarizes the operation of the port C pins.

| Table 12-4 | Port C | C Pin | Functions |
|------------|--------|-------|-----------|
|------------|--------|-------|-----------|

|            |   |                  | I/O Pin Modo                          | Accesses to DDRC | Access    | es to PTC                |
|------------|---|------------------|---------------------------------------|------------------|-----------|--------------------------|
| FICFUE BIL |   | FICBI            |                                       | Read/Write       | Read      | Write                    |
| 1          | 0 | X <sup>(1)</sup> | Input, V <sub>DD</sub> <sup>(4)</sup> | DDRC6-DDRC0      | Pin       | PTC6–PTC0 <sup>(3)</sup> |
| 0          | 0 | Х                | Input, Hi-Z <sup>(2)</sup>            | DDRC6-DDRC0      | Pin       | PTC6–PTC0 <sup>(3)</sup> |
| X          | 1 | Х                | Output                                | DDRC6-DDRC0      | PTC6-PTC0 | PTC6-PTC0                |

Notes:

X = Don't care

2. Hi-Z = High impedance

3. Writing affects data register, but does not affect input.

4. I/O pin pulled up to  $V_{DD}$  by internal pullup device.



#### Serial Communications Interface Module (SCI)

## 13.4.2.2 Character Transmission

During an SCI transmission, the transmit shift register shifts a character out to the PTE0/TxD pin. The SCI data register (SCDR) is the write-only buffer between the internal data bus and the transmit shift register. To initiate an SCI transmission:

- 1. Enable the SCI by writing a logic 1 to the enable SCI bit (ENSCI) in SCI control register 1 (SCC1).
- 2. Enable the transmitter by writing a logic 1 to the transmitter enable bit (TE) in SCI control register 2 (SCC2).
- 3. Clear the SCI transmitter empty bit by first reading SCI status register 1 (SCS1) and then writing to the SCDR.
- 4. Repeat step 3 for each subsequent transmission.

At the start of a transmission, transmitter control logic automatically loads the transmit shift register with a preamble of logic 1s. After the preamble shifts out, control logic transfers the SCDR data into the transmit shift register. A logic 0 start bit automatically goes into the least significant bit position of the transmit shift register. A logic 1 stop bit goes into the most significant bit position.

The SCI transmitter empty bit, SCTE, in SCS1 becomes set when the SCDR transfers a byte to the transmit shift register. The SCTE bit indicates that the SCDR can accept new data from the internal data bus. If the SCI transmit interrupt enable bit, SCTIE, in SCC2 is also set, the SCTE bit generates a transmitter CPU interrupt request.

When the transmit shift register is not transmitting a character, the PTE0/TxD pin goes to the idle condition, logic 1. If at any time software clears the ENSCI bit in SCI control register 1 (SCC1), the transmitter and receiver relinquish control of the port E pins.

## 13.4.2.3 Break Characters

Writing a logic 1 to the send break bit, SBK, in SCC2 loads the transmit shift register with a break character. A break character contains all logic 0s and has no start, stop, or parity bit. Break character length depends on the M bit in SCC1. As long as SBK is at logic 1, transmitter logic continuously loads break characters into the transmit shift register. After software clears the SBK bit, the shift register finishes transmitting the last break character and then transmits at least one logic 1. The automatic logic 1 at the end of a break character guarantees the recognition of the start bit of the next character.

The SCI recognizes a break character when a start bit is followed by eight or nine logic 0 data bits and a logic 0 where the stop bit should be.

Receiving a break character has these effects on SCI registers:

- Sets the framing error bit (FE) in SCS1
- Sets the SCI receiver full bit (SCRF) in SCS1
- Clears the SCI data register (SCDR)
- Clears the R8 bit in SCC3
- Sets the break flag bit (BKF) in SCS2
- May set the overrun (OR), noise flag (NF), parity error (PE), or reception in progress flag (RPF) bits

#### 13.4.2.4 Idle Characters

An idle character contains all logic 1s and has no start, stop, or parity bit. Idle character length depends on the M bit in SCC1. The preamble is a synchronizing idle character that begins every transmission.



#### Serial Communications Interface Module (SCI)

#### ILIE — Idle Line Interrupt Enable Bit

This read/write bit enables the IDLE bit to generate SCI receiver CPU interrupt requests. Reset clears the ILIE bit.

- 1 = IDLE enabled to generate CPU interrupt requests
- 0 = IDLE not enabled to generate CPU interrupt requests

## TE — Transmitter Enable Bit

Setting this read/write bit begins the transmission by sending a preamble of 10 or 11 logic 1s from the transmit shift register to the PTE0/TxD pin. If software clears the TE bit, the transmitter completes any transmission in progress before the PTE0/TxD returns to the idle condition (logic 1). Clearing and then setting TE during a transmission queues an idle character to be sent after the character currently being transmitted. Reset clears the TE bit.

1 = Transmitter enabled

0 = Transmitter disabled

#### NOTE

Writing to the TE bit is not allowed when the enable SCI bit (ENSCI) is clear. ENSCI is in SCI control register 1.

#### **RE** — Receiver Enable Bit

Setting this read/write bit enables the receiver. Clearing the RE bit disables the receiver but does not affect receiver interrupt flag bits. Reset clears the RE bit.

1 = Receiver enabled

0 = Receiver disabled

## NOTE

Writing to the RE bit is not allowed when the enable SCI bit (ENSCI) is clear. ENSCI is in SCI control register 1.

#### **RWU** — Receiver Wakeup Bit

This read/write bit puts the receiver in a standby state during which receiver interrupts are disabled. The WAKE bit in SCC1 determines whether an idle input or an address mark brings the receiver out of the standby state and clears the RWU bit. Reset clears the RWU bit.

1 = Standby state

0 = Normal operation

#### SBK — Send Break Bit

Setting and then clearing this read/write bit transmits a break character followed by a logic 1. The logic 1 after the break character guarantees recognition of a valid start bit. If SBK remains set, the transmitter continuously transmits break characters with no logic 1s between them. Reset clears the SBK bit.

1 = Transmit break characters

0 = No break characters being transmitted

#### NOTE

Do not toggle the SBK bit immediately after setting the SCTE bit. Toggling SBK before the preamble begins causes the SCI to send a break character instead of a preamble.



#### Serial Communications Interface Module (SCI)

#### FE — Receiver Framing Error Bit

This clearable, read-only bit is set when a logic 0 is accepted as the stop bit. FE generates an SCI error CPU interrupt request if the FEIE bit in SCC3 also is set. Clear the FE bit by reading SCS1 with FE set and then reading the SCDR. Reset clears the FE bit.

- 1 = Framing error detected
- 0 = No framing error detected



Figure 13-13. Flag Clearing Sequence

#### PE — Receiver Parity Error Bit

This clearable, read-only bit is set when the SCI detects a parity error in incoming data. PE generates an SCI error CPU interrupt request if the PEIE bit in SCC3 is also set. Clear the PE bit by reading SCS1 with PE set and then reading the SCDR. Reset clears the PE bit.

- 1 = Parity error detected
- 0 = No parity error detected

## 13.8.5 SCI Status Register 2

SCI status register 2 contains flags to signal the following conditions:

- Break character detected
- Incoming data



# Chapter 14 System Integration Module (SIM)

# 14.1 Introduction

This section describes the system integration module (SIM). Together with the CPU, the SIM controls all MCU activities. A block diagram of the SIM is shown in Figure 14-1. Table 14-1 is a summary of the SIM input/output (I/O) registers. The SIM is a system state controller that coordinates CPU and exception timing. The SIM is responsible for:

- Bus clock generation and control for CPU and peripherals:
  - Stop/wait/reset/break entry and recovery
  - Internal clock control
- Master reset control, including power-on reset (POR) and COP timeout
- Interrupt arbitration

Table 14-1 shows the internal signal names used in this section.

| Signal Name | Description                                                                                 |
|-------------|---------------------------------------------------------------------------------------------|
| CGMXCLK     | Buffered version of OSC1 from clock generator module (CGM)                                  |
| CGMVCLK     | PLL output                                                                                  |
| CGMOUT      | PLL-based or OSC1-based clock output from CGM module<br>(Bus clock = CGMOUT divided by two) |
| IAB         | Internal address bus                                                                        |
| IDB         | Internal data bus                                                                           |
| PORRST      | Signal from the power-on reset module to the SIM                                            |
| IRST        | Internal reset signal                                                                       |
| R/W         | Read/write signal                                                                           |

#### Table 14-1. Signal Name Conventions



#### System Integration Module (SIM)



Figure 14-1. SIM Block Diagram

| Addr.  | Register Name                              |        | Bit 7           | 6   | 5   | 4          | 3    | 2      | 1    | Bit 0 |
|--------|--------------------------------------------|--------|-----------------|-----|-----|------------|------|--------|------|-------|
| \$FE00 | SIM Break Status Register<br>(SBSR)        | Read:  | B               | R   | R   | R          | R    | R      | SBSW | R     |
|        |                                            | Write: | /rite:          |     |     |            |      |        | Note |       |
|        |                                            | Reset: |                 | -   |     |            |      |        | 0    |       |
|        | Note: Writing a logic 0 clears SBSW.       |        |                 |     |     |            |      |        |      |       |
| \$FE01 | SIM Reset Status Register<br>(SRSR)        | Read:  | POR             | PIN | COP | ILOP       | ILAD | MODRST | LVI  | 0     |
|        |                                            | Write: |                 |     |     |            |      |        |      |       |
|        |                                            | POR:   | 1               | 0   | 0   | 0          | 0    | 0      | 0    | 0     |
| \$FE02 | SIM Upper Byte Address<br>Register (SUBAR) | Read:  | B               | B   | B   | B          | B    | D      | B    | Р     |
|        |                                            | Write: | 11              | 11  | 11  | п          | 11   | 11     | 11   |       |
|        |                                            | Reset: |                 | _   |     |            |      |        |      |       |
|        |                                            | (      | = Unimplemented |     | R   | = Reserved |      |        |      |       |

Figure 14-2. SIM I/O Register Summary



#### System Integration Module (SIM)

## 14.2.1 Bus Timing

In user mode, the internal bus frequency is either the crystal oscillator output (CGMXCLK) divided by four or the PLL output (CGMVCLK) divided by four.

## 14.2.2 Clock Startup from POR or LVI Reset

When the power-on reset module or the low-voltage inhibit module generates a reset, the clocks to the CPU and peripherals are inactive and held in an inactive phase until after the 4096 CGMXCLK cycle POR timeout has completed. The RST pin is driven low by the SIM during this entire period. The IBUS clocks start upon completion of the timeout.

## 14.2.3 Clocks in Stop Mode and Wait Mode

Upon exit from stop mode by an interrupt, break, or reset, the SIM allows CGMXCLK to clock the SIM counter. The CPU and peripheral clocks do not become active until after the stop delay timeout. This timeout is selectable as 4096 or 32 CGMXCLK cycles. (See 14.6.2 Stop Mode.)

In wait mode, the CPU clocks are inactive. The SIM also produces two sets of clocks for other modules. Refer to the wait mode subsection of each module to see if the module is active or inactive in wait mode. Some modules can be programmed to be active in wait mode.

# 14.3 Reset and System Initialization

The MCU has these reset sources:

- Power-on reset module (POR)
- External reset pin (RST)
- Computer operating properly module (COP)
- Low-voltage inhibit module (LVI)
- Illegal opcode
- Illegal address

All of these resets produce the vector \$FFFE:\$FFFF (\$FEFE:\$FEFF in monitor mode) and assert the internal reset signal (IRST). IRST causes all registers to be returned to their default values and all modules to be returned to their reset states.

An internal reset clears the SIM counter (see 14.4 SIM Counter), but an external reset does not. Each of the resets sets a corresponding bit in the SIM reset status register (SRSR). (See 14.7 SIM Registers.)

## 14.3.1 External Pin Reset

The  $\overrightarrow{RST}$  pin circuit includes an internal pullup device. Pulling the asynchronous  $\overrightarrow{RST}$  pin low halts all processing. The PIN bit of the SIM reset status register (SRSR) is set as long as  $\overrightarrow{RST}$  is held low for a minimum of 67 CGMXCLK cycles, assuming that neither the POR nor the LVI was the source of the reset. See Table 14-2 for details. Figure 14-4 shows the relative timing.

| Reset Recovery Type | Actual Number of Cycles |  |  |  |  |
|---------------------|-------------------------|--|--|--|--|
| POR/LVI             | 4163 (4096 + 64 + 3)    |  |  |  |  |
| All others          | 67 (64 + 3)             |  |  |  |  |

 Table 14-2. Reset Recovery Type

**Timer Interface Module (TIM)** 

#### NOTE

If you read TCNTH during a break interrupt, be sure to unlatch TCNTL by reading TCNTL before exiting the break interrupt. Otherwise, TCNTL retains the value latched during the break.





## 17.9.3 TIM Counter Modulo Registers

The read/write TIM modulo registers contain the modulo value for the TIM counter. When the TIM counter reaches the modulo value, the overflow flag (TOF) becomes set, and the TIM counter resumes counting from \$0000 at the next timer clock. Writing to the high byte (TMODH) inhibits the TOF bit and overflow interrupts until the low byte (TMODL) is written. Reset sets the TIM counter modulo registers.



Figure 17-7. TIM Counter Modulo Register High (TMODH)

Address: T1MODL, \$0024 and T2MODL, \$002F

|                 | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|-----------------|-------|---|---|---|---|---|---|-------|
| Read:<br>Write: | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| Reset:          | 1     | 1 | 1 | 1 | 1 | 1 | 1 | 1     |

Figure 17-8. TIM Counter Modulo Register Low (TMODL)





#### **Break Module (BRK)**

When the internal address bus matches the value written in the break address registers or when software writes a 1 to the BRKA bit in the break status and control register, the CPU starts a break interrupt by:

- Loading the instruction register with the SWI instruction
- Loading the program counter with \$FFFC and \$FFFD (\$FEFC and \$FEFD in monitor mode)

The break interrupt timing is:

- When a break address is placed at the address of the instruction opcode, the instruction is not executed until after completion of the break interrupt routine.
- When a break address is placed at an address of an instruction operand, the instruction is executed before the break interrupt.
- When software writes a 1 to the BRKA bit, the break interrupt occurs just before the next instruction is executed.

By updating a break address and clearing the BRKA bit in a break interrupt routine, a break interrupt can be generated continuously.

#### CAUTION

A break address should be placed at the address of the instruction opcode. When software does not change the break address and clears the BRKA bit in the first break interrupt routine, the next break interrupt will not be generated after exiting the interrupt routine even when the internal address bus matches the value written in the break address registers.

## 18.2.1.1 Flag Protection During Break Interrupts

The system integration module (SIM) controls whether or not module status bits can be cleared during the break state. The BCFE bit in the break flag control register (SBFCR) enables software to clear status bits during the break state. See Figure 18-7. SIM Break Flag Control Register (SBFCR) and the **Break Interrupts** subsection for each module.

#### 18.2.1.2 TIM During Break Interrupts

A break interrupt stops the timer counter.

#### 18.2.1.3 COP During Break Interrupts

The COP is disabled during a break interrupt when  $V_{TST}$  is present on the  $\overline{RST}$  pin.

#### **18.2.2 Break Module Registers**

These registers control and monitor operation of the break module:

- Break status and control register (BRKSCR)
- Break address register high (BRKH)
- Break address register low (BRKL)
- Break status register (SBSR)
- Break flag control register (SBFCR)



#### **Electrical Specifications**

| Characteristic <sup>(1)</sup>                                                                                 | Symbol                              | Min                   | Тур <sup>(2)</sup> | Мах     | Unit |
|---------------------------------------------------------------------------------------------------------------|-------------------------------------|-----------------------|--------------------|---------|------|
| Pullup resistors (as input only)<br>Ports PTA7/KBD7–PTA0/KBD0, PTC6–PTC0,<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 | _                  | 9       | 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.20                  | 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 |

Notes:

1.  $V_{DD}$  = 5.0 Vdc ± 10%,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_L$  to  $T_H$ , unless otherwise noted

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

3. Run (operating) I<sub>DD</sub> measured using external square wave clock source ( $f_{OSC}$  = 32.8 MHz). All inputs 0.2V 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 run I<sub>DD</sub>. Measured with all modules enabled.

4. Wait I<sub>DD</sub> measured using external square wave clock source ( $f_{OSC}$  = 32.8 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 PLL and LVI enabled.

5. Stop  $I_{DD}$  is measured with OSC1 = V<sub>SS</sub>.

6. Stop I<sub>DD</sub> with TBM enabled is measured using an external square wave clock source (f<sub>OSC</sub> = 32.8 MHz). All inputs 0.2V 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_{\mbox{SS}}$  and  $V_{\mbox{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.

- 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 19.12 ADC Characteristics.

12. Maximum is highest voltage that POR is guaranteed.

13. Maximum is highest voltage that POR is possible.

14. If minimum V<sub>DD</sub> is not reached before the internal POR reset is released, RST must be driven low externally until minimum V<sub>DD</sub> is reached.



# **19.11 Typical Supply Currents**



Figure 19-14. Typical Operating I<sub>DD</sub>, with All Modules Turned On (–40  $^{\circ}$ C to 85  $^{\circ}$ C)



Figure 19-15. Typical Wait Mode I<sub>DD</sub>, with all Modules Disabled (–40  $^{\circ}$ C to 85  $^{\circ}$ C)



Figure 19-16. Typical Stop Mode I<sub>DD</sub>, with all Modules Disabled (–40 °C to 85 °C)