

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             | Active                                                     |
|----------------------------|------------------------------------------------------------|
| Core Processor             | HC08                                                       |
| Core Size                  | 8-Bit                                                      |
| Speed                      | 8.4MHz                                                     |
| Connectivity               | CANbus, SCI, SPI                                           |
| Peripherals                | LVD, POR, PWM                                              |
| Number of I/O              | 64                                                         |
| Program Memory Size        | 32KB (32K x 8)                                             |
| Program Memory Type        | FLASH                                                      |
| EEPROM Size                | 512 x 8                                                    |
| RAM Size                   | 1K x 8                                                     |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                |
| Data Converters            | A/D 15x8b                                                  |
| Oscillator Type            | Internal                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                          |
| Mounting Type              | Surface Mount                                              |
| Package / Case             | 64-QFP                                                     |
| Supplier Device Package    | 64-QFP (14x14)                                             |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=mc908az32acfu |

Email: info@E-XFL.COM

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



| 24.12.4   | Data Segment Registers (DSRn)                   | 281 |
|-----------|-------------------------------------------------|-----|
| 24.12.5   | Transmit Buffer Priority Registers              | 281 |
| 24.13 Pro | ogrammer's Model of Control Registers           | 281 |
| 24.13.1   | MSCAN08 Module Control Register 0               | 283 |
| 24.13.2   | MSCAN08 Module Control Register 1               | 284 |
| 24.13.3   | MSCAN08 Bus Timing Register 0                   | 285 |
| 24.13.4   | MSCAN08 Bus Timing Register 1                   | 286 |
| 24.13.5   | MSCAN08 Receiver Flag Register (CRFLG)          | 287 |
| 24.13.6   | MSCAN08 Receiver Interrupt Enable Register      | 289 |
| 24.13.7   | MSCAN08 Transmitter Flag Register.              | 290 |
| 24.13.8   | MSCAN08 Transmitter Control Register            | 291 |
| 24.13.9   | MSCAN08 Identifier Acceptance Control Register. | 292 |
| 24.13.10  | MSCAN08 Receive Error Counter                   | 293 |
| 24.13.11  | MSCAN08 Transmit Error Counter                  | 293 |
| 24.13.12  | MSCAN08 Identifier Acceptance Registers         | 294 |
| 24.13.13  | MSCAN08 Identifier Mask Registers (CIDMR0–3)    | 295 |

# Chapter 25 Electrical Specifications

| 25.1 E  | Electrical Specifications                                    | 297 |
|---------|--------------------------------------------------------------|-----|
| 25.1.1  | Maximum Ratings                                              | 297 |
| 25.1.2  | Functional Operating Range                                   | 298 |
| 25.1.3  | Thermal Characteristics                                      | 298 |
| 25.1.4  | 5.0 Volt DC Electrical Characteristics                       | 299 |
| 25.1.5  | Control Timing                                               | 300 |
| 25.1.6  | ADC Characteristics                                          | 300 |
| 25.1.7  | 5.0 Vdc $\pm$ 0.5 V Serial Peripheral Interface (SPI) Timing | 301 |
| 25.1.8  | CGM Operating Conditions                                     | 304 |
| 25.1.9  | CGM Component Information                                    | 304 |
| 25.1.10 | CGM Acquisition/Lock Time Information                        | 305 |
| 25.1.11 | Timer Module Characteristics                                 | 306 |
| 25.1.12 | RAM Memory Characteristics                                   | 306 |
| 25.1.13 | EEPROM Memory Characteristics                                | 306 |
| 25.1.14 | FLASH Memory Characteristics.                                | 307 |
| 25.2    | Mechanical Specifications                                    | 307 |

# Chapter 26 Revision History

| 26.1 | Major Changes Between Revision 2.0 and Revision 1.0 | 311 |
|------|-----------------------------------------------------|-----|
| 26.2 | Major Changes Between Revision 1.0 and Revision 0.0 | 311 |

# Glossary





# 1.4.1 Power Supply Pins (V<sub>DD</sub> and V<sub>SS</sub>)

V<sub>DD</sub> and V<sub>SS</sub> are the power supply and ground pins. The MCU operates from a single power supply.

Fast signal transitions on MCU pins place high, short-duration current demands on the power supply. To prevent noise problems, take special care to provide power supply bypassing at the MCU as shown in Figure 1-3. Place the C1 bypass capacitor as close to the MCU as possible. Use a high-frequency response ceramic capacitor for C1. C2 is an optional bulk current bypass capacitor for use in applications that require the port pins to source high current levels.



NOTE: Component values shown represent typical applications.

#### Figure 1-3. Power Supply Bypassing

V<sub>SS</sub> is also the ground for the port output buffers and the ground return for the serial clock in the Serial Peripheral Interface module (SPI). See Chapter 17 Serial Peirpheral Interface (SPI).

#### NOTE

*V<sub>SS</sub>* must be grounded for proper MCU operation.

# 1.4.2 Oscillator Pins (OSC1 and OSC2)

The OSC1 and OSC2 pins are the connections for the on-chip oscillator circuit. See Chapter 8 Clock Generator Module (CGM).

# 1.4.3 External Reset Pin (RST)

A logic 0 on the  $\overline{\text{RST}}$  pin forces the MCU to a known startup state.  $\overline{\text{RST}}$  is bidirectional, allowing a reset of the entire system. It is driven low when any internal reset source is asserted. See Chapter 7 System Integration Module (SIM) for more information.

# 1.4.4 External Interrupt Pin (IRQ)

IRQ is an asynchronous external interrupt pin. See Chapter 15 External Interrupt Module (IRQ1).

# 1.4.5 Analog Power Supply Pin (V<sub>DDA</sub>)

 $V_{DDA}$  is the power supply pin for the analog portion of the Clock Generator Module (CGM). See Chapter 8 Clock Generator Module (CGM).



Memory Map

| \$0A00                |                                                          |
|-----------------------|----------------------------------------------------------|
| $\downarrow$          | UNIMPLEMENTED (30,208 BYTES)                             |
| \$7FFF                |                                                          |
| \$8000                |                                                          |
| $\downarrow$          | FLASH (32,256 BYTES)                                     |
| \$FDFF                |                                                          |
| \$FE00                | SIM BREAK STATUS REGISTER (SBSR)                         |
| \$FE01                | SIM RESET STATUS REGISTER (SRSR)                         |
| \$FE02                | RESERVED                                                 |
| \$FE03                | SIM BREAK FLAG CONTROL REGISTER (SBFCR)                  |
| \$FE04                |                                                          |
| $\downarrow$          | RESERVED (5 BYTES)                                       |
| \$FE08                |                                                          |
| \$FE09                | Configuration Write-Once Register (CONFIG-2)             |
| \$FE0A                | RESERVED                                                 |
| \$FE0B                | RESERVED                                                 |
| \$FE0C                | BREAK ADDRESS REGISTER HIGH (BRKH)                       |
| \$FE0D                | BREAK ADDRESS REGISTER LOW (BRKL)                        |
| \$FE0E                | BREAK STATUS AND CONTROL REGISTER (BSCR)                 |
| \$FE0F                | LVI STATUS REGISTER (LVISR)                              |
| \$FE10                | EEPROM DIVIDER HIGH NON-VOLATILE REGISTER<br>(EEDIVHNVR) |
| \$FE11                | EEPROM DIVIDER LOW NON-VOLATILE REGISTER<br>(EEDIVLNVR)  |
| \$FE12                |                                                          |
| $\downarrow$          | RESERVED (8 BYTES)                                       |
| \$FE19                |                                                          |
| \$FE1A                | EEPROM DIVIDER HIGH REGISTER (EEDIVH)                    |
| \$FE1B                | EEPROM DIVIDER LOW REGISTER (EEDIVL)                     |
| \$FE1C                | EEPROM NON-VOLATILE REGISTER (EENVR)                     |
| \$FE1D                | EEPROM CONTROL REGISTER (EECR)                           |
| \$FE1E                | RESERVED                                                 |
| \$FE1F                | EEPROM ARRAY CONFIGURATION REGISTER (EEACR)              |
| \$FE20                |                                                          |
| $\downarrow$          | MONITOR ROM (320 BYTES)                                  |
| \$FF5F                |                                                          |
|                       |                                                          |
| \$FF60                |                                                          |
| \$FF60<br>↓           | UNIMPLEMENTED (32 BYTES)                                 |
| \$FF60<br>↓<br>\$FF7F | UNIMPLEMENTED (32 BYTES)                                 |

Figure 2-1. Memory Map (Sheet 2 of 3)

MC68HC908AZ32A Data Sheet, Rev. 2



#### System Integration Module (SIM)

| IAB                                                | WAIT ADI                                                                            | DR X                        | WAIT ADD                       | PR + 1                  | S                      | AME             | X                              | SAME    | X           |         |
|----------------------------------------------------|-------------------------------------------------------------------------------------|-----------------------------|--------------------------------|-------------------------|------------------------|-----------------|--------------------------------|---------|-------------|---------|
| IDB                                                | X                                                                                   | PREVIOUS                    | DATA                           | NEXT OP                 | CODE                   | Χ               | SAME                           | X       | SAME        |         |
| R/W                                                |                                                                                     |                             | у                              |                         |                        |                 |                                |         |             |         |
| NOT                                                | E: Previous d                                                                       | ata can be<br><b>Figu</b> i | operand o<br>r <b>e 7-12</b> . | data or the<br>. Wait N | WAIT o<br><b>/Iode</b> | opcode<br>Entry | , depending<br><b>/ Timing</b> | on the  | last instru | uction. |
| IAB                                                | \$61                                                                                | E0B                         | \$6E0                          | OC \$00                 | FF X                   | \$00FE          | \$00FD                         | \$00    | FC          |         |
| IDB                                                | \$A6 \$A                                                                            | .6 \ \$                     | A6 X                           | \$01                    | \$0B                   | \$6             | E                              | X       | X           |         |
| EXITST                                             | OPWAIT                                                                              |                             |                                |                         |                        |                 |                                |         |             |         |
| NOTE                                               | NOTE: EXITSTOPWAIT = $\overrightarrow{RST}$ pin OR CPU interrupt OR break interrupt |                             |                                |                         |                        |                 |                                |         |             |         |
| Figure 7-13. Wait Recovery from Interrupt or Break |                                                                                     |                             |                                |                         |                        |                 |                                |         |             |         |
|                                                    |                                                                                     |                             | -                              | 32 →<br>Cycles          | <b>⊲</b> − 32<br>Cycle | <b>→</b><br>es  |                                |         |             |         |
| I                                                  | AB                                                                                  | \$6E0B                      |                                |                         |                        |                 | KAN BSTV                       | стн 🛛 ғ | ISTVCTL     |         |

#### 7.6.2 Stop Mode

IDB

RST

CGMXCLK

\$A6

\$A6

\$A6

In stop mode, the SIM counter is reset and the system clocks are disabled. An interrupt request from a module can cause an exit from stop mode. Stacking for interrupts begins after the selected stop recovery time has elapsed. Reset also causes an exit from stop mode.

Figure 7-14. Wait Recovery from Internal Reset

The SIM disables the clock generator module outputs (CGMOUT and CGMXCLK) in stop mode, stopping the CPU and peripherals. Stop recovery time is selectable using the SSREC bit in the configuration register (CONFIG-1). If SSREC is set, stop recovery is reduced from the normal delay of 4096 CGMXCLK cycles down to 32. This is ideal for applications using canned oscillators that do not require long startup times from stop mode.

**NOTE** External crystal applications should use the full stop recovery time by clearing the SSREC bit.

The break module is inactive in Stop mode. The STOP instruction does not affect break module register states.



# Chapter 8 Clock Generator Module (CGM)

# 8.1 Introduction

The CGM generates the crystal clock signal, CGMXCLK, which operates at the frequency of the crystal. The CGM also generates the base clock signal, CGMOUT, from which the system clocks are derived. CGMOUT is based on either the crystal clock divided by two or the phase-locked loop (PLL) clock, CGMVCLK, divided by two. The PLL is a frequency generator designed for use with 1-MHz to 16-MHz crystals or ceramic resonators. The PLL can generate an 8-MHz bus frequency without using high frequency crystals.

# 8.2 Features

Features of the CGM include:

- Phase-Locked Loop with Output Frequency in Integer Multiples of the Crystal Reference
- Programmable Hardware Voltage-Controlled Oscillator (VCO) for Low-Jitter Operation
- Automatic Bandwidth Control Mode for Low-Jitter Operation
- Automatic Frequency Lock Detector
- CPU Interrupt on Entry or Exit from Locked Condition

# 8.3 Functional Description

The CGM consists of three major submodules:

- Crystal oscillator circuit The crystal oscillator circuit generates the constant crystal frequency clock, CGMXCLK.
- Phase-locked loop (PLL) The PLL generates the programmable VCO frequency clock CGMVCLK.
- Base clock selector circuit This software-controlled circuit selects either CGMXCLK divided by two or the VCO clock, CGMVCLK, divided by two as the base clock, CGMOUT. The system clocks are derived from CGMOUT.

Figure 8-1 shows the structure of the CGM.

# 8.3.1 Crystal Oscillator Circuit

The crystal oscillator circuit consists of an inverting amplifier and an external crystal. The OSC1 pin is the input to the amplifier and the OSC2 pin is the output. The SIMOSCEN signal enables the crystal oscillator circuit.

The CGMXCLK signal is the output of the crystal oscillator circuit and runs at a rate equal to the crystal frequency. CGMXCLK is then buffered to produce CGMRCLK, the PLL reference clock.



#### **Clock Generator Module (CGM)**

loop filter then slightly alters the dc voltage on the external capacitor connected to CGMXFC based on the width and direction of the correction pulse. The filter can make fast or slow corrections depending on its mode, as described in 8.3.2.2 Acquisition and Tracking Modes. The value of the external capacitor and the reference frequency determines the speed of the corrections and the stability of the PLL.

The lock detector compares the frequencies of the VCO feedback clock, CGMVDV, and the final reference clock, CGMRDV. Therefore, the speed of the lock detector is directly proportional to the final reference frequency, f<sub>CGMRDV</sub>. The circuit determines the mode of the PLL and the lock condition based on this comparison.

#### 8.3.2.2 Acquisition and Tracking Modes

The PLL filter is manually or automatically configurable into one of two operating modes:

- Acquisition mode In acquisition mode, the filter can make large frequency corrections to the VCO. This mode is used at PLL startup or when the PLL has suffered a severe noise hit and the VCO frequency is far off the desired frequency. When in acquisition mode, the ACQ bit is clear in the PLL bandwidth control register. See 8.5.2 PLL Bandwidth Control Register.
- Tracking mode In tracking mode, the filter makes only small corrections to the frequency of the VCO. PLL jitter is much lower in tracking mode, but the response to noise is also slower. The PLL enters tracking mode when the VCO frequency is nearly correct, such as when the PLL is selected as the base clock source. See 8.3.3 Base Clock Selector Circuit. The PLL is automatically in tracking mode when it's not in acquisition mode or when the ACQ bit is set.

#### 8.3.2.3 Manual and Automatic PLL Bandwidth Modes

The PLL can change the bandwidth or operational mode of the loop filter manually or automatically.

In automatic bandwidth control mode (AUTO = 1), the lock detector automatically switches between acquisition and tracking modes. Automatic bandwidth control mode also is used to determine when the VCO clock, CGMVCLK, is safe to use as the source for the base clock, CGMOUT. See 8.5.2 PLL Bandwidth Control Register. If PLL CPU interrupt requests are enabled, the software can wait for a PLL CPU interrupt request and then check the LOCK bit. If CPU interrupts are disabled, software can poll the LOCK bit continuously (during PLL startup, usually) or at periodic intervals. In either case, when the LOCK bit is set, the VCO clock is safe to use as the source for the base clock. See 8.3.3 Base Clock Selector Circuit. If the VCO is selected as the source for the base clock and the LOCK bit is clear, the PLL has suffered a severe noise hit and the software must take appropriate action, depending on the application. See 8.6 Interrupts.

These conditions apply when the PLL is in automatic bandwidth control mode:

- The ACQ bit (see 8.5.2 PLL Bandwidth Control Register) is a read-only indicator of the mode of the filter. See 8.3.2.2 Acquisition and Tracking Modes.
- The  $\overline{ACQ}$  bit is set when the VCO frequency is within a certain tolerance,  $\Delta_{trk}$ , and is cleared when the VCO frequency is out of a certain tolerance,  $\Delta_{unt}$ . See Chapter 25 Electrical Specifications.
- The LOCK bit is a read-only indicator of the locked state of the PLL.
- The LOCK bit is set when the VCO frequency is within a certain tolerance, Δ<sub>Lock</sub>, and is cleared when the VCO frequency is out of a certain tolerance, Δ<sub>unl</sub>. See Chapter 25 Electrical Specifications.
- CPU interrupts can occur if enabled (PLLIE = 1) when the PLL's lock condition changes, toggling the LOCK bit. See 8.5.1 PLL Control Register.



**Brake Module** 

# 11.5.2 Break Address Registers

The break address registers contain the high and low bytes of the desired breakpoint address. Reset clears the break address registers.



Figure 11-4. Break Address Registers (BRKH and BRKL)



Monitor ROM (MON)

# 12.3.2 Data Format

Communication with the monitor ROM is in standard non-return-to-zero (NRZ) mark/space data format. (See Figure 12-2 and Figure 12-3.)

The data transmit and receive rate can be anywhere up to 28.8 kBaud. Transmit and receive baud rates must be identical.



Figure 12-3. Sample Monitor Waveforms

# 12.3.3 Echoing

As shown in Figure 12-4, the monitor ROM immediately echoes each received byte back to the PTA0 pin for error checking.

Any result of a command appears after the echo of the last byte of the command.



Figure 12-4. Read Transaction

# 12.3.4 Break Signal

A start bit followed by nine low bits is a break signal. (See Figure 12-5). When the monitor receives a break signal, it drives the PTA0 pin high for the duration of two bits before echoing the break signal.



Figure 12-5. Break Transaction

MC68HC908AZ32A Data Sheet, Rev. 2



Low Voltage Inhibit (LVI)



Figure 14-1. LVI Module Block Diagram



Figure 14-2. LVI I/O Register Summary

# 14.3.1 Polled LVI Operation

In applications that can operate at  $V_{DD}$  levels below the LVI<sub>TRIPF</sub> level, software can monitor  $V_{DD}$  by polling the LVIOUT bit. In the configuration register, the LVIPWR bit must be at logic 1 to enable the LVI module, and the LVIRST bit must be at logic 0 to disable LVI resets.

# 14.3.2 Forced Reset Operation

In applications that require  $V_{DD}$  to remain above the LVI<sub>TRIPF</sub> level, enabling LVI resets allows the LVI module to reset the MCU when  $V_{DD}$  falls to the LVI<sub>TRIPF</sub> level and remains at or below that level for nine or more consecutive CPU cycles. In the configuration register, the LVIPWR and LVIRST bits must be at logic 1 to enable the LVI module and to enable LVI resets.

# 14.3.3 False Reset Protection

The V<sub>DD</sub> pin level is digitally filtered to reduce false resets due to power supply noise. In order for the LVI module to reset the MCU,V<sub>DD</sub> must remain at or below the LVI<sub>TRIPF</sub> level for nine or more consecutive CPU cycles. V<sub>DD</sub> must be above LVI<sub>TRIPR</sub> for only one CPU cycle to bring the MCU out of reset.



Low Voltage Inhibit (LVI)

### 14.6.2 Stop Mode

With the LVISTOP and LVIPWR bits in the configuration register programmed to a logic 1, the LVI module will be active after a STOP instruction. Because CPU clocks are disabled during stop mode, the LVI trip must bypass the digital filter to generate a reset and bring the MCU out of stop.

With the LVIPWR bit in the configuration register programmed to logic 1 and the LVISTOP bit at a logic 0, the LVI module will be inactive after a STOP instruction.

Note that 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 specified operating voltage  $V_{DD}$ .



#### Serial Communications Interface (SCI)

#### 16.4.2.1 Character Length

The transmitter can accommodate either 8-bit or 9-bit data. The state of the M bit in SCI control register 1 (SCC1) determines character length. When transmitting 9-bit data, bit T8 in SCI control register 3 (SCC3) is the ninth bit (bit 8).

### 16.4.2.2 Character Transmission

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

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

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

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

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

#### 16.4.2.3 Break Characters

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

The SCI recognizes a break character when a start bit is followed by eight or nine logic 0 data bits and a logic 0 where the stop bit should be. Receiving a break character has the following effects on SCI registers:

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





 Parity error (PE) — The PE bit in SCS1 is set when the SCI detects a parity error in incoming data. The parity error interrupt enable bit, PEIE, in SCC3 enables PE to generate SCI error CPU interrupt requests.

# **16.5 Low-Power Modes**

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

# 16.5.1 Wait Mode

The SCI module remains active in wait mode. Any enabled CPU interrupt request from the SCI module can bring the MCU out of wait mode.

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

# 16.5.2 Stop Mode

The SCI module is inactive in stop mode. The STOP instruction does not affect SCI register states. Any enabled CPU interrupt request from the SCI module does not bring the MCU out of Stop mode. SCI module operation resumes after the MCU exits stop mode.

Because the internal clock is inactive during stop mode, entering stop mode during an SCI transmission or reception results in invalid data.

# 16.6 SCI During Break Module Interrupts

The BCFE bit in the break flag control register (BFCR) enables software to clear status bits during the break state. (See Chapter 11 Brake Module).

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 two-step read/write clearing procedure. If software does the first step on such a bit before the break, the bit cannot change during the break state as long as BCFE is at logic 0. After the break, doing the second step clears the status bit.

# 16.7 I/O Signals

Port E shares two of its pins with the SCI module. The two SCI I/O pins are:

- PTE0/SCTxD Transmit data
- PTE1/SCRxD Receive data

# 16.7.1 PTE0/SCTxD (Transmit Data)

The PTE0/SCTxD pin is the serial data output from the SCI transmitter. The SCI shares the PTE0/SCTxD pin with port E. When the SCI is enabled, the PTE0/SCTxD pin is an output regardless of the state of the DDRE2 bit in data direction register E (DDRE).



#### Serial Peirpheral Interface (SPI)

The first part of Figure 17-7 shows how to read the SPSCR and SPDR to clear the SPRF without problems. However, as illustrated by the second transmission example, the OVRF flag can be set in between the time that SPSCR and SPDR are read.

In this case, an overflow can be easily missed. Since no more SPRF interrupts can be generated until this OVRF is serviced, it will not be obvious that bytes are being lost as more transmissions are completed. To prevent this, either enable the OVRF interrupt or do another read of the SPSCR after the read of the SPDR. This ensures that the OVRF was not set before the SPRF was cleared and that future transmissions will complete with an SPRF interrupt. Figure 17-8 illustrates this process. Generally, to avoid this second SPSCR read, enable the OVRF to the CPU by setting the ERRIE bit (SPSCR).



Figure 17-8. Clearing SPRF When OVRF Interrupt Is Not Enabled

# 17.6.2 Mode Fault Error

For the MODF flag (in SPSCR) to be set, the mode fault error enable bit (MODFEN in SPSCR) must be set. Clearing the MODFEN bit does not clear the MODF flag but does prevent MODF from being set again after MODF is cleared.

MODF generates a receiver/error CPU interrupt request if the error interrupt enable bit (ERRIE in SPSCR) is also set. The SPRF, MODF, and OVRF interrupts share the same CPU interrupt vector. MODF and OVRF can generate a receiver/error CPU interrupt request. (See Figure 17-9). It is not possible to enable only MODF or OVRF to generate a receiver/error CPU interrupt request. However, leaving MODFEN low prevents MODF from being set.



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 two-step read/write clearing procedure. If software does the first step on such a bit before the break, the bit cannot change during the break state as long as BCFE is at logic 0. After the break, doing the second step clears the status bit.

Since the SPTE bit cannot be cleared during a break with the BCFE bit cleared, a write to the data register in break mode will not initiate a transmission nor will this data be transferred into the shift register. Therefore, a write to the SPDR in break mode with the BCFE bit cleared has no effect.

# 17.12 I/O Signals

The SPI module has four I/O pins and shares three of them with a parallel I/O port.

- MISO Data received
- MOSI Data transmitted
- SPSCK Serial clock
- SS Slave select
- V<sub>SS</sub> Clock ground

The SPI has limited inter-integrated circuit ( $I^2C$ ) capability (requiring software support) as a master in a single-master environment. To communicate with  $I^2C$  peripherals, MOSI becomes an open-drain output when the SPWOM bit in the SPI control register is set. In  $I^2C$  communication, the MOSI and MISO pins are connected to a bidirectional pin from the  $I^2C$  peripheral and through a pullup resistor to  $V_{DD}$ .

# 17.12.1 MISO (Master In/Slave Out)

MISO is one of the two SPI module pins that transmit serial data. In full duplex operation, the MISO pin of the master SPI module is connected to the MISO pin of the slave SPI module. The master SPI simultaneously receives data on its MISO pin and transmits data from its MOSI pin.

Slave output data on the MISO pin is enabled only when the <u>SPI</u> is configured as a slave. The SPI is configured as a slave when its <u>SPMSTR</u> bit is logic 0 and its <u>SS</u> pin is at logic 0. To support a multiple-slave system, a logic 1 on the <u>SS</u> pin puts the MISO pin in a high-impedance state.

When enabled, the SPI controls data direction of the MISO pin regardless of the state of the data direction register of the shared I/O port.

# 17.12.2 MOSI (Master Out/Slave In)

MOSI is one of the two SPI module pins that transmit serial data. In full duplex operation, the MOSI pin of the master SPI module is connected to the MOSI pin of the slave SPI module. The master SPI simultaneously transmits data from its MOSI pin and receives data on its MISO pin.

When enabled, the SPI controls data direction of the MOSI pin regardless of the state of the data direction register of the shared I/O port.



Timer Interface Module A (TIMA)

# **18.8.4 TIMA Channel Status and Control Registers**

Each of the TIMA channel status and control registers:

- Flags input captures and output compares
- Enables input capture and output compare interrupts
- Selects input capture, output compare or PWM operation
- Selects high, low or toggling output on output compare
- Selects rising edge, falling edge or any edge as the active input capture trigger
- Selects output toggling on TIMA overflow
- Selects 0% and 100% PWM duty cycle
- Selects buffered or unbuffered output compare/PWM operation



and Control Registers (TASC0–TASC5)

MC68HC908AZ32A Data Sheet, Rev. 2

#### I/O Registers





#### Figure 18-7. TIMA Channel Status and Control Registers (TASC0–TASC5) (Continued)

#### CHxF — Channel x Flag Bit

When channel x is an input capture channel, this read/write bit is set when an active edge occurs on the channel x pin. When channel x is an output compare channel, CHxF is set when the value in the TIMA counter registers matches the value in the TIMA channel x registers.

When CHxIE = 1, clear CHxF by reading TIMA channel x status and control register with CHxF set and then writing a logic 0 to CHxF. If another interrupt request occurs before the clearing sequence is complete, then writing logic 0 to CHxF has no effect. Therefore, an interrupt request cannot be lost due to inadvertent clearing of CHxF.

Reset clears the CHxF bit. Writing a logic 1 to CHxF has no effect.

1 = Input capture or output compare on channel x

0 = No input capture or output compare on channel x

#### CHxIE — Channel x Interrupt Enable Bit

This read/write bit enables TIMA CPU interrupts on channel x.

Reset clears the CHxIE bit.

1 = Channel x CPU interrupt requests enabled

0 = Channel x CPU interrupt requests disabled

#### MSxB — Mode Select Bit B

This read/write bit selects buffered output compare/PWM operation. MSxB exists only in the TIMA channel 0, TIMA channel 2 and TIMA channel 4 status and control registers.

Setting MS0B disables the channel 1 status and control register and reverts TACH1 pin to general-purpose I/O.

Setting MS2B disables the channel 3 status and control register and reverts TACH3 pin to general-purpose I/O.

Setting MS4B disables the channel 5 status and control register and reverts TACH5 pin to general-purpose I/O.

Reset clears the MSxB bit.

1 = Buffered output compare/PWM operation enabled

0 = Buffered output compare/PWM operation disabled



#### Timer Interface Module B (TIMB)

#### PS[2:0] — Prescaler Select Bits

These read/write bits select either the PTD4/ATD12 pin or one of the seven prescaler outputs as the input to the TIMB counter as Table 19-1 shows. Reset clears the PS[2:0] bits.

| PS[2:0] | TIMB Clock Source       |
|---------|-------------------------|
| 000     | Internal Bus Clock ÷1   |
| 001     | Internal Bus Clock ÷ 2  |
| 010     | Internal Bus Clock ÷ 4  |
| 011     | Internal Bus Clock ÷ 8  |
| 100     | Internal Bus Clock ÷ 16 |
| 101     | Internal Bus Clock ÷ 32 |
| 110     | Internal Bus Clock ÷ 64 |
| 111     | PTD4/ATD12              |

Table 19-1. Prescaler Selection

#### 19.8.2 TIMB Counter Registers

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

NOTE

If TBCNTH is read during a break interrupt, be sure to unlatch TBCNTL by reading TBCNTL before exiting the break interrupt. Otherwise, TBCNTL retains the value latched during the break.

| Register Name and Address |        | TBCNTH - | \$0041   |        |        |        |       |       |
|---------------------------|--------|----------|----------|--------|--------|--------|-------|-------|
|                           | Bit 7  | 6        | 5        | 4      | 3      | 2      | 1     | Bit 0 |
| Read:                     | BIT 15 | BIT 14   | BIT 13   | BIT 12 | BIT 11 | BIT 10 | BIT 9 | BIT 8 |
| Write:                    | R      | R        | R        | R      | R      | R      | R     | R     |
| Reset:                    | 0      | 0        | 0        | 0      | 0      | 0      | 0     | 0     |
| Register Name and Address |        |          | TBCNTL — | \$0042 |        |        |       |       |
|                           | Bit 7  | 6        | 5        | 4      | 3      | 2      | 1     | Bit 0 |
| Read:                     | BIT 7  | BIT 6    | BIT 5    | BIT 4  | BIT 3  | BIT 2  | BIT 1 | BIT 0 |
| Write:                    | R      | R        | R        | R      | R      | R      | R     | R     |
| Reset:                    | 0      | 0        | 0        | 0      | 0      | 0      | 0     | 0     |
|                           | R      | Reserved |          |        |        |        |       |       |







#### ACKK — Keyboard Acknowledge Bit

Writing a logic 1 to this write-only bit clears the keyboard interrupt request. ACKK always reads as logic 0. Reset clears ACKK.

#### IMASKK — Keyboard Interrupt Mask Bit

Writing a logic 1 to this read/write bit prevents the output of the keyboard interrupt mask from generating interrupt requests. Reset clears the IMASKK bit.

1 = Keyboard interrupt requests masked

0 = Keyboard interrupt requests not masked

#### MODEK — Keyboard Triggering Sensitivity Bit

This read/write bit controls the triggering sensitivity of the keyboard interrupt pins. Reset clears MODEK.

1 = Keyboard interrupt requests on falling edges and low levels

0 = Keyboard interrupt requests on falling edges only

#### 22.7.2 Keyboard Interrupt Enable Register

The keyboard interrupt enable register enables or disables each port G and each port H pin to operate as a keyboard interrupt pin.



#### Figure 22-4. Keyboard Interrupt Enable Register (KBIER)

#### KBIE4–KBIE0 — Keyboard Interrupt Enable Bits

Each of these read/write bits enables the corresponding keyboard interrupt pin to latch interrupt requests. Reset clears the keyboard interrupt enable register.

- 1 = PDx pin enabled as keyboard interrupt pin
- 0 = PDx pin not enabled as keyboard interrupt pin



I/O Ports

# 23.4 Port C

Port C is an 6-bit general-purpose bidirectional I/O port. Note that PTC5 is only available on 64-pin package options.

# 23.4.1 Port C Data Register

The port C data register contains a data latch for each of the six port C pins.



Figure 23-8. Port C Data Register (PTC)

# PTC[5:0] — Port C Data Bits

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

# MCLK — System Clock Bit

The system clock is driven out of PTC2 when enabled by MCLKEN bit in PTCDDR7.

# 23.4.2 Data Direction Register C

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



Figure 23-9. Data Direction Register C (DDRC)

# MCLKEN — MCLK Enable Bit

This read/write bit enables MCLK to be an output signal on PTC2. If MCLK is enabled, DDRC2 has no effect. Reset clears this bit.

- 1 = MCLK output enabled
- 0 = MCLK output disabled

# DDRC[5:0] — Data Direction Register C Bits

These read/write bits control port C data direction. Reset clears DDRC[7:0], configuring all port C pins as inputs.

1 = Corresponding port C pin configured as output

0 = Corresponding port C pin configured as input

# MC68HC908AZ32A Data Sheet, Rev. 2



#### **Identifier Acceptance Filter**



