# E·XFL

#### NXP USA Inc. - MC908GZ60CFUER 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               | CANbus, SCI, SPI                                                       |
| Peripherals                | LVD, POR, PWM                                                          |
| Number of I/O              | 53                                                                     |
| Program Memory Size        | 60KB (60K x 8)                                                         |
| Program Memory Type        | FLASH                                                                  |
| EEPROM Size                | -                                                                      |
| RAM Size                   | 2K x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                                              |
| Data Converters            | A/D 24x10b                                                             |
| Oscillator Type            | Internal                                                               |
| Operating Temperature      | -40°C ~ 85°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/mc908gz60cfuer |

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 212.                                        | Reset:          |       | Unaffected by reset |         |         |                        |         |          |            |  |  |  |
| \$0019                     | ESCI Baud Rate Register<br>(SCBR)                    | Read:<br>Write: | LINT  | LINR                | SCP1    | SCP0    | R                      | SCR2    | SCR1     | SCR0       |  |  |  |
|                            | See page 212.                                        | Reset:          | 0     | 0                   | 0       | 0       | 0                      | 0       | 0        | 0          |  |  |  |
| Kevboard Status and Contro |                                                      | Read:           | 0     | 0                   | 0       | 0       | KEYF                   | 0       | IMACKK   | MODEK      |  |  |  |
| \$001A                     | Register (INTKBSCR)                                  | Write:          |       |                     |         |         |                        | ACKK    | INASKK   |            |  |  |  |
|                            | See page 120.                                        | 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 121.                                        | Reset:          | 0     | 0                   | 0       | 0       | 0                      | 0       | 0        | 0          |  |  |  |
|                            | Timebase Module Control<br>Register (TBCR)           | Read:           | TBIF  | TBD2                | TBD1    | TBBO    | 0                      | TRIE    |          | P          |  |  |  |
| \$001C                     |                                                      | Write:          |       | TUNE                | IDITI   | TDITO   | TACK                   | IDIL    | TOON     | n          |  |  |  |
|                            | See page 262.                                        | 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     | INIAGI   | NIODL      |  |  |  |
|                            | See page 114.                                        | Reset:          | 0     | 0                   | 0       | 0       | 0                      | 0       | 0        | 0          |  |  |  |
|                            | Configuration Register 2                             | Read:           | 0     |                     | MCLK1   | MCI KO  | MSCAN-                 | TMBCLK- | OSCENIN- | SCIBDSBC   |  |  |  |
| \$001E                     | (CONFIG2) <sup>(1)</sup><br>See nage 92              | Write:          |       | MOLINOLL            | WOLKI   | WIOLINO | EN <sup>(1)</sup>      | SEL     | STOP     | COLDEDITIO |  |  |  |
|                            | 000 page 02.                                         | 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 | LVI5OR3 <sup>(1)</sup> | SSREC   | STOP     | COPD       |  |  |  |
|                            | See page 93.                                         | Reset:          | 0     | 0                   | 0       | 0       | 0                      | 0       | 0        | 0          |  |  |  |

1. One-time writable register after each reset, except MSCANEN and LVI5OR3 bits. MSCANEN andLVI5OR3 bits are only reset via POR (power-on reset).

|            | TIM1 Status and Control |        | TOF           | TOIE       | TSTOP | 0           | 0  | DC0          |     | DEO   |
|------------|-------------------------|--------|---------------|------------|-------|-------------|----|--------------|-----|-------|
| \$0020     | Register (T1SC)         | Write: | 0             | TOIL       | 13105 | TRST        |    | F 32         | F31 | F 30  |
|            | See page 271.           | 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 2 | See page 273.           | 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 273.           | Reset: | 0             | 0          | 0     | 0           | 0  | 0            | 0   | 0     |
|            | TIM1 Counter Modulo     | Read:  | <b>Bit 15</b> | 14         | 12    | 10          | 11 | 10           | 0   | Dit 0 |
| \$0023     | Register High (T1MODH)  | Write: | DIL 15        | 14         | 15    | 12          | 11 | 10           | 9   | Dit o |
|            | See page 273.           | Reset: | 1             | 1          | 1     | 1           | 1  | 1            | 1   | 1     |
|            |                         |        |               | = Unimplem | ented | R = Reserve | d  | U = Unaffect | ed  |       |

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



#### FLASH-1 Memory (FLASH-1)







# Chapter 3 Analog-to-Digital Converter (ADC)

### 3.1 Introduction

This section describes the 10-bit analog-to-digital converter (ADC).

### 3.2 Features

Features of the ADC module include:

- 24 channels with multiplexed input
- Linear successive approximation with monotonicity
- 10-bit resolution
- Single or continuous conversion
- Conversion complete flag or conversion complete interrupt
- Selectable ADC clock
- Left or right justified result
- Left justified sign data mode

### 3.3 Functional Description

The ADC provides 24 pins for sampling external sources at pins PTG7/AD23–PTG0/AD16, PTA7/KBD7/AD15–PTA0/KBD0/AD8, and PTB7/AD7–PTB0/AD0. An analog multiplexer allows the single ADC converter to select one of 24 ADC channels as ADC voltage in (V<sub>ADIN</sub>). V<sub>ADIN</sub> is converted by the successive approximation register-based analog-to-digital converter. When the conversion is completed, ADC places the result in the ADC data register and sets a flag or generates an interrupt. See Figure 3-2.

### 3.3.1 ADC Port I/O Pins

PTG7/AD23–PTG0/AD16, PTA7/KBD7/AD15–PTA0/KBD0/AD8, and PTB7/AD7–PTB0/AD0 are general-purpose I/O (input/output) pins that share with the ADC channels. The channel select bits define which ADC channel/port pin will be used as the input signal. The ADC overrides the port I/O logic by forcing that pin as input to the ADC. The remaining ADC channels/port pins are controlled by the port I/O logic and can be used as general-purpose I/O. Writes to the port register or data direction register (DDR) will not have any affect on the port pin that is selected by the ADC. A read of a port pin in use by the ADC will return a 0.



#### MUL7–MUL0 — Multiplier Select Bits

These read/write bits control the low byte of the modulo feedback divider that selects the VCO frequency multiplier, N. (See 4.3.3 PLL Circuits and 4.3.6 Programming the PLL.) MUL7–MUL0 cannot be written when the PLLON bit in the PCTL is set. A value of \$0000 in the multiplier select registers configures the modulo feedback divider the same as a value of \$0001. Reset initializes the register to \$40 for a default multiply value of 64.

#### NOTE

The multiplier select bits have built-in protection such that they cannot be written when the PLL is on (PLLON = 1).

#### 4.5.5 PLL VCO Range Select Register

The PLL VCO range select register (PMRS) contains the programming information required for the hardware configuration of the VCO.

| Address:        | \$003A |      |      |      |      |      |      |       |
|-----------------|--------|------|------|------|------|------|------|-------|
|                 | Bit 7  | 6    | 5    | 4    | 3    | 2    | 1    | Bit 0 |
| Read:<br>Write: | VRS7   | VRS6 | VRS5 | VRS4 | VRS3 | VRS2 | VRS1 | VRS0  |
| Reset:          | 0      | 1    | 0    | 0    | 0    | 0    | 0    | 0     |

Figure 4-8. PLL VCO Range Select Register (PMRS)

#### NOTE

Verify that the value of the PMRS register is appropriate for the given reference and VCO clock frequencies before enabling the PLL. See 4.3.6 Programming the PLL for detailed instructions on selecting the proper value for these control bits.

#### VRS7–VRS0 — VCO Range Select Bits

These read/write bits control the hardware center-of-range linear multiplier L which, in conjunction with E (See 4.3.3 PLL Circuits, 4.3.6 Programming the PLL, and 4.5.1 PLL Control Register.), controls the hardware center-of-range frequency,  $f_{VRS}$ . VRS7–VRS0 cannot be written when the PLLON bit in the PCTL is set. (See 4.3.7 Special Programming Exceptions.) A value of \$00 in the VCO range select register disables the PLL and clears the BCS bit in the PLL control register (PCTL). (See 4.3.8 Base Clock Selector Circuit and 4.3.7 Special Programming Exceptions.). Reset initializes the register to \$40 for a default range multiply value of 64.

#### NOTE

The VCO range select bits have built-in protection such that they cannot be written when the PLL is on (PLLON = 1) and such that the VCO clock cannot be selected as the source of the base clock (BCS = 1) if the VCO range select bits are all clear.

The PLL VCO range select register must be programmed correctly. Incorrect programming can result in failure of the PLL to achieve lock.



# Chapter 5 Configuration Register (CONFIG)

### 5.1 Introduction

This section describes the configuration registers, CONFIG1 and CONFIG2. The configuration registers enable or disable these options:

- Stop mode recovery time (32 CGMXCLK cycles or 4096 CGMXCLK cycles)
- COP timeout period (262,128 or 8176 CGMXCLK cycles)
- STOP instruction
- Computer operating properly module (COP)
- Low-voltage inhibit (LVI) module control and voltage trip point selection
- Enable/disable the oscillator (OSC) during stop mode
- Enable/disable an extra divide by 128 prescaler in timebase module
- Enable for scalable controller area network (MSCAN)
- Selectable clockout (MCLK) feature with divide by 1, 2, and 4 of the bus or crystal frequency
- Timebase clock select

### 5.2 Functional Description

The configuration registers are used in the initialization of various options. The configuration registers can be written once after each reset. All of the configuration register bits are cleared during reset. Since the various options affect the operation of the microcontroller unit (MCU), it is recommended that these registers be written immediately after reset. The configuration registers are located at \$001E and \$001F and may be read at anytime.

#### NOTE

On a FLASH device, the options except MSCANEN and LVI5OR3 are one-time writable by the user after each reset. These bits are one-time writable by the user only after each POR (power-on reset). The CONFIG registers are not in the FLASH memory but are special registers containing one-time writable latches after each reset. Upon a reset, the CONFIG registers default to predetermined settings as shown in Figure 5-1 and Figure 5-2.



#### **Configuration Register (CONFIG)**

#### LVI5OR3 — LVI 5-V or 3-V Operating Mode Bit

LVI5OR3 selects the voltage operating mode of the LVI module (see Chapter 11 Low-Voltage Inhibit (LVI)). The voltage mode selected for the LVI should match the operating  $V_{DD}$  (see Chapter 21

Electrical Specifications) for the LVI's voltage trip points for each of the modes.

1 = LVI operates in 5-V mode

0 = LVI operates in 3-V mode

#### NOTE

The LVI5OR3 bit is cleared by a power-on reset (POR) only. Other resets will leave this bit unaffected.

#### SSREC — Short Stop Recovery Bit

SSREC enables the CPU to exit stop mode with a delay of 32 CGMXCLK cycles instead of a 4096-CGMXCLK cycle delay.

1 = Stop mode recovery after 32 CGMXCLK cycles

0 = Stop mode recovery after 4096 CGMXCLK cycles

#### NOTE

Exiting stop mode by any reset will result in the long stop recovery.

The short stop recovery delay can be enabled when using a crystal or resonator and the OSCENINSTOP bit is set. The short stop recovery delay can be enabled when an external oscillator is used, regardless of the OSCENINSTOP setting.

The short stop recovery delay must be disabled when the OSCENINSTOP bit is clear and a crystal or resonator is used.

#### STOP — STOP Instruction Enable Bit

STOP enables the STOP instruction.

- 1 = STOP instruction enabled
- 0 = STOP instruction treated as illegal opcode

#### COPD — COP Disable Bit

COPD disables the COP module. See Chapter 6 Computer Operating Properly (COP) Module.

- 1 = COP module disabled
- 0 = COP module enabled



#### 7.3.3 Stack Pointer

The stack pointer is a 16-bit register that contains the address of the next location on the stack. During a reset, the stack pointer is preset to \$00FF. The reset stack pointer (RSP) instruction sets the least significant byte to \$FF and does not affect the most significant byte. The stack pointer decrements as data is pushed onto the stack and increments as data is pulled from the stack.

In the stack pointer 8-bit offset and 16-bit offset addressing modes, the stack pointer can function as an index register to access data on the stack. The CPU uses the contents of the stack pointer to determine the conditional address of the operand.



Figure 7-4. Stack Pointer (SP)

#### NOTE

The location of the stack is arbitrary and may be relocated anywhere in random-access memory (RAM). Moving the SP out of page 0 (\$0000 to \$00FF) frees direct address (page 0) space. For correct operation, the stack pointer must point only to RAM locations.

#### 7.3.4 Program Counter

The program counter is a 16-bit register that contains the address of the next instruction or operand to be fetched.

Normally, the program counter automatically increments to the next sequential memory location every time an instruction or operand is fetched. Jump, branch, and interrupt operations load the program counter with an address other than that of the next sequential location.

During reset, the program counter is loaded with the reset vector address located at \$FFFE and \$FFFF. The vector address is the address of the first instruction to be executed after exiting the reset state.



Figure 7-5. Program Counter (PC)



**Central Processor Unit (CPU)** 

### 7.7 Instruction Set Summary

Table 7-1 provides a summary of the M68HC08 instruction set.

| Source                                                                                            |                                                                        |                                                                                                  |   |   | Eff | ec        | t |     | ess                                                                                                      | de                                                           | bne                                                | s                                    |
|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|---|---|-----|-----------|---|-----|----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|----------------------------------------------------|--------------------------------------|
| Form                                                                                              | Operation                                                              | Description                                                                                      | v | Ч |     |           | 7 | C   | ddre<br>ode                                                                                              | bco                                                          | pera                                               | ycle                                 |
| ADC #opr<br>ADC opr<br>ADC opr<br>ADC opr,X<br>ADC opr,X<br>ADC ,X<br>ADC opr,SP<br>ADC opr,SP    | Add with Carry                                                         | A ← (A) + (M) + (C)                                                                              | ţ | ţ | -   | t         | ¢ | ţ   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                                      | <b>O</b><br>A9<br>B9<br>C9<br>D9<br>E9<br>F9<br>9EE9<br>9ED9 | O<br>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 |
| ADD #opr<br>ADD opr<br>ADD opr<br>ADD opr,X<br>ADD opr,X<br>ADD opr,X<br>ADD opr,SP<br>ADD opr,SP | Add without Carry                                                      | A ← (A) + (M)                                                                                    | ţ | ţ | _   | ţ         | ţ | ţ   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                                      | AB<br>BB<br>CB<br>DB<br>EB<br>FB<br>9EEB<br>9EDB             | 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 |
| AIS #opr                                                                                          | Add Immediate Value (Signed) to SP                                     | $SP \leftarrow (SP) + (16 \ \ M)$                                                                | - | - | -   | -         | - | -   | IMM                                                                                                      | A7                                                           | ii                                                 | 2                                    |
| AIX #opr                                                                                          | Add Immediate Value (Signed) to H:X                                    | $H:X \leftarrow (H:X) + (16 \mathrel{{\scriptstyle \triangleleft}} M)$                           | - | - | -   | -         | - | -   | IMM                                                                                                      | AF                                                           | ii                                                 | 2                                    |
| AND #opr<br>AND opr<br>AND opr<br>AND opr,X<br>AND opr,X<br>AND ,X<br>AND opr,SP<br>AND opr,SP    | Logical AND                                                            | A ← (A) & (M)                                                                                    | 0 | - | _   | ţ         | ţ | -   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                                      | A4<br>B4<br>C4<br>D4<br>E4<br>F4<br>9EE4<br>9ED4             | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ff<br>ee ff    | 2 3 4 4 3 2 4 5                      |
| ASL opr<br>ASLA<br>ASLX<br>ASL opr,X<br>ASL ,X<br>ASL ,X<br>ASL opr,SP                            | Arithmetic Shift Left<br>(Same as LSL)                                 | C                                                                                                | ţ | _ | _   | ţ         | ţ | ţ   | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1                                                                    | 38<br>48<br>58<br>68<br>78<br>9E68                           | dd<br>ff<br>ff                                     | 4<br>1<br>4<br>3<br>5                |
| ASR opr<br>ASRA<br>ASRX<br>ASR opr,X<br>ASR opr,X<br>ASR opr,SP                                   | Arithmetic Shift Right                                                 |                                                                                                  | ţ | _ | _   | ţ         | ţ | ţ   | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1                                                                    | 37<br>47<br>57<br>67<br>77<br>9E67                           | dd<br>ff<br>ff                                     | 4<br>1<br>4<br>3<br>5                |
| BCC rel                                                                                           | Branch if Carry Bit Clear                                              | $PC \leftarrow (PC) + 2 + rel ? (C) = 0$                                                         | - | - | —   | _         | - | -   | REL                                                                                                      | 24                                                           | rr                                                 | 3                                    |
| BCLR n, opr                                                                                       | Clear Bit n in M                                                       | Mn ← 0                                                                                           | _ | _ | _   | _         | _ | _   | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 11<br>13<br>15<br>17<br>19<br>1B<br>1D<br>1F                 | dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>4 |
| BCS rel                                                                                           | Branch if Carry Bit Set (Same as BLO)                                  | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (C) = 1$                                                | - | - | -   | -         | - | -   | REL                                                                                                      | 25                                                           | rr                                                 | 3                                    |
| BEQ rel                                                                                           | Branch if Equal                                                        | ranch if Equal $PC \leftarrow (PC) + 2 + rel? (Z) = 1$                                           |   | - | -   | -         | - | -   | REL                                                                                                      | 27                                                           | rr                                                 | 3                                    |
| BGE opr                                                                                           | Branch if Greater Than or Equal To (Signed Operands)                   | ich if Greater Than or Equal To PC $\leftarrow$ (PC) + 2 + rel? (N $\oplus$ V) = 0 ned Operands) |   | - | -   | -         | - | -   | REL                                                                                                      | 90                                                           | rr                                                 | 3                                    |
| BGT opr                                                                                           | Branch if Greater Than (Signed<br>Operands)                            | _                                                                                                | - | - | -   | -         | - | REL | 92                                                                                                       | rr                                                           | 3                                                  |                                      |
| BHCC rel                                                                                          | Branch if Half Carry Bit Clear $PC \leftarrow (PC) + 2 + rel? (H) = 0$ |                                                                                                  |   |   |     | -         | - | -   | REL                                                                                                      | 28                                                           | rr                                                 | 3                                    |
| BHCS rel                                                                                          | Branch if Half Carry Bit Set                                           | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (H) = 1$                                                | - | - | -   | <u> -</u> | - | -   | REL                                                                                                      | 29                                                           | rr                                                 | 3                                    |
| BHI <i>rel</i>                                                                                    | Branch if Higher                                                       | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (C) \mid (Z) = 0$                                       | - | - | -   | -         | - | -   | REL                                                                                                      | 22                                                           | rr                                                 | 3                                    |

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



**Central Processor Unit (CPU)** 

.

| Course                                                                                         |                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |        | Eff | ect | t        |   | SS                                                  | de                                               | pu                                        | s                     |
|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|-----|-----|----------|---|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------|-----------------------|
| Form                                                                                           | Operation                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | v | о<br>Ц |     |     | n<br>  7 | 6 | ddre<br>ode                                         | bco                                              | pera                                      | /cle                  |
|                                                                                                |                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | v | п      | •   | IN  | 2        | C | Ă                                                   | ō                                                | ō                                         | С<br>С                |
| PULA                                                                                           | Pull A from Stack                                                 | $SP \leftarrow (SP + 1); Pull (A)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | - | -      | -   | -   | -        | - | INH                                                 | 86                                               |                                           | 2                     |
|                                                                                                | Pull H from Stack                                                 | $SP \leftarrow (SP + 1); Pull (H)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | - | -      | -   | -   | -        | - |                                                     | 8A                                               |                                           | 2                     |
| PULX                                                                                           | Pull X from Stack                                                 | $SP \leftarrow (SP + 1); Pull(X)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | - | -      | -   | -   | -        | - |                                                     | 88                                               | 44                                        | 2                     |
| ROLA<br>ROLX<br>ROL <i>opr</i> ,X<br>ROL ,X<br>ROL <i>opr</i> ,SP                              | Rotate Left through Carry                                         | C ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← \to _ | ţ | _      | _   | 1   | ţ        | ţ | INH<br>INH<br>IX1<br>IX<br>SP1                      | 49<br>59<br>69<br>79<br>9E69                     | 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}{l} 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}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ţ | ţ      | ţ   | 1   | ţ        | ţ | INH                                                 | 80                                               |                                           | 7                     |
| RTS                                                                                            | Return from Subroutine                                            | $SP \leftarrow SP + 1$ ; Pull (PCH)<br>$SP \leftarrow SP + 1$ ; Pull (PCL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | - | -      | -   | I   | _        | - | 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 \leftarrow (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 ← 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | - | -      | -   | -   | -        | 1 | INH                                                 | 99                                               |                                           | 1                     |
| SEI                                                                                            | Set Interrupt Mask                                                | l ← 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | - | -      | 1   | -   | -        | - | INH                                                 | 9B                                               |                                           | 2                     |
| STA opr<br>STA opr<br>STA opr,X<br>STA opr,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) \leftarrow (H{:}X)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0 | -      | -   | \$  | \$       | - | DIR                                                 | 35                                               | dd                                        | 4                     |
| STOP                                                                                           | Enable Interrupts, Stop Processing,<br>Refer to MCU Documentation | $I \leftarrow 0$ ; Stop Processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | - | -      | 0   | 1   | -        | - | INH                                                 | 8E                                               |                                           | 1                     |
| STX opr<br>STX opr<br>STX opr,X<br>STX opr,X<br>STX,X<br>STX,X<br>STX opr,SP<br>STX opr,SP     | Store X in M                                                      | M ← (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 II<br>ee ff<br>ff<br>ee ff       | 344<br>324<br>5       |
| SUB #opr<br>SUB opr<br>SUB opr<br>SUB opr,X<br>SUB opr,X<br>SUB ,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 | 23443245              |

| Table 7-1. | Instruction | Set Summary | (Sheet 5 of 6) |
|------------|-------------|-------------|----------------|
|------------|-------------|-------------|----------------|



#### External Interrupt (IRQ)



Figure 8-1. IRQ Module Block Diagram

When an interrupt pin is both falling-edge and low-level triggered (MODE = 1), the interrupt remains set until both of these events occur:

- Vector fetch or software clear
- Return of the interrupt pin to a high level

The vector fetch or software clear may occur before or after the interrupt pin returns to a high level. As long as the pin is low, the interrupt request remains pending. A reset will clear the latch and the MODE control bit, thereby clearing the interrupt even if the pin stays low.

When set, the IMASK bit in the INTSCR masks all external interrupt requests. A latched interrupt request is not presented to the interrupt priority logic unless the IMASK bit is clear.









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

Another way to avoid a false interrupt:

- 1. Configure the keyboard pins as outputs by setting the appropriate DDRA bits in data direction register A.
- 2. Write 1s (or 0s) to the appropriate port A data register bits.
- 3. Enable the KBI pins and polarity by setting the appropriate KBIEx bits in the keyboard interrupt enable register and the KBIPx bits in the keyboard interrupt polarity register.

### 9.5 Low-Power Modes

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

#### 9.5.1 Wait Mode

The keyboard module remains active in wait mode. Clearing the IMASKK bit in the keyboard status and control register enables keyboard interrupt requests to bring the MCU out of wait mode.

### 9.5.2 Stop Mode

The keyboard module remains active in stop mode. Clearing the IMASKK bit in the keyboard status and control register enables keyboard interrupt requests to bring the MCU out of stop mode.

### 9.6 Keyboard Module During Break Interrupts

The system integration module (SIM) controls whether the keyboard interrupt latch can be cleared during the break state. The BCFE bit in the break flag control register (BFCR) enables software to clear status bits during the break state.

To allow software to clear the keyboard interrupt 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 the latch during the break state, write a 0 to the BCFE bit. With BCFE at 0 (its default state), writing to the keyboard acknowledge bit (ACKK) in the keyboard status and control register during the break state has no effect. See 9.7.1 Keyboard Status and Control Register.

### 9.7 I/O Registers

These registers control and monitor operation of the keyboard module:

- Keyboard status and control register (INTKBSCR)
- Keyboard interrupt enable register (INTKBIER)
- Keyboard interrupt polarity register (INTKBIPR)



MSCAN08 Controller (MSCAN08)

### 12.11 Memory Map

The MSCAN08 occupies 128 bytes in the CPU08 memory space. The absolute mapping is implementation dependent with the base address being a multiple of 128.

| \$0500 | CONTROL REGISTERS |
|--------|-------------------|
| \$0508 | 9 BYTES           |
| \$0509 | RESERVED          |
| \$050D | 5 BYTES           |
| \$050E | ERROR COUNTERS    |
| \$050F | 2 BYTES           |
| \$0510 | IDENTIFIER FILTER |
| \$0517 | 8 BYTES           |
| \$0518 | RESERVED          |
| \$053F | 40 BYTES          |
| \$0540 | RECEIVE BUFFER    |
| \$054F |                   |
| \$0550 | TRANSMIT BUFFFB 0 |
| \$055F |                   |
| \$0560 | TRANSMIT BUFFFB 1 |
| \$056F |                   |
| \$0570 | TRANSMIT BUFFFB 2 |
| \$057F | HUMONIN BOTTETTZ  |

Figure 12-10. MSCAN08 Memory Map



Input/Output (I/O) Ports

| Port | Bit | DDR   | Мо         | odule Control | Мос | Iule Control | Pin          |
|------|-----|-------|------------|---------------|-----|--------------|--------------|
|      | 0   | DDRD0 |            |               |     |              | PTD0/SS/MCLK |
|      | 1   | DDRD1 | <b>CDI</b> | <u>ede</u>    |     |              | PTD1/MISO    |
|      | 2   | DDRD2 | 581        | SPE           |     |              | PTD2/MOSI    |
|      | 3   | DDRD3 |            |               |     |              | PTD3/SPSCK   |
|      | 4   | DDRD4 | TIM        | ELS0B:ELS0A   |     | —            | PTD4/T1CH0   |
|      | 5   | DDRD5 |            | ELS1B:ELS1A   |     |              | PTD5/T1CH1   |
|      | 6   | DDRD6 | TIMO       | ELS0B:ELS0A   |     |              | PTD6/T2CH0   |
|      | 7   | DDRD7 | TIMZ       | ELS1B:ELS1A   |     |              | PTD7/T2CH1   |
|      | 0   | DDRE0 | SCI        | ENSCI         |     |              | PTE0/TxD     |
|      | 1   | DDRE1 | 501        | ENGOI         |     |              | PTE1/RxD     |
| F    | 2   | DDRE2 |            |               |     |              | PTE2         |
|      | 3   | DDRE3 |            |               |     |              | PTE3         |
|      | 4   | DDRE4 |            |               |     |              | PTE4         |
|      | 5   | DDRE5 |            |               |     |              | PTE5         |
|      | 0   | DDRF0 |            |               |     |              | PTF0         |
|      | 1   | DDRF1 |            |               |     |              | PTF1         |
|      | 2   | DDRF2 |            |               |     |              | PTF2         |
| F    | 3   | DDRF3 |            |               |     |              | PTF3         |
| '    | 4   | DDRF4 |            | ELS2B:ELS2A   |     |              | PTF4/T2CH2   |
|      | 5   | DDRF5 | TIM2       | ELS3B:ELS3A   |     |              | PTF5/T2CH3   |
|      | 6   | DDRF6 | TIMZ       | ELS4B:ELS4A   |     |              | PTF6/T2CH4   |
|      | 7   | DDRF7 |            | ELS5B:ELS5A   |     |              | PTF7/T2CH5   |
|      | 0   | DDRG0 |            |               |     |              | PTG0/AD16    |
|      | 1   | DDRG1 |            |               |     |              | PTG1/AD17    |
|      | 2   | DDRG2 |            |               |     |              | PTG2/AD18    |
| G    | 3   | DDRG3 |            |               |     |              | PTG3/AD19    |
| G    | 4   | DDRG4 | ADC        | ADON[20.10]   |     | _            | PTG4/AD20    |
|      | 5   | DDRG5 |            |               |     |              | PTG5/AD21    |
|      | 6   | DDRG6 |            |               |     |              | PTG6/AD22    |
|      | 7   | DDRG7 |            |               |     |              | PTG7/AD23    |

| Table 13-1. Port Control Register Bits S | Summary (Continued) |
|------------------------------------------|---------------------|
|------------------------------------------|---------------------|



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

### 14.8.2 ESCI Control Register 2

ESCI control register 2 (SCC2):

- Enables these CPU interrupt requests:
  - SCTE bit to generate transmitter CPU interrupt requests
  - TC bit to generate transmitter CPU interrupt requests
  - SCRF bit to generate receiver CPU interrupt requests
  - IDLE bit to generate receiver CPU interrupt requests
- Enables the transmitter
- Enables the receiver
- Enables ESCI wakeup
- Transmits ESCI break characters



Figure 14-11. ESCI Control Register 2 (SCC2)

#### SCTIE — ESCI Transmit Interrupt Enable Bit

This read/write bit enables the SCTE bit to generate ESCI transmitter CPU interrupt requests. Setting the SCTIE bit in SCC2 enables the SCTE bit to generate CPU interrupt requests. Reset clears the SCTIE bit.

1 = SCTE enabled to generate CPU interrupt

0 = SCTE not enabled to generate CPU interrupt

#### TCIE — Transmission Complete Interrupt Enable Bit

This read/write bit enables the TC bit to generate ESCI transmitter CPU interrupt requests. Reset clears the TCIE bit.

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

#### SCRIE — ESCI Receive Interrupt Enable Bit

This read/write bit enables the SCRF bit to generate ESCI receiver CPU interrupt requests. Setting the SCRIE bit in SCC2 enables the SCRF bit to generate CPU interrupt requests. Reset clears the SCRIE bit.

1 = SCRF enabled to generate CPU interrupt

0 = SCRF not enabled to generate CPU interrupt

#### ILIE — Idle Line Interrupt Enable Bit

This read/write bit enables the IDLE bit to generate ESCI 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



System Integration Module (SIM)

### 15.2 SIM Bus Clock Control and Generation

The bus clock generator provides system clock signals for the CPU and peripherals on the MCU. The system clocks are generated from an incoming clock, CGMOUT, as shown in Figure 15-3. This clock originates from either an external oscillator or from the on-chip PLL.



Figure 15-3. System Clock Signals

### 15.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.

### 15.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 bus clocks start upon completion of the timeout.

### 15.2.3 Clocks in Stop Mode and Wait Mode

Upon exit from stop mode by an interrupt 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 15.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.



#### **Transmission Formats**

pin of the master must be high or must be reconfigured as general-purpose I/O not affecting the SPI. (See 16.6.2 Mode Fault Error.) When CPHA = 1, the master begins driving its MOSI pin on the first SPSCK edge. Therefore, the slave uses the first SPSCK edge as a start transmission signal. The  $\overline{SS}$  pin can remain low between transmissions. This format may be preferable in systems having only one master and only one slave driving the MISO data line.



When CPHA = 1 for a slave, the first edge of the SPSCK indicates the beginning of the transmission. This causes the SPI to leave its idle state and begin driving the MISO pin with the MSB of its data. Once the transmission begins, no new data is allowed into the shift register from the transmit data register. Therefore, the SPI data register of the slave must be loaded with transmit data before the first edge of SPSCK. Any data written after the first edge is stored in the transmit data register and transferred to the shift register after the current transmission.

#### 16.4.4 Transmission Initiation Latency

When the SPI is configured as a master (SPMSTR = 1), writing to the SPDR starts a transmission. CPHA has no effect on the delay to the start of the transmission, but it does affect the initial state of the SPSCK signal. When CPHA = 0, the SPSCK signal remains inactive for the first half of the first SPSCK cycle. When CPHA = 1, the first SPSCK cycle begins with an edge on the SPSCK line from its inactive to its active level. The SPI clock rate (selected by SPR1:SPR0) affects the delay from the write to SPDR and the start of the SPI transmission. (See Figure 16-8.) The internal SPI clock in the master is a free-running derivative of the internal MCU clock. To conserve power, it is enabled only when both the SPE and SPMSTR bits are set. Since the SPI clock is free-running, it is uncertain where the write to the SPDR occurs relative to the slower SPSCK. This uncertainty causes the variation in the initiation delay shown in Figure 16-8. This delay is no longer than a single SPI bit time. That is, the maximum delay is two MCU bus cycles for DIV2, eight MCU bus cycles for DIV8, 32 MCU bus cycles for DIV32, and 128 MCU bus cycles for DIV128.

#### Timer Interface Module (TIM1)

N

| Addr.  | Register Name                                |                 | Bit 7  | 6          | 5      | 4                         | 3              | 2      | 1     | Bit 0    |  |  |
|--------|----------------------------------------------|-----------------|--------|------------|--------|---------------------------|----------------|--------|-------|----------|--|--|
|        | TIM1 Status and Control                      | Read:           | TOF    | TOIE       | TOTOD  | 0                         | 0              | DCO    | DC1   | DCO      |  |  |
| \$0020 | Register (T1SC)                              | Write:          | 0      | IUIE       | 1310P  | TRST                      |                | P 52   | P31   | P30      |  |  |
|        | See page 271.                                | Reset:          | 0      | 0          | 1      | 0                         | 0              | 0      | 0     | 0        |  |  |
|        | TIM1 Counter Register High                   | Read:           | Bit 15 | Bit 14     | Bit 13 | Bit 12                    | Bit 11         | Bit 10 | Bit 9 | Bit 8    |  |  |
| \$0021 | (T1CNTH)                                     | Write:          |        |            |        |                           |                |        |       |          |  |  |
|        | See page 273.                                | Reset:          | 0      | 0          | 0      | 0                         | 0              | 0      | 0     | 0        |  |  |
|        | TIM1 Counter Register Low                    | Read:           | Bit 7  | Bit 6      | Bit 5  | Bit 4                     | Bit 3          | Bit 2  | Bit 1 | Bit 0    |  |  |
| \$0022 | (T1CNTL)                                     | Write:          |        |            |        |                           |                |        |       |          |  |  |
|        | See page 273.                                |                 | 0      | 0          | 0      | 0                         | 0              | 0      | 0     | 0        |  |  |
|        | TIM1 Counter Modulo Register                 |                 | Bit 15 | Bit 14     | Bit 13 | Bit 12                    | Bit 11         | Bit 10 | Bit 9 | Bit 8    |  |  |
| \$0023 | Hign (11MODH)<br>See page 273.               | Write:          |        |            |        |                           |                |        |       |          |  |  |
|        |                                              | Reset:          | 1      | 1          | 1      | 1                         | 1              | 1      | 1     | 1        |  |  |
| \$0024 | TIM1 Counter Modulo Register<br>Low (T1MODL) | Read:<br>Write: | Bit 7  | Bit 6      | Bit 5  | Bit 4                     | Bit 3          | Bit 2  | Bit 1 | Bit 0    |  |  |
|        | See page 273.                                |                 | 1      | 1          | 1      | 1                         | 1              | 1      | 1     | 1        |  |  |
|        | TIM1 Channel 0 Status and                    | Read:           | CH0F   | CHOIE      | MEOR   | MEOA                      |                |        | TOVO  | CHOMAX   |  |  |
| \$0025 | Control Register (T1SC0)                     | Write:          | 0      |            | IVISUD | MSUA                      | ELSUD          | ELSUA  | 1000  | CHUIVIAX |  |  |
|        | See page 274.                                | Reset:          | 0      | 0          | 0      | 0                         | 0              | 0      | 0     | 0        |  |  |
| \$0026 | TIM1 Channel 0 Register High<br>(T1CH0H)     | Read:<br>Write: | Bit 15 | Bit 14     | Bit 13 | Bit 12                    | Bit 11         | Bit 10 | Bit 9 | Bit 8    |  |  |
|        | See page 277.                                | Reset:          |        |            |        | Indeterminate after reset |                |        |       |          |  |  |
| \$0027 | TIM1 Channel 0 Register Low<br>(T1CH0L)      | Read:<br>Write: | Bit 7  | Bit 6      | Bit 5  | Bit 4                     | Bit 3          | Bit 2  | Bit 1 | Bit 0    |  |  |
|        | See page 277.                                | Reset:          |        |            |        | Indetermina               | te after reset |        |       |          |  |  |
|        | TIM1 Channel 1 Status and                    | Read:           | CH1F   |            | 0      | MC1A                      |                |        | TOVI  |          |  |  |
| \$0028 | Control Register (T1SC1)                     | Write:          | 0      | UNIE       |        | MOTA                      | ELSID          | ELSIA  | 1001  | CITIVIAN |  |  |
|        | See page 274.                                | Reset:          | 0      | 0          | 0      | 0                         | 0              | 0      | 0     | 0        |  |  |
| \$0029 | TIM1 Channel 1 Register High<br>(T1CH1H)     | Read:<br>Write: | Bit 15 | Bit 14     | Bit 13 | Bit 12                    | Bit 11         | Bit 10 | Bit 9 | Bit 8    |  |  |
|        | See page 277.                                | Reset:          |        |            |        | Indetermina               | te after reset | 1      |       |          |  |  |
| \$002A | TIM1 Channel 1 Register Low<br>(T1CH1L)      | Read:<br>Write: | Bit 7  | Bit 6      | Bit 5  | Bit 4                     | Bit 3          | Bit 2  | Bit 1 | Bit 0    |  |  |
|        | See page 277.                                | Reset:          |        | _          |        | Indetermina               | te after reset | 1      |       |          |  |  |
|        |                                              |                 |        | = Unimplen | nented |                           |                |        |       |          |  |  |

= Unimplemented

Figure 18-3. TIM1 I/O Register Summary



#### Timer Interface Module (TIM2)

Writing to the TIM2 channel 5 registers enables the TIM2 channel 5 registers to synchronously control the output after the TIM2 overflows. At each subsequent overflow, the TIM2 channel registers (4 or 5) that control the output are the ones written to last. T2SC4 controls and monitors the buffered output compare function, and TIM2 channel 5 status and control register (T2SC5) is unused. While the MS4B bit is set, the channel 5 pin, T2CH5, is available as a general-purpose I/O pin.

#### NOTE

In buffered output compare operation, do not write new output compare 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 output compares.

#### 19.3.4 Pulse Width Modulation (PWM)

By using the toggle-on-overflow feature with an output compare channel, the TIM2 can generate a PWM signal. The value in the TIM2 counter modulo registers determines the period of the PWM signal. The channel pin toggles when the counter reaches the value in the TIM2 counter modulo registers. The time between overflows is the period of the PWM signal.

As Figure 19-4 shows, the output compare value in the TIM2 channel registers determines the pulse width of the PWM signal. The time between overflow and output compare is the pulse width. Program the TIM2 to clear the channel pin on output compare if the polarity of the PWM pulse is 1 (ELSxA = 0). Program the TIM2 to set the pin if the polarity of the PWM pulse is 0 (ELSxA = 1).



Figure 19-4. PWM Period and Pulse Width

The value in the TIM2 counter modulo registers and the selected prescaler output determines the frequency of the PWM output. The frequency of an 8-bit PWM signal is variable in 256 increments. Writing \$00FF (255) to the TIM2 counter modulo registers produces a PWM period of 256 times the internal bus clock period if the prescaler select value is 000 (see 19.8.1 TIM2 Status and Control Register).

The value in the TIM2 channel registers determines the pulse width of the PWM output. The pulse width of an 8-bit PWM signal is variable in 256 increments. Writing \$0080 (128) to the TIM2 channel registers produces a duty cycle of 128/256 or 50%.



#### Development Support



Figure 20-9. Simplified Monitor Mode Entry Flowchart



#### 20.3.1.1 Normal Monitor Mode

If  $V_{TST}$  is applied to  $\overline{IRQ}$  and PTB4 is low upon monitor mode entry, the bus frequency is a divide-by-two of the input clock. If PTB4 is high with  $V_{TST}$  applied to  $\overline{IRQ}$  upon monitor mode entry, the bus frequency will be a divide-by-four of the input clock. Holding the PTB4 pin low when entering monitor mode causes a bypass of a divide-by-two stage at the oscillator *only if*  $V_{TST}$  *is applied to*  $\overline{IRQ}$ . In this event, the CGMOUT frequency is equal to the CGMXCLK frequency, and the OSC1 input directly generates internal bus clocks. In this case, the OSC1 signal must have a 50% duty cycle at maximum bus frequency.

When monitor mode was entered with  $V_{TST}$  on  $\overline{IRQ}$ , the computer operating properly (COP) is disabled as long as  $V_{TST}$  is applied to either  $\overline{IRQ}$  or  $\overline{RST}$ .

This condition states that as long as  $V_{TST}$  is maintained on the  $\overline{IRQ}$  pin after entering monitor mode, or if  $V_{TST}$  is applied to  $\overline{RST}$  after the initial reset to get into monitor mode (when  $V_{TST}$  was applied to  $\overline{IRQ}$ ), then the COP will be disabled. In the latter situation, after  $V_{TST}$  is applied to the  $\overline{RST}$  pin,  $V_{TST}$  can be removed from the  $\overline{IRQ}$  pin in the interest of freeing the  $\overline{IRQ}$  for normal functionality in monitor mode.

#### 20.3.1.2 Forced Monitor Mode

If entering monitor mode without high voltage on IRQ, then all port B pin requirements and conditions, including the PTB4 frequency divisor selection, are not in effect. This is to reduce circuit requirements when performing in-circuit programming.

#### NOTE

If the reset vector is blank and monitor mode is entered, the chip will see an additional reset cycle after the initial power-on reset (POR). Once the reset vector has been programmed, the traditional method of applying a voltage,  $V_{TST}$ , to  $\overline{IRQ}$  must be used to enter monitor mode.

An external oscillator of 8 MHz is required for a baud rate of 7200, as the internal bus frequency is automatically set to the external frequency divided by four.

When the forced monitor mode is entered the COP is always disabled regardless of the state of  $\overline{IRQ}$  or RST.

#### 20.3.1.3 Monitor Vectors

In monitor mode, the MCU uses different vectors for reset, SWI (software interrupt), and break interrupt than those for user mode. The alternate vectors are in the \$FE page instead of the \$FF page and allow code execution from the internal monitor firmware instead of user code.

Table 20-2 summarizes the differences between user mode and monitor mode.

|         | Functions            |                     |                                       |        |                    |                   |  |  |  |  |  |  |
|---------|----------------------|---------------------|---------------------------------------|--------|--------------------|-------------------|--|--|--|--|--|--|
| Modes   | Reset<br>Vector High | Reset<br>Vector Low | Reset Break<br>Vector Low Vector High |        | SWI<br>Vector High | SWI<br>Vector Low |  |  |  |  |  |  |
| User    | \$FFFE               | \$FFFF              | \$FFFC                                | \$FFFD | \$FFFC             | \$FFFD            |  |  |  |  |  |  |
| Monitor | \$FEFE               | \$FEFF              | \$FEFC                                | \$FEFD | \$FEFC             | \$FEFD            |  |  |  |  |  |  |

#### Table 20-2. Mode Differences