# E·XFL



#### 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             | Obsolete                                                               |
|----------------------------|------------------------------------------------------------------------|
| Core Processor             | HC08                                                                   |
| Core Size                  | 8-Bit                                                                  |
| Speed                      | 8MHz                                                                   |
| Connectivity               | -                                                                      |
| Peripherals                | LVD, POR, PWM                                                          |
| Number of I/O              | 5                                                                      |
| Program Memory Size        | 4KB (4K x 8)                                                           |
| Program Memory Type        | FLASH                                                                  |
| EEPROM Size                | -                                                                      |
| RAM Size                   | 128 x 8                                                                |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                            |
| Data Converters            | A/D 6x10b                                                              |
| Oscillator Type            | Internal                                                               |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                     |
| Mounting Type              | Surface Mount                                                          |
| Package / Case             | 8-SOIC (0.209", 5.30mm Width)                                          |
| Supplier Device Package    | 8-SO                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc908qt4amdwer |

Email: info@E-XFL.COM

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



#### **Revision History**

The following revision history table summarizes changes contained in this document. For your convenience, the page number designators have been linked to the appropriate location.

# **Revision History**

| Date              | Revision<br>Level | Description                                                                                                                     | Page<br>Number(s)          |
|-------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| December,<br>2005 | N/A               | Initial release                                                                                                                 | N/A                        |
|                   |                   | Added 1.7 Unused Pin Termination.                                                                                               | 20                         |
|                   |                   | Figure 4-1. Auto Wakeup Interrupt Request Generation Logic — Corrected clock source.                                            | 51                         |
|                   |                   | 4.3 Functional Description — Clarified operation.                                                                               | 52                         |
|                   |                   | 4.5.1 Wait Mode — Corrected operation details.                                                                                  | 53                         |
| _                 |                   | 4.6.4 Configuration Register 2 — Corrected clock source.                                                                        | 55                         |
| August,<br>2006   | 1                 | 4.6.5 Configuration Register 1 — Added SSREC bit description.                                                                   | 55                         |
|                   |                   | 5.2 Functional Description — Corrected clock source.                                                                            | 58                         |
|                   |                   | 12.1 Introduction — Replaced note.                                                                                              | 103                        |
|                   |                   | 13.7.2 Stop Mode — Corrected clock source.                                                                                      | 121                        |
|                   |                   | 16.12 Supply Current Characteristics — Updated maximum values for SI <sub>DD</sub> at both 5 V and 3 V.                         | 165                        |
|                   |                   | A.2.3 Improved Auto Wakeup Module (AWU) — Corrected clock source.                                                               | 194                        |
|                   |                   | Chapter 3 Analog-to-Digital Converter (ADC10) Module — Renamed ADCSC register to ADSCR to be consistent with development tools. | 37                         |
|                   |                   | Figure 15-18. Monitor Mode Entry Timing — Changed CGMXCLK to BUSCLKX4                                                           | 154                        |
| 0 m mil           |                   | 16.12 Supply Current Characteristics — Added note 6 below table                                                                 | 165                        |
| April,<br>2007    | 2                 | Chapter 17 Ordering Information and Mechanical Specifications — Updated chapter to include:                                     |                            |
|                   |                   | Table 17-1. Consumer and Industrial Device Numbering System                                                                     | 171                        |
|                   |                   | 17.3 Orderable Part Numbering System                                                                                            | 171                        |
|                   |                   | 17.3.1 Consumer and Industrial Orderable Part Numbering System                                                                  | 172                        |
|                   |                   | 17.3.2 Automotive Orderable Part Number System                                                                                  | 172                        |
| March,<br>2010    | 3                 | Clarify internal oscillator trim register information.                                                                          | 27, 30, 31,<br>34, 95, 101 |



#### **Direct Page Registers**

| Addr.                 | Register Name                                          |                 | Bit 7           | 6                         | 5      | 4           | 3              | 2        | 1      | Bit 0   |  |
|-----------------------|--------------------------------------------------------|-----------------|-----------------|---------------------------|--------|-------------|----------------|----------|--------|---------|--|
|                       | TIM Channel 1 Status and                               | Read:           | CH1F            | CH1IE                     | 0      | MS1A        | FLS1B          | FLS1A    | TOV1   | CH1MAX  |  |
| \$0028                | Control Register (TSC1)                                | Write:          | 0               | Unite                     |        | MOTA        | LLOID          | LLOIA    | 1001   | OTTIMAX |  |
|                       | See page 135.                                          | Reset:          | 0               | 0                         | 0      | 0           | 0              | 0        | 0      | 0       |  |
| \$0029                | TIM Channel 1<br>Register High (TCH1H)                 | Read:<br>Write: | Bit 15          | Bit 14                    | Bit 13 | Bit 12      | Bit 11         | Bit 10   | Bit 9  | Bit 8   |  |
|                       | See page 137.                                          | Reset:          |                 | Indeterminate after reset |        |             |                |          |        |         |  |
| \$002A                | TIM Channel 1<br>Register Low (TCH1L)                  | Read:<br>Write: | Bit 7           | Bit 6                     | Bit 5  | Bit 4       | Bit 3          | Bit 2    | Bit 1  | Bit 0   |  |
|                       | See page 137.                                          | Reset:          |                 |                           |        | Indetermina | te after reset |          |        |         |  |
| \$002B<br>↓<br>\$0035 | Reserved                                               |                 |                 |                           |        |             |                |          |        |         |  |
|                       |                                                        |                 |                 |                           |        |             |                |          |        |         |  |
|                       | Oscillator Status and                                  | Read:           | OSCOPT1         | OSCOPTO                   | ICES1  | ICESO       | ECES1          | ECES0    | ECGON  | ECGST   |  |
| \$0036 Control Reg    | Control Register (OSCSC)                               | Write:          | 0000111         | 0000110                   | 101 01 | 101 00      | LOI OI         |          | LOUON  |         |  |
|                       | See page 100.                                          | Reset:          | 0               | 0                         | 1      | 0           | 0              | 0        | 0      | 0       |  |
|                       |                                                        |                 |                 |                           |        | 1           | 1              |          | r      |         |  |
| \$0037                | Reserved                                               |                 |                 |                           |        |             |                |          |        |         |  |
|                       |                                                        | 1               |                 |                           |        | I           |                |          | 1      |         |  |
| \$0038                | Oscillator Trim Register<br>(OSCTRIM)<br>See page 101. | Read:<br>Write: | TRIM7           | TRIM6                     | TRIM5  | TRIM4       | TRIM3          | TRIM2    | TRIM1  | TRIM0   |  |
|                       |                                                        | Reset:          | 1               | 0                         | 0      | 0           | 0              | 0        | 0      | 0       |  |
| \$0039                | <b>-</b> .                                             |                 |                 |                           |        |             |                |          |        |         |  |
| ↓<br>\$003B           | Reserved                                               |                 |                 |                           |        |             |                |          |        |         |  |
| ,                     |                                                        |                 |                 |                           |        |             |                |          | L      |         |  |
| \$003C                | ADC10 Status and Control<br>Register (ADSCR)           | Read:<br>Write: | 0000            | AIEN                      | ADCO   | ADCH4       | ADCH3          | ADCH2    | ADCH1  | ADCH0   |  |
|                       | See page 46.                                           | Reset:          | 0               | 0                         | 0      | 1           | 1              | 1        | 1      | 1       |  |
|                       | ADC10 Data Register High                               | Read:           | 0               | 0                         | 0      | 0           | 0              | 0        | AD9    | AD8     |  |
| \$003D                | (ADRH)                                                 | Write:          | R               | R                         | R      | R           | R              | R        | R      | R       |  |
|                       | See page 48.                                           | Reset:          | 0               | 0                         | 0      | 0           | 0              | 0        | 0      | 0       |  |
|                       | ADC10 Data Register Low                                | Read:           | AD7             | AD6                       | AD5    | AD4         | AD3            | AD2      | AD1    | AD0     |  |
| \$003E                | (ADRL)                                                 | Write:          | R               | R                         | R      | R           | R              | R        | R      | R       |  |
|                       | See page 48.                                           | Reset:          | 0               | 0                         | 0      | 0           | 0              | 0        | 0      | 0       |  |
| \$003F                | ADC10 Clock Register<br>(ADCLK)                        | Read:<br>Write: | ADLPC           | ADIV1                     | ADIV0  | ADICLK      | MODE1          | MODE0    | ADLSMP | ACLKEN  |  |
|                       | See page 48.                                           | Reset:          | 0               | 0                         | 0      | 0           | 0              | 0        | 0      | 0       |  |
|                       |                                                        |                 | = Unimplemented |                           |        | R           | = Reserved     | U = Unaf | fected |         |  |





#### Memory

| Addr.        | Register Name               |        | Bit 7  | 6          | 5      | 4      | 3          | 2         | 1     | Bit 0 |
|--------------|-----------------------------|--------|--------|------------|--------|--------|------------|-----------|-------|-------|
|              | Break Status Register       | Read:  | в      | Р          | Б      | Б      | Б          | Р         | SBSW  | Р     |
| \$FE00       | (BSR)                       | Write: | R      | п          | ň      | n n    | п          | n         | 0     | 'n    |
|              | See page 143.               | Reset: |        | •          | •      |        |            |           | 0     |       |
|              | SIM Reset Status Register   | Read:  | POR    | PIN        | COP    | ILOP   | ILAD       | MODRST    | LVI   | 0     |
| \$FE01       | (SRSR)                      | Write: |        |            |        |        |            |           |       |       |
|              | See page 122.               | POR:   | 1      | 0          | 0      | 0      | 0          | 0         | 0     | 0     |
|              | Break Auxiliary             | Read:  | 0      | 0          | 0      | 0      | 0          | 0         | 0     | PDCOD |
| \$FE02       | Register (BRKAR)            | Write: |        |            |        |        |            |           |       | BDCOP |
|              | See page 143.               | Reset: | 0      | 0          | 0      | 0      | 0          | 0         | 0     | 0     |
|              | Break Flag Control          | Read:  | BCEE   | B          | в      | в      | в          | в         | в     | в     |
| \$FE03       | Register (BFCR)             | Write: | DOIL   | 11         | 11     | 11     | 11         | 11        |       | 11    |
|              | See page 143.               | Reset: | 0      |            | -      |        |            |           |       |       |
|              | Interrupt Status Register 1 | Read:  | IF6    | IF5        | IF4    | IF3    | IF2        | IF1       | 0     | 0     |
| \$FE04       | (INT1)                      | Write: | R      | R          | R      | R      | R          | R         | R     | R     |
|              | See page 119.               | Reset: | 0      | 0          | 0      | 0      | 0          | 0         | 0     | 0     |
|              | Interrupt Status Register 2 | Read:  | IF14   | IF13       | IF12   | IF11   | IF10       | IF9       | IF8   | IF7   |
| \$FE05       | (INT2)                      | Write: | R      | R          | R      | R      | R          | R         | R     | R     |
|              | See page 119.               | Reset: | 0      | 0          | 0      | 0      | 0          | 0         | 0     | 0     |
| Interru      | Interrupt Status Register 3 | Read:  | IF22   | IF21       | IF20   | IF19   | IF18       | IF17      | IF16  | IF15  |
| \$FE06       | (INT3)                      | Write: | R      | R          | R      | R      | R          | R         | R     | R     |
|              | See page 119.               | Reset: | 0      | 0          | 0      | 0      | 0          | 0         | 0     | 0     |
| <b>*----</b> |                             |        |        |            |        |        |            |           |       |       |
| \$FE07       | Reserved                    |        |        |            |        |        |            |           |       |       |
|              |                             | l      |        |            |        |        |            |           |       |       |
|              | ELASH Control Projetor      | Read:  | 0      | 0          | 0      | 0      |            |           |       |       |
| \$FE08       | (FLCR)                      | Write: |        |            |        |        | HVEN       | MASS      | ERASE | PGM   |
|              | See page 29.                | Reset: | 0      | 0          | 0      | 0      | 0          | 0         | 0     | 0     |
|              | Break Address High          | Read:  | Diste  | Director   | D'L 40 | Disto  | Direct     | Di to     | Dito  | Dito  |
| \$FE09       | Register (BRKH)             | Write: | Bit 15 | Bit 14     | Bit 13 | Bit 12 | Bit 11     | Bit 10    | Bit 9 | Bit 8 |
|              | See page 142.               | Reset: | 0      | 0          | 0      | 0      | 0          | 0         | 0     | 0     |
|              | Break Address low           | Read:  | D# 7   | DH C       |        | D:4 4  | DH 0       | DHO       | Dia 4 | DHO   |
| \$FE0A       | Register (BRKL)             | Write: | BIT /  | BIT 6      | BIT 2  | BIT 4  | BIT 3      | BIT 2     | BITI  | BITU  |
|              | See page 142.               | Reset: | 0      | 0          | 0      | 0      | 0          | 0         | 0     | 0     |
|              | Break Status and Control    | Read:  | חחת    |            | 0      | 0      | 0          | 0         | 0     | 0     |
| \$FE0B       | Register (BRKSCR)           | Write: | BHKE   | внка       |        |        |            |           |       |       |
|              | See page 143.               | Reset: | 0      | 0          | 0      | 0      | 0          | 0         | 0     | 0     |
|              |                             |        |        | = Unimplem | nented | R      | = Reserved | U = Unafi | ected |       |

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



#### **Direct Page Registers**

| Addr.                 | Register Name                                   |                 | Bit 7  | 6                                       | 5     | 4                           | 3          | 2          | 1     | Bit 0 |  |
|-----------------------|-------------------------------------------------|-----------------|--------|-----------------------------------------|-------|-----------------------------|------------|------------|-------|-------|--|
|                       | LVI Status Register                             | Read:           | LVIOUT | 0                                       | 0     | 0                           | 0          | 0          | 0     | R     |  |
| \$FE0C                | (LVISR)                                         | Write:          |        |                                         |       |                             |            |            |       |       |  |
|                       | See page 91.                                    | Reset:          | 0      | 0                                       | 0     | 0                           | 0          | 0          | 0     | 0     |  |
| \$FE0D<br>↓<br>\$FE0F | Reserved                                        |                 |        |                                         |       |                             |            |            |       |       |  |
| \$FFBE                | FLASH Block Protect<br>Register (FLBPR)         | Read:<br>Write: | BPR7   | BPR6                                    | BPR5  | BPR4                        | BPR3       | BPR2       | BPR1  | BPR0  |  |
|                       | See page 34.                                    | Reset:          |        | Unaffected by reset                     |       |                             |            |            |       |       |  |
| \$FFBF                | Reserved                                        |                 |        |                                         |       |                             |            |            |       |       |  |
|                       |                                                 | F               |        | r                                       |       |                             | r          |            |       | 1     |  |
| \$FFC0                | Internal Oscillator Trim<br>(Factory Programmed | Read:<br>Write: | TRIM7  | TRIM6                                   | TRIM5 | TRIM4                       | TRIM3      | TRIM2      | TRIM1 | TRIM0 |  |
|                       | VDD = 3.0 V)                                    | Reset:          |        |                                         |       | Unaffecte                   | d by reset |            |       |       |  |
| \$FFC1                | Internal Oscillator Trim<br>(Factory Programmed | Read:<br>Write: | TRIM7  | TRIM6                                   | TRIM5 | TRIM4                       | TRIM3      | TRIM2      | TRIM1 | TRIM0 |  |
|                       | VDD = 5.0 V)                                    | Reset:          |        | Unaffected by reset                     |       |                             |            |            |       |       |  |
|                       |                                                 | Dente           |        |                                         |       |                             |            | 0.0        |       |       |  |
|                       | COP Control Register                            | Head:           |        |                                         |       |                             |            |            |       |       |  |
| <b>φ</b> ΗΗΗ          | (COPCIL)<br>See page 63.                        | vvrite:         |        |                                         |       |                             |            | NNY VALUE) |       |       |  |
|                       | 000 page 00.                                    | Reset:          |        | [ ] ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ |       | Unattecte                   | a by reset |            | ( t I |       |  |
|                       |                                                 |                 |        | = Unimplem                              | ented | K = Reserved U = Unaffected |            |            |       |       |  |

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



break, the bit cannot change during the break state as long as BCFE is cleared. After the break, doing the second step clears the status bit.

# 3.7 I/O Signals

The ADC10 module shares its pins with general-purpose input/output (I/O) port pins. See Figure 3-1 for port location of these shared pins. The ADC10 on this MCU uses  $V_{DD}$  and  $V_{SS}$  as its supply and reference pins. This MCU does not have an external trigger source.

# 3.7.1 ADC10 Analog Power Pin (V<sub>DDA</sub>)

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

NOTE

If externally available, route  $V_{DDA}$  carefully for maximum noise immunity and place bypass capacitors as near as possible to the package.

# 3.7.2 ADC10 Analog Ground Pin (V<sub>SSA</sub>)

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

In cases where separate power supplies are used for analog and digital power, the ground connection between these supplies should be at the  $V_{SSA}$  pin. This should be the only ground connection between these supplies if possible. The  $V_{SSA}$  pin makes a good single point ground location.

# 3.7.3 ADC10 Voltage Reference High Pin (V<sub>REFH</sub>)

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

#### NOTE

Route  $V_{REFH}$  carefully for maximum noise immunity and place bypass capacitors as near as possible to the package.

AC current in the form of current spikes required to supply charge to the capacitor array at each successive approximation step is drawn through the V<sub>REFH</sub> and V<sub>REFL</sub> loop. The best external component to meet this current demand is a 0.1  $\mu$ F capacitor with good high frequency characteristics. This capacitor is connected between V<sub>REFH</sub> and V<sub>REFL</sub> and must be placed as close as possible to the package pins. Resistance in the path is not recommended because the current will cause a voltage drop which could result in conversion errors. Inductance in this path must be minimum (parasitic only).

# 3.7.4 ADC10 Voltage Reference Low Pin (V<sub>REFL</sub>)

 $V_{REFL}$  is the power supply for setting the low-reference voltage for the converter. In some packages,  $V_{REFL}$  is connected internally to  $V_{SSA}$ . If externally available, connect the  $V_{REFL}$  pin to the same voltage potential as  $V_{SSA}$ . There will be a brief current associated with  $V_{REFL}$  when the sampling capacitor is



#### Analog-to-Digital Converter (ADC10) Module

charging. If externally available, connect the  $V_{\text{REFL}}$  pin to the same potential as  $V_{\text{SSA}}$  at the single point ground location.

# 3.7.5 ADC10 Channel Pins (ADn)

The ADC10 has multiple input channels. Empirical data shows that capacitors on the analog inputs improve performance in the presence of noise or when the source impedance is high. 0.01  $\mu$ F capacitors with good high-frequency characteristics are sufficient. These capacitors are not necessary in all cases, but when used they must be placed as close as possible to the package pins and be referenced to V<sub>SSA</sub>.

# 3.8 Registers

These registers control and monitor operation of the ADC10:

- ADC10 status and control register, ADSCR
- ADC10 data registers, ADRH and ADRL
- ADC10 clock register, ADCLK

### 3.8.1 ADC10 Status and Control Register

This section describes the function of the ADC10 status and control register (ADSCR). Writing ADSCR aborts the current conversion and initiates a new conversion (if the ADCH[4:0] bits are equal to a value other than all 1s).

|                 | Bit 7 | 6    | 5    | 4     | 3     | 2     | 1     | Bit 0 |
|-----------------|-------|------|------|-------|-------|-------|-------|-------|
| Read:<br>Write: | COCO  | AIEN | ADCO | ADCH4 | ADCH3 | ADCH2 | ADCH1 | ADCH0 |
| Reset:          | 0     | 0    | 0    | 1     | 1     | 1     | 1     | 1     |

#### Figure 3-3. ADC10 Status and Control Register (ADSCR)

#### COCO — Conversion Complete Bit

COCO is a read-only bit which is set each time a conversion is completed. This bit is cleared whenever the status and control register is written or whenever the data register (low) is read.

- 1 = Conversion completed
- 0 = Conversion not completed

#### AIEN — ADC10 Interrupt Enable Bit

When this bit is set, an interrupt is generated at the end of a conversion. The interrupt signal is cleared when the data register is read or the status/control register is written.

1 = ADC10 interrupt enabled

0 = ADC10 interrupt disabled

#### ADCO — ADC10 Continuous Conversion Bit

When this bit is set, the ADC10 will begin to convert samples continuously (continuous conversion mode) and update the result registers at the end of each conversion, provided the ADCH[4:0] bits do not decode to all 1s. The ADC10 will continue to convert until the MCU enters reset, the MCU enters stop mode (if ACLKEN is clear), ADCLK is written, or until ADSCR is written again. If stop is entered (with ACLKEN low), continuous conversions will cease and can be restarted only with a write to ADSCR. Any write to ADSCR with ADCO set and the ADCH bits not all 1s will abort the current conversion and begin continuous conversions.



### 6.3.7 COPRS (COP Rate Select)

The COPRS signal reflects the state of the COP rate select bit (COPRS) in the configuration register 1 (CONFIG1). See Chapter 5 Configuration Register (CONFIG).

# 6.4 Interrupts

The COP does not generate CPU interrupt requests.

# 6.5 Monitor Mode

The COP is disabled in monitor mode when  $V_{TST}$  is present on the IRQ pin.

# 6.6 Low-Power Modes

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

### 6.6.1 Wait Mode

The COP continues to operate during wait mode. To prevent a COP reset during wait mode, periodically clear the COP counter.

### 6.6.2 Stop Mode

Stop mode turns off the BUSCLKX4 input to the COP and clears the SIM counter. Service the COP immediately before entering or after exiting stop mode to ensure a full COP timeout period after entering or exiting stop mode.

# 6.7 COP Module During Break Mode

The COP is disabled during a break interrupt with monitor mode when BDCOP bit is set in break auxiliary register (BRKAR).

# 6.8 Register

The COP control register (COPCTL) is located at address \$FFFF and overlaps the reset vector. Writing any value to \$FFFF clears the COP counter and starts a new timeout period. Reading location \$FFFF returns the low byte of the reset vector.



Figure 6-2. COP Control Register (COPCTL)

# External Interrupt (IRQ)



PTA[0:5]: Higher current sink and source capability

PTB[0:7]: Not available on 8-pin devices

### Figure 8-1. Block Diagram Highlighting IRQ Block and Pin

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

#### NOTE

The interrupt mask (I) in the condition code register (CCR) masks all interrupt requests, including the IRQ interrupt request.

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



### 11.3.1.2 XTAL Oscillator Clock (XTALCLK)

XTALCLK is the XTAL oscillator output signal. It runs at the full speed of the crystal ( $f_{XCLK}$ ) and comes directly from the crystal oscillator circuit. Figure 11-2 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. The frequency of XTALCLK can be unstable at start up.

### 11.3.1.3 RC Oscillator Clock (RCCLK)

RCCLK is the RC oscillator output signal. Its frequency is directly proportional to the time constant of the external R ( $R_{EXT}$ ) and internal C. Figure 11-3 shows only the logical relation of RCCLK to OSC1 and may not represent the actual circuitry.

### 11.3.1.4 Internal Oscillator Clock (INTCLK)

INTCLK is the internal oscillator output signal. INTCLK is software selectable to be nominally 12.8 MHz, 8.0 MHz, or 4.0 MHz. INTCLK can be digitally adjusted using the oscillator trimming feature of the OSCTRIM register (see 11.3.2.1 Internal Oscillator Trimming).

### 11.3.1.5 Bus Clock Times 4 (BUSCLKX4)

BUSCLKX4 is the same frequency as the input clock (XTALCLK, RCCLK, or INTCLK). This signal is driven to the SIM module and is used during recovery from reset and stop and is the clock source for the COP module.

### 11.3.1.6 Bus Clock Times 2 (BUSCLKX2)

The frequency of this signal is equal to half of the BUSCLKX4. This signal is driven to the SIM for generation of the bus clocks used by the CPU and other modules on the MCU. BUSCLKX2 will be divided by two in the SIM. The internal bus frequency is one fourth of the XTALCLK, RCCLK, or INTCLK frequency.

### 11.3.2 Internal Oscillator

The internal oscillator circuit is designed for use with no external components to provide a clock source with a tolerance of less than  $\pm 25\%$  untrimmed. An 8-bit register (OSCTRIM) allows the digital adjustment to a tolerance of ACC<sub>INT</sub>. See the oscillator characteristics in the Electrical section of this data sheet.

The internal oscillator is capable of generating clocks of 12.8 MHz, 8.0 MHz, or 4.0 MHz (INTCLK) resulting in a bus frequency (INTCLK divided by 4) of 3.2 MHz, 2.0 MHz, or 1.0 MHz respectively. The bus clock is software selectable and defaults to the 3.2-MHz bus out of reset. Users can increase the bus frequency based on the voltage range of their application.

Figure 11-3 shows how BUSCLKX4 is derived from INTCLK and OSC2 can output BUSCLKX4 by setting OSC2EN.

#### 11.3.2.1 Internal Oscillator Trimming

OSCTRIM allows a clock period adjustment of +127 and -128 steps. Increasing the OSCTRIM value increases the clock period, which decreases the clock frequency. Trimming allows the internal clock frequency to be fine tuned to the target frequency.

All devices are factory programmed with trim values that are stored in FLASH memory at locations \$FFC0 and \$FFC1. The trim value is **not** automatically loaded into the OSCTRIM register. User software must



Oscillator (OSC) Module

# 11.8 Registers

The oscillator module contains two registers:

- Oscillator status and control register (OSCSC)
- Oscillator trim register (OSCTRIM)

# 11.8.1 Oscillator Status and Control Register

The oscillator status and control register (OSCSC) contains the bits for switching between internal and external clock sources. If the application uses an external crystal, bits in this register are used to select the crystal oscillator amplifier necessary for the desired crystal. While running off the internal clock source, the user can use bits in this register to select the internal clock source frequency.





#### OSCOPT1:OSCOPT0 — OSC Option Bits

These read/write bits allow the user to change the clock source for the MCU. The default reset condition has the bus clock being derived from the internal oscillator. See 11.3.2.2 Internal to External Clock Switching for information on changing clock sources.

| OSCOPT1 | OSCOPT0 | Oscillator Modes                                          |
|---------|---------|-----------------------------------------------------------|
| 0       | 0       | Internal oscillator (frequency selected using ICFSx bits) |
| 0       | 1       | External oscillator clock                                 |
| 1       | 0       | External RC                                               |
| 1       | 1       | External crystal (range selected using ECFSx bits)        |

#### ICFS1:ICFS0 — Internal Clock Frequency Select Bits

These read/write bits enable the frequency to be increased for applications requiring a faster bus clock when running off the internal oscillator. The WAIT instruction has no effect on the oscillator logic. BUSCLKX2 and BUSCLKX4 continue to drive to the SIM module.

| ICFS1 | ICFS0 | Internal Clock Frequency           |
|-------|-------|------------------------------------|
| 0     | 0     | 4.0 MHz                            |
| 0     | 1     | 8.0 MHz                            |
| 1     | 0     | 12.8 MHz — default reset condition |
| 1     | 1     | Reserved                           |



Input/Output Ports (PORTS)

### 12.4.3 Port B Input Pullup Enable Register

The port B input pullup enable register (PTBPUE) contains a software configurable pullup device for each of the eight port B pins. Each bit is individually configurable and requires the corresponding data direction register, DDRBx, be configured as input. Each pullup device is automatically and dynamically disabled when its corresponding DDRBx bit is configured as output.



Figure 12-8. Port B Input Pullup Enable Register (PTBPUE)

### PTBPUE[7:0] — Port B Input Pullup Enable Bits

These read/write bits are software programmable to enable pullup devices on port B pins

- 1 = Corresponding port B pin configured to have internal pull if its DDRB bit is set to 0
- 0 = Pullup device is disconnected on the corresponding port B pin regardless of the state of its DDRB bit.

### 12.4.4 Port B Summary Table

Table 12-2 summarizes the operation of the port A pins when used as a general-purpose input/output pins.

| DDRB | РТВ              | I/O Pin                    | Accesses to DDRB | Accesses to PTB |                          |  |
|------|------------------|----------------------------|------------------|-----------------|--------------------------|--|
| Bit  | Bit              | Mode                       | Read/Write       | Read            | Write                    |  |
| 0    | X <sup>(1)</sup> | Input, Hi-Z <sup>(2)</sup> | DDRB7-DDRB0      | Pin             | PTB7–PTB0 <sup>(3)</sup> |  |
| 1    | Х                | Output                     | DDRB7-DDRB0      | Pin             | PTB7–PTB0                |  |

#### Table 12-2. Port B Pin Functions

1. X = don't care

2. Hi-Z = high impedance

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





# **13.6 Exception Control**

Normal sequential program execution can be changed in three different ways:

- 1. Interrupts
  - a. Maskable hardware CPU interrupts
  - b. Non-maskable software interrupt instruction (SWI)
- 2. Reset
- 3. Break interrupts

### 13.6.1 Interrupts

An interrupt temporarily changes the sequence of program execution to respond to a particular event. Figure 13-7 flow charts the handling of system interrupts.

Interrupts are latched, and arbitration is performed in the SIM at the start of interrupt processing. The arbitration result is a constant that the CPU uses to determine which vector to fetch. Once an interrupt is latched by the SIM, no other interrupt can take precedence, regardless of priority, until the latched interrupt is serviced (or the I bit is cleared).

At the beginning of an interrupt, the CPU saves the CPU register contents on the stack and sets the interrupt mask (I bit) to prevent additional interrupts. At the end of an interrupt, the RTI instruction recovers the CPU register contents from the stack so that normal processing can resume. Figure 13-8 shows interrupt entry timing. Figure 13-9 shows interrupt recovery timing.

#### 13.6.1.1 Hardware Interrupts

A hardware interrupt does not stop the current instruction. Processing of a hardware interrupt begins after completion of the current instruction. When the current instruction is complete, the SIM checks all pending hardware interrupts. If interrupts are not masked (I bit clear in the condition code register), and if the corresponding interrupt enable bit is set, the SIM proceeds with interrupt processing; otherwise, the next instruction is fetched and executed.

If more than one interrupt is pending at the end of an instruction execution, the highest priority interrupt is serviced first. Figure 13-10 demonstrates what happens when two interrupts are pending. If an interrupt is pending upon exit from the original interrupt service routine, the pending interrupt is serviced before the LDA instruction is executed.

The LDA opcode is prefetched by both the INT1 and INT2 return-from-interrupt (RTI) instructions. However, in the case of the INT1 RTI prefetch, this is a redundant operation.

#### NOTE

To maintain compatibility with the M6805 Family, the H register is not pushed on the stack during interrupt entry. If the interrupt service routine modifies the H register or uses the indexed addressing mode, software should save the H register and then restore it prior to exiting the routine.



#### 13.6.2.1 Interrupt Status Register 1

|        | Bit 7 | 6          | 5   | 4   | 3   | 2   | 1 | Bit 0 |
|--------|-------|------------|-----|-----|-----|-----|---|-------|
| Read:  | IF6   | IF5        | IF4 | IF3 | IF2 | IF1 | 0 | 0     |
| Write: | R     | R          | R   | R   | R   | R   | R | R     |
| Reset: | 0     | 0          | 0   | 0   | 0   | 0   | 0 | 0     |
|        | R     | = Reserved |     |     |     |     |   |       |



#### IF1–IF6 — Interrupt Flags

These flags indicate the presence of interrupt requests from the sources shown in Table 13-3.

1 = Interrupt request present

0 = No interrupt request present

#### Bit 0, 1 — Always read 0

#### 13.6.2.2 Interrupt Status Register 2

|        | Bit 7 | 6          | 5    | 4    | 3    | 2   | 1   | Bit 0 |
|--------|-------|------------|------|------|------|-----|-----|-------|
| Read:  | IF14  | IF13       | IF12 | IF11 | IF10 | IF9 | IF8 | IF7   |
| Write: | R     | R          | R    | R    | R    | R   | R   | R     |
| Reset: | 0     | 0          | 0    | 0    | 0    | 0   | 0   | 0     |
|        | R     | = Reserved |      |      |      |     |     |       |

Figure 13-12. Interrupt Status Register 2 (INT2)

#### IF7–IF14 — Interrupt Flags

This flag indicates the presence of interrupt requests from the sources shown in Table 13-3.

1 = Interrupt request present

0 = No interrupt request present

#### 13.6.2.3 Interrupt Status Register 3

|        | Bit 7 | 6          | 5    | 4    | 3    | 2    | 1    | Bit 0 |
|--------|-------|------------|------|------|------|------|------|-------|
| Read:  | IF22  | IF21       | IF20 | IF19 | IF18 | IF17 | IF16 | IF15  |
| Write: | R     | R          | R    | R    | R    | R    | R    | R     |
| Reset: | 0     | 0          | 0    | 0    | 0    | 0    | 0    | 0     |
|        | R     | = Reserved |      |      |      |      |      |       |

#### Figure 13-13. Interrupt Status Register 3 (INT3)

#### IF15–IF22 — Interrupt Flags

These flags indicate the presence of interrupt requests from the sources shown in Table 13-3.

1 = Interrupt request present

0 = No interrupt request present



#### System Integration Module (SIM)

The SIM counter is held in reset from the execution of the STOP instruction until the beginning of stop recovery. It is then used to time the recovery period. Figure 13-17 shows stop mode entry timing and Figure 13-18 shows the stop mode recovery time from interrupt or break

**NOTE** To minimize stop current, all pins configured as inputs should be driven to

#### a logic 1 or logic 0. CPUSTOP ADDRESS BUS STOP ADDR STOP ADDR + 1 SAME SAME PREVIOUS DATA NEXT OPCODE SAME SAME DATA BUS R/W NOTE: Previous data can be operand data or the STOP opcode, depending on the last instruction. Figure 13-17. Stop Mode Entry Timing STOP RECOVERY PERIOD BUSCLKX4 INTERRUPT STOP + 2 STOP + 2 ADDRESS BUS STOP +1 SP SP - 1 SP - 2 SP - 3

Figure 13-18. Stop Mode Recovery from Interrupt

# **13.8 SIM Registers**

The SIM has two memory mapped registers.

### 13.8.1 SIM Reset Status Register

The SRSR register contains flags that show the source of the last reset. The status register will automatically clear after reading SRSR. A power-on reset sets the POR bit and clears all other bits in the register. All other reset sources set the individual flag bits but do not clear the register. More than one reset source can be flagged at any time depending on the conditions at the time of the internal or external reset. For example, the POR and LVI bit can both be set if the power supply has a slow rise time.







# Chapter 15 Development Support

# **15.1 Introduction**

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

# 15.2 Break Module (BRK)

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

Features include:

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

### 15.2.1 Functional Description

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

The following events can cause a break interrupt to occur:

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

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

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

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

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







#### Table 15-7. READSP (Read Stack Pointer) Command





The MCU executes the SWI and PSHH instructions when it enters monitor mode. The RUN command tells the MCU to execute the PULH and RTI instructions. Before sending the RUN command, the host can modify the stacked CPU registers to prepare to run the host program. The READSP command returns the incremented stack pointer value, SP + 1. The high and low bytes of the program counter are at addresses SP + 5 and SP + 6.

|                              | SP     |
|------------------------------|--------|
| HIGH BYTE OF INDEX REGISTER  | SP + 1 |
| CONDITION CODE REGISTER      | SP + 2 |
| ACCUMULATOR                  | SP + 3 |
| LOW BYTE OF INDEX REGISTER   | SP + 4 |
| HIGH BYTE OF PROGRAM COUNTER | SP + 5 |
| LOW BYTE OF PROGRAM COUNTER  | SP + 6 |
|                              | SP + 7 |
|                              |        |

Figure 15-17. Stack Pointer at Monitor Mode Entry



# 16.7 5-V Control Timing

| Characteristic <sup>(1)</sup>                                 | Symbol                                 | Min                 | Max | Unit             |
|---------------------------------------------------------------|----------------------------------------|---------------------|-----|------------------|
| Internal operating frequency                                  | f <sub>OP</sub><br>(f <sub>BUS</sub> ) | _                   | 8   | MHz              |
| Internal clock period (1/f <sub>OP</sub> )                    | t <sub>cyc</sub>                       | 125                 | _   | ns               |
| RST input pulse width low <sup>(2)</sup>                      | t <sub>RL</sub>                        | 100                 | —   | ns               |
| IRQ interrupt pulse width low (edge-triggered) <sup>(2)</sup> | t <sub>ILIH</sub>                      | 100                 | _   | ns               |
| IRQ interrupt pulse period <sup>(2)</sup>                     | t <sub>ILIL</sub>                      | Note <sup>(3)</sup> | —   | t <sub>cyc</sub> |

1. V<sub>DD</sub> = 4.5 to 5.5 Vdc, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub>; timing shown with respect to 20% V<sub>DD</sub> and 70% V<sub>SS</sub>, unless otherwise noted.

2. Values are based on characterization results, not tested in production.

3. The minimum period is the number of cycles it takes to execute the interrupt service routine plus 1  $t_{cyc}$ .



Figure 16-3. RST and IRQ Timing



**Mechanical Drawings** 

Case 968 page 2 of 3

\_\_\_\_\_



**Mechanical Drawings** 

Case 648 page 3 of 3



**Ordering Information and Mechanical Specifications** 

Case 948F page 1 of 3