

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               | I <sup>2</sup> C, IRSCI, SCI, SPI                          |
| Peripherals                | LED, LVD, POR, PWM                                         |
| Number of I/O              | 32                                                         |
| Program Memory Size        | 16KB (16K x 8)                                             |
| Program Memory Type        | FLASH                                                      |
| EEPROM Size                | -                                                          |
| RAM Size                   | 1K x 8                                                     |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                |
| Data Converters            | A/D 8x10b                                                  |
| Oscillator Type            | Internal                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                          |
| Mounting Type              | Surface Mount                                              |
| Package / Case             | 48-LQFP                                                    |
| Supplier Device Package    | 48-LQFP (7x7)                                              |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=mc908ap16cfae |

Email: info@E-XFL.COM

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





# MC68HC908AP64 MC68HC908AP32 MC68HC908AP16 MC68HC908AP8

**Data Sheet** 

To provide the most up-to-date information, the revision of our documents on the World Wide Web will be the most current. Your printed copy may be an earlier revision. To verify you have the latest information available, refer to:

#### http://www.freescale.com

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.

Freescale<sup>™</sup> and the Freescale logo are trademarks of Freescale Semiconductor, Inc. This product incorporates SuperFlash® technology licensed from SST.

© Freescale Semiconductor, Inc., 2005, 2007. All rights reserved.



## **Revision History**

\_\_\_\_\_

| Date         | Revision<br>Level | Description                                                                                                                                                                                                                              | Page<br>Number(s) |
|--------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| January 2007 | 4                 | 15.7.2 ADC Clock Control Register — Changed "The ADC clock should<br>be set to between 500kHz and 2MHz" to "The ADC clock should be set<br>to between 500kHz and 1MHz"                                                                   | 254               |
|              |                   | Table 22-4 . DC Electrical Characteristics (5V) — Updated $V_{OL}$ values.                                                                                                                                                               | 299               |
| August 2005  | 3                 | Table 22-6 . Oscillator Specifications (5V) and Table 22-10 . Oscillator Specifications (3V) — Corrected internal oscillator clock frequency, $f_{\rm ICLK}$ . Updated crystal oscillator component values $C_L,C_1,C_2,R_B,$ and $R_S.$ | 301, 305          |
|              |                   | Added MC68HC908AP16/AP8 information throughout.                                                                                                                                                                                          | —                 |
| October 2003 | 2.5               | Section 10. Monitor ROM (MON) — Corrected RAM address to \$60.                                                                                                                                                                           | 167               |
|              |                   | Section 24. Electrical Specifications — Added run and wait $\rm I_{DD}$ data for 8MHz at 3V.                                                                                                                                             | 421               |
| August 2003  | 2.4               | Section 24. Electrical Specifications — Updated stop I <sub>DD</sub> data.                                                                                                                                                               | 417, 421          |
|              |                   | Removed MC68HC908AP16 references throughout.                                                                                                                                                                                             | _                 |
|              |                   | Table 1-2 . Pin Functions — Added footnote for V <sub>REG</sub> .                                                                                                                                                                        | 30                |
|              |                   | 5.3 Configuration Register 1 (CONFIG1) — Clarified LVIPWRD and LVIREGD bits.                                                                                                                                                             | 67                |
| July 2003    | 2.3               | Section 8. Clock Generator Module (CGM), 8.7.2 Stop Mode — Updated BSC bit behavior.                                                                                                                                                     | 125               |
|              |                   | 10.5 ROM-Resident Routines — Corrected data size limits and control byte size for EE_READ and EE_WRITE.                                                                                                                                  | 168–193           |
|              |                   | Figure 12-2 . Timebase Control Register (TBCR) — Corrected register address.                                                                                                                                                             | 207               |
|              |                   | Section 24. Electrical Specifications — Updated.                                                                                                                                                                                         | 415               |
| May 2003     | 2.2               | Updated for $f_{NOM} = 125 \text{ kHz}$ and filter components in CGM section.                                                                                                                                                            | 101               |
|              |                   | Updated electricals.                                                                                                                                                                                                                     | 415               |





Figure 1-3. 44-Pin QFP Pin Assignments



 $V_{DDA}$  and  $V_{SSA}$  are the power supply and ground pins for the analog circuits of the MCU. These pins should be decoupled as per the digital power supply pins.





Figure 1-5. Power Supply Bypassing

### **1.7 Regulator Power Supply Configuration (VREG)**

 $V_{REG}$  is the output from the on-chip regulator. All internal logics, except for the I/O pads, are powered by  $V_{REG}$  output.  $V_{REG}$  requires an external ceramic bypass capacitor of 100 nF as Figure 1-6 shows. Place the bypass capacitor as close to the  $V_{REG}$  pin as possible.



Figure 1-6. Regulator Power Supply Bypassing



**Central Processor Unit (CPU)** 

| Source                                                                                           | Operation                                            | Description                                                         | Effect on<br>CCR |   |   |   |   |   | dress<br>ode                                                                                             | code                                             | erand                                                                         | rcles                                               |
|--------------------------------------------------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------|------------------|---|---|---|---|---|----------------------------------------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------------------------------------------------|-----------------------------------------------------|
| FOIII                                                                                            |                                                      |                                                                     | v                | н | I | Ν | z | С | Ad                                                                                                       | do                                               | do                                                                            | С<br>О                                              |
| BIT #opr<br>BIT opr<br>BIT opr,X<br>BIT opr,X<br>BIT opr,X<br>BIT ,X<br>BIT opr,SP<br>BIT opr,SP | Bit Test                                             | (A) & (M)                                                           | 0                | _ | _ | o | 0 | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                                      | A5<br>B5<br>C5<br>D5<br>E5<br>F5<br>9EE5<br>9ED5 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff                                     | 2<br>3<br>4<br>3<br>2<br>4<br>5                     |
| BLE opr                                                                                          | Branch if Less Than or Equal To<br>(Signed Operands) | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (Z) \mid (N \oplus V) = 1$ | _                | - | _ | - | - | - | REL                                                                                                      | 93                                               | rr                                                                            | 3                                                   |
| BLO rel                                                                                          | Branch if Lower (Same as BCS)                        | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (C) = 1$                   | -                | - | - | - | - | - | REL                                                                                                      | 25                                               | rr                                                                            | 3                                                   |
| BLS rel                                                                                          | Branch if Lower or Same                              | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (C) \mid (Z) = 1$          | -                | - | - | - | - | - | REL                                                                                                      | 23                                               | rr                                                                            | 3                                                   |
| BLT opr                                                                                          | Branch if Less Than (Signed Operands)                | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (N \oplus V) = 1$          | -                | - | - | - | - | - | REL                                                                                                      | 91                                               | rr                                                                            | 3                                                   |
| BMC rel                                                                                          | Branch if Interrupt Mask Clear                       | PC ← (PC) + 2 + <i>rel</i> ? (I) = 0                                | -                | - | - | - | - | - | REL                                                                                                      | 2C                                               | rr                                                                            | 3                                                   |
| BMI rel                                                                                          | Branch if Minus                                      | PC ← (PC) + 2 + <i>rel</i> ? (N) = 1                                | -                | - | - | - | - | - | REL                                                                                                      | 2B                                               | rr                                                                            | 3                                                   |
| BMS rel                                                                                          | Branch if Interrupt Mask Set                         | PC ← (PC) + 2 + <i>rel</i> ? (I) = 1                                | -                | - | - | - | - | - | REL                                                                                                      | 2D                                               | rr                                                                            | 3                                                   |
| BNE <i>rel</i>                                                                                   | Branch if Not Equal                                  | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (Z) = 0$                   | -                | - | - | - | - | - | REL                                                                                                      | 26                                               | rr                                                                            | 3                                                   |
| BPL rel                                                                                          | Branch if Plus                                       | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (N) = 0$                   | -                | - | - | - | - | - | REL                                                                                                      | 2A                                               | rr                                                                            | 3                                                   |
| BRA <i>rel</i>                                                                                   | Branch Always                                        | $PC \leftarrow (PC) + 2 + \mathit{rel}$                             | -                | - | - | - | - | - | REL                                                                                                      | 20                                               | rr                                                                            | 3                                                   |
| BRCLR n,opr,rel                                                                                  | Branch if Bit <i>n</i> in M Clear                    | PC ← (PC) + 3 + <i>rel</i> ? (Mn) = 0                               | _                | _ | _ | _ | _ | o | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 01<br>03<br>05<br>07<br>09<br>0B<br>0D<br>0F     | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 |
| BRN rel                                                                                          | Branch Never                                         | $PC \gets (PC) + 2$                                                 | -                | - | _ | - | - | - | REL                                                                                                      | 21                                               | rr                                                                            | 3                                                   |
| BRSET n,opr,rel                                                                                  | Branch if Bit <i>n</i> in M Set                      | PC ← (PC) + 3 + <i>rel</i> ? (Mn) = 1                               | _                | _ | _ | _ | _ | o | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b5)<br>DIR (b7)             | 00<br>02<br>04<br>06<br>08<br>0A<br>0C<br>0E     | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5      |
| BSET n,opr                                                                                       | Set Bit <i>n</i> in M                                | Mn ← 1                                                              | _                | _ | _ | _ | _ | _ | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b5)<br>DIR (b7)             | 10<br>12<br>14<br>16<br>18<br>1A<br>1C<br>1E     | dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd                            | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>4                |

### Table 4-1. Instruction Set Summary



Description Reads stack pointer Operand None Data Returns incremented stack pointer value (SP + 1) in Returned high-byte:low-byte order Opcode \$0C **Command Sequence** FROM HOST SI SF READSP READSP HIGH LOW ECHO RETURN



#### Table 8-9. RUN (Run User Program) 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.



#### **ROM-Resident Routines**

During the software execution, it does not consume any dedicated RAM location, the run-time heap will extend the system stack, all other RAM location will not be affected.



Figure 8-9. Data Block Format for ROM-Resident Routines

The control and data bytes are described below.

- **Bus speed** This one byte indicates the operating bus speed of the MCU. The value of this byte should be equal to 4 times the bus speed. E.g., for a 4MHz bus, the value is 16 (\$10). This control byte is useful where the MCU clock source is switched between the PLL clock and the crystal clock.
- **Data size** This one byte indicates the number of bytes in the data array that are to be manipulated. The maximum data array size is 255. Routines EE\_WRITE and EE\_READ are restricted to manipulate a data array between 7 to 15 bytes. Whereas routines ERARNGE and MON\_ERARNGE do not manipulate a data array, thus, this data size byte has no meaning.
- Start address These two bytes, high byte followed by low byte, indicate the start address of the FLASH memory to be manipulated.
- **Data array** This data array contains data that are to be manipulated. Data in this array are programmed to FLASH memory by the programming routines: PRGRNGE, MON\_PRGRNGE, EE\_WRITE. For the read routines: LDRNGE and EE\_READ, data is read from FLASH and stored in this array.

### 8.5.1 PRGRNGE

PRGRNGE is used to program a range of FLASH locations with data loaded into the data array.

| Routine Name        | PRGRNGE                                                                                                                                     |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Routine Description | Program a range of locations                                                                                                                |
| Calling Address     | \$FC34                                                                                                                                      |
| Stack Used          | 15 bytes                                                                                                                                    |
| Data Block Format   | Bus speed (BUS_SPD)<br>Data size (DATASIZE)<br>Start address high (ADDRH)<br>Start address (ADDRL)<br>Data 1 (DATA1)<br>:<br>Data N (DATAN) |

#### Table 8-11. PRGRNGE Routine



Monitor ROM (MON)

### 8.5.6 EE\_WRITE

EE\_WRITE is used to write a set of data from the data array to FLASH.

Table 8-16. EE\_WRITE Routine

| Routine Name        | EE_WRITE                                                                                                                                                                  |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Routine Description | Emulated EEPROM write. Data size ranges from 7 to 15 bytes at a time.                                                                                                     |
| Calling Address     | \$FF36                                                                                                                                                                    |
| Stack Used          | 30 bytes                                                                                                                                                                  |
| Data Block Format   | Bus speed (BUS_SPD)<br>Data size (DATASIZE) <sup>(1)</sup><br>Starting address (ADDRH) <sup>(2)</sup><br>Starting address (ADDRL) <sup>(1)</sup><br>Data 1<br>:<br>Data N |

1. The minimum data size is 7 bytes. The maximum data size is 15 bytes.

2. The start address must be a page boundary start address.

The start location of the FLASH to be programmed is specified by the address ADDRH:ADDRL and the number of bytes in the data array is specified by DATASIZE. The minimum number of bytes that can be programmed in one routine call is 7 bytes, the maximum is 15 bytes. ADDRH:ADDRL must always be the start of boundary address (the page start address: \$X000, \$X200, \$X400, \$X600, \$X800, \$XA00, \$XC00, or \$XE00) and DATASIZE must be the same size when accessing the same page.

In some applications, the user may want to repeatedly store and read a set of data from an area of non-volatile memory. This is easily possible when using an EEPROM array. As the write and erase operations can be executed on a byte basis. For FLASH memory, the minimum erase size is the page — 512 bytes per page for MC68HC908AP64. If the data array size is less than the page size, writing and erasing to the same page cannot fully utilize the page. Unused locations in the page will be wasted. The EE\_WRITE routine is designed to emulate the properties similar to the EEPROM. Allowing a more efficient use of the FLASH page for data storage.

When the user dedicates a page of FLASH for data storage, and the size of the data array defined, each call of the EE\_WRTIE routine will automatically transfer the data in the data array (in RAM) to the next blank block of locations in the FLASH page. Once a page is filled up, the EE\_WRITE routine automatically erases the page, and starts reuse the page again. In the 512-byte page, an 9-byte control block is used by the routine to monitor the utilization of the page. In effect, only 503 bytes are used for data storage. (see Figure 8-10). The page control operations are transparent to the user.

When using this routine to store a 8-byte data array, the FLASH page can be programmed 62 times before the an erase is required. In effect, the write/erase endurance is increased by 62 times. When a 15-byte data array is used, the write/erase endurance is increased by 33 times. Due to the FLASH page size limitation, the data array is limited from 7 bytes to 15 bytes.



#### **Functional Description**

| Addr.           | Register Name           |                    | Bit 7  | 6            | 5      | 4            | 3              | 2     | 1    | Bit 0  |
|-----------------|-------------------------|--------------------|--------|--------------|--------|--------------|----------------|-------|------|--------|
|                 | TIM1 Status and Control | Read:              | TOF    | TOIE         | TSTOP  | 0            | 0              | PS2   | PS1  | PSO    |
| \$0020          | Register                | Write:             | 0      |              | 10101  | TRST         |                | 1.02  | 101  | 100    |
|                 | (T1SC)                  | Reset:             | 0      | 0            | 1      | 0            | 0              | 0     | 0    | 0      |
|                 | TIM1 Counter Register   | Read:              | Bit 15 | 14           | 13     | 12           | 11             | 10    | 9    | Bit 8  |
| \$0021          | High                    | Write:             |        |              |        |              |                |       |      |        |
|                 | (T1CNTH)                | Reset:             | 0      | 0            | 0      | 0            | 0              | 0     | 0    | 0      |
|                 | TIM1 Counter Register   | Read:              | Bit 7  | 6            | 5      | 4            | 3              | 2     | 1    | Bit 0  |
| \$0022          |                         | Write:             |        |              |        |              |                |       |      |        |
|                 | (IICNIL)                | Reset:             | 0      | 0            | 0      | 0            | 0              | 0     | 0    |        |
| ¢0000           | I IM Counter Modulo     | Read:              | Bit 15 | 14           | 13     | 12           | 11             | 10    | 9    | Bit 8  |
| \$0023          |                         | Popot:             |        | 4            | 1      | 1            | 1              |       |      |        |
|                 |                         | Dood               | I      | 1            |        | 1            | I              | I     | 1    |        |
| \$0024          | Register Low            | Mrito              | Bit 7  | 6            | 5      | 4            | 3              | 2     | 1    | Bit 0  |
| ψ00 <b>2</b> 4  | (T1MODI)                | Reset              | 1      | 1            | 1      | 1            | 1              | 1     | 1    | 1      |
|                 | TIM1 Channel 0 Status   | Read               | CH0F   | ·            | 1      | 1            | 1              | I     | 1    |        |
| \$0025          | and Control Register    | Write:             | 0      | CHOIE        | MS0B   | MS0A         | ELS0B          | ELS0A | TOV0 | CH0MAX |
| ,               | (T1SC0)                 | Reset:             | 0      | 0            | 0      | 0            | 0              | 0     | 0    | 0      |
|                 | TIM1 Channel 0          | Read:              | Bit 15 | 14           | 13     | 10           | 11             | 10    | 0    | Bit 8  |
| \$0026          | Register High           | Write:             | DIL 15 | 14           | 15     | 12           | 11             | 10    | 3    | DILO   |
|                 | (T1CH0H)                | Reset:             |        |              |        | Indeterminat | te after reset |       |      |        |
|                 | TIM1 Channel 0          | Read:              | Bit 7  | 6            | 5      | 4            | 3              | 2     | 1    | Bit 0  |
| \$0027          | Register Low            | Write:             | Ditt   | Ů            | Ŭ      |              |                | -     | •    | Dirt   |
|                 | (T1CH0L)                | Reset:             |        | 1            | -      | Indeterminat | te after reset |       |      | ,      |
|                 | TIM1 Channel 1 Status   | Read:              | CH1F   | CH1IE        | 0      | MS1A         | ELS1B          | ELS1A | TOV1 | CH1MAX |
| \$0028          | and Control Register    | Write:             | 0      |              |        |              |                |       |      |        |
|                 |                         | Reset:             | 0      | 0            | 0      | 0            | 0              | 0     | 0    |        |
| ¢0000           | I IM1 Channel 1         | Head:              | Bit 15 | 14           | 13     | 12           | 11             | 10    | 9    | Bit 8  |
| \$00Z9          |                         | Resot              |        |              |        | Indeterminat | to after recet |       |      |        |
|                 | TIM1 Channel 1          | Road.              |        |              |        | Indetermina  |                |       |      |        |
| \$0024          | Register Low            | Write <sup>.</sup> | Bit 7  | 6            | 5      | 4            | 3              | 2     | 1    | Bit 0  |
| φ00 <u>2</u> /γ | (T1CH1L)                | Reset:             |        |              |        | Indeterminat | te after reset |       |      | ļJ     |
|                 | TIM2 Status and Control | Read:              | TOF    |              |        | 0            | 0              |       |      |        |
| \$002B          | Register                | Write:             | 0      | TOIE         | TSTOP  | TRST         | -              | PS2   | PS1  | PS0    |
|                 | (T2SC)                  | Reset:             | 0      | 0            | 1      | 0            | 0              | 0     | 0    | 0      |
|                 | TIM2 Counter Register   | Read:              | Bit 15 | 14           | 13     | 12           | 11             | 10    | 9    | Bit 8  |
| \$002C          | High                    | Write:             |        |              |        |              |                |       |      |        |
|                 | (T2CNTH)                | Reset:             | 0      | 0            | 0      | 0            | 0              | 0     | 0    | 0      |
|                 | TIM2 Counter Register   | Read:              | Bit 7  | 6            | 5      | 4            | 3              | 2     | 1    | Bit 0  |
| \$002D          | Low                     | Write:             |        |              |        |              |                |       |      |        |
|                 | (T2CNTL)                | Reset:             | 0      | 0            | 0      | 0            | 0              | 0     | 0    | 0      |
|                 | TIM2 Counter Modulo     | Read:              | Bit 15 | 14           | 13     | 12           | 11             | 10    | 9    | Bit 8  |
| \$002E          | Register High           | Write:             |        |              |        |              |                |       |      |        |
|                 | (T2MODH)                | Reset:             | 1      | 1            | 1      | 1            | 1              | 1     | 1    | 1      |
|                 |                         |                    |        | ] = Unimplem | nented |              |                |       |      |        |

### Figure 9-2. TIM I/O Register Summary (Sheet 1 of 2)

# NP

#### Timer Interface Module (TIM)

| Addr.         | Register Name                       |                 | Bit 7  | 6                         | 5      | 4           | 3              | 2     | 1    | Bit 0  |  |
|---------------|-------------------------------------|-----------------|--------|---------------------------|--------|-------------|----------------|-------|------|--------|--|
| \$002F        | TIM2 Counter Modulo<br>Register Low | Read:<br>Write: | Bit 7  | 6                         | 5      | 4           | 3              | 2     | 1    | Bit 0  |  |
|               | (T2MODL)                            | Reset:          | 1      | 1                         | 1      | 1           | 1              | 1     | 1    | 1      |  |
|               | TIM2 Channel 0 Status               | Read:           | CH0F   | CHOIE                     | MS0B   | MS0A        | ELS0B          | ELS0A | TOVO | CHOMAX |  |
| \$0030        | and Control Register                | Write:          | 0      |                           |        |             |                |       |      |        |  |
|               | (T2SC0)                             | Reset:          | 0      | 0                         | 0      | 0           | 0              | 0     | 0    | 0      |  |
| \$0031        | TIM2 Channel 0<br>Register High     | Read:<br>Write: | Bit 15 | 14                        | 13     | 12          | 11             | 10    | 9    | Bit 8  |  |
|               | (T2CH0H)                            | Reset:          |        | Indeterminate after reset |        |             |                |       |      |        |  |
| ¢0000         | TIM2 Channel 0                      | Read:           | Bit 7  | 6                         | 5      | 4           | 3              | 2     | 1    | Bit 0  |  |
| \$0032        |                                     | Pocot:          |        |                           |        |             |                |       |      |        |  |
|               | TIMO Channel 1 Ctatus               | Deedu           | CLIFE  |                           | 0      |             |                |       |      |        |  |
| <b>\$0000</b> | TIM2 Channel T Status               | Neau.           |        | CH1IE                     | 0      | MS1A        | ELS1B          | ELS1A | TOV1 | CH1MAX |  |
| \$0033        |                                     | write: [        | 0      |                           |        |             |                |       |      |        |  |
|               | (12501)                             | Reset:          | 0      | 0                         | 0      | 0           | 0              | 0     | 0    | 0      |  |
| \$0034        | TIM2 Channel 1<br>Register High     | Read:<br>Write: | Bit 15 | 14                        | 13     | 12          | 11             | 10    | 9    | Bit 8  |  |
| +             | (T2CH1H)                            | Reset:          |        |                           |        | Indetermina | te after reset |       |      |        |  |
| <b>*</b> ~~~~ | TIM2 Channel 1                      | Read:           | Bit 7  | 6                         | 5      | 4           | 3              | 2     | 1    | Bit 0  |  |
| \$0035        |                                     | vvrite:         |        |                           |        | <br>        |                |       |      |        |  |
|               | (126H1L)                            | Heset:          |        | 1                         |        | indetermina | ie atter reset |       |      |        |  |
|               |                                     |                 |        | = Unimplem                | nented |             |                |       |      |        |  |

Figure 9-2. TIM I/O Register Summary (Sheet 2 of 2)

### 9.4.1 TIM Counter Prescaler

The TIM clock source can be one of the seven prescaler outputs. The prescaler generates seven clock rates from the internal bus clock. The prescaler select bits, PS[2:0], in the TIM status and control register select the TIM clock source.

### 9.4.2 Input Capture

With the input capture function, the TIM can capture the time at which an external event occurs. When an active edge occurs on the pin of an input capture channel, the TIM latches the contents of the TIM counter into the TIM channel registers, TCHxH:TCHxL. The polarity of the active edge is programmable. Input captures can generate TIM CPU interrupt requests.

### 9.4.3 Output Compare

With the output compare function, the TIM can generate a periodic pulse with a programmable polarity, duration, and frequency. When the counter reaches the value in the registers of an output compare channel, the TIM can set, clear, or toggle the channel pin. Output compares can generate TIM CPU interrupt requests.

### 9.4.3.1 Unbuffered Output Compare

Any output compare channel can generate unbuffered output compare pulses as described in 9.4.3 Output Compare. The pulses are unbuffered because changing the output compare value requires writing the new value over the old value currently in the TIM channel registers.



### **11.4 Functional Description**

Figure 11-2 shows the structure of the SCI module. The SCI allows full-duplex, asynchronous, NRZ serial communication among the MCU and remote devices, including other MCUs. The transmitter and receiver of the SCI operate independently, although they use the same baud rate generator. During normal operation, the CPU monitors the status of the SCI, writes the data to be transmitted, and processes received data.

The baud rate clock source for the SCI can be selected via the configuration bit, SCIBDSRC, of the CONFIG2 register (\$001D).







#### Serial Communications Interface Module (SCI)

#### NEIE — Receiver Noise Error Interrupt Enable Bit

This read/write bit enables SCI error CPU interrupt requests generated by the noise error bit, NE. Reset clears NEIE.

- 1 = SCI error CPU interrupt requests from NE bit enabled
- 0 = SCI error CPU interrupt requests from NE bit disabled

#### FEIE — Receiver Framing Error Interrupt Enable Bit

This read/write bit enables SCI error CPU interrupt requests generated by the framing error bit, FE. Reset clears FEIE.

- 1 = SCI error CPU interrupt requests from FE bit enabled
- 0 = SCI error CPU interrupt requests from FE bit disabled

#### PEIE — Receiver Parity Error Interrupt Enable Bit

This read/write bit enables SCI error CPU interrupt

requests generated by the parity error bit, PE. (See 11.8.4 SCI Status Register 1.) Reset clears PEIE.

- 1 = SCI error CPU interrupt requests from PE bit enabled
- 0 = SCI error CPU interrupt requests from PE bit disabled

### 11.8.4 SCI Status Register 1

SCI status register 1 (SCS1) contains flags to signal these conditions:

- Transfer of SCDR data to transmit shift register complete
- Transmission complete
- Transfer of receive shift register data to SCDR complete
- Receiver input idle
- Receiver overrun
- Noisy data
- Framing error
- Parity error



#### Figure 11-12. SCI Status Register 1 (SCS1)

#### SCTE — SCI Transmitter Empty Bit

This clearable, read-only bit is set when the SCDR transfers a character to the transmit shift register. SCTE can generate an SCI transmitter CPU interrupt request. When the SCTIE bit in SCC2 is set, SCTE generates an SCI transmitter CPU interrupt request. In normal operation, clear the SCTE bit by reading SCS1 with SCTE set and then writing to SCDR. Reset sets the SCTE bit.

- 1 = SCDR data transferred to transmit shift register
- 0 = SCDR data not transferred to transmit shift register



#### Infrared Serial Communications Interface Module (IRSCI)

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

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

#### 12.5.2.3 Break Characters

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

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

Receiving a break character has the following effects on SCI registers:

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

#### 12.5.2.4 Idle Characters

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

If the TE bit is cleared during a transmission, the TxD pin becomes idle after completion of the transmission in progress. Clearing and then setting the TE bit during a transmission queues an idle character to be sent after the character currently being transmitted.

#### NOTE

When queueing an idle character, return the TE bit to logic 1 before the stop bit of the current character shifts out to the TxD pin. Setting TE after the stop bit appears on TxD causes data previously written to the IRSCDR to be lost.

Toggle the TE bit for a queued idle character when the SCTE bit becomes set and just before writing the next byte to the IRSCDR.

#### 12.5.2.5 Transmitter Interrupts

The following conditions can generate CPU interrupt requests from the SCI transmitter:



#### Infrared Serial Communications Interface Module (IRSCI)

The maximum percent difference between the receiver count and the transmitter count of a slow 8-bit character with no errors is

$$\left|\frac{154 - 147}{154}\right| \times 100 = 4.54\%$$

For a 9-bit character, data sampling of the stop bit takes the receiver 10 bit times  $\times$  16 RT cycles + 10 RT cycles = 170 RT cycles.

With the misaligned character shown in Figure 12-10, the receiver counts 170 RT cycles at the point when the count of the transmitting device is 10 bit times  $\times$  16 RT cycles + 3 RT cycles = 163 RT cycles.

The maximum percent difference between the receiver count and the transmitter count of a slow 9-bit character with no errors is

$$\left|\frac{170 - 163}{170}\right| \times 100 = 4.12\%$$

#### **Fast Data Tolerance**

Figure 12-11 shows how much a fast received character can be misaligned without causing a noise error or a framing error. The fast stop bit ends at RT10 instead of RT16 but is still there for the stop bit data samples at RT8, RT9, and RT10.



Figure 12-11. Fast Data

For an 8-bit character, data sampling of the stop bit takes the receiver 9 bit times  $\times$  16 RT cycles + 10 RT cycles = 154 RT cycles.

With the misaligned character shown in Figure 12-11, the receiver counts 154 RT cycles at the point when the count of the transmitting device is 10 bit times  $\times$  16 RT cycles = 160 RT cycles.

The maximum percent difference between the receiver count and the transmitter count of a fast 8-bit character with no errors is

$$\left|\frac{154 - 160}{154}\right| \times 100 = 3.90\%$$

For a 9-bit character, data sampling of the stop bit takes the receiver 10 bit times  $\times$  16 RT cycles + 10 RT cycles = 170 RT cycles.

With the misaligned character shown in Figure 12-11, the receiver counts 170 RT cycles at the point when the count of the transmitting device is 11 bit times  $\times$  16 RT cycles = 176 RT cycles.

The maximum percent difference between the receiver count and the transmitter count of a fast 9-bit character with no errors is



Infrared Serial Communications Interface Module (IRSCI)

| SCP1 and SCP0 | Prescaler<br>Divisor (PD) | SCR2, SCR1,<br>and SCR0 | Baud Rate<br>Divisor (BD) | Baud Rate<br>(f <sub>BUS</sub> = 4.9152 MHz) |
|---------------|---------------------------|-------------------------|---------------------------|----------------------------------------------|
| 00            | 1                         | 000                     | 1                         | _                                            |
| 00            | 1                         | 001                     | 2                         | _                                            |
| 00            | 1                         | 010                     | 4                         | 76800                                        |
| 00            | 1                         | 011                     | 8                         | 38400                                        |
| 00            | 1                         | 100                     | 16                        | 19200                                        |
| 00            | 1                         | 101                     | 32                        | 9600                                         |
| 00            | 1                         | 110                     | 64                        | 4800                                         |
| 00            | 1                         | 111                     | 128                       | 2400                                         |
| 01            | 3                         | 000                     | 1                         | _                                            |
| 01            | 3                         | 001                     | 2                         | 51200                                        |
| 01            | 3                         | 010                     | 4                         | 25600                                        |
| 01            | 3                         | 011                     | 8                         | 12800                                        |
| 01            | 3                         | 100                     | 16                        | 6400                                         |
| 01            | 3                         | 101                     | 32                        | 3200                                         |
| 01            | 3                         | 110                     | 64                        | 1600                                         |
| 01            | 3                         | 111                     | 128                       | 800                                          |
| 10            | 4                         | 000                     | 1                         | 76800                                        |
| 10            | 4                         | 001                     | 2                         | 38400                                        |
| 10            | 4                         | 010                     | 4                         | 19200                                        |
| 10            | 4                         | 011                     | 8                         | 9600                                         |
| 10            | 4                         | 100                     | 16                        | 4800                                         |
| 10            | 4                         | 101                     | 32                        | 2400                                         |
| 10            | 4                         | 110                     | 64                        | 1200                                         |
| 10            | 4                         | 111                     | 128                       | 600                                          |
| 11            | 13                        | 000                     | 1                         | 23632                                        |
| 11            | 13                        | 001                     | 2                         | 11816                                        |
| 11            | 13                        | 010                     | 4                         | 5908                                         |
| 11            | 13                        | 011                     | 8                         | 2954                                         |
| 11            | 13                        | 100                     | 16                        | 1477                                         |
| 11            | 13                        | 101                     | 32                        | 739                                          |
| 11            | 13                        | 110                     | 64                        | 369                                          |
| 11            | 13                        | 111                     | 128                       | 185                                          |





- The shift register is cleared.
- The SPI state counter is cleared, making it ready for a new complete transmission.
- All the SPI port logic is defaulted back to being general-purpose I/O.

These items are reset only by a system reset:

- All control bits in the SPCR register
- All control bits in the SPSCR register (MODFEN, ERRIE, SPR1, and SPR0)
- The status flags SPRF, OVRF, and MODF

By not resetting the control bits when SPE is low, the user can clear SPE between transmissions without having to set all control bits again when SPE is set back high for the next transmission.

By not resetting the SPRF, OVRF, and MODF flags, the user can still service these interrupts after the SPI has been disabled. The user can disable the SPI by writing 0 to the SPE bit. The SPI can also be disabled by a mode fault occurring in an SPI that was configured as a master with the MODFEN bit set.

### 13.10 Low-Power Modes

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

#### 13.10.1 Wait Mode

The SPI module remains active after the execution of a WAIT instruction. In wait mode the SPI module registers are not accessible by the CPU. Any enabled CPU interrupt request from the SPI module can bring the MCU out of wait mode.

If SPI module functions are not required during wait mode, reduce power consumption by disabling the SPI module before executing the WAIT instruction.

To exit wait mode when an overflow condition occurs, enable the OVRF bit to generate CPU interrupt requests by setting the error interrupt enable bit (ERRIE). (See 13.8 Interrupts.)

#### 13.10.2 Stop Mode

The SPI module is inactive after the execution of a STOP instruction. The STOP instruction does not affect register conditions. SPI operation resumes after an external interrupt. If stop mode is exited by reset, any transfer in progress is aborted, and the SPI is reset.

### 13.11 SPI During Break Interrupts

The system integration module (SIM) controls whether status bits in other modules can be cleared during the break state. The BCFE bit in the SIM break flag control register (SBFCR) enables software to clear status bits during the break state. (See Chapter 7 System Integration Module (SIM).)

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

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



Port A is an 8-bit special-function port that shares all of its pins with the analog-to-digital converter (ADC) module. Port A pins also have LED direct drive capability.

### 16.2.1 Port A Data Register (PTA)

The port A data register contains a data latch for each of the eight port A pins.

| Address:              | \$0000    |           |           |           |            |           |           |           |  |
|-----------------------|-----------|-----------|-----------|-----------|------------|-----------|-----------|-----------|--|
|                       | Bit 7     |           | 5         | 4         | 3          | 2         | 1         | Bit 0     |  |
| Read:                 | DTA7      | DTAG      | DTA5      | ρτλι      | DTV3       | ρτλο      | PTA1      | ΡΤΛΟ      |  |
| Write:                | FTA/      | FTAU      | FTAJ      | LIV4      | FIAJ       | FTAZ      | FIAI      | TIAU      |  |
| Reset:                |           |           |           | Unaffecte | d by reset |           |           |           |  |
| Alternative Function: | ADC7      | ADC6      | ADC5      | ADC4      | ADC3       | ADC2      | ADC1      | ADC0      |  |
| Additional Function:  | LED drive  | LED drive | LED drive | LED drive |  |

Figure 16-2. Port A Data Register (PTA)

### PTA[7:0] — Port A Data Bits

These read/write bits are software-programmable. Data direction of each port A pin is under the control of the corresponding bit in data direction register A. Reset has no effect on port A data.

### ADC7-ADC0 — ADC Channels 7 to 0

ADC7–ADC0 are pins used for the input channels to the analog-to-digital converter module. The channel select bits, ADCH[4:0], in the ADC status and control register define which port pin will be used as an ADC input and overrides any control from the port I/O logic.

### NOTE

Care must be taken when reading port A while applying analog voltages to ADC7–ADC0 pins. If the appropriate ADC channel is not enabled, excessive current drain may occur if analog voltages are applied to the PTAx/ADCx pin, while PTA is read as a digital input. Those ports not selected as analog input channels are considered digital I/O ports.

### LED drive — Direct LED drive pins

PTA7–PTA0 pins can be configured for direct LED drive. See 16.2.3 Port-A LED Control Register (LEDA).

### 16.2.2 Data Direction Register (DDRA)

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



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





Figure 16-11. Port C I/O Circuit

When DDRCx is a logic 1, reading address \$0002 reads the PTCx data latch. When DDRCx is a logic 0, reading address \$0002 reads the voltage level on the pin. The data latch can always be written, regardless of the state of its data direction bit.

Table 16-4 summarizes the operation of the port C pins.

| DDRC |                  | I/O Pin Mode               | Accesses to DDRC | Accesse  | s to PTC                |
|------|------------------|----------------------------|------------------|----------|-------------------------|
| Bit  | FIGBR            |                            | Read/Write       | Read     | Write                   |
| 0    | X <sup>(1)</sup> | Input, Hi-Z <sup>(2)</sup> | DDRC[7:0]        | Pin      | PTC[7:0] <sup>(3)</sup> |
| 1    | Х                | Output                     | DDRC[7:0]        | PTC[7:0] | PTC[7:0]                |

Table 16-4. Port C Pin Functions

1. X = don't care.

2. Hi-Z = high impedance.

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

### 16.5 Port D

Port D is an 8-bit special function port that shares all of its pins with the keyboard interrupt module.

### 16.5.1 Port D Data Register (PTD)

The port D data register contains a data latch for each of the eight port D pins.



Figure 16-12. Port D Data Register (PTD)



# Chapter 20 Low-Voltage Inhibit (LVI)

### 20.1 Introduction

This section describes the low-voltage inhibit (LVI) module. The LVI module monitors the voltage on the  $V_{DD}$  pin and  $V_{REG}$  pin, and can force a reset when  $V_{DD}$  voltage falls below  $V_{TRIPF1}$ , or  $V_{REG}$  voltage falls below  $V_{TRIPF2}$ .

#### NOTE

The  $V_{REG}$  pin is the output of the internal voltage regulator and is guaranteed to meet operating specification as long as  $V_{DD}$  is within the MCU operating voltage.

The LVI feature is intended to provide the safe shutdown of the microcontroller and thus protection of related circuitry prior to any application  $V_{DD}$  voltage collapsing completely to an unsafe level. It is not intended that users operate the microcontroller at lower than the specified operating voltage, VDD.

### 20.2 Features

Features of the LVI module include:

- Independent voltage monitoring circuits for V<sub>DD</sub> and V<sub>REG</sub>
- Independent disable for V<sub>DD</sub> and V<sub>REG</sub> LVI circuits
- Programmable LVI reset
- Programmable stop mode operation

| Addr.  | Register Name              |        | Bit 7  | 6          | 5     | 4 | 3 | 2 | 1 | Bit 0 |
|--------|----------------------------|--------|--------|------------|-------|---|---|---|---|-------|
|        | I.V.I. Status Desistar     | Read:  | LVIOUT | 0          | 0     | 0 | 0 | 0 | 0 | 0     |
| \$FE0F | \$FE0F LVI Status Register |        |        |            |       |   |   |   |   |       |
|        |                            | Reset: | 0      | 0          | 0     | 0 | 0 | 0 | 0 | 0     |
|        |                            |        |        | = Unimplem | ented |   |   |   |   |       |

Figure 20-1. LVI I/O Register Summary

### 20.3 Functional Description

Figure 20-2 shows the structure of the LVI module. The LVI is enabled out of reset. The LVI module contains independent bandgap reference circuit and comparator for monitoring the  $V_{DD}$  voltage and the  $V_{REG}$  voltage. An LVI reset performs a MCU internal reset and drives the RST pin low to provide low-voltage protection to external peripheral devices.

LVISTOP, LVIPWRD, LVIRSTD, and LVIREGD are in the CONFIG1 register. See Chapter 3 Configuration & Mask Option Registers (CONFIG & MOR) for details of the LVI configuration bits. Once