

Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

#### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Obsolete                                                               |
|----------------------------|------------------------------------------------------------------------|
| Core Processor             | HCS12                                                                  |
| Core Size                  | 16-Bit                                                                 |
| Speed                      | 25MHz                                                                  |
| Connectivity               | CANbus, EBI/EMI, SCI, SPI                                              |
| Peripherals                | POR, PWM, WDT                                                          |
| Number of I/O              | 60                                                                     |
| Program Memory Size        | 96KB (96K x 8)                                                         |
| Program Memory Type        | FLASH                                                                  |
| EEPROM Size                | -                                                                      |
| RAM Size                   | 4K x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 2.35V ~ 5.5V                                                           |
| Data Converters            | A/D 8x10b                                                              |
| Oscillator Type            | Internal                                                               |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                      |
| Mounting Type              | Surface Mount                                                          |
| Package / Case             | 80-QFP                                                                 |
| Supplier Device Package    | 80-QFP (14x14)                                                         |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc9s12c96cfuer |

Email: info@E-XFL.COM

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



Chapter 2 Port Integration Module (PIM9C32) Block Description

### 2.3.2.3.6 Port M Polarity Select Register (PPSM)

Module Base + 0x0015



#### Figure 2-22. Port M Polarity Select Register (PPSM)

### Read: Anytime.

Write: Anytime.

#### Table 2-20. PPSM Field Descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5–0<br>PPSM[5:0] | <ul> <li>Polarity Select Port M — This register selects whether a pull-down or a pull-up device is connected to the pin.</li> <li>A pull-up device is connected to the associated port M pin, if enabled by the associated bit in register PERM and if the port is used as input or as wired-or output.</li> <li>A pull-down device is connected to the associated port M pin, if enabled by the associated bit in register PERM and if the port is used as input.</li> </ul> |

### 2.3.2.3.7 Port M Wired-OR Mode Register (WOMM)

Module Base + 0x0016



#### Figure 2-23. Port M Wired-OR Mode Register (WOMM)

Read: Anytime.

Write: Anytime.

#### Table 2-21. WOMM Field Descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                       |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5–0<br>WOMM[5:0] | <ul> <li>Wired-OR Mode Port M — This register configures the output pins as wired-or. If enabled the output is driven active low only (open-drain). A logic level of "1" is not driven. This bit has no influence on pins used as inputs.</li> <li>Output buffers operate as push-pull outputs.</li> <li>Output buffers operate as open-drain outputs.</li> </ul> |

Chapter 3 Module Mapping Control (MMCV4) Block Description

| PIX5 | PIX4 | PIX3 | PIX2 | PIX1 | PIX0 | Program Space<br>Selected |
|------|------|------|------|------|------|---------------------------|
| 0    | 0    | 0    | 0    | 0    | 0    | 16K page 0                |
| 0    | 0    | 0    | 0    | 0    | 1    | 16K page 1                |
| 0    | 0    | 0    | 0    | 1    | 0    | 16K page 2                |
| 0    | 0    | 0    | 0    | 1    | 1    | 16K page 3                |
| -    | -    | -    | -    | -    | -    |                           |
| •    | •    | •    | •    | •    | •    |                           |
| •    | •    | •    | •    | •    | •    |                           |
| -    | -    |      | -    | -    | -    |                           |
| •    | -    | -    | -    | -    | -    |                           |
| 1    | 1    | 1    | 1    | 0    | 0    | 16K page 60               |
| 1    | 1    | 1    | 1    | 0    | 1    | 16K page 61               |
| 1    | 1    | 1    | 1    | 1    | 0    | 16K page 62               |
| 1    | 1    | 1    | 1    | 1    | 1    | 16K page 63               |

Table 3-14. Program Page Index Register Bits

# 3.4 Functional Description

The MMC sub-block performs four basic functions of the core operation: bus control, address decoding and select signal generation, memory expansion, and security decoding for the system. Each aspect is described in the following subsections.

# 3.4.1 Bus Control

The MMC controls the address bus and data buses that interface the core with the rest of the system. This includes the multiplexing of the input data buses to the core onto the main CPU read data bus and control of data flow from the CPU to the output address and data buses of the core. In addition, the MMC manages all CPU read data bus swapping operations.

# 3.4.2 Address Decoding

As data flows on the core address bus, the MMC decodes the address information, determines whether the internal core register or firmware space, the peripheral space or a memory register or array space is being addressed and generates the correct select signal. This decoding operation also interprets the mode of operation of the system and the state of the mapping control registers in order to generate the proper select. The MMC also generates two external chip select signals, emulation chip select ( $\overline{\text{ECS}}$ ) and external chip select ( $\overline{\text{XCS}}$ ).

## 3.4.2.1 Select Priority and Mode Considerations

Although internal resources such as control registers and on-chip memory have default addresses, each can be relocated by changing the default values in control registers. Normally, I/O addresses, control registers,



#### Chapter 6 Background Debug Module (BDMV4) Block Description

- Nine hardware commands using free cycles, if available, for minimal CPU intervention
- Hardware commands not requiring active BDM
- 15 firmware commands execute from the standard BDM firmware lookup table
- Instruction tagging capability
- Software control of BDM operation during wait mode
- Software selectable clocks
- When secured, hardware commands are allowed to access the register space in special single-chip mode, if the FLASH and EEPROM erase tests fail.

## 6.1.2 Modes of Operation

BDM is available in all operating modes but must be enabled before firmware commands are executed. Some system peripherals may have a control bit which allows suspending the peripheral function during background debug mode.

### 6.1.2.1 Regular Run Modes

All of these operations refer to the part in run mode. The BDM does not provide controls to conserve power during run mode.

• Normal operation

General operation of the BDM is available and operates the same in all normal modes.

• Special single-chip mode

In special single-chip mode, background operation is enabled and active out of reset. This allows programming a system with blank memory.

• Special peripheral mode

BDM is enabled and active immediately out of reset. BDM can be disabled by clearing the BDMACT bit in the BDM status (BDMSTS) register. The BDM serial system should not be used in special peripheral mode.

### NOTE

The BDM serial system should not be used in special peripheral mode since the CPU, which in other modes interfaces with the BDM to relinquish control of the bus during a free cycle or a steal operation, is not operating in this mode.

• Emulation modes

General operation of the BDM is available and operates the same as in normal modes.

### 6.1.2.2 Secure Mode Operation

If the part is in secure mode, the operation of the BDM is reduced to a small subset of its regular run mode operation. Secure operation prevents access to FLASH or EEPROM other than allowing erasure.



Chapter 6 Background Debug Module (BDMV4) Block Description



### 6.4.6 BDM Serial Interface

The BDM communicates with external devices serially via the BKGD pin. During reset, this pin is a mode select input which selects between normal and special modes of operation. After reset, this pin becomes the dedicated serial interface pin for the BDM.

The BDM serial interface is timed using the clock selected by the CLKSW bit in the status register see Section 6.3.2.1, "BDM Status Register (BDMSTS)." This clock will be referred to as the target clock in the following explanation.

The BDM serial interface uses a clocking scheme in which the external host generates a falling edge on the BKGD pin to indicate the start of each bit time. This falling edge is sent for every bit whether data is transmitted or received. Data is transferred most significant bit (MSB) first at 16 target clock cycles per bit. The interface times out if 512 clock cycles occur between falling edges from the host.

The BKGD pin is a pseudo open-drain pin and has an weak on-chip active pull-up that is enabled at all times. It is assumed that there is an external pull-up and that drivers connected to BKGD do not typically drive the high level. Because R-C rise time could be unacceptably long, the target system and host provide brief driven-high (speedup) pulses to drive BKGD to a logic 1. The source of this speedup pulse is the host for transmit cases and the target for receive cases.

The timing for host-to-target is shown in Figure 6-7 and that of target-to-host in Figure 6-8 and Figure 6-9. All four cases begin when the host drives the BKGD pin low to generate a falling edge. Because the host and target are operating from separate clocks, it can take the target system up to one full clock cycle to recognize this edge. The target measures delays from this perceived start of the bit time while the host measures delays from the point it actually drove BKGD low to start the bit up to one target clock cycle



#### Chapter 6 Background Debug Module (BDMV4) Block Description

The commands are described as follows:

- ACK\_ENABLE enables the hardware handshake protocol. The target will issue the ACK pulse when a CPU command is executed by the CPU. The ACK\_ENABLE command itself also has the ACK pulse as a response.
- ACK\_DISABLE disables the ACK pulse protocol. In this case, the host needs to use the worst case delay time at the appropriate places in the protocol.

The default state of the BDM after reset is hardware handshake protocol disabled.

All the read commands will ACK (if enabled) when the data bus cycle has completed and the data is then ready for reading out by the BKGD serial pin. All the write commands will ACK (if enabled) after the data has been received by the BDM through the BKGD serial pin and when the data bus cycle is complete. See Section 6.4.3, "BDM Hardware Commands," and Section 6.4.4, "Standard BDM Firmware Commands," for more information on the BDM commands.

The ACK\_ENABLE sends an ACK pulse when the command has been completed. This feature could be used by the host to evaluate if the target supports the hardware handshake protocol. If an ACK pulse is issued in response to this command, the host knows that the target supports the hardware handshake protocol. If the target does not support the hardware handshake protocol the ACK pulse is not issued. In this case, the ACK\_ENABLE command is ignored by the target because it is not recognized as a valid command.

The BACKGROUND command will issue an ACK pulse when the CPU changes from normal to background mode. The ACK pulse related to this command could be aborted using the SYNC command.

The GO command will issue an ACK pulse when the CPU exits from background mode. The ACK pulse related to this command could be aborted using the SYNC command.

The GO\_UNTIL command is equivalent to a GO command with exception that the ACK pulse, in this case, is issued when the CPU enters into background mode. This command is an alternative to the GO command and should be used when the host wants to trace if a breakpoint match occurs and causes the CPU to enter active background mode. Note that the ACK is issued whenever the CPU enters BDM, which could be caused by a breakpoint match or by a BGND instruction being executed. The ACK pulse related to this command could be aborted using the SYNC command.

The TRACE1 command has the related ACK pulse issued when the CPU enters background active mode after one instruction of the application program is executed. The ACK pulse related to this command could be aborted using the SYNC command.

The TAGGO command will not issue an ACK pulse because this would interfere with the tagging function shared on the same pin.



#### Chapter 7 Debug Module (DBGV1) Block Description

#### Table 7-12. DBGCC Field Descriptions

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | <ul> <li>Comparator C Compare Bits — The comparator C compare bits control whether comparator C will compare the address bus bits [15:0] to a logic 1 or logic 0. See Table 7-13.</li> <li>0 Compare corresponding address bit to a logic 0</li> <li>1 Compare corresponding address bit to a logic 1</li> <li>Note: This register will be cleared automatically when the DBG module is armed in LOOP1 mode.</li> </ul> |

#### Table 7-13. Comparator C Compares

| PAGSEL | EXTCMP Compare           | High-Byte Compare                 |  |  |
|--------|--------------------------|-----------------------------------|--|--|
| x0     | No compare               | DBGCCH[7:0] = AB[15:8]            |  |  |
| x1     | EXTCMP[5:0] = XAB[21:16] | DBGCCH[7:0] = XAB[15:14],AB[13:8] |  |  |

### 7.3.2.7 Debug Control Register 2 (DBGC2)

Module Base + 0x0028

Starting address location affected by INITRG register setting.

|        | 7                     | 6    | 5   | 4     | 3                    | 2                 | 1                  | 0                |
|--------|-----------------------|------|-----|-------|----------------------|-------------------|--------------------|------------------|
| R<br>W | BKABEN <sup>(1)</sup> | FULL | BDM | TAGAB | BKCEN <sup>(2)</sup> | TAGC <sup>2</sup> | RWCEN <sup>2</sup> | RWC <sup>2</sup> |
| Reset  | 0                     | 0    | 0   | 0     | 0                    | 0                 | 0                  | 0                |

1. When BKABEN is set (BKP mode), all bits in DBGC2 are available. When BKABEN is cleared and DBG is used in DBG mode, bits FULL and TAGAB have no meaning.

2. These bits can be used in BKP mode and DBG mode (when capture mode is not set in LOOP1) to provide a third breakpoint.

#### Figure 7-13. Debug Control Register 2 (DBGC2)

#### Table 7-14. DBGC2 Field Descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>BKABEN | <ul> <li>Breakpoint Using Comparator A and B Enable — This bit enables the breakpoint capability using comparator A and B, when set (BKP mode) the DBGEN bit in DBGC1 cannot be set.</li> <li>0 Breakpoint module off</li> <li>1 Breakpoint module on</li> </ul>                                                                                                                |
| 6<br>FULL   | <ul> <li>Full Breakpoint Mode Enable — This bit controls whether the breakpoint module is in dual mode or full mode.<br/>In full mode, comparator A is used to match address and comparator B is used to match data. See<br/>Section 7.4.1.2, "Full Breakpoint Mode," for more details.</li> <li>0 Dual address mode enabled</li> <li>1 Full breakpoint mode enabled</li> </ul> |
| 5<br>BDM    | Background Debug Mode Enable — This bit determines if the breakpoint causes the system to enter<br>background debug mode (BDM) or initiate a software interrupt (SWI).0Go to software interrupt on a break request1Go to BDM on a break request                                                                                                                                 |



#### Chapter 8 Analog-to-Digital Converter (ATD10B8C) Block Description

| Address           | Name            |           | Bit 7     | 6          | 5           | 4       | 3     | 2     | 1         | Bit 0          |
|-------------------|-----------------|-----------|-----------|------------|-------------|---------|-------|-------|-----------|----------------|
|                   |                 | R         | BIT 9 MSB | BIT 8      | BIT 7       | BIT 6   | BIT 5 | BIT 4 | BIT 3     | BIT 2          |
| 0x001E            | ATDDR7H         |           | BIT 7 MSB | BIT 6      | BIT 5       | BIT 4   | BIT 3 | BIT 2 | BIT 1     | BIT 0          |
|                   |                 | w         |           |            |             |         |       |       |           |                |
|                   |                 | R         | BIT 1     | BIT 0      | 0           | 0       | 0     | 0     | 0         | 0              |
| 0x001F            | ATDDR7L         |           | u         | u          | 0           | 0       | 0     | 0     | 0         | 0              |
| <b>Dight lust</b> | ified Recult De | w         |           |            |             |         |       |       |           |                |
| nigiii Jusi       | illeu nesult Da |           | 0         | 0          | 0           | 0       | 0     | 0     |           |                |
| 0v0010            |                 | п         | 0         | 0          | 0           | 0       | 0     | 0     | 0         |                |
| 0,0010            | AIDDITOT        | w         |           |            | •           | •       | •     | •     |           |                |
|                   |                 | B         | BIT 7     | BIT 6      | BIT 5       | BIT 4   | BIT 3 | BIT 2 | BIT 1     | BIT 0          |
| 0x0011            | ATDDB0L         |           | BIT 7 MSB | BIT 6      | BIT 5       | BIT 4   | BIT 3 | BIT 2 | BIT 1     | BIT 0          |
|                   | /               | w         |           |            |             |         |       |       |           |                |
|                   |                 | R         | 0         | 0          | 0           | 0       | 0     | 0     | BIT 9 MSB | BIT 8          |
| 0x0012            | ATDDR1H         |           | 0         | 0          | 0           | 0       | 0     | 0     | 0         | 0              |
|                   |                 | w         |           |            |             |         |       |       |           |                |
|                   |                 | R         | BIT 7     | BIT 6      | BIT 5       | BIT 4   | BIT 3 | BIT 2 | BIT 1     | BIT 0          |
| 0x0013            | ATDDR1L         |           | BIT 7 MSB | BIT 6      | BIT 5       | BIT 4   | BIT 3 | BIT 2 | BIT 1     | BIT 0          |
|                   |                 | W         |           |            |             |         |       |       |           |                |
|                   |                 | R         | 0         | 0          | 0           | 0       | 0     | 0     | BIT 9 MSB | BIT 8          |
| 0x0014            | ATDDR2H         |           | 0         | 0          | 0           | 0       | 0     | 0     | 0         | 0              |
|                   |                 | W         |           |            |             |         |       |       |           |                |
|                   |                 | R         | BIT 7     | BIT 6      | BIT 5       | BIT 4   | BIT 3 | BIT 2 | BIT 1     | BIT 0          |
| 0x0015            | ATDDR2L         |           | BIT / MSB | BII 6      | BII 5       | BIT 4   | BIT 3 | BIT 2 | BIL1      | BII 0          |
|                   |                 | vv        |           |            | -           | -       |       |       |           |                |
| 0.0010            |                 | К         | 0         | 0          | 0           | 0       | 0     | 0     | BIL 9 W2B | BIL 8          |
| 0X0016            | AIDDR3H         | <u>مر</u> | 0         | 0          | 0           | 0       | 0     | 0     | 0         | 0              |
|                   |                 |           | PIT 7     | PIT 6      | PIT 5       |         | PIT 2 |       | DIT 1     | BIT 0          |
| 0x0017            |                 | п         | BIT 7 MSB | BIT 6      | BIT 5       | BIT 4   | BIT 3 | BIT 2 | BIT 1     | BIT 0<br>BIT 0 |
| 0,0017            | AIDDINE         | w         | 2         | 2 0        | 2 0         | 2       | 2.1.0 |       |           | 2 0            |
|                   |                 | R         | 0         | 0          | 0           | 0       | 0     | 0     | BIT 9 MSB | BIT 8          |
| 0x0018            | ATDDR4H         |           | 0         | 0          | 0           | 0       | 0     | 0     | 0         | 0              |
|                   |                 | w         |           |            |             |         |       |       |           |                |
|                   |                 | R         | BIT 7     | BIT 6      | BIT 5       | BIT 4   | BIT 3 | BIT 2 | BIT 1     | BIT 0          |
| 0x0019            | ATDDR4L         |           | BIT 7 MSB | BIT 6      | BIT 5       | BIT 4   | BIT 3 | BIT 2 | BIT 1     | BIT 0          |
|                   |                 | W         |           |            |             |         |       |       |           |                |
|                   |                 | R         | 0         | 0          | 0           | 0       | 0     | 0     | BIT 9 MSB | BIT 8          |
| 0x001A            | ATDDR5H         |           | 0         | 0          | 0           | 0       | 0     | 0     | 0         | 0              |
|                   |                 | W         |           |            |             |         |       |       |           |                |
|                   |                 | R         | BIT 7     | BIT 6      | BIT 5       | BIT 4   | BIT 3 | BIT 2 | BIT 1     | BIT 0          |
| 0x001B            | ATDDR5L         |           | BIT 7 MSB | BIT 6      | BIT 5       | BIT 4   | BIT 3 | BIT 2 | BIT 1     | BIT 0          |
|                   |                 | W         |           |            |             |         |       |       |           |                |
|                   |                 |           |           | = Unimpler | nented or R | eserved |       |       |           |                |

Figure 8-2. ATD Register Summary (Sheet 3 of 4)



Chapter 8 Analog-to-Digital Converter (ATD10B8C) Block Description

| Address                     | Name    |   | Bit 7     | 6     | 5     | 4     | 3     | 2     | 1         | Bit 0 |
|-----------------------------|---------|---|-----------|-------|-------|-------|-------|-------|-----------|-------|
|                             |         | R | 0         | 0     | 0     | 0     | 0     | 0     | BIT 9 MSB | BIT 8 |
| 0x001C                      | ATDDR6H |   | 0         | 0     | 0     | 0     | 0     | 0     | 0         | 0     |
|                             |         | W |           |       |       |       |       |       |           |       |
|                             |         | R | BIT 7     | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1     | BIT 0 |
| 0x001D                      | ATDDR6L |   | BIT 7 MSB | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1     | BIT 0 |
|                             |         | W |           |       |       |       |       |       |           |       |
|                             |         | R | 0         | 0     | 0     | 0     | 0     | 0     | BIT 9 MSB | BIT 8 |
| 0x001E                      | ATDDR7H |   | 0         | 0     | 0     | 0     | 0     | 0     | 0         | 0     |
|                             |         | W |           |       |       |       |       |       |           |       |
|                             |         | R | BIT 7     | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1     | BIT 0 |
| 0x001F                      | ATDDR7L |   | BIT 7 MSB | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1     | BIT 0 |
|                             |         | W |           |       |       |       |       |       |           |       |
| = Unimplemented or Reserved |         |   |           |       |       |       |       |       |           |       |

Figure 8-2. ATD Register Summary (Sheet 4 of 4)

### NOTE

Register Address = Module Base Address + Address Offset, where the Module Base Address is defined at the MCU level and the Address Offset is defined at the module level.



#### Chapter 10 Freescale's Scalable Controller Area Network (S12MSCANV2)

In cases of more than one buffer having the same lowest priority, the message buffer with the lower index number wins.

Module Base + 0xXXXD





Read: Anytime when TXEx flag is set (see Section 10.3.2.7, "MSCAN Transmitter Flag Register (CANTFLG)") and the corresponding transmit buffer is selected in CANTBSEL (see Section 10.3.2.11, "MSCAN Transmit Buffer Selection Register (CANTBSEL)").

Write: Anytime when TXEx flag is set (see Section 10.3.2.7, "MSCAN Transmitter Flag Register (CANTFLG)") and the corresponding transmit buffer is selected in CANTBSEL (see Section 10.3.2.11, "MSCAN Transmit Buffer Selection Register (CANTBSEL)").

### 10.3.3.5 Time Stamp Register (TSRH–TSRL)

If the TIME bit is enabled, the MSCAN will write a time stamp to the respective registers in the active transmit or receive buffer right after the EOF of a valid message on the CAN bus (see Section 10.3.2.1, "MSCAN Control Register 0 (CANCTL0)"). In case of a transmission, the CPU can only read the time stamp after the respective transmit buffer has been flagged empty.

The timer value, which is used for stamping, is taken from a free running internal CAN bit clock. A timer overrun is not indicated by the MSCAN. The timer is reset (all bits set to 0) during initialization mode. The CPU can only read the time stamp registers.



Module Base + 0xXXXE



| Field      | Description                                                                                                                                           |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5<br>PCLK5 | Pulse Width Channel 5 Clock Select0 Clock A is the clock source for PWM channel 5.1 Clock SA is the clock source for PWM channel 5.                   |
| 4<br>PCLK4 | Pulse Width Channel 4 Clock Select0 Clock A is the clock source for PWM channel 4.1 Clock SA is the clock source for PWM channel 4.                   |
| 3<br>PCLK3 | Pulse Width Channel 3 Clock Select0 Clock B is the clock source for PWM channel 3.1 Clock SB is the clock source for PWM channel 3.                   |
| 2<br>PCLK2 | Pulse Width Channel 2 Clock Select0 Clock B is the clock source for PWM channel 2.1 Clock SB is the clock source for PWM channel 2.                   |
| 1<br>PCLK1 | Pulse Width Channel 1 Clock Select0 Clock A is the clock source for PWM channel 1.1 Clock SA is the clock source for PWM channel 1.                   |
| 0<br>PCLK0 | Pulse Width Channel 0 Clock Select         0 Clock A is the clock source for PWM channel 0.         1 Clock SA is the clock source for PWM channel 0. |

#### Table 12-4. PWMCLK Field Descriptions

### 12.3.2.4 PWM Prescale Clock Select Register (PWMPRCLK)

This register selects the prescale clock source for clocks A and B independently.

Module Base + 0x0003



#### Figure 12-6. PWM Prescaler Clock Select Register (PWMPRCLK)

Read: anytime

Write: anytime

### NOTE

PCKB2–PCKB0 and PCKA2–PCKA0 register bits can be written anytime. If the clock prescale is changed while a PWM signal is being generated, a truncated or stretched pulse can occur during the transition.



To calculate the output frequency in center aligned output mode for a particular channel, take the selected clock source frequency for the channel (A, B, SA, or SB) and divide it by twice the value in the period register for that channel.

- PWMx frequency = clock (A, B, SA, or SB) / (2\*PWMPERx)
- PWMx duty cycle (high time as a% of period):
  - Polarity = 0 (PPOLx = 0) Duty cycle = [(PWMPERx-PWMDTYx)/PWMPERx] \* 100%
  - Polarity = 1 (PPOLx = 1) Duty cycle = [PWMDTYx / PWMPERx] \* 100%

As an example of a center aligned output, consider the following case:

Clock source = bus clock, where bus clock = 10 MHz (100 ns period) PPOLx = 0 PWMPERx = 4 PWMDTYx = 1 PWMx frequency = 10 MHz/8 = 1.25 MHz PWMx period = 800 ns PWMx duty cycle = 3/4 \*100% = 75%

Shown below is the output waveform generated.



Figure 12-39. PWM Center Aligned Output Example Waveform

## 12.4.2.7 PWM 16-Bit Functions

The PWM timer also has the option of generating 6-channels of 8-bits or 3-channels of 16-bits for greater PWM resolution}. This 16-bit channel option is achieved through the concatenation of two 8-bit channels.

The PWMCTL register contains three control bits, each of which is used to concatenate a pair of PWM channels into one 16-bit channel. Channels 4 and 5 are concatenated with the CON45 bit, channels 2 and 3 are concatenated with the CON23 bit, and channels 0 and 1 are concatenated with the CON01 bit.

### NOTE

Change these bits only when both corresponding channels are disabled.

When channels 4 and 5 are concatenated, channel 4 registers become the high-order bytes of the double byte channel as shown in Figure 12-40. Similarly, when channels 2 and 3 are concatenated, channel 2 registers become the high-order bytes of the double byte channel. When channels 0 and 1 are concatenated, channel 0 registers become the high-order bytes of the double byte channel.



Chapter 13 Serial Communications Interface (S12SCIV2) Block Description

# 13.4 Functional Description

This section provides a complete functional description of the SCI block, detailing the operation of the design from the end user perspective in a number of subsections.

Figure 13-9 shows the structure of the SCI module. The SCI allows full duplex, asynchronous, NRZ serial communication between the CPU and remote devices, including other CPUs. The SCI transmitter and receiver operate independently, although they use the same baud rate generator. The CPU monitors the status of the SCI, writes the data to be transmitted, and processes received data.



Figure 13-9. SCI Block Diagram



### 13.4.5 Single-Wire Operation

Normally, the SCI uses two pins for transmitting and receiving. In single-wire operation, the RXD pin is disconnected from the SCI. The SCI uses the TXD pin for both receiving and transmitting.



Figure 13-22. Single-Wire Operation (LOOPS = 1, RSRC = 1)

Enable single-wire operation by setting the LOOPS bit and the receiver source bit, RSRC, in SCI control register 1 (SCICR1). Setting the LOOPS bit disables the path from the **Rx Input** signal to the receiver. Setting the RSRC bit connects the receiver input to the output of the TXD pin driver. Both the transmitter and receiver must be enabled (TE = 1 and RE = 1). The TXDIR bit (SCISR2[1]) determines whether the TXD pin is going to be used as an input (TXDIR = 0) or an output (TXDIR = 1) in this mode of operation.

### 13.4.6 Loop Operation

In loop operation the transmitter output goes to the receiver input. The **Rx Input** signal is disconnected from the SCI



Figure 13-23. Loop Operation (LOOPS = 1, RSRC = 0)

Enable loop operation by setting the LOOPS bit and clearing the RSRC bit in SCI control register 1 (SCICR1). Setting the LOOPS bit disables the path from the **Rx Input** signal to the receiver. Clearing the RSRC bit connects the transmitter output to the receiver input. Both the transmitter and receiver must be enabled (TE = 1 and RE = 1).

# 13.5 Initialization Information

## 13.5.1 Reset Initialization

The reset state of each individual bit is listed in Section 13.3, "Memory Map and Registers" which details the registers and their bit fields. All special functions or modes which are initialized during or just following reset are described within this section.



## 15.3.2 Register Descriptions

This section consists of register descriptions in address order. Each description includes a standard register diagram with an associated figure number. Details of register bit and field function follow the register diagrams, in bit order.

| Register<br>Name |        | Bit 7  | 6      | 5      | 4      | 3      | 2      | 1     | Bit 0 |
|------------------|--------|--------|--------|--------|--------|--------|--------|-------|-------|
| 0x0000<br>TIOS   | R<br>W | IOS7   | IOS6   | IOS5   | IOS4   | IOS3   | IOS2   | IOS1  | IOS0  |
| 0.0004           | _      |        |        |        |        |        |        |       | -     |
| 0x0001<br>CFORC  | R<br>W | 0      |        |        |        | 0      |        |       | 0     |
|                  | vv     | FUC7   | FUC6   | FUC5   | F0C4   | F0C3   | F002   | FUCT  | FUCU  |
| 0x0002<br>OC7M   | R<br>W | OC7M7  | OC7M6  | OC7M5  | OC7M4  | OC7M3  | OC7M2  | OC7M1 | OC7M0 |
| 0x0003<br>OC7D   | R<br>W | OC7D7  | OC7D6  | OC7D5  | OC7D4  | OC7D3  | OC7D2  | OC7D1 | OC7D0 |
| 0x0004<br>TCNTH  | R<br>W | TCNT15 | TCNT14 | TCNT13 | TCNT12 | TCNT11 | TCNT10 | TCNT9 | TCNT8 |
| 0x0005<br>TCNTL  | R<br>W | TCNT7  | TCNT6  | TCNT5  | TCNT4  | TCNT3  | TCNT2  | TCNT1 | TCNT0 |
| 0x0006<br>TSCR1  | R<br>W | TEN    | TSWAI  | TSFRZ  | TFFCA  | 0      | 0      | 0     | 0     |
| 0x0007<br>TTOV   | R<br>W | TOV7   | TOV6   | TOV5   | TOV4   | TOV3   | TOV2   | TOV1  | TOV0  |
| 0x0008<br>TCTL1  | R<br>W | OM7    | OL7    | OM6    | OL6    | OM5    | OL5    | OM4   | OL4   |
| 0x0009<br>TCTL2  | R<br>W | OM3    | OL3    | OM2    | OL2    | OM1    | OL1    | OM0   | OL0   |
| 0x000A<br>TCTL3  | R<br>W | EDG7B  | EDG7A  | EDG6B  | EDG6A  | EDG5B  | EDG5A  | EDG4B | EDG4A |
| 0x000B<br>TCTL4  | R<br>W | EDG3B  | EDG3A  | EDG2B  | EDG2A  | EDG1B  | EDG1A  | EDG0B | EDG0A |
| 0x000C<br>TIE    | R<br>W | C7I    | C6I    | C5I    | C4I    | C3I    | C2I    | C1I   | C0I   |
|                  |        |        |        |        |        |        |        |       |       |

= Unimplemented or Reserved

#### Figure 15-5. TIM16B8CV1 Register Summary

# 16.2 External Signal Description

Due to the nature of VREG3V3V2 being a voltage regulator providing the chip internal power supply voltages most signals are power supply signals connected to pads.

Table 16-1 shows all signals of VREG3V3V2 associated with pins.

| Name                          | Port                                                         | Function                                     | Reset State | Pull Up |
|-------------------------------|--------------------------------------------------------------|----------------------------------------------|-------------|---------|
| V <sub>DDR</sub>              |                                                              | VREG3V3V2 power input (positive supply)      | _           | —       |
| V <sub>DDA</sub>              |                                                              | VREG3V3V2 quiet input (positive supply)      | _           | _       |
| V <sub>SSA</sub>              | _                                                            | VREG3V3V2 quiet input (ground)               | —           | _       |
| V <sub>DD</sub>               | V <sub>DD</sub> – VREG3V3V2 primary output (positive supply) |                                              | _           | _       |
| V <sub>SS</sub>               | —                                                            | VREG3V3V2 primary output (ground)            | —           | _       |
| V <sub>DDPLL</sub>            | —                                                            | VREG3V3V2 secondary output (positive supply) | _           | _       |
| V <sub>SSPLL</sub>            | V <sub>SSPLL</sub> – VREG3V3V2 secondary output (ground)     |                                              |             |         |
| V <sub>REGEN</sub> (optional) | —                                                            | VREG3V3V2 (Optional) Regulator Enable        | _           | —       |

#### Table 16-1. VREG3V3V2 — Signal Properties

### NOTE

Check device overview chapter for connectivity of the signals.

# 16.2.1 V<sub>DDR</sub> — Regulator Power Input

Signal V<sub>DDR</sub> is the power input of VREG3V3V2. All currents sourced into the regulator loads flow through this pin. A chip external decoupling capacitor (100 nF...220 nF, X7R ceramic) between V<sub>DDR</sub> and V<sub>SSR</sub> can smoothen ripple on V<sub>DDR</sub>.

For entering Shutdown Mode, pin V<sub>DDR</sub> should also be tied to ground on devices without a V<sub>REGEN</sub> pin.

# 16.2.2 V<sub>DDA</sub>, V<sub>SSA</sub> — Regulator Reference Supply

Signals  $V_{DDA}/V_{SSA}$  which are supposed to be relatively quiet are used to supply the analog parts of the regulator. Internal precision reference circuits are supplied from these signals. A chip external decoupling capacitor (100 nF...220 nF, X7R ceramic) between  $V_{DDA}$  and  $V_{SSA}$  can further improve the quality of this supply.



## 19.3.2 Register Descriptions

The Flash module contains a set of 16 control and status registers located between module base + 0x0000 and 0x000F. A summary of the Flash module registers is given in Figure 19-5. Detailed descriptions of each register bit are provided.

| Register<br>Name                 |         | Bit 7                       | 6      | 5      | 4      | 3     | 2      | 1     | Bit 0 |  |  |  |
|----------------------------------|---------|-----------------------------|--------|--------|--------|-------|--------|-------|-------|--|--|--|
| 0x0000<br>FCLKDIV                | R<br>W  | FDIVLD                      | PRDIV8 | FDIV5  | FDIV4  | FDIV3 | FDIV2  | FDIV1 | FDIV0 |  |  |  |
| 0x0001                           | R       | KEYEN1                      | KEYEN0 | NV5    | NV4    | NV3   | NV2    | SEC1  | SEC0  |  |  |  |
| FSEC                             | W       |                             |        |        |        |       |        |       |       |  |  |  |
| 0x0002<br>RESERVED1<br>(1)       | R<br>W  | 0                           | 0      | 0      | 0      | 0     | 0      | 0     | 0     |  |  |  |
| 0x0003<br>FCNFG                  | R<br>W  | CBEIE                       | CCIE   | KEYACC | 0      | 0     | 0      | 0     | 0     |  |  |  |
| 0x0004<br>FPROT                  | R<br>W  | FPOPEN                      | NV6    | FPHDIS | FPHS1  | FPHS0 | FPLDIS | FPLS1 | FPLS0 |  |  |  |
| 0x0005<br>FSTAT                  | R<br>W  | CBEIF                       | CCIF   | PVIOL  | ACCERR | 0     | BLANK  | FAIL  | DONE  |  |  |  |
| 0x0006                           | R       | 0                           | CMDB6  |        | 0      | 0     | CMDB2  | 0     | CMDB0 |  |  |  |
| FCMD                             | W       |                             |        |        |        |       |        |       |       |  |  |  |
| 0x0007                           | R       | 0                           | 0      | 0      | 0      | 0     | 0      | 0     | 0     |  |  |  |
|                                  | vv<br>R |                             |        |        |        |       |        |       |       |  |  |  |
| FADDRHI <sup>1</sup>             | W       | FABHI                       |        |        |        |       |        |       |       |  |  |  |
| 0x0008<br>FADDRHI <sup>1</sup>   | R<br>W  | 0 FABHI                     |        |        |        |       |        |       |       |  |  |  |
| 0x0009<br>FADDRLO <sup>1</sup>   | R<br>W  |                             | FABLO  |        |        |       |        |       |       |  |  |  |
| 0x000A<br>FDATAHI <sup>1</sup>   | R<br>W  | FDHI                        |        |        |        |       |        |       |       |  |  |  |
| 0x000B<br>FDATAL O <sup>1</sup>  | R<br>W  | FDLO                        |        |        |        |       |        |       |       |  |  |  |
| 0x000C                           | R       | 0                           | 0      | 0      | 0      | 0     | 0      | 0     | 0     |  |  |  |
| RESERVED3 <sup>1</sup>           | w       |                             |        |        |        |       |        |       |       |  |  |  |
| 0x000D                           | R       | 0                           | 0      | 0      | 0      | 0     | 0      | 0     | 0     |  |  |  |
| 0x000E                           | R       | 0                           | 0      | 0      | 0      | 0     | 0      | 0     | 0     |  |  |  |
| RESERVED5 <sup>1</sup>           | W       |                             |        |        |        |       |        |       |       |  |  |  |
| 0x000F<br>RESERVED6 <sup>1</sup> | R<br>W  | 0                           | 0      | 0      | 0      | 0     | 0      | 0     | 0     |  |  |  |
|                                  |         | = Unimplemented or Reserved |        |        |        |       |        |       |       |  |  |  |

Figure 19-5. Flash Register Summary

1. Intended for factory test purposes only.



then FCLKDIV register bits PRDIV8 and FDIV[5:0] are to be set as described in Figure 21-21.

For example, if the oscillator clock frequency is 950 kHz and the bus clock is 10 MHz, FCLKDIV bits FDIV[5:0] should be set to 4 (000100) and bit PRDIV8 set to 0. The resulting FCLK is then 190 kHz. As a result, the Flash algorithm timings are increased over optimum target by:

 $(200 - 190)/200 \times 100 = 5\%$ 

Command execution time will increase proportionally with the period of FCLK.

#### CAUTION

Because of the impact of clock synchronization on the accuracy of the functional timings, programming or erasing the Flash array cannot be performed if the bus clock runs at less than 1 MHz. Programming or erasing the Flash array with an input clock < 150 kHz should be avoided. Setting FCLKDIV to a value such that FCLK < 150 kHz can destroy the Flash array due to overstress. Setting FCLKDIV to a value such that (1/FCLK + Tbus) <  $5\mu$ s can result in incomplete programming or erasure of the Flash array cells.

If the FCLKDIV register is written, the bit FDIVLD is set automatically. If the FDIVLD bit is 0, the FCLKDIV register has not been written since the last reset. If the FCLKDIV register has not been written to, the Flash command loaded during a command write sequence will not execute and the ACCERR flag in the FSTAT register will set.



# Appendix A Electrical Characteristics

# A.1 General

### NOTE

The electrical characteristics given in this section are preliminary and should be used as a guide only. Values cannot be guaranteed by Freescale and are subject to change without notice.

The parts are specified and tested over the 5V and 3.3V ranges. For the intermediate range, generally the electrical specifications for the 3.3V range apply, but the parts are not tested in production test in the intermediate range.

This supplement contains the most accurate electrical information for the MC9S12C-Family / MC9S12GC-Family microcontrollers available at the time of publication. The information should be considered **PRELIMINARY** and is subject to change.

This introduction is intended to give an overview on several common topics like power supply, current injection etc.

# A.1.1 Parameter Classification

The electrical parameters shown in this supplement are guaranteed by various methods. To give the customer a better understanding the following classification is used and the parameters are tagged accordingly in the tables where appropriate.

### NOTE

This classification will be added at a later release of the specification

- P: Those parameters are guaranteed during production testing on each individual device.
- C: Those parameters are achieved by the design characterization by measuring a statistically relevant sample size across process variations. They are regularly verified by production monitors.
- T: Those parameters are achieved by design characterization on a small sample size from typical devices. All values shown in the typical column are within this category.
- D: Those parameters are derived mainly from simulations.

# A.1.2 Power Supply

The MC9S12C-Family / MC9S12GC-Family and MC9S12GC Family members utilize several pins to supply power to the I/O ports, A/D converter, oscillator and PLL as well as the internal logic.

The  $V_{DDA}$ ,  $V_{SSA}$  pair supplies the A/D converter.

The V<sub>DDX</sub>, V<sub>SSX</sub> pair supplies the I/O pins

The  $V_{DDR}$ ,  $V_{SSR}$  pair supplies the internal voltage regulator.



| Condi | Conditions are V <sub>DDX</sub> =3.3V +/-10%, Temperature from -40°C to +140°C, unless otherwise noted |                                                                                                          |                                      |                        |     |                        |      |  |  |  |
|-------|--------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------|-----|------------------------|------|--|--|--|
| Num   | С                                                                                                      | Rating                                                                                                   |                                      | Min                    | Тур | Мах                    | Unit |  |  |  |
| 1     | Р                                                                                                      | Input High Voltage                                                                                       | V <sub>IH</sub>                      | 0.65*V <sub>DD5</sub>  |     | _                      | V    |  |  |  |
|       | Т                                                                                                      | Input High Voltage                                                                                       | V <sub>IH</sub>                      | —                      |     | V <sub>DD5</sub> + 0.3 | V    |  |  |  |
| 2     | Р                                                                                                      | Input Low Voltage                                                                                        | V <sub>IL</sub>                      | —                      |     | 0.35*V <sub>DD5</sub>  | V    |  |  |  |
|       | Т                                                                                                      | Input Low Voltage                                                                                        | V <sub>IL</sub>                      | V <sub>SS5</sub> – 0.3 |     | —                      | V    |  |  |  |
| 3     | С                                                                                                      | Input Hysteresis                                                                                         | V <sub>HYS</sub>                     | —                      | 250 | _                      | mV   |  |  |  |
| 4     | Р                                                                                                      | Input Leakage Current (pins in high ohmic input mode) <sup>(1)</sup><br>$V_{in} = V_{DD5}$ or $V_{SS5}$  | I <sub>.in</sub>                     | -1                     |     | 1                      | μA   |  |  |  |
| 5     | с                                                                                                      | Output High Voltage (pins in output mode)<br>Partial Drive $I_{OH} = -0.75$ mA                           | V <sub>OH</sub>                      | V <sub>DD5</sub> – 0.4 | _   | _                      | V    |  |  |  |
| 6     | Р                                                                                                      | Output High Voltage (pins in output mode)<br>Full Drive I <sub>OH</sub> = -4mA                           | V <sub>OH</sub>                      | V <sub>DD5</sub> – 0.4 | _   | _                      | V    |  |  |  |
| 7     | с                                                                                                      | Output Low Voltage (pins in output mode)<br>Partial Drive I <sub>OL</sub> = +0.9mA                       | V <sub>OL</sub>                      | _                      | _   | 0.4                    | V    |  |  |  |
| 8     | Р                                                                                                      | Output Low Voltage (pins in output mode)<br>Full Drive I <sub>OL</sub> = +4.75mA                         | V <sub>OL</sub>                      | _                      | _   | 0.4                    | V    |  |  |  |
| 9     | Р                                                                                                      | Internal Pull Up Device Current, tested at V <sub>IL</sub> Max.                                          | I <sub>PUL</sub>                     | —                      |     | -60                    | μA   |  |  |  |
| 10    | С                                                                                                      | Internal Pull Up Device Current, tested at V <sub>IH</sub> Min.                                          | I <sub>PUH</sub>                     | -6                     |     | _                      | μA   |  |  |  |
| 11    | Ρ                                                                                                      | Internal Pull Down Device Current, tested at V <sub>IH</sub> Min.                                        | I <sub>PDH</sub>                     | —                      | -   | 60                     | μA   |  |  |  |
| 12    | С                                                                                                      | Internal Pull Down Device Current, tested at V <sub>IL</sub> Max.                                        | I <sub>PDL</sub>                     | 6                      | _   | —                      | μA   |  |  |  |
| 11    | D                                                                                                      | Input Capacitance                                                                                        | C <sub>in</sub>                      | —                      | 7   | —                      | πΦ   |  |  |  |
| 12    | т                                                                                                      | Injection current <sup>(2)</sup><br>Single Pin limit<br>Total Device Limit. Sum of all injected currents | I <sub>ICS</sub><br>I <sub>ICP</sub> | -2.5<br>-25            | _   | 2.5<br>25              | μΑ   |  |  |  |
| 13    | Р                                                                                                      | Port P, J Interrupt Input Pulse filtered <sup>(3)</sup>                                                  | t <sub>PIGN</sub>                    | —                      | _   | 3                      | μs   |  |  |  |
| 14    | Р                                                                                                      | Port P, J Interrupt Input Pulse passed <sup>3</sup>                                                      | t <sub>PVAL</sub>                    | 10                     | _   | _                      | μs   |  |  |  |

#### Table A-7. 3.3V I/O Characteristics

1. Maximum leakage current occurs at maximum operating temperature. Current decreases by approximately one-half for each 8 C to 12 C in the temperature range from 50 C to 125 C

2. Refer to Section A.1.4, "Current Injection", for more details

3. Parameter only applies in STOP or Pseudo STOP mode.

# A.1.10 Supply Currents

This section describes the current consumption characteristics of the device as well as the conditions for the measurements.

### A.1.10.1 Measurement Conditions

All measurements are without output loads. Unless otherwise noted the currents are measured in single chip mode, internal voltage regulator enabled and at 25MHz bus frequency using a 4MHz oscillator.



**Appendix A Electrical Characteristics** 

## A.4.1.3 SRAM Data Retention

Provided an appropriate external reset signal is applied to the MCU, preventing the CPU from executing code when  $V_{DD5}$  is out of specification limits, the SRAM contents integrity is guaranteed if after the reset the PORF bit in the CRG Flags Register has not been set.

## A.4.1.4 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.4.1.5 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.4.1.6 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. In Pseudo Stop Mode the voltage regulator is switched to reduced performance mode to reduce power consumption. The returning out of pseudo stop to full performance takes  $t_{vup}$ . The controller can be woken up by internal or external interrupts. After  $t_{wrs}$  in Wait or  $t_{vup} + t_{wrs}$  in Pseudo Stop the CPU starts fetching the interrupt vector.

## A.4.2 Oscillator

The device features an internal Colpitts and Pierce oscillator. The selection of Colpitts oscillator or Pierce oscillator/external clock depends on the XCLKS signal which is sampled during reset. Pierce oscillator/external clock mode allows the input of a square wave. Before asserting the oscillator to the internal system clocks the quality of the oscillation is checked for each start from either power-on, STOP or oscillator fail.  $t_{CQOUT}$  specifies the maximum time before switching to the internal self clock mode after POR or STOP if a proper oscillation is not detected. The quality check also determines the minimum oscillator start-up time  $t_{UPOSC}$ . The device also features a clock monitor. A Clock Monitor Failure is asserted if the frequency of the incoming clock signal is below the Assert Frequency  $f_{CMFA}$ .