

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               | -                                                          |
| Peripherals                | LED, LVD, POR, PWM                                         |
| Number of I/O              | 23                                                         |
| Program Memory Size        | 4KB (4K x 8)                                               |
| Program Memory Type        | FLASH                                                      |
| EEPROM Size                | -                                                          |
| RAM Size                   | 128 x 8                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 3.3V                                                |
| Data Converters            | A/D 12x8b                                                  |
| Oscillator Type            | External                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                          |
| Mounting Type              | Surface Mount                                              |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                             |
| Supplier Device Package    | 28-SOIC                                                    |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=mc908jl3ecdwe |

Email: info@E-XFL.COM

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



**Table of Contents** 

## Appendix C MC68HC908KL3E/KK3E

| C.1 | Introduction       | 175 |
|-----|--------------------|-----|
| C.2 | MCU Block Diagram  | 175 |
| C.3 | Pin Assignments    | 175 |
| C.4 | Reserved Registers | 178 |
| C.5 | Reserved Vectors   | 178 |
| C.6 | Order Numbers      | 178 |



# Chapter 1 General Description

## 1.1 Introduction

The MC68H(R)C908JL3E is a member of the low-cost, high-performance M68HC08 Family of 8-bit microcontroller units (MCUs). The M68HC08 Family is based on the customer-specified integrated circuit (CSIC) design strategy. All MCUs in the family use the enhanced M68HC08 central processor unit (CPU08) and are available with a variety of modules, memory sizes and types, and package types.

A list of MC68H(R)C908JL3E device variations is shown in Table 1-1.

| Device<br>Type                      | Operating<br>Voltage | LVI | ADC | Oscillator<br>Option | Memory              | Pin<br>Count | Device         |
|-------------------------------------|----------------------|-----|-----|----------------------|---------------------|--------------|----------------|
|                                     |                      |     |     |                      | 4 096 bytes Elash   | 28           | MC68HC908JL3E  |
|                                     |                      |     |     | XTAL                 | 4,090 bytes i lash  | 20           | MC68HC908JK3E  |
| Flach                               | 31/ 51/              | Voc | Voc |                      | 1,536 bytes Flash   | 20           | MC68HC908JK1E  |
| FIASI                               | 30,30                | 165 | 165 | RC                   | 4 096 bytes Elash   | 28           | MC68HRC908JL3E |
|                                     |                      |     |     |                      | 4,090 bytes i lasti | 20           | MC68HRC908JK3E |
|                                     |                      |     |     |                      | 1,536 bytes Flash   | 20           | MC68HRC908JK1E |
|                                     |                      |     |     | XTAL                 | 4 006 bytes Elash   | 28           | MC68HLC908JL3E |
| Low Voltage<br>Flash <sup>(1)</sup> | 2.2 to 5.5V          | No  | Yes |                      | 4,090 bytes Flash   | 20           | MC68HLC908JK3E |
|                                     |                      |     |     |                      | 1,536 bytes Flash   | 20           | MC68HLC908JK1E |
|                                     |                      |     |     | νται                 |                     | 28           | MC68HC08JL3E   |
| DOM(2)                              | 21/ 51/              | Voc | Voc | ATAL                 | 4 006 butos POM     | 20           | MC68HC08JK3E   |
| ROM-                                | 30,30                | 165 | 165 | PC                   |                     | 28           | MC68HRC08JL3E  |
|                                     |                      |     |     | RC                   |                     | 20           | MC68HRC08JK3E  |
| Flash,                              | 31/ 51/              | Voc | No  |                      |                     | 28           | MC68HC908KL3E  |
| ADC-less <sup>(3)</sup>             | 37,37                | 162 | INU | AIAL                 | 4,000 Dyles Fidsh   | 20           | MC68HC908KK3E  |

### Table 1-1. Summary of Device Variations

1. Low-voltage Flash devices are documented in Appendix A MC68HLC908JL3E/JK3E/JK1E.

2. ROM devices are documented in Appendix B MC68H(R)C08JL3E/JK3E.

3. Flash, ADC-less devices are documented in Appendix C MC68HC908KL3E/KK3E.

All references to the MC68H(R)C908JL3E in this data book apply equally to the MC68H(R)C908JK3E and MC68H(R)C908JK1E, unless otherwise stated.

#### **Pin Assignments**





NC: No connection





### Memory

| Addr.                 | Register Name                                   |                 | Bit 7 | 6     | 5       | 4            | 3            | 2      | 1     | Bit 0 |
|-----------------------|-------------------------------------------------|-----------------|-------|-------|---------|--------------|--------------|--------|-------|-------|
|                       |                                                 | Read:           | 0     | IF5   | IF4     | IF3          | 0            | IF1    | 0     | 0     |
| \$FE04                | Interrupt Status Register 1<br>(INIT1)          | Write:          | R     | R     | R       | R            | R            | R      | R     | R     |
|                       | (((((()))))))))))))))))))))))))))))))))         | Reset:          | 0     | 0     | 0       | 0            | 0            | 0      | 0     | 0     |
|                       | late much Otatura Da sister O                   | Read:           | IF14  | 0     | 0       | 0            | 0            | 0      | 0     | 0     |
| \$FE05                | Interrupt Status Register 2<br>(INT2)           | Write:          | R     | R     | R       | R            | R            | R      | R     | R     |
|                       | (                                               | Reset:          | 0     | 0     | 0       | 0            | 0            | 0      | 0     | 0     |
|                       | Interrupt Status Degister 2                     | Read:           | 0     | 0     | 0       | 0            | 0            | 0      | 0     | IF15  |
| \$FE06                | (INT3)                                          | Write:          | R     | R     | R       | R            | R            | R      | R     | R     |
|                       | (                                               | Reset:          | 0     | 0     | 0       | 0            | 0            | 0      | 0     | 0     |
| \$FE07                | Reserved                                        | Read:<br>Write: | R     | R     | R       | R            | R            | R      | R     | R     |
|                       |                                                 | Б. Г.           |       |       |         |              |              |        |       |       |
| *==00                 | Flash Control Register                          | Read:           | 0     | 0     | 0       | 0            | HVEN         | MASS   | ERASE | PGM   |
| \$FE08                | (FLCR)                                          | write:          |       |       |         |              |              | •      |       |       |
|                       |                                                 | Reset:          | 0     | 0     | 0       | 0            | 0            | 0      | U     | 0     |
| \$FE09                | \$FE09 Flash Block Protect<br>Begister (FL BPB) | Write:          | BPR7  | BPR6  | BPR5    | BPR4         | BPR3         | BPR2   | BPR1  | BPR0  |
|                       |                                                 | Reset:          | 0     | 0     | 0       | 0            | 0            | 0      | 0     | 0     |
| \$FE0A<br>↓<br>\$FE0B | Reserved                                        | Read:<br>Write: | R     | R     | R       | R            | R            | R      | R     | R     |
| ф. <u>со</u> в        |                                                 | n               |       |       |         |              |              |        |       |       |
| \$FE0C                | Break Address High<br>Begister (BBKH)           | Read:<br>Write: | Bit15 | Bit14 | Bit13   | Bit12        | Bit11        | Bit10  | Bit9  | Bit8  |
|                       |                                                 | Reset:          | 0     | 0     | 0       | 0            | 0            | 0      | 0     | 0     |
| \$FE0D                | Break Address Low                               | Read:<br>Write: | Bit7  | Bit6  | Bit5    | Bit4         | Bit3         | Bit2   | Bit1  | Bit0  |
|                       |                                                 | Reset:          | 0     | 0     | 0       | 0            | 0            | 0      | 0     | 0     |
|                       | Due als Otation and Original                    | Read:           | PDKE  | PDKA  | 0       | 0            | 0            | 0      | 0     | 0     |
| \$FE0E                | Break Status and Control<br>Begister (BBKSCB)   | Write:          | DHKE  | DRKA  |         |              |              |        |       |       |
| Register (BRKSCR)     |                                                 | Reset:          | 0     | 0     | 0       | 0            | 0            | 0      | 0     | 0     |
|                       |                                                 | _               |       |       |         |              |              |        |       |       |
|                       |                                                 | Read:           |       |       |         | Low byte of  | reset vector |        |       |       |
| \$FFFF                | COP Control Register                            | Write:          |       |       | Writing | g clears COP | counter (any | value) |       |       |
|                       |                                                 | Reset:          |       |       |         | Unaffecte    | d by reset   |        |       |       |

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

R

= Reserved

= Unimplemented



**Central Processor Unit (CPU)** 

## 4.3.5 Condition Code Register

The 8-bit condition code register contains the interrupt mask and five flags that indicate the results of the instruction just executed. Bits 6 and 5 are set permanently to 1. The following paragraphs describe the functions of the condition code register.



Figure 4-6. Condition Code Register (CCR)

### V — Overflow Flag

The CPU sets the overflow flag when a two's complement overflow occurs. The signed branch instructions BGT, BGE, BLE, and BLT use the overflow flag.

- 1 = Overflow
- 0 = No overflow

### H — Half-Carry Flag

The CPU sets the half-carry flag when a carry occurs between accumulator bits 3 and 4 during an add-without-carry (ADD) or add-with-carry (ADC) operation. The half-carry flag is required for binary-coded decimal (BCD) arithmetic operations. The DAA instruction uses the states of the H and C flags to determine the appropriate correction factor.

1 = Carry between bits 3 and 4

0 = No carry between bits 3 and 4

### I — Interrupt Mask

When the interrupt mask is set, all maskable CPU interrupts are disabled. CPU interrupts are enabled when the interrupt mask is cleared. When a CPU interrupt occurs, the interrupt mask is set automatically after the CPU registers are saved on the stack, but before the interrupt vector is fetched.

- 1 = Interrupts disabled
- 0 = Interrupts enabled

### NOTE

To maintain M6805 Family compatibility, the upper byte of the index register (H) is not stacked automatically. If the interrupt service routine modifies H, then the user must stack and unstack H using the PSHH and PULH instructions.

After the I bit is cleared, the highest-priority interrupt request is serviced first. A return-from-interrupt (RTI) instruction pulls the CPU registers from the stack and restores the interrupt mask from the stack. After any reset, the interrupt mask is set and can be cleared only by the clear interrupt mask software instruction (CLI).

### N — Negative Flag

The CPU sets the negative flag when an arithmetic operation, logic operation, or data manipulation produces a negative result, setting bit 7 of the result.

1 = Negative result

0 = Non-negative result



**Central Processor Unit (CPU)** 

| Source                                                                                         |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   | Effect<br>on CCR |    |    |    | SSS                                                 | de                                               | and                                             | ş                                    |
|------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|------------------|----|----|----|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------------|--------------------------------------|
| Form                                                                                           | Operation                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | v | н | 1                | N  | z  | С  | vddre<br>1ode                                       | opco                                             | pera                                            | ycle                                 |
| CLR opr<br>CLRA<br>CLRX<br>CLRH<br>CLR opr,X<br>CLR ,X<br>CLR opr,SP                           | Clear                            | $\begin{array}{c} M \leftarrow \$00 \\ A \leftarrow \$00 \\ X \leftarrow \$00 \\ H \leftarrow \$00 \\ M \leftarrow \$00 \\ M \leftarrow \$00 \\ M \leftarrow \$00 \\ M \leftarrow \$00 \end{array}$                                                                                                                                                                                                                                                                                                                                           | 0 | _ | _                | 0  | 1  | _  | DIR<br>INH<br>INH<br>INH<br>IX1<br>IX<br>SP1        | 3F<br>4F<br>5F<br>8C<br>6F<br>7F<br>9E6F         | dd<br>ff                                        | <b>3</b><br>1<br>1<br>3<br>2<br>4    |
| CMP #opr<br>CMP opr<br>CMP opr<br>CMP opr,X<br>CMP opr,X<br>CMP X<br>CMP opr,SP<br>CMP opr,SP  | Compare A with M                 | (A) – (M)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ţ | _ | _                | ţ  | ţ  | ţ  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A1<br>B1<br>C1<br>E1<br>F1<br>9EE1<br>9ED1       | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff       | 23443245                             |
| COM opr<br>COMA<br>COMX<br>COM opr,X<br>COM ,X<br>COM opr,SP                                   | Complement (One's Complement)    | $\begin{array}{l} M \leftarrow (\underline{M}) = \$FF - (M) \\ A \leftarrow (A) = \$FF - (M) \\ X \leftarrow (\mathbf{X}) = \$FF - (M) \\ M \leftarrow (\underline{M}) = \$FF - (M) \end{array}$                                                                                                                                                                                                       | 0 | _ | _                | 1  | ţ  | 1  | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 33<br>43<br>53<br>63<br>73<br>9E63               | dd<br>ff<br>ff                                  | 4<br>1<br>4<br>3<br>5                |
| CPHX # <i>opr</i><br>CPHX <i>opr</i>                                                           | Compare H:X with M               | (H:X) – (M:M + 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ţ | - | -                | \$ | \$ | \$ | IMM<br>DIR                                          | 65<br>75                                         | ii ii+1<br>dd                                   | 3<br>4                               |
| CPX #opr<br>CPX opr<br>CPX opr<br>CPX ,X<br>CPX opr,X<br>CPX opr,X<br>CPX opr,SP<br>CPX opr,SP | Compare X with M                 | (X) – (M)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ţ | _ | _                | ţ  | ţ  | ţ  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A3<br>B3<br>C3<br>D3<br>E3<br>F3<br>9EE3<br>9ED3 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ff<br>ee ff | 2<br>3<br>4<br>3<br>2<br>4<br>5      |
| DAA                                                                                            | Decimal Adjust A                 | (A) <sub>10</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | U | - | -                | 1  | 1  | t  | INH                                                 | 72                                               |                                                 | 2                                    |
| DBNZ opr,rel<br>DBNZA rel<br>DBNZX rel<br>DBNZ opr,X,rel<br>DBNZ X,rel<br>DBNZ opr,SP,rel      | Decrement and Branch if Not Zero | $\begin{array}{l} A \leftarrow (A) - 1 \text{ or } M \leftarrow (M) - 1 \text{ or } X \leftarrow (X) - 1 \\ PC \leftarrow (PC) + 3 + \mathit{rel} ? (\mathit{result}) \neq 0 \\ PC \leftarrow (PC) + 2 + \mathit{rel} ? (\mathit{result}) \neq 0 \\ PC \leftarrow (PC) + 2 + \mathit{rel} ? (\mathit{result}) \neq 0 \\ PC \leftarrow (PC) + 3 + \mathit{rel} ? (\mathit{result}) \neq 0 \\ PC \leftarrow (PC) + 2 + \mathit{rel} ? (\mathit{result}) \neq 0 \\ PC \leftarrow (PC) + 4 + \mathit{rel} ? (\mathit{result}) \neq 0 \end{array}$ | _ | _ | _                | -  | -  | _  | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3B<br>4B<br>5B<br>6B<br>7B<br>9E6B               | dd rr<br>rr<br>rr<br>ff rr<br>ff rr<br>ff rr    | 5<br>3<br>3<br>5<br>4<br>6           |
| DEC opr<br>DECA<br>DECX<br>DEC opr,X<br>DEC ,X<br>DEC opr,SP                                   | Decrement                        | $\begin{array}{l} M \leftarrow (M) - 1 \\ A \leftarrow (A) - 1 \\ X \leftarrow (X) - 1 \\ M \leftarrow (M) - 1 \\ M \leftarrow (M) - 1 \\ M \leftarrow (M) - 1 \end{array}$                                                                                                                                                                                                                                                                                                                                                                   | ţ | _ | _                | \$ | 1  | _  | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3A<br>4A<br>5A<br>6A<br>7A<br>9E6A               | dd<br>ff<br>ff                                  | 4<br>1<br>4<br>3<br>5                |
| DIV                                                                                            | Divide                           | $A \leftarrow (H:A)/(X)$<br>H $\leftarrow$ Remainder                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | - | - | -                | -  | 1  | t  | INH                                                 | 52                                               |                                                 | 7                                    |
| EOR #opr<br>EOR opr<br>EOR opr<br>EOR opr,X<br>EOR opr,X<br>EOR X<br>EOR opr,SP<br>EOR opr,SP  | Exclusive OR M with A            | $A \leftarrow (A \oplus M)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0 | _ | _                | ţ  | ţ  | _  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A8<br>B8<br>C8<br>D8<br>E8<br>F8<br>9EE8<br>9ED8 | 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 |
| INC opr<br>INCA<br>INCX<br>INC opr,X<br>INC ,X<br>INC opr,SP                                   | Increment                        | $\begin{array}{c} M \leftarrow (M) + 1\\ A \leftarrow (A) + 1\\ X \leftarrow (X) + 1\\ M \leftarrow (M) + 1\\ M \leftarrow (M) + 1\\ M \leftarrow (M) + 1 \end{array}$                                                                                                                                                                                                                                                                                                                                                                        | ţ | _ | _                | ţ  | ţ  | _  | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3C<br>4C<br>5C<br>6C<br>7C<br>9E6C               | dd<br>ff<br>ff                                  | 4<br>1<br>4<br>3<br>5                |



#### System Integration Module (SIM)



Figure 5-1. SIM Block Diagram

| Addr.                        | Register Name         | _               | Bit 7 | 6          | 5     | 4    | 3    | 2          | 1            | Bit 0 |
|------------------------------|-----------------------|-----------------|-------|------------|-------|------|------|------------|--------------|-------|
| \$FE00                       | Break Status Register | Read:<br>Write: | R     | R          | R     | R    | R    | R          | SBSW<br>NOTE | R     |
|                              | (DON)                 | Reset:          | 0     | 0          | 0     | 0    | 0    | 0          | 0            | 0     |
| Note: Writin                 | g a 0 clears SBSW.    |                 |       |            |       |      |      |            |              |       |
|                              | Deast Otatus Desister | Read:           | POR   | PIN        | COP   | ILOP | ILAD | MODRST     | LVI          | 0     |
| \$FE01 Reset Status Register | Write:                |                 |       |            |       |      |      |            |              |       |
|                              | (non)                 | POR:            | 1     | 0          | 0     | 0    | 0    | 0          | 0            | 0     |
| \$FE02                       | Reserved              | Read:<br>Write: | R     | R          | R     | R    | R    | R          | R            | R     |
|                              |                       | Reset:          |       |            |       |      |      |            |              |       |
| \$FE03                       | Break Flag Control    | Read:<br>Write: | BCFE  | R          | R     | R    | R    | R          | R            | R     |
|                              |                       | Reset:          | 0     |            |       |      | -    |            |              |       |
|                              |                       |                 |       | = Unimplem | ented |      | R    | = Reserved |              |       |

Figure 5-2. SIM I/O Register Summary



System Integration Module (SIM)

## 5.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 5.4 SIM Counter), but an external reset does not. Each of the resets sets a corresponding bit in the reset status register (RSR). (See 5.7 SIM Registers.)

## 5.3.1 External Pin Reset

The  $\overline{\text{RST}}$  pin circuits include an internal pull-up device. Pulling the asynchronous  $\overline{\text{RST}}$  pin low halts all processing. The PIN bit of the reset status register (RSR) is set as long as  $\overline{\text{RST}}$  is held low for a minimum of 67 2OSCOUT cycles, assuming that the POR was not the source of the reset. See Table 5-2 for details. Figure 5-4 shows the relative timing.

| Reset Type | Number of Cycles Required to Set PIN |
|------------|--------------------------------------|
| POR        | 4163 (4096 + 64 + 3)                 |
| All others | 67 (64 + 3)                          |





## 5.3.2 Active Resets from Internal Sources

All internal reset sources actively pull the RST pin low for 32 2OSCOUT cycles to allow resetting of external peripherals. The internal reset signal IRST continues to be asserted for an additional 32 cycles (Figure 5-5). An internal reset can be caused by an illegal address, illegal opcode, COP time-out, or POR. (See Figure 5-6.) Note that for POR resets, the SIM cycles through 4096 2OSCOUT cycles during which the SIM forces the RST pin low. The internal reset signal then follows the sequence from the falling edge of RST shown in Figure 5-5.



## 6.4 I/O Signals

The following paragraphs describe the oscillator I/O signals.

## 6.4.1 Crystal Amplifier Input Pin (OSC1)

OSC1 pin is an input to the crystal oscillator amplifier or the input to the RC oscillator circuit.

## 6.4.2 Crystal Amplifier Output Pin (OSC2/PTA6/RCCLK)

For the X-tal oscillator device, OSC2 pin is the output of the crystal oscillator inverting amplifier.

For the RC oscillator device, OSC2 pin can be configured as a general purpose I/O pin PTA6, or the output of the internal RC oscillator clock, RCCLK.

| Device                   | Oscillator | OSC2 pin function                                                                              |  |  |  |  |
|--------------------------|------------|------------------------------------------------------------------------------------------------|--|--|--|--|
| MC68HC908JL3E/JK3E/JK1E  | X-tal      | Inverting OSC1                                                                                 |  |  |  |  |
| MC68HRC908JL3E/JK3E/JK1E | RC         | Controlled by PTA6EN bit in PTAPUER (\$0D)<br>PTA6EN = 0: RCCLK output<br>PTA6EN = 1: PTA6 I/O |  |  |  |  |

## 6.4.3 Oscillator Enable Signal (SIMOSCEN)

The SIMOSCEN signal comes from the system integration module (SIM) and enables/disables the X-tal oscillator circuit or the RC-oscillator.

## 6.4.4 X-tal Oscillator Clock (XTALCLK)

XTALCLK is the X-tal oscillator output signal. It runs at the full speed of the crystal ( $f_{XCLK}$ ) and comes directly from the crystal oscillator circuit. Figure 6-1 shows only the logical relation of XTALCLK to OSC1 and OSC2 and may not represent the actual circuitry. The duty cycle of XTALCLK is unknown and may depend on the crystal and other external factors. Also, the frequency and amplitude of XTALCLK can be unstable at start-up.

## 6.4.5 RC Oscillator Clock (RCCLK)

RCCLK is the RC oscillator output signal. Its frequency is directly proportional to the time constant of the external R and C. Figure 6-2 shows only the logical relation of RCCLK to OSC1 and may not represent the actual circuitry.

## 6.4.6 Oscillator Out 2 (2OSCOUT)

2OSCOUT is same as the input clock (XTALCLK or RCCLK). This signal is driven to the SIM module and is used to determine the COP cycles.

## 6.4.7 Oscillator Out (OSCOUT)

The frequency of this signal is equal to half of the 2OSCOUT, this signal is driven to the SIM for generation of the bus clocks used by the CPU and other modules on the MCU. OSCOUT will be divided again in the SIM and results in the internal bus frequency being one fourth of the XTALCLK or RCCLK frequency.



# Chapter 7 Monitor ROM (MON)

## 7.1 Introduction

This section describes the monitor ROM (MON) and the monitor mode entry methods. The monitor ROM allows complete testing of the MCU through a single-wire interface with a host computer. This mode is also used for programming and erasing of Flash memory in the MCU. Monitor mode entry can be achieved without use of the higher test voltage,  $V_{TST}$ , as long as vector addresses \$FFFE and \$FFFF are blank, thus reducing the hardware requirements for in-circuit programming.

## 7.2 Features

Features of the monitor ROM include the following:

- Normal user-mode pin functionality
- One pin dedicated to serial communication between monitor ROM and host computer
- Standard mark/space non-return-to-zero (NRZ) communication with host computer
- Execution of code in RAM or Flash
- Flash memory security feature<sup>(1)</sup>
- Flash memory programming interface
- 960 bytes monitor ROM code size
- Monitor mode entry without high voltage, V<sub>TST</sub>, if reset vector is blank (\$FFFE and \$FFFF contain \$FF)
- Standard monitor mode entry if high voltage, V<sub>TST</sub>, is applied to IRQ

## 7.3 Functional Description

The monitor ROM receives and executes commands from a host computer. Figure 7-1 shows a example circuit used to enter monitor mode and communicate with a host computer via a standard RS-232 interface.

Simple monitor commands can access any memory address. In monitor mode, the MCU can execute host-computer code in RAM while most MCU pins retain normal operating mode functions. All communication between the host computer and the MCU is through the PTB0 pin. A level-shifting and multiplexing interface is required between PTB0 and the host computer. PTB0 is used in a wired-OR configuration and requires a pull-up resistor.

<sup>1.</sup> No security feature is absolutely secure. However, Freescale's strategy is to make reading or copying the Flash difficult for unauthorized users.



### Monitor ROM (MON)



Figure 7-1. Monitor Mode Circuit



### **Functional Description**

| Addr.    | Register Name                            |        | Bit 7                          | 6       | 5        | 4            | 3              | 2     | 1    | Bit 0    |
|----------|------------------------------------------|--------|--------------------------------|---------|----------|--------------|----------------|-------|------|----------|
|          | TIMOLIA                                  | Read:  | TOF                            | TOIE    | TSTOP    | 0            | 0              | DC0   | DQ1  | PSO      |
| \$0020   | TIM Status and Control<br>Register (TSC) | Write: | 0                              | TOIL    | 13105    | TRST         |                | F 32  | FOI  | F 30     |
|          |                                          | Reset: | 0                              | 0       | 1        | 0            | 0              | 0     | 0    | 0        |
|          | TIM Counter Desister Llish               | Read:  | Bit15                          | Bit14   | Bit13    | Bit12        | Bit11          | Bit10 | Bit9 | Bit8     |
| \$0021   | (TCNTH)                                  | Write: |                                |         |          |              |                |       |      |          |
|          |                                          | Reset: | 0                              | 0       | 0        | 0            | 0              | 0     | 0    | 0        |
|          | TIM Counter Degister Low                 | Read:  | Bit7                           | Bit6    | Bit5     | Bit4         | Bit3           | Bit2  | Bit1 | Bit0     |
| \$0022   | (TCNTL)                                  | Write: |                                |         |          |              |                |       |      |          |
|          | ( )                                      | Reset: | 0                              | 0       | 0        | 0            | 0              | 0     | 0    | 0        |
|          | TIM Counter Module Degister              | Read:  | Bit15                          | Rit14   | Bit13    | Bit12        | Bit11          | Bit10 | Rit9 | Bit8     |
| \$0023   | High (TMODH)                             | Write: | Ditto                          | DITT    | Ditto    | DITZ         | Ditt           | DitTO | Dito | Dito     |
|          | 5 ( )                                    | Reset: | 1                              | 1       | 1        | 1            | 1              | 1     | 1    | 1        |
|          | TIM Counter Module Degister              | Read:  | Bit7                           | Bit6    | Rit5     | Rit4         | Bit3           | Bit2  | Rit1 | Bit0     |
| \$0024   | Low (TMODL)                              | Write: | Diti                           | Dito    | Dito     | Ditt         | Bito           | DILL  | Ditt | Dito     |
|          |                                          |        | 1                              | 1       | 1        | 1            | 1              | 1     | 1    | 1        |
| \$0025 T | TIM Channel O Status and                 | Read:  | CH0F                           | CHOIE   | MSOB     | MSOA         | ELS0B          | ELS04 | τονο | CHOMAX   |
|          | Control Register (TSC0)                  | Write: | 0                              | OTIOL   | MOOD     | WOON         | LLOOD          | LEOUN | 1000 |          |
|          | <b>0</b> ( )                             | Reset: | 0                              | 0       | 0        | 0            | 0              | 0     | 0    | 0        |
|          | TIM Channel O Degister High              | Read:  | Bit15                          | Bit14   | Bit13    | Bit12        | Bit11          | Bit10 | Rit9 | Bit8     |
| \$0026   | (TCH0H)                                  | Write: | Birlo                          |         | Birlo    | DITE         | Darr           |       |      | Dito     |
|          |                                          | Reset: |                                |         |          | Indeterminat | te after reset |       |      |          |
|          | TIM Channel 0 Register Low               | Read:  | Bit7                           | Bit6    | Bit5     | Bit4         | Bit3           | Bit2  | Bit1 | Bit0     |
| \$0027   | (TCHOL)                                  | Write: | Bill                           | Bito    | Bito     | BRI          | Dito           | DILL  | BRI  | Ditto    |
|          |                                          | Reset: |                                |         | r        | Indeterminat | te after reset |       |      |          |
|          | TIM Channel 1 Status and                 | Read:  | CH1F                           | CH1IE   | 0        | MS1A         | ELS1B          | ELS1A | TOV1 | CH1MAX   |
| \$0028   | Control Register (TSC1)                  | Write: | 0                              | •••••   |          |              |                |       |      | •••••••• |
|          | • • •                                    | Reset: | 0                              | 0       | 0        | 0            | 0              | 0     | 0    | 0        |
|          | TIM Channel 1 Degister High              | Read:  | Bit15                          | Bit14   | Bit13    | Bit12        | Bit11          | Bit10 | Bit9 | Bit8     |
| \$0029   | (TCH1H)                                  | Write: | 20                             | 2       | 20       |              |                | 20    | 2.10 | 2        |
|          | . ,                                      | Reset: |                                | 1       | r        | Indeterminat | te after reset |       |      | ,        |
|          | TIM Channel 1 Begister Low               | Read:  | Bit7                           | Bit6    | Bit5     | Bit4         | Bit3           | Bit2  | Bit1 | Bit0     |
| \$002A   | (TCH1L)                                  | Write: |                                | 2.10    | 2.10     |              | 2.10           |       |      |          |
|          |                                          | Reset: | set: Indeterminate after reset |         |          |              |                |       |      |          |
|          |                                          |        |                                | = Unimp | lemented |              |                |       |      |          |

Figure 8-2. TIM I/O Register Summary



#### I/O Registers

### 8.9.2 TIM Counter Registers (TCNTH:TCNTL)

The two read-only TIM counter registers contain the high and low bytes of the value in the TIM counter. Reading the high byte (TCNTH) latches the contents of the low byte (TCNTL) into a buffer. Subsequent reads of TCNTH do not affect the latched TCNTL value until TCNTL is read. Reset clears the TIM counter registers. Setting the TIM reset bit (TRST) also clears the TIM counter registers.

> **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.





### 8.9.3 TIM Counter Modulo Registers (TMODH:TMODL)

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 8-6. TIM Counter Modulo Registers (TMODH:TMODL)

**NOTE** Reset the TIM counter before writing to the TIM counter modulo registers.



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

| Addr.  | Register Name                           |                 | Bit 7  | 6           | 5       | 4       | 3       | 2       | 1       | Bit 0   |
|--------|-----------------------------------------|-----------------|--------|-------------|---------|---------|---------|---------|---------|---------|
|        |                                         | Read:           | 0      | 0           | 0       | 0       |         |         | דוומחדם |         |
| \$000A | Port D Control Register<br>(PDCR)       | Write:          |        |             |         |         | SLOWD7  | SLOWDO  | FIDFU   | FIDEOU  |
|        | ()                                      | Reset:          | 0      | 0           | 0       | 0       | 0       | 0       | 0       | 0       |
| \$000D | Port A Input Pull-up Enable<br>Register | Read:<br>Write: | PTA6EN | PTAPUE6     | PTAPUE5 | PTAPUE4 | PTAPUE3 | PTAPUE2 | PTAPUE1 | PTAPUE0 |
|        | (PTAPUE)                                | Reset:          | 0      | 0           | 0       | 0       | 0       | 0       | 0       | 0       |
|        |                                         |                 |        | = Unimpleme | ented   |         |         |         |         |         |

### Figure 10-1. I/O Port Register Summary

| <b>.</b> . |     |       |            | <b>D</b> '                        |                 |                                |
|------------|-----|-------|------------|-----------------------------------|-----------------|--------------------------------|
| Port       | Bit | DDR   | Module     | Register                          | Control Bit     | Pin                            |
|            | 0   | DDRA0 |            |                                   | KBIE0           | PTA0/KBI0                      |
|            | 1   | DDRA1 |            |                                   | KBIE1           | PTA1/KBI1                      |
|            | 2   | DDRA2 | <b>VDI</b> |                                   | KBIE2           | PTA2/KBI2                      |
| ۸          | 3   | DDRA3 | KDI        | KDIER (\$001D)                    | KBIE3           | PTA3/KBI3                      |
| A          | 4   | DDRA4 |            |                                   | KBIE4           | PTA4/KBI4                      |
|            | 5   | DDRA5 |            |                                   | KBIE5           | PTA5/KBI5                      |
|            | 6   | DDRA6 | OSC<br>KBI | PTAPUE (\$000D)<br>KBIER (\$001B) | PTA6EN<br>KBIE6 | RCCLK/PTA6/KBI6 <sup>(1)</sup> |
|            | 0   | DDRB0 |            |                                   |                 | PTB0/ADC0                      |
|            | 1   | DDRB1 |            |                                   |                 | PTB1/ADC1                      |
|            | 2   | DDRB2 |            |                                   |                 | PTB2/ADC2                      |
| Р          | 3   | DDRB3 |            |                                   |                 | PTB3/ADC3                      |
| D          | 4   | DDRB4 | ADC        | AD3Ch (\$003C)                    |                 | PTB4/ADC4                      |
|            | 5   | DDRB5 |            |                                   |                 | PTB5/ADC5                      |
|            | 6   | DDRB6 |            |                                   |                 | PTB6/ADC6                      |
|            | 7   | DDRB7 |            |                                   |                 | PTB7/ADC7                      |
|            | 0   | DDRD0 |            |                                   |                 | PTD0/ADC11                     |
|            | 1   | DDRD1 |            |                                   |                 | PTD1/ADC10                     |
|            | 2   | DDRD2 | ADC        |                                   | ADCH[4.0]       | PTD2/ADC9                      |
| П          | 3   | DDRD3 |            |                                   |                 | PTD3/ADC8                      |
| U          | 4   | DDRD4 | TIM        | TSC0 (\$0025)                     | ELS0B:ELS0A     | PTD4/TCH0                      |
|            | 5   | DDRD5 |            | TSC1 (\$0028)                     | ELS1B:ELS1A     | PTD5/TCH1                      |
|            | 6   | DDRD6 |            |                                   | —               | PTD6                           |
|            | 7   | DDRD7 | _          | _                                 | _               | PTD7                           |

### Table 10-1. Port Control Register Bits Summary

1. RCCLK/PTA6/KBI6 pin is only available on MC68HRC908JL3E/JK3E/JK1E devices (RC option); PTAPUE register has priority control over the port pin. RCCLK/PTA6/KBI6 is the OSC2 pin on MC68HC908JL3E/JK3E/JK1E devices (X-TAL option).



## 11.3.1 IRQ Pin

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

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

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

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

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

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

Use the BIH or BIL instruction to read the logic level on the IRQ pin.

### NOTE

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

### NOTE

An internal pull-up resistor to  $V_{DD}$  is connected to the  $\overline{IRQ}$  pin; this can be disabled by setting the IRQPUD bit in the CONFIG2 register (\$001E).

## 11.4 IRQ Module During Break Interrupts

The system integration module (SIM) controls whether the IRQ latch can be cleared during the break state. The BCFE bit in the break flag control register (BFCR) enables software to clear the latches during the break state. (See Chapter 5 System Integration Module (SIM).)

To allow software to clear the IRQ latch during a break interrupt, write a one 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 latches during the break state, write a zero to the BCFE bit. With BCFE at zero (its default state), writing to the ACK bit in the IRQ status and control register during the break state has no effect on the IRQ latch.



# Chapter 12 Keyboard Interrupt Module (KBI)

## **12.1 Introduction**

The keyboard interrupt module (KBI) provides seven independently maskable external interrupts which are accessible via PTA0–PTA6 pins.

## 12.2 Features

Features of the keyboard interrupt module include the following:

- Seven keyboard interrupt pins with separate keyboard interrupt enable bits and one keyboard interrupt mask
- Software configurable pull-up device if input pin is configured as input port bit
- Programmable edge-only or edge- and level- interrupt sensitivity
- Exit from low-power modes

| Addr.  | Register Name                                   |        | Bit 7 | 6               | 5     | 4     | 3     | 2     | 1      | Bit 0 |
|--------|-------------------------------------------------|--------|-------|-----------------|-------|-------|-------|-------|--------|-------|
| \$001A | Keyboard Status and Control<br>Register (KBSCR) | Read:  | 0     | 0               | 0     | 0     | KEYF  | 0     | IMASKK | MODEK |
|        |                                                 | Write: |       |                 |       |       |       | ACKK  |        |       |
|        |                                                 | Reset: | 0     | 0               | 0     | 0     | 0     | 0     | 0      | 0     |
| \$001B | Keyboard Interrupt Enable<br>Register (KBIER)   | Read:  | 0     | KBIE6           | KBIE5 | KBIE4 | KBIE3 | KBIE2 | KBIE1  | KBIE0 |
|        |                                                 | Write: |       |                 |       |       |       |       |        |       |
|        |                                                 | Reset: | 0     | 0               | 0     | 0     | 0     | 0     | 0      | 0     |
|        |                                                 |        |       | = Unimplemented |       |       |       |       |        |       |

### Figure 12-1. KBI I/O Register Summary

## 12.3 I/O Pins

The seven keyboard interrupt pins are shared with standard port I/O pins. The full name of the KBI pins are listed in Table 12-1. The generic pin name appear in the text that follows.

### Table 12-1. Pin Name Conventions

| KBI<br>Generic Pin Name | Full MCU Pin Name              | Pin Selected for KBI Function<br>by KBIEx Bit in KBIER |  |  |  |
|-------------------------|--------------------------------|--------------------------------------------------------|--|--|--|
| KBI0–KBI5               | PTA0/KBI0–PTA5/KBI5            | KBIE0–KBIE5                                            |  |  |  |
| KBI6                    | RCCLK/PTA6/KBI6 <sup>(1)</sup> | KBIE6                                                  |  |  |  |

1. RCCLK/PTA6/KBI6 pin is only available on MC68HRC908JL3E/JK3E/JK1E devices (RC option).



The vector fetch or software clear and the return of all enabled keyboard interrupt pins to 1 may occur in any order.

If the MODEK bit is clear, the keyboard interrupt pin is falling-edge-sensitive only. With MODEK clear, a vector fetch or software clear immediately clears the keyboard interrupt request.

Reset clears the keyboard interrupt request and the MODEK bit, clearing the interrupt request even if a keyboard interrupt pin stays at 0.

The keyboard flag bit (KEYF) in the keyboard status and control register can be used to see if a pending interrupt exists. The KEYF bit is not affected by the keyboard interrupt mask bit (IMASKK) which makes it useful in applications where polling is preferred.

To determine the logic level on a keyboard interrupt pin, disable the pull-up device, use the data direction register to configure the pin as an input and then read the data register.

### NOTE

Setting a keyboard interrupt enable bit (KBIEx) forces the corresponding keyboard interrupt pin to be an input, overriding the data direction register. However, the data direction register bit must be a 0 for software to read the pin.

### 12.4.1 Keyboard Initialization

When a keyboard interrupt pin is enabled, it takes time for the internal pull-up to reach a logic 1. 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 the IMASKK bit in the keyboard status and control register.
- 2. Enable the KBI pins by setting the appropriate KBIEx bits in the keyboard interrupt enable register.
- 3. Write to the ACKK bit in the keyboard status and control register to clear any false interrupts.
- 4. Clear the IMASKK bit.

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 the data direction register A.
- 2. Write 1s to the appropriate port A data register bits.
- 3. Enable the KBI pins by setting the appropriate KBIEx bits in the keyboard interrupt enable register.

## 12.5 Keyboard Interrupt Registers

Two registers control the operation of the keyboard interrupt module:

- Keyboard status and control register
- Keyboard interrupt enable register



### Table 16-7. DC Electrical Characteristics (3V) (Continued)

| Characteristic <sup>(1)</sup> | Symbol     | Min | Typ <sup>(2)</sup> | Max  | Unit |
|-------------------------------|------------|-----|--------------------|------|------|
| LVI reset voltage             | $V_{LVR3}$ | 2.0 | 2.4                | 2.69 | V    |

1.  $V_{DD}$  = 2.7 to 3.3 Vdc,  $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<sub>OP</sub> = 2MHz). All inputs 0.2V from rail. No dc loads. Less than 100 pF on all outputs. CL = 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<sub>OP</sub> = 2MHz). All inputs 0.2V from rail. No dc loads. Less than 100 pF on all outputs.  $C_L = 20$  pF on OSC2. All ports configured as inputs. OSC2 capacitance linearly affects wait  $I_{DD}$ . 5. Stop  $I_{DD}$  measured with OSC1 grounded; no port pins sourcing current. LVI is disabled.

6. Maximum is highest voltage that POR is guaranteed.

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

8.  $R_{PU1}$  and  $R_{PU2}$  are measured at  $V_{DD} = 5.0$  V.

## 16.9 3V Control Timing

### Table 16-8. Control Timing (3V)

| Characteristic <sup>(1)</sup>               | Symbol           | Min | Max | Unit |
|---------------------------------------------|------------------|-----|-----|------|
| Internal operating frequency <sup>(2)</sup> | f <sub>OP</sub>  | —   | 4   | MHz  |
| RST input pulse width low <sup>(3)</sup>    | t <sub>IRL</sub> | 1.5 |     | μs   |

1.  $V_{DD}$  = 2.7 to 3.3 Vdc,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_L$  to  $T_H$ ; timing shown with respect to 20%  $V_{DD}$  and 70%  $V_{DD}$ , unless otherwise noted.

2. Some modules may require a minimum frequency greater than dc for proper operation; see appropriate table for this information.

3. Minimum pulse width reset is guaranteed to be recognized. It is possible for a smaller pulse width to cause a reset.



## **16.11 Typical Supply Currents**



Figure 16-3. Typical Operating I<sub>DD</sub> (MC68HC908JL3E/JK3E/JK1E), with All Modules Turned On (25°C)



Figure 16-4. Typical Operating I<sub>DD</sub> (MC68HRC908JL3E/JK3E/JK1E), with All Modules Turned On (25°C)



Figure 16-5. Typical Wait Mode I<sub>DD</sub> (MC68HC908JL3E/JK3E/JK1E), with All Modules Turned Off ( $25^{\circ}$ C)



**Ordering Information**