

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             | HCS12                                                        |
| Core Size                  | 16-Bit                                                       |
| Speed                      | 25MHz                                                        |
| Connectivity               | CANbus, EBI/EMI, I <sup>2</sup> C, SCI, SPI                  |
| Peripherals                | LCD, Motor control PWM, POR, PWM, WDT                        |
| Number of I/O              | 91                                                           |
| Program Memory Size        | 128KB (128K × 8)                                             |
| Program Memory Type        | FLASH                                                        |
| EEPROM Size                | 2K x 8                                                       |
| RAM Size                   | 6K x 8                                                       |
| Voltage - Supply (Vcc/Vdd) | 2.35V ~ 2.75V                                                |
| Data Converters            | A/D 16x10b                                                   |
| Oscillator Type            | Internal                                                     |
| Operating Temperature      | -40°C ~ 85°C (TA)                                            |
| Mounting Type              | Surface Mount                                                |
| Package / Case             | 112-LQFP                                                     |
| Supplier Device Package    | 112-LQFP (20x20)                                             |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=s9s12hz128j3cal |

Email: info@E-XFL.COM

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



Chapter 1 MC9S12HZ256 Device Overview

# 1.3 Part ID Assignments and Mask Set Numbers

The part ID is located in two 8-bit registers PARTIDH and PARTIDL at addresses 0x001A and 0X001B, respectively. The rado-only value is a unique part ID for each revision of the chip. Table 1-6 shows the assigned part ID and Mask Set numbers.

| Part Names                                                                           | Mask Set    | 1<br>Part ID  |
|--------------------------------------------------------------------------------------|-------------|---------------|
| MC9S12HZ256<br>MC9S12HZ128<br>MC9S12HZ64<br>MC9S12HN64<br>MC3S12HZ256<br>MC3S12HZ128 | 2L16Y/3L16Y | 0x1402/0x1403 |
| MC3S12HZ64<br>MC3S12HN64<br>MC3S12HZ32<br>MC3S12HN32                                 | 1M36C       | 0x1501        |

Table 1-6. Assigned Part ID and Mask Set Numbers

<sup>1</sup> The coding is as follows:

Bit 15-12: Major family identifier Bit 11-8: Minor family identifier

Bit 7-4: Major mask set revision including fab transfers

Bit 3-0: Minor non-full mask set revision

The device memory sizes are located in two 8-bit registers MEMSIZ0 and MEMZI1 (addresses 0x001C and 0x001D after reset). Table 1-7 shows the read-only values of these registers. Refer to the HCS12 MMC block description chapter for further details.

### Table 1-7. Memory Size Registers

| Part Names  | MEMSIZ0 | MEMSIZ1 |
|-------------|---------|---------|
| MC9S12HZ256 | 0x15    | 0x81    |
| MC9S12HZ128 |         |         |
| MC9S12HZ64  |         |         |
| MC9S12HN64  |         |         |
| MC3S12HZ256 |         |         |
| MC3S12HZ128 |         |         |
| MC3S12HZ64  | 0x01    | 0x80    |
| MC3S12HN64  |         |         |
| MC3S12HZ32  |         |         |
| MC3S12HN32  |         |         |



Chapter 1 MC9S12HZ256 Device Overview

# 1.5.6.19 PM2 / RXCAN0 — Port M I/O Pin 2

PM2 is a general-purpose input or output pin. It can be configured as the receive pin RXCAN0 of the scalable controller area network controller 0 (CAN0)

# 1.5.6.20 PP5 / PWM5 — Port P I/O Pin 5

PP5 is a general-purpose input or output pin. It can be configured as pulse width modulator (PWM) channel output PWM5 or the serial clock pin SCL of the inter-IC bus interface (IIC).

## 1.5.6.21 PP4 / PWM4 — Port P I/O Pin 4

PP4 is a general-purpose input or output pin. It can be configured as pulse width modulator (PWM) channel output PWM4 or the serial data pin SDA of the inter-IC bus interface (IIC).

## 1.5.6.22 PP3 / PWM3 — Port P I/O Pin 3

PP3 is a general-purpose input or output pin. It can be configured as pulse width modulator (PWM) channel output PWM3.

## 1.5.6.23 PP2 / PWM2 — Port P I/O Pin 2

PP2 is a general-purpose input or output pin. It can be configured as pulse width modulator (PWM) channel output PWM2 or the receive pin RXD1 of the serial communication interface 1 (SCI1).

### 1.5.6.24 PP1 / PWM1 — Port P I/O Pin 1

PP1 is a general-purpose input or output pin. It can be configured as pulse width modulator (PWM) channel output PWM1.

### 1.5.6.25 PP0 / PWM0 — Port P I/O Pin 0

PP0 is a general-purpose input or output pin. It can be configured as pulse width modulator (PWM) channel output PWM0 or the transmit pin TXD1 of the serial communication interface 1 (SCI1).

## 1.5.6.26 PS7 / SS — Port S I/O Pin 7

PS7 is a general-purpose input or output pin. It can be configured as slave select pin  $\overline{SS}$  of the serial peripheral interface (SPI).

# 1.5.6.27 PS6 / SCK — Port S I/O Pin 6

PS6 is a general-purpose input or output pin. It can be configured as serial clock pin SCK of the serial peripheral interface (SPI).



Chapter 2 256 Kbyte Flash Module (FTS256K2V1)

# 2.3.1 Module Memory Map

The Flash memory map is shown in Figure 2-2. The HCS12 architecture places the Flash memory addresses between 0x4000 and 0xFFFF which corresponds to three 16-Kbyte pages. The content of the HCS12 core PPAGE register is used to map the logical middle page ranging from address 0x8000 to 0xBFFF to any physical 16 Kbyte page in the Flash memory. By placing 0x3E or 0x3F in the HCS12 Core PPAGE register, the associated 16 Kbyte pages appear twice in the MCU memory map.

The FPROT register, described in Section 2.3.2.5, "Flash Protection Register (FPROT)", can be set to globally protect a Flash block. However, three separate memory regions, one growing upward from the first address in the next-to-last page in the Flash block (called the lower region), one growing downward from the last address in the last page in the Flash block (called the higher region), and the remaining addresses in the Flash block, can be activated for protection. The Flash locations of these protectable regions are shown in Table 2-2. The higher address region of Flash block 0 is mainly targeted to hold the boot loader code because it covers the vector space. The lower address region of any Flash block can be used for EEPROM emulation in an MCU without an EEPROM module because it can remain unprotected while the remaining addresses are protected from program or erase.

Security information that allows the MCU to restrict access to the Flash module is stored in the Flash configuration field found in Flash block 0, described in Table 2-1.

| Unpaged<br>Flash Address | Paged Flash<br>Address<br>(PPAGE 0x3F) | Size<br>(Bytes) | Description                                                                                          |
|--------------------------|----------------------------------------|-----------------|------------------------------------------------------------------------------------------------------|
| 0xFF00 – 0xFF07          | 0xBF00 – 0xBF07                        | 8               | Backdoor Comparison Key<br>Refer to Section 2.6.1, "Unsecuring the MCU using Backdoor Key<br>Access" |
| 0xFF08 – 0xFF0B          | 0xBF08 – 0xBF0B                        | 4               | Reserved                                                                                             |
| 0xFF0C                   | 0xBF0C                                 | 1               | Block 1 Flash Protection Byte<br>Refer to Section 2.3.2.7, "Flash Status Register (FSTAT)"           |
| 0xFF0D                   | 0xBF0D                                 | 1               | Block 0 Flash Protection Byte<br>Refer toSection 2.3.2.7, "Flash Status Register (FSTAT)"            |
| 0xFF0E                   | 0xBF0E                                 | 1               | Flash Nonvolatile Byte<br>Refer to Section 2.3.2.9, "Flash Control Register (FCTL)"                  |
| 0xFF0F                   | 0xBF0F                                 | 1               | Flash Security Byte<br>Refer to Section 2.3.2.2, "Flash Security Register (FSEC)"                    |

### Table 2-1. Flash Configuration Field



## 2.4.1.3.5 Mass Erase Command

The mass erase command is used to erase a Flash memory block using an embedded algorithm. If the Flash block to be erased contains any protected area, the PVIOL flag in the FSTAT register will set and the mass erase command will not launch. After the mass erase command has successfully launched, the CCIF flag in the FSTAT register will set after the mass erase operation has completed unless a second command has been buffered.



Figure 2-27. Example Mass Erase Command Flow

MC9S12HZ256 Data Sheet, Rev. 2.05



#### Chapter 5 Clocks and Reset Generator (CRGV4)

The PLL filter can be manually or automatically configured into one of two possible operating modes:

• Acquisition mode

In acquisition mode, the filter can make large frequency corrections to the VCO. This mode is used at PLL start-up 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 TRACK status bit is cleared in the CRGFLG 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 and the TRACK bit is set in the CRGFLG register.

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 PLL clock (PLLCLK) is safe to use as the source for the system and core clocks. If PLL LOCK interrupt requests are enabled, the software can wait for an interrupt request and then check the LOCK bit. If CPU interrupts are disabled, software can poll the LOCK bit continuously (during PLL start-up, usually) or at periodic intervals. In either case, only when the LOCK bit is set, is the PLLCLK clock safe to use as the source for the system and core clocks 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.

The following conditions apply when the PLL is in automatic bandwidth control mode (AUTO = 1):

- The TRACK bit is a read-only indicator of the mode of the filter.
- The TRACK bit is set when the VCO frequency is within a certain tolerance,  $\Delta_{trk}$ , and is clear when the VCO frequency is out of a certain tolerance,  $\Delta_{unt}$ .
- 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,  $\Delta_{\text{Lock}}$ , and is cleared when the VCO frequency is out of a certain tolerance,  $\Delta_{\text{unl}}$ .
- CPU interrupts can occur if enabled (LOCKIE = 1) when the lock condition changes, toggling the LOCK bit.

The PLL can also operate in manual mode (AUTO = 0). Manual mode is used by systems that do not require an indicator of the lock condition for proper operation. Such systems typically operate well below the maximum system frequency ( $f_{sys}$ ) and require fast start-up. The following conditions apply when in manual mode:

- ACQ is a writable control bit that controls the mode of the filter. Before turning on the PLL in manual mode, the ACQ bit should be asserted to configure the filter in acquisition mode.
- After turning on the PLL by setting the PLLON bit software must wait a given time  $(t_{acq})$  before entering tracking mode (ACQ = 0).
- After entering tracking mode software must wait a given time  $(t_{al})$  before selecting the PLLCLK as the source for system and core clocks (PLLSEL = 1).



# 7.4.1.2 Analog Input Multiplexer

The analog input multiplexer connects one of the 16 external analog input channels to the sample and hold machine.

# 7.4.1.3 Sample Buffer Amplifier

The sample amplifier is used to buffer the input analog signal so that the storage node can be quickly charged to the sample potential.

# 7.4.1.4 Analog-to-Digital (A/D) Machine

The A/D machine performs analog to digital conversions. The resolution is program selectable at either 8 or 10 bits. The A/D machine uses a successive approximation architecture. It functions by comparing the stored analog sample potential with a series of digitally generated analog potentials. By following a binary search algorithm, the A/D machine locates the approximating potential that is nearest to the sampled potential.

When not converting the A/D machine disables its own clocks. The analog electronics continue drawing quiescent current. The power down (ADPU) bit must be set to disable both the digital clocks and the analog power consumption.

Only analog input signals within the potential range of  $V_{RL}$  to  $V_{RH}$  (A/D reference potentials) will result in a non-railed digital output codes.

# 7.4.2 Digital Sub-Block

This subsection explains some of the digital features in more detail. See register descriptions for all details.

## 7.4.2.1 External Trigger Input

The external trigger feature allows the user to synchronize ATD conversions to the external environment events rather than relying on software to signal the ATD module when ATD conversions are to take place. The external trigger signal (out of reset ATD channel 15, configurable in ATDCTL1) is programmable to be edge or level sensitive with polarity control. Table 7-27 gives a brief description of the different combinations of control bits and their effect on the external trigger function.

| ETRIGLE | ETRIGP | ETRIGE | SCAN | Description                                                                   |
|---------|--------|--------|------|-------------------------------------------------------------------------------|
| Х       | Х      | 0      | 0    | Ignores external trigger. Performs one conversion sequence and stops.         |
| Х       | Х      | 0      | 1    | Ignores external trigger. Performs continuous conversion sequences.           |
| 0       | 0      | 1      | Х    | Falling edge triggered. Performs one conversion sequence per trigger.         |
| 0       | 1      | 1      | Х    | Rising edge triggered. Performs one conversion sequence per trigger.          |
| 1       | 0      | 1      | Х    | Trigger active low. Performs continuous conversions while trigger is active.  |
| 1       | 1      | 1      | Х    | Trigger active high. Performs continuous conversions while trigger is active. |

 Table 7-27. External Trigger Control Bits

During a conversion, if additional active edges are detected the overrun error flag ETORF is set.





| Module Base + 0<br>0<br>0<br>0<br>0 | )x001C (CAN<br>)x001D (CAN<br>)x001E (CAN<br>)x001F (CAN | NDMR4)<br>NDMR5)<br>NDMR6)<br>NDMR7) |     |     |     |     |     |     |
|-------------------------------------|----------------------------------------------------------|--------------------------------------|-----|-----|-----|-----|-----|-----|
|                                     | 7                                                        | 6                                    | 5   | 4   | 3   | 2   | 1   | 0   |
| R<br>W                              | AM7                                                      | AM6                                  | AM5 | AM4 | AM3 | AM2 | AM1 | AM0 |
| Reset                               | 0                                                        | 0                                    | 0   | 0   | 0   | 0   | 0   | 0   |
| - 6                                 | 7                                                        | 6                                    | 5   | 4   | 3   | 2   | 1   | 0   |
| R<br>W                              | AM7                                                      | AM6                                  | AM5 | AM4 | AM3 | AM2 | AM1 | AM0 |
| Reset                               | 0                                                        | 0                                    | 0   | 0   | 0   | 0   | 0   | 0   |
| _                                   | 7                                                        | 6                                    | 5   | 4   | 3   | 2   | 1   | 0   |
| R<br>W                              | AM7                                                      | AM6                                  | AM5 | AM4 | AM3 | AM2 | AM1 | AM0 |
| Reset                               | 0                                                        | 0                                    | 0   | 0   | 0   | 0   | 0   | 0   |
| _                                   | 7                                                        | 6                                    | 5   | 4   | 3   | 2   | 1   | 0   |
| R<br>W                              | AM7                                                      | AM6                                  | AM5 | AM4 | AM3 | AM2 | AM1 | AM0 |
| Reset                               | 0                                                        | 0                                    | 0   | 0   | 0   | 0   | 0   | 0   |

### Figure 12-20. MSCAN Identifier Mask Registers (Second Bank) — CANIDMR4–CANIDMR7

Read: Anytime

Write: Anytime in initialization mode (INITRQ = 1 and INITAK = 1)

#### Table 12-24. CANIDMR4–CANIDMR7 Register Field Descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0<br>AM[7:0] | <ul> <li>Acceptance Mask Bits — If a particular bit in this register is cleared, this indicates that the corresponding bit in the identifier acceptance register must be the same as its identifier bit before a match is detected. The message is accepted if all such bits match. If a bit is set, it indicates that the state of the corresponding bit in the identifier acceptance register does not affect whether or not the message is accepted.</li> <li>0 Match corresponding acceptance code register and identifier bits</li> <li>1 Ignore corresponding acceptance code register bit</li> </ul> |



#### Chapter 13 Serial Communication Interface (SCIV4)

indicating that the received byte can be read. If the receive interrupt enable bit, RIE, in SCI control register 2 (SCICR2) is also set, the RDRF flag generates an RDRF interrupt request.

# 13.4.5.3 Data Sampling

The receiver samples the RXD pin at the RT clock rate. The RT clock is an internal signal with a frequency 16 times the baud rate. To adjust for baud rate mismatch, the RT clock (see Figure 13-15) is re-synchronized:

- After every start bit
- After the receiver detects a data bit change from logic 1 to logic 0 (after the majority of data bit samples at RT8, RT9, and RT10 returns a valid logic 1 and the majority of the next RT8, RT9, and RT10 samples returns a valid logic 0)

To locate the start bit, data recovery logic does an asynchronous search for a logic 0 preceded by three logic 1s. When the falling edge of a possible start bit occurs, the RT clock begins to count to 16.



To verify the start bit and to detect noise, data recovery logic takes samples at RT3, RT5, and RT7. Table 13-14 summarizes the results of the start bit verification samples.

| RT3, RT5, and RT7 Samples | Start Bit Verification | Noise Flag |
|---------------------------|------------------------|------------|
| 000                       | Yes                    | 0          |
| 001                       | Yes                    | 1          |
| 010                       | Yes                    | 1          |
| 011                       | No                     | 0          |
| 100                       | Yes                    | 1          |
| 101                       | No                     | 0          |
| 110                       | No                     | 0          |
| 111                       | No                     | 0          |

| Table 13-14. | Start Bit | Verification |
|--------------|-----------|--------------|
|--------------|-----------|--------------|

If start bit verification is not successful, the RT clock is reset and a new search for a start bit begins.



#### Chapter 14 Serial Peripheral Interface (SPIV3)

The baud rate generator is activated only when the SPI is in the master mode and a serial transfer is taking place. In the other cases, the divider is disabled to decrease  $I_{DD}$  current.

BaudRateDivisor =  $(SPPR + 1) \bullet 2^{(SPR + 1)}$ 

### Figure 14-11. Baud Rate Divisor Equation

## 14.4.5 Special Features

## 14.4.5.1 **SS** Output

The  $\overline{SS}$  output feature automatically drives the  $\overline{SS}$  pin low during transmission to select external devices and drives it high during idle to deselect external devices. When  $\overline{SS}$  output is selected, the  $\overline{SS}$  output pin is connected to the  $\overline{SS}$  input pin of the external device.

The  $\overline{SS}$  output is available only in master mode during normal SPI operation by asserting SSOE and MODFEN bit as shown in Table 14-3.

The mode fault feature is disabled while  $\overline{SS}$  output is enabled.

NOTE

Care must be taken when using the  $\overline{SS}$  output feature in a multimaster system because the mode fault feature is not available for detecting system errors between masters.

## 14.4.5.2 Bidirectional Mode (MOSI or MISO)

The bidirectional mode is selected when the SPC0 bit is set in SPI Control Register 2 (see Table 14-9). In this mode, the SPI uses only one serial data pin for the interface with external device(s). The MSTR bit decides which pin to use. The MOSI pin becomes the serial data I/O (MOMI) pin for the master mode, and the MISO pin becomes serial data I/O (SISO) pin for the slave mode. The MISO pin in master mode and MOSI pin in slave mode are not used by the SPI.

| When SPE = 1                   | Master Mode MSTR = 1                      | Slave Mode MSTR = 0                 |
|--------------------------------|-------------------------------------------|-------------------------------------|
| Normal Mode<br>SPC0 = 0        | Serial Out MOSI<br>SPI<br>Serial In MISO  | Serial In<br>SPI<br>Serial Out MISO |
| Bidirectional Mode<br>SPC0 = 1 | Serial Out<br>SPI<br>BIDIROE<br>Serial In | Serial In<br>SPI<br>Serial Out      |

Table 14-9. Normal Mode and Bidirectional Mode



# 15.3.2.1 PWM Enable Register (PWME)

Each PWM channel has an enable bit (PWMEx) to start its waveform output. When any of the PWMEx bits are set (PWMEx = 1), the associated PWM output is enabled immediately. However, the actual PWM waveform is not available on the associated PWM output until its clock source begins its next cycle due to the synchronization of PWMEx and the clock source.

### NOTE

The first PWM cycle after enabling the channel can be irregular.

An exception to this is when channels are concatenated. After concatenated mode is enabled (CONxx bits set in PWMCTL register), enabling/disabling the corresponding 16-bit PWM channel is controlled by the low-order PWMEx bit. In this case, the high-order bytes PWMEx bits have no effect and their corresponding PWM output lines are disabled.

While in run mode, if all six PWM channels are disabled (PWME5-PWME0 = 0), the prescaler counter shuts off for power savings.



Figure 15-3. PWM Enable Register (PWME)

Read: anytime

Write: anytime

| Field      | Description                                                                                                                                                                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5<br>PWME5 | <ul> <li>Pulse Width Channel 5 Enable</li> <li>0 Pulse width channel 5 is disabled.</li> <li>1 Pulse width channel 5 is enabled. The pulse modulated signal becomes available at PWM,output bit 5 when its clock source begins its next cycle.</li> </ul>                                                                          |
| 4<br>PWME4 | <ul> <li>Pulse Width Channel 4 Enable</li> <li>0 Pulse width channel 4 is disabled.</li> <li>1 Pulse width channel 4 is enabled. The pulse modulated signal becomes available at PWM, output bit 4 when its clock source begins its next cycle. If CON45 = 1, then bit has no effect and PWM output line 4 is disabled.</li> </ul> |
| 3<br>PWME3 | <ul> <li>Pulse Width Channel 3 Enable</li> <li>0 Pulse width channel 3 is disabled.</li> <li>1 Pulse width channel 3 is enabled. The pulse modulated signal becomes available at PWM, output bit 3 when its clock source begins its next cycle.</li> </ul>                                                                         |
| 2<br>PWME2 | <ul> <li>Pulse Width Channel 2 Enable</li> <li>0 Pulse width channel 2 is disabled.</li> <li>1 Pulse width channel 2 is enabled. The pulse modulated signal becomes available at PWM, output bit 2 when its clock source begins its next cycle. If CON23 = 1, then bit has no effect and PWM output line 2 is disabled.</li> </ul> |



# 15.4.2.1 PWM Enable

Each PWM channel has an enable bit (PWMEx) to start its waveform output. When any of the PWMEx bits are set (PWMEx = 1), the associated PWM output signal is enabled immediately. However, the actual PWM waveform is not available on the associated PWM output until its clock source begins its next cycle due to the synchronization of PWMEx and the clock source. An exception to this is when channels are concatenated. Refer to Section 15.4.2.7, "PWM 16-Bit Functions," for more detail.

### NOTE

The first PWM cycle after enabling the channel can be irregular.

On the front end of the PWM timer, the clock is enabled to the PWM circuit by the PWMEx bit being high. There is an edge-synchronizing circuit to guarantee that the clock will only be enabled or disabled at an edge. When the channel is disabled (PWMEx = 0), the counter for the channel does not count.

## 15.4.2.2 PWM Polarity

Each channel has a polarity bit to allow starting a waveform cycle with a high or low signal. This is shown on the block diagram as a mux select of either the Q output or the  $\overline{Q}$  output of the PWM output flip-flop. When one of the bits in the PWMPOL register is set, the associated PWM channel output is high at the beginning of the waveform, then goes low when the duty count is reached. Conversely, if the polarity bit is 0, the output starts low and then goes high when the duty count is reached.

## 15.4.2.3 PWM Period and Duty

Dedicated period and duty registers exist for each channel and are double buffered so that if they change while the channel is enabled, the change will NOT take effect until one of the following occurs:

- The effective period ends
- The counter is written (counter resets to 0x0000)
- The channel is disabled

In this way, the output of the PWM will always be either the old waveform or the new waveform, not some variation in between. If the channel is not enabled, then writes to the period and duty registers will go directly to the latches as well as the buffer.

A change in duty or period can be forced into effect "immediately" by writing the new value to the duty and/or period registers and then writing to the counter. This forces the counter to reset and the new duty and/or period values to be latched. In addition, because the counter is readable it is possible to know where the count is with respect to the duty value and software can be used to make adjustments.

### NOTE

When forcing a new period or duty into effect immediately, an irregular PWM cycle can occur.

Depending on the polarity bit, the duty registers will contain the count of either the high time or the low time.

MC9S12HZ256 Data Sheet, Rev. 2.05



Chapter 15 Pulse-Width Modulator (PWM8B6CV1)



Figure 15-40. PWM 16-Bit Mode

When using the 16-bit concatenated mode, the clock source is determined by the low-order 8-bit channel clock select control bits. That is channel 5 when channels 4 and 5 are concatenated, channel 3 when channels 2 and 3 are concatenated, and channel 1 when channels 0 and 1 are concatenated. The resulting PWM is output to the pins of the corresponding low-order 8-bit channel as also shown in Figure 15-40. The polarity of the resulting PWM output is controlled by the PPOLx bit of the corresponding low-order 8-bit channel as well.

After concatenated mode is enabled (CONxx bits set in PWMCTL register), enabling/disabling the corresponding 16-bit PWM channel is controlled by the low-order PWMEx bit. In this case, the high-order bytes PWMEx bits have no effect and their corresponding PWM output is disabled.

In concatenated mode, writes to the 16-bit counter by using a 16-bit access or writes to either the low or high-order byte of the counter will reset the 16-bit counter. Reads of the 16-bit counter must be made by 16-bit access to maintain data coherency.

Either left aligned or center aligned output mode can be used in concatenated mode and is controlled by the low-order CAEx bit. The high-order CAEx bit has no effect.



# Chapter 17 Dual Output Voltage Regulator (VREG3V3V2)

# 17.1 Introduction

The VREG3V3 is a dual output voltage regulator providing two separate 2.5 V (typical) supplies differing in the amount of current that can be sourced. The regulator input voltage range is from 3.3 V up to 5 V (typical).

# 17.1.1 Features

The block VREG3V3 includes these distinctive features:

- Two parallel, linear voltage regulators — Bandgap reference
- Low-voltage detect (LVD) with low-voltage interrupt (LVI)
- Power-on reset (POR)
- Low-voltage reset (LVR)

# 17.1.2 Modes of Operation

There are three modes VREG3V3 can operate in:

• Full-performance mode (FPM) (MCU is not in stop mode)

The regulator is active, providing the nominal supply voltage of 2.5 V with full current sourcing capability at both outputs. Features LVD (low-voltage detect), LVR (low-voltage reset), and POR (power-on reset) are available.

• Reduced-power mode (RPM) (MCU is in stop mode)

The purpose is to reduce power consumption of the device. The output voltage may degrade to a lower value than in full-performance mode, additionally the current sourcing capability is substantially reduced. Only the POR is available in this mode, LVD and LVR are disabled.

• Shutdown mode

Controlled by V<sub>REGEN</sub> (see device overview chapter for connectivity of V<sub>REGEN</sub>).

This mode is characterized by minimum power consumption. The regulator outputs are in a high impedance state, only the POR feature is available, LVD and LVR are disabled.

This mode must be used to disable the chip internal regulator VREG3V3, i.e., to bypass the VREG3V3 to use external supplies.



Chapter 17 Dual Output Voltage Regulator (VREG3V3V2)

The regulator is a linear series regulator with a bandgap reference in its Full Performance Mode and a voltage clamp in Reduced Power Mode. All load currents flow from input  $V_{DDR}$  to  $V_{SS}$  or  $V_{SSPLL}$ , the reference circuits are connected to  $V_{DDA}$  and  $V_{SSA}$ .

# 17.4.2 Full-Performance Mode

In Full Performance Mode, a fraction of the output voltage  $(V_{DD})$  and the bandgap reference voltage are fed to an operational amplifier. The amplified input voltage difference controls the gate of an output driver which basically is a large NMOS transistor connected to the output.

# 17.4.3 Reduced-Power Mode

In Reduced Power Mode, the driver gate is connected to a buffered fraction of the input voltage ( $V_{DDR}$ ). The operational amplifier and the bandgap are disabled to reduce power consumption.

# 17.4.4 LVD — Low-Voltage Detect

sub-block LVD is responsible for generating the low-voltage interrupt (LVI). LVD monitors the input voltage ( $V_{DDA}-V_{SSA}$ ) and continuously updates the status flag LVDS. Interrupt flag LVIF is set whenever status flag LVDS changes its value. The LVD is available in FPM and is inactive in Reduced Power Mode and Shutdown Mode.

# 17.4.5 POR — Power-On Reset

This functional block monitors output  $V_{DD}$ . If  $V_{DD}$  is below  $V_{PORD}$ , signal POR is high, if it exceeds  $V_{PORD}$ , the signal goes low. The transition to low forces the CPU in the power-on sequence.

Due to its role during chip power-up this module must be active in all operating modes of VREG3V3.

# 17.4.6 LVR — Low-Voltage Reset

Block LVR monitors the primary output voltage  $V_{DD}$ . If it drops below the assertion level ( $V_{LVRA}$ ) signal LVR asserts and when rising above the deassertion level ( $V_{LVRD}$ ) signal LVR negates again. The LVR function is available only in Full Performance Mode.

# 17.4.7 CTRL — Regulator Control

This part contains the register block of VREG3V3 and further digital functionality needed to control the operating modes. CTRL also represents the interface to the digital core logic.

| _                            | 7                           | 6    | 5     | 4 | 3     | 2 | 1     | 0   |  |
|------------------------------|-----------------------------|------|-------|---|-------|---|-------|-----|--|
| R                            | MODO                        |      |       | 0 | 11/16 | 0 |       | EME |  |
| W                            | NODC                        | MODE | NIODA |   | 1015  |   | EIVIK |     |  |
| Reset                        |                             |      |       |   |       |   |       |     |  |
| Special Single Chip          | 0                           | 0    | 0     | 0 | 0     | 0 | 0     | 0   |  |
| Emulation Expanded<br>Narrow | 0                           | 0    | 1     | 0 | 1     | 0 | 1     | 1   |  |
| Special Test                 | 0                           | 1    | 0     | 0 | 1     | 0 | 0     | 0   |  |
| Emulation Expanded<br>Wide   | 0                           | 1    | 1     | 0 | 1     | 0 | 1     | 1   |  |
| Normal Single Chip           | 1                           | 0    | 0     | 0 | 0     | 0 | 0     | 0   |  |
| Normal Expanded<br>Narrow    | 1                           | 0    | 1     | 0 | 0     | 0 | 0     | 0   |  |
| Peripheral                   | 1                           | 1    | 0     | 0 | 0     | 0 | 0     | 0   |  |
| Normal Expanded Wide         | 1                           | 1    | 1     | 0 | 0     | 0 | 0     | 0   |  |
|                              | = Unimplemented or Reserved |      |       |   |       |   |       |     |  |

# 21.3.2.9 Mode Register (MODE)

Figure 21-13. Mode Register (MODE)

Read: Anytime (provided this register is in the map).

Write: Each bit has specific write conditions. Please refer to the descriptions of each bit on the following pages.

The MODE register is used to establish the operating mode and other miscellaneous functions (i.e., internal visibility and emulation of port E and K).

In special peripheral mode, this register is not accessible but it is reset as shown to system configuration features. Changes to bits in the MODE register are delayed one cycle after the write.

This register is not in the on-chip memory map in expanded and special peripheral modes. Therefore, these accesses will be echoed externally.





<sup>2</sup> PC Board according to EIA/JEDEC Standard 51-2

<sup>3</sup> PC Board according to EIA/JEDEC Standard 51-7

# A.1.9 I/O Characteristics

This section describes the characteristics of all 5V I/O pins. All parameters are not always applicable, e.g. not all pins feature pull up/down resistances.

| Conditions are shown in Table A-4 unless otherwise noted |   |                                                                                                                                              |                  |                         |                        |                        |      |  |  |  |
|----------------------------------------------------------|---|----------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------|------------------------|------------------------|------|--|--|--|
| Num                                                      | С | Rating                                                                                                                                       | Symbol           | Min                     | Тур                    | Max                    | Unit |  |  |  |
| 1                                                        | Р | Input High Voltage                                                                                                                           | V <sub>IH</sub>  | 0.65*V <sub>DD5</sub>   | _                      | V <sub>DD5</sub> + 0.3 | V    |  |  |  |
| 2                                                        | Р | Input Low Voltage                                                                                                                            | V <sub>IL</sub>  | V <sub>SS5</sub> – 0.3  | -                      | 0.35*V <sub>DD5</sub>  | V    |  |  |  |
| 3                                                        | С | Input Hysteresis                                                                                                                             | V <sub>HYS</sub> |                         | 250                    |                        | mV   |  |  |  |
| 4                                                        | Ρ | Input Leakage Current except PU, PV (pins in high impedance input mode) <sup>1</sup><br>$V_{in} = V_{DD5} \text{ or } V_{SS5}$               | l <sub>in</sub>  | -1.0                    | -                      | 1.0                    | μA   |  |  |  |
| 5                                                        | P | Input Leakage Current PU, PV (pins in high impedance input mode) <sup>2</sup><br>$V_{in} = V_{DD5} \text{ or } V_{SS5}$                      | l <sub>in</sub>  | -2.5                    | -                      | 2.5                    | μA   |  |  |  |
| 6                                                        | P | Output High Voltage (pins in output mode, except PU and PV)<br>Partial Drive $I_{OH} = -1.0$ mA<br>Full Drive $I_{OH} = -10$ mA              | V <sub>OH</sub>  | V <sub>DD5</sub> – 0.8  | _                      | _                      | V    |  |  |  |
| 7                                                        | P | Output Low Voltage (pins in output mode except PU<br>and PV)<br>Partial Drive I <sub>OL</sub> = +1.0mA<br>Full Drive I <sub>OL</sub> = +10mA | V <sub>OL</sub>  | -                       | _                      | 0.8                    | V    |  |  |  |
| 8                                                        | Ρ | Output High Voltage (pins PU and PV in output mode)<br>$I_{OH} = -20mA$ (typical value at 25°C)                                              | V <sub>OH</sub>  | V <sub>DD5</sub> – 0.32 | V <sub>DD5</sub> – 0.2 | -                      | V    |  |  |  |
| 9                                                        | Ρ | Output Low Voltage (pins PU and PV in output mode)<br>IOL = +20mA (typical value at $25^{\circ}$ C)                                          | V <sub>OL</sub>  | -                       | .2                     | 0.32                   | V    |  |  |  |
| 10                                                       | С | Output Rise Time (pins PU and PV in output mode with slew control enabled) V_DD5=5V, R_{load}=1K\Omega, 10% to 90% of V <sub>OH</sub>        | t <sub>r</sub>   | 60                      | 100                    | 130                    | ns   |  |  |  |
| 11                                                       | С | Output Fall Time (pins PU and PV in output mode with slew control enabled) V_{DD5}=5V, R_{load}=1K\Omega, 10% to 90% of V_OH                 | t <sub>f</sub>   | 60                      | 100                    | 130                    | ns   |  |  |  |
| 12                                                       | Р | Internal Pull Up Device Current,<br>tested at V <sub>IL</sub> Max.                                                                           | I <sub>PUL</sub> | -                       | -                      | -130                   | μΑ   |  |  |  |
| 13                                                       | Ρ | Internal Pull Up Device Current,<br>tested at V <sub>IH</sub> Min.                                                                           | I <sub>PUH</sub> | -10                     | -                      | -                      | μA   |  |  |  |
| 14                                                       | Ρ | Internal Pull Down Device Current,<br>tested at V <sub>IH</sub> Min.                                                                         | I <sub>PDH</sub> | -                       | -                      | 130                    | μA   |  |  |  |

| Table A- | 6. 5V | I/O ( | Charact | teristics |
|----------|-------|-------|---------|-----------|
|----------|-------|-------|---------|-----------|

**Appendix A Electrical Characteristics** 



The setup time can be ignored for this operation.

## A.3.1.4 Mass Erase

Erasing a NVM block takes:

 $t_{mass} \approx 20000 \cdot \frac{1}{f_{NVMOP}}$ The setup time can be ignored for this operation.

### A.3.1.5 Blank Check

The time it takes to perform a blank check on the Flash or EEPROM is dependent on the location of the first non-blank word starting at relative address zero. It takes one bus cycle per word to verify plus a setup of the command.

$$t_{check} \approx location \cdot t_{cyc} + 10 \cdot t_{cyc}$$

| Conditions are shown in Table A-4 unless otherwise noted |   |                                                        |                     |                    |     |                     |                  |  |  |
|----------------------------------------------------------|---|--------------------------------------------------------|---------------------|--------------------|-----|---------------------|------------------|--|--|
| Num                                                      | С | Rating                                                 | Symbol              | Min                | Тур | Мах                 | Unit             |  |  |
| 1                                                        | D | External Oscillator Clock                              | f <sub>NVMOSC</sub> | 0.5                |     | 50 <sup>1</sup>     | MHz              |  |  |
| 2                                                        | D | Bus frequency for Programming or Erase Operations      | f <sub>NVMBUS</sub> | 1                  |     |                     | MHz              |  |  |
| 3                                                        | D | Operating Frequency                                    | f <sub>NVMOP</sub>  | 150                |     | 200                 | kHz              |  |  |
| 4                                                        | Ρ | Single Word Programming Time                           | t <sub>swpgm</sub>  | 46 <sup>2</sup>    |     | 74.5 <sup>3</sup>   | μs               |  |  |
| 5                                                        | D | Flash Burst Programming consecutive word <sup>4</sup>  | t <sub>bwpgm</sub>  | 20.4 <sup>2</sup>  |     | 31 <sup>3</sup>     | μs               |  |  |
| 6                                                        | D | Flash Burst Programming Time for 32 Words <sup>4</sup> | t <sub>brpgm</sub>  | 678.4 <sup>2</sup> |     | 1035.5 <sup>3</sup> | μs               |  |  |
| 7                                                        | Р | Sector Erase Time                                      | t <sub>era</sub>    | 20 <sup>5</sup>    |     | 26.7 <sup>3</sup>   | ms               |  |  |
| 8                                                        | Р | Mass Erase Time                                        | t <sub>mass</sub>   | 100 <sup>5</sup>   |     | 133 <sup>3</sup>    | ms               |  |  |
| 9                                                        | D | Blank Check Time Flash per block                       | t <sub>check</sub>  | 11 <sup>6</sup>    |     | 32778 <sup>7</sup>  | t <sub>cyc</sub> |  |  |
| 10                                                       | D | Blank Check Time EEPROM per block                      | t <sub>check</sub>  | 11 <sup>6</sup>    |     | 2058 <sup>7</sup>   | t <sub>cyc</sub> |  |  |

#### Table A-11. NVM Timing Characteristics

<sup>1</sup> Restrictions for oscillator in crystal mode apply!

 $^2$  Minimum Programming times are achieved under maximum NVM operating frequency  $f_{\rm NVMOP}$  and maximum bus frequency  $f_{\rm bus}.$ 

<sup>3</sup> Maximum Erase and Programming times are achieved under particular combinations of f<sub>NVMOP</sub> and bus frequency f<sub>bus</sub>. Refer to formulae in Sections Section A.3.1.1, "Single Word Programming," through Section A.3.1.4, "Mass Erase," for guidance.

<sup>4</sup> urst Programming operations are not applicable to EEPROM

- <sup>5</sup> Minimum Erase times are achieved under maximum NVM operating frequency f<sub>NVMOP</sub>
- <sup>6</sup> Minimum time, if first word in the array is not blank
- <sup>7</sup> Maximum time to complete check on an erased block



**Appendix A Electrical Characteristics** 

# A.5.1.3 External Reset

When external reset is asserted for a time greater than  $PW_{RSTL}$  the CRG module generates an internal reset, and the CPU starts fetching the reset vector without doing a clock quality check, if there was an oscillation before reset.

# A.5.1.4 Stop Recovery

Out of STOP the controller can be woken up by an external interrupt. A clock quality check as after POR is performed before releasing the clocks to the system.

# A.5.1.5 Pseudo Stop and Wait Recovery

The recovery from Pseudo STOP and Wait are essentially the same since the oscillator was not stopped in both modes. The controller can be woken up by internal or external interrupts. After  $t_{wrs}$  the CPU starts fetching the interrupt vector.



Appendix B PCB Layout Guidelines



Figure B-2. Recommended PCB Layout for 80-pin QFP



#### Appendix G Detailed Register Map

### 0x00D0–0x00D7 SCI1 (Asynchronous Serial Interface) (continued)

| Address | Name     |   | 7     | 6  | 5  | 4     | 3       | 2       | 1     | 0   |
|---------|----------|---|-------|----|----|-------|---------|---------|-------|-----|
|         | SCI15P2  | R | 0     | 0  | 0  |       |         | BDK13   |       | RAF |
| 000000  | 30113112 | W |       |    |    | TATUL | INTI OL | DIVIVIO | TADIN |     |
| 020006  |          | R | R8 To | тο | 0  | 0     | 0       | 0       | 0     | 0   |
| 000000  | SCHERN   | W |       | 10 |    |       |         |         |       |     |
| 020007  |          | R | R7    | R6 | R5 | R4    | R3      | R2      | R1    | R0  |
| 0,0001  | SCHURL   | W | T7    | T6 | T5 | T4    | Т3      | T2      | T1    | Т0  |

### 0x00D8–0x00DF SPI (Serial Peripheral Interface)

| Address | Name       |        | 7    | 6      | 5      | 4     | 3       | 2     | 1       | 0     |      |             |
|---------|------------|--------|------|--------|--------|-------|---------|-------|---------|-------|------|-------------|
| 0x00D8  | SPICR1     | R<br>W | SPIE | SPE    | SPTIE  | MSTR  | CPOL    | CPHA  | SSOE    | LSBFE |      |             |
| 020000  |            | R      | 0    | 0      | 0      |       |         | 0     | SPISWAI | SPCO  |      |             |
| 000003  | 0110112    | W      |      |        |        |       | DIDINOL |       |         | 01 00 |      |             |
|         | CDIRD      | SDIBD  | R    | 0      | SPPR2  | SPPR1 | SPPRO   | 0     | SPR2    | SPR1  | SPRO |             |
|         | OFIDIX     | W      |      | 011112 | OFFICE |       |         | 01112 | 0       |       |      |             |
|         | SDISD      | R      | SPIF | 0      | SPTEF  | MODF  | 0       | 0     | 0       | 0     |      |             |
| UXUUDB  | SFISK      | W      |      |        |        |       |         |       |         |       |      |             |
| 020000  | Percentred | R      | 0    | 0      | 0      | 0     | 0       | 0     | 0       | 0     |      |             |
| UXUUDC  | Reserveu   | W      |      |        |        |       |         |       |         |       |      |             |
| 0~0000  |            | R      |      | R      | Bit7   | 6     | Б       | 4     | 2       | n     | 1    | <b>BitO</b> |
| 000000  | SFIDK      | W      | DILI | 0      | 5      | 4     | 5       | 2     | 1       | Bito  |      |             |
| 0x00DE- | Pagaryad   | R      | 0    | 0      | 0      | 0     | 0       | 0     | 0       | 0     |      |             |
| 0x00DF  | Reserveu   | W      |      |        |        |       |         |       |         |       |      |             |

### 0x00E0-0x00FF PWM (Pulse Width Modulator 8 Bit 6 Channel) (Sheet 1 of 2)

| Address | Name      |        | 7     | 6      | 5      | 4      | 3       | 2       | 1                                                                                                                                            | 0     |
|---------|-----------|--------|-------|--------|--------|--------|---------|---------|----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 0x00E0  | PWME      | R      | 0     | 0      | PWME5  | PWME4  | PWME3   | PWME2   | PWME1                                                                                                                                        | PWME0 |
|         |           | VV     |       | 0      |        |        |         |         |                                                                                                                                              |       |
| 0x00E1  | PWMPOL    | R      | 0     | 0      | PPOL5  | PPOL4  | PPOL3   | PPOL2   | PPOL1                                                                                                                                        | PPOL0 |
|         |           | VV     | -     |        |        |        |         |         |                                                                                                                                              |       |
| 0x00E2  | PWMCLK    | R      | 0     | 0      | PCLK5  | PCLK4  | PCLK3   | PCLK2   | PCLK1                                                                                                                                        | PCLK0 |
|         | -         | W      |       |        |        | _      |         | -       | PWME1           PPOL1           PCLK1           PCKA1           CAE1           0           0           0           0           0           0 |       |
| 0v00E3  |           | R      | 0     | PCKB2  | PCKB1  | DCKBO  | 0       | PCKA2   | 2 PCKA1                                                                                                                                      | PCKA0 |
|         |           | W      |       | TONDZ  | TONDI  | I ONDO |         | 1 01042 |                                                                                                                                              |       |
|         |           | R      | 0     | 0      | 0.055  |        |         | CAE2    | CAE1                                                                                                                                         | CAE0  |
| 0X00E4  | PWWCAE    | W      |       |        | CAES   | CAE4   | CAES    | CAEZ    |                                                                                                                                              |       |
| 0x00E5  | PWMCTI    | R      | 0     | CON45  | CON23  | CON01  | PSW/AI  | PFR7    | 0                                                                                                                                            | 0     |
|         | TWINGTE   | W      |       | 001140 | 001120 |        | 1 000/0 | 11112   |                                                                                                                                              |       |
| 0,00000 | PWMTST    | R      | 0     | 0      | 0      | 0      | 0       | 0       | 0                                                                                                                                            | 0     |
|         | Test Only | W      |       |        |        |        |         |         |                                                                                                                                              |       |
|         | PWMPRSC   | R      | 0     | 0      | 0      | 0      | 0       | 0       | 0                                                                                                                                            | 0     |
| 0X00E7  | Test Only | W      |       |        |        |        |         |         |                                                                                                                                              |       |
| 0x00E8  | PWMSCLA   | R<br>W | Bit 7 | 6      | 5      | 4      | 3       | 2       | 1                                                                                                                                            | Bit 0 |