

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             | CPU12                                                                  |
| Core Size                  | 16-Bit                                                                 |
| Speed                      | 8MHz                                                                   |
| Connectivity               | SCI, SPI                                                               |
| Peripherals                | POR, PWM, WDT                                                          |
| Number of I/O              | 63                                                                     |
| Program Memory Size        | 32KB (32K x 8)                                                         |
| Program Memory Type        | FLASH                                                                  |
| EEPROM Size                | 768 x 8                                                                |
| RAM Size                   | 1K x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                            |
| Data Converters            | A/D 8x10b                                                              |
| Oscillator Type            | External                                                               |
| 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/xc912bc32cfue8 |

Email: info@E-XFL.COM

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



Chapter 11 Pulse-Width Modulator (PWM)

| 11.1    | Introduction                                         | 125 |
|---------|------------------------------------------------------|-----|
| 11.2    | PWM Register Descriptions                            | 128 |
| 11.2.1  | PWM Clocks and Concatenate Register                  | 128 |
| 11.2.2  | PWM Clock Select and Polarity Register               | 129 |
| 11.2.3  | PWM Enable Register                                  | 130 |
| 11.2.4  | PWM Prescale Counter                                 | 131 |
| 11.2.5  | PWM Scale Register 0                                 | 131 |
| 11.2.6  | PWM Scale Counter 0 Value                            | 131 |
| 11.2.7  | PWM Scale Register 1                                 | 132 |
| 11.2.8  | PWM Scale Counter 1 Value                            | 132 |
| 11.2.9  | PWM Channel Counters 0–3                             | 133 |
| 11.2.10 | PWM Channel Period Registers 0–3                     | 134 |
| 11.2.11 | PWM Channel Duty Registers 0–3                       | 135 |
| 11.2.12 | 2 PWM Control Register                               | 136 |
| 11.2.13 | 3 PWM Special Mode Register                          | 137 |
| 11.2.14 | Port P Data Register                                 | 137 |
| 11.2.15 | 5 Port P Data Direction Register                     | 138 |
| 11.3    | PWM Boundary Cases.                                  | 138 |
| 11.4    | Using the Output Compare 7 Feature to Generate a PWM | 138 |
| 11.4.1  | PWM Period Calculation                               | 139 |
| 11.4.2  | Equipment                                            | 139 |
| 11.4.3  | Code Listing                                         | 140 |

## Chapter 12 Standard Timer (TIM)

| 12.1    | Introduction                                       | 141 |
|---------|----------------------------------------------------|-----|
| 12.2    | Timer Registers                                    | 141 |
| 12.2.1  | Timer Input Capture/Output Compare Select Register | 141 |
| 12.3    | Block Diagram                                      | 142 |
| 12.3.1  | Timer Compare Force Register                       | 143 |
| 12.3.2  | Output Compare 7 Mask Register                     | 143 |
| 12.3.3  | Output Compare 7 Data Register                     | 143 |
| 12.3.4  | Timer Count Register                               | 144 |
| 12.3.5  | Timer System Control Register                      | 144 |
| 12.3.6  | Timer Control Registers                            | 145 |
| 12.3.7  | Timer Interrupt Mask Registers                     | 146 |
| 12.3.8  | Timer Interrupt Flag Registers                     | 148 |
| 12.3.9  | Timer Input Capture/Output Compare Registers       | 149 |
| 12.3.10 | Pulse Accumulator Control Register                 | 151 |
| 12.3.11 | Pulse Accumulator Flag Register                    | 153 |
| 12.3.12 | 2 16-Bit Pulse Accumulator Count Register          | 153 |
| 12.3.13 | 3 Timer Test Register                              | 154 |
| 12.3.14 | Timer Port Data Register                           | 154 |
| 12.3.15 | 5 Data Direction Register for Timer Port           | 155 |
| 12.4    | Timer Operation in Modes                           | 155 |



# Chapter 1 General Description

## 1.1 Introduction

The MC68HC912B32, MC68HC12BE32 and MC68HC(9)12BC32, are 16-bit microcontroller units (MCUs) composed of standard on-chip peripherals. The multiplexed external bus can also operate in an 8-bit narrow mode for interfacing with single 8-bit wide memory in lower-cost systems. There is a slight feature set difference between the four pin-for-pin compatible devices as shown in Table 1-1.

| Features                                                                        | MC68HC912B32 | MC68HC12BE32 | MC68HC912BC32 | MC68HC12BC32 |
|---------------------------------------------------------------------------------|--------------|--------------|---------------|--------------|
| CPU12                                                                           | Х            | Х            | Х             | Х            |
| Multiplexed bus                                                                 | х            | х            | х             | х            |
| 32-Kbyte FLASH electrically erasable,<br>programmable read-only memory (EEPROM) | Х            |              | Х             |              |
| 32-Kbyte read-only memory (ROM)                                                 |              | х            |               | х            |
| 768-byte EEPROM                                                                 | Х            | Х            | Х             | х            |
| 1-Kbyte random-access memory (RAM)                                              | Х            | Х            | Х             | х            |
| Analog-to-digital (A/D) converter                                               | х            | х            | х             | х            |
| Standard timer module (TIM)                                                     | х            |              | х             | х            |
| Enhanced capture timer (ECT)                                                    |              | Х            |               |              |
| Pulse-width modulator (PWM)                                                     | х            | х            | х             | х            |
| Asynchronous serial communications interface (SCII)                             | х            | х            | х             | х            |
| Synchronous serial peripheral interface (SPI)                                   | х            | х            | Х             | х            |
| J1850 byte data link communication (BDLC)                                       | х            | х            |               |              |
| Controller area network module (CAN)                                            |              |              | Х             | Х            |
| Computer operating properly (COP) watchdog timer                                | х            | х            | х             | х            |
| Slow mode clock divider                                                         | х            | х            | Х             | х            |
| 80-pin quad flat pack (QFP)                                                     | х            | х            | Х             | х            |
| Single-wire background debug mode (BDM)                                         | Х            | Х            | Х             | Х            |

## Table 1-1. M68HC12B Series Feature Set Comparisons



selectable (interrupt control register, INTCR). IRQ is always configured to level-sensitive triggering at reset. When the MCU is reset, the IRQ function is masked in the condition code register.

This pin is always an input and can always be read. In special modes, it can be used to apply external EEPROM V<sub>PP</sub> in support of EEPROM testing. External V<sub>PP</sub> is not needed for normal EEPROM program and erase cycles. Because the IRQ pin is also used as an EEPROM programming voltage pin, there is an internal resistive pullup on the pin.

## 1.6.3.5 XIRQ

XIRQ is the non-maskable external interrupt pin. It provides a means of requesting a non-maskable interrupt after reset initialization. During reset, the X bit in the condition code register (CCR) is set and any interrupt is masked until MCU software enables it. Because the XIRQ input is level sensitive, it can be connected to a multiple-source wired-OR network. This pin is always an input and can always be read. There is an active pullup on this pin while in reset and immediately out of reset. The pullup can be turned off by clearing the PUPE bit in the pullup control register (PUCR). XIRQ is often used as a power loss detect interrupt.

When  $\overline{\text{XIRQ}}$  or  $\overline{\text{IRQ}}$  are used with multiple interrupt sources ( $\overline{\text{IRQ}}$  must be configured for level-sensitive operation if there is more than one source of  $\overline{\text{IRQ}}$  interrupt), each source must drive the interrupt input with an open-drain type of driver to avoid contention between outputs. There must also be an interlock mechanism at each interrupt source so that the source holds the interrupt line low until the MCU recognizes and acknowledges the interrupt request. If the interrupt line is held low, the MCU recognizes another interrupt as soon as the interrupt mask bit in the MCU is cleared, normally upon return from an interrupt.

## 1.6.3.6 SMODN, MODA, and MODB

SMODN, MODA, and MODB are the mode-select signals. Their state during reset determines the MCU operating mode. After reset, MODA and MODB can be configured as instruction queue tracking signals IPIPE0 and IPIPE1. MODA and MODB have active pulldowns during reset.

The SMODN pin can be used as BKGD or TAGHI after reset.

## NOTE

To aid in mode selection, refer to Figure 1-8 and Figure 1-9. These schematics are provided as suggestive layouts only.

## 1.6.3.7 BKGD

BKGD is the single-wire background mode pin. It receives and transmits serial background debugging commands. A special self-timing protocol is used. The BKGD pin has an active pullup when configured as input; BKGD has no pullup control. Currently, the tool connection configuration shown in Figure 1-7 is used.



Figure 1-7. BDM Tool Connector



#### General Description

## 1.6.4.4 Port DLC

The MC68HC912B32 and MC68HC12BE32 contain the port DLC.

Byte data link communications (BDLC) pins can be configured as general-purpose I/O port DLC. When BDLC functions are not enabled, the port has seven general-purpose I/O pins, PDLC6–PDLC0. The port DLC control register (DLCSCR) controls port DLC function. The BDLC function, enabled with the BDLCEN bit, takes precedence over other port functions.

The port DLC data direction register (DDRDLC) determines whether each port DLC pin is an input or output. Setting a bit in DDRDLC makes the corresponding pin in port DLC an output; clearing a bit makes the corresponding pin an input. After reset, port DLC pins are configured as inputs.

When the PUPDLC bit in the DLCSCR register is set, all port DLC input pins are pulled up internally by an active pullup device.

Setting the RDPDLC bit in register DLCSCR causes all port DLC outputs to have reduced drive level. Levels are at normal drive capability after reset. RDPDLC can be written anytime after reset. Refer to Chapter 15 Byte Data Link Communications (BDLC).

## 1.6.4.5 Port CAN

The MC68HC(9)12BC32 contains the port CAN.

The port CAN has five general-purpose I/O pins, PCAN[6:2]. The msCAN12 receive pin, RxCAN, and transmit pin, TxCAN, cannot be configured as general-purpose I/O on port CAN.

The msCAN data direction register (DDRCAN) determines whether each port CAN pin PCAN[6:2] is an input or output. Setting a bit in DDRCAN makes the corresponding pin in port CAN an output; clearing a bit makes the corresponding pin an input. After reset, port CAN pins PCAN[6:2] are configured as inputs.

When a read to the port CAN is performed, the value read from the most significant bit (MSB) depends on the MSB, PCAN7, of the port CAN data register, PORTCAN, and the MSB of DDRCAN: it is 0 if DDRCAN7 = 0 and is PCAN7 if DDRCAN7 = 1.

When the PEUCAN bit in the port CAN control register (PCTLCAN) is set, port CAN input pins PCAN[6:2] are pulled up internally by an active pullup device.

Setting the RDRCAN bit in register PCTLCAN causes the port CAN outputs PCAN[6:2] to have reduced drive level. Levels are at normal drive capability after reset. RDRCAN can be written anytime after reset. Refer to Chapter 16 msCAN12 Controller.

## 1.6.4.6 Port AD

Port AD provides input to the analog-to-digital subsystem and general-purpose input. When analog-to-digital functions are not enabled, the port has eight general-purpose input pins, PAD7–PAD0. The ADPU bit in the ATD control register 2 (ATDCTL2) enables the A/D function.

Port AD pins are inputs; no data direction register is associated with this port. The port has no resistive input loads and no reduced drive controls. Refer to Chapter 17 Analog-to-Digital Converter (ATD).



**Clock Selection and Generation** 



Notes:

Driven by slow clock divider in wait mode. Drives on-chip peripherals except BDLC and timer.
Remains at oscillator divided by 2 rate in wait mode. Drives BDLC and timer.

### Figure 10-4. Internal Clock Relationships in Wait Mode



**Clock Generation Module (CGM)** 

## 10.7.2 Real-Time Interrupt Control Register



## Figure 10-6. Real-Time Interrupt Control Register (RTICTL)

#### Read: Anytime

Write: Varies on a bit-by-bit basis

## **RTIE** — Real-Time Interrupt Enable Bit

- Write anytime.
  - 0 = Interrupt requests from RTI are disabled.
  - 1 = Interrupt is requested when RTI is set.

### RSWAI — RTI and COP Stop While in Wait Bit

Write once in normal modes, anytime in special modes.

- 0 = Allows the RTI and COP to continue running in wait
- 1 = Disables both the RTI and COP when the part goes into wait

#### **RSBCK** — **RTI** and **COP** Stop While in Background Debug Mode Bit

Write once in normal modes, anytime in special modes.

- 0 = Allows the RTI and COP to continue running while in background mode
- 1 = Disables RTI and COP when the part is in background mode (useful for emulation)

#### **RTBYP** — Real-Time Interrupt Divider Chain Bypass Bit

Write is not allowed in normal modes, anytime in special modes.

- 0 = Divider chain functions normally.
- 1 = Divider chain is bypassed, allows faster testing. The divider chain is normally P divided by 2<sup>13</sup>, when bypass becomes P divided by 4.

#### RTR2, RTR1, and RTR0 — Real-Time Interrupt Rate Select Bits

#### Write anytime.

Rate select for real-time interrupt. The E clock is used for this module.

| Table 10-3. | Real-Time | Interrupt Rates | 3 |
|-------------|-----------|-----------------|---|
|-------------|-----------|-----------------|---|

| RTR2 | RTR1 | RTR0 | Divide E By:    | Timeout Period<br>E = 4.0 MHz | Timeout Period<br>E = 8.0 MHz |
|------|------|------|-----------------|-------------------------------|-------------------------------|
| 0    | 0    | 0    | OFF             | OFF                           | OFF                           |
| 0    | 0    | 1    | 2 <sup>13</sup> | 2.048 ms                      | 1.024 ms                      |
| 0    | 1    | 0    | 2 <sup>14</sup> | 4.096 ms                      | 2.048 ms                      |
| 0    | 1    | 1    | 2 <sup>15</sup> | 8.196 ms                      | 4.096 ms                      |
| 1    | 0    | 0    | 2 <sup>16</sup> | 16.384 ms                     | 8.196 ms                      |
| 1    | 0    | 1    | 2 <sup>17</sup> | 32.768 ms                     | 16.384 ms                     |
| 1    | 1    | 0    | 2 <sup>18</sup> | 65.536 ms                     | 32.768 ms                     |
| 1    | 1    | 1    | 2 <sup>19</sup> | 131.72 ms                     | 65.536 ms                     |





## **10.8 Clock Divider Chains**

Figure 10-10, Figure 10-11, Figure 10-12, and Figure 10-13 summarize the clock divider chains for these peripherals:

- SCI Serial peripheral interface
- BDLC Byte data link communications
- RTI Real-time interrupt
- COP Computer operating properly
- TIM Standard timer module
- ECT Enhanced capture timer
- SPI Serial peripheral interface
- ATD Analog-to-digital converter
- BDM Background debug mode



Figure 10-10. Clock Chain for SCI, BDLC, RTI, and COP



## C7I–C0I — Input Capture/Output Compare x Interrupt Enable Bits





Read: Anytime

Write: Anytime

## TOI — Timer Overflow Interrupt Enable Bit

- 0 = Interrupt inhibited
- 1 = Hardware interrupt requested when TOF flag set

## PUPT — Timer Pullup Resistor Enable Bit

This enable bit controls pullup resistors on the timer port pins when the pins are configured as inputs.

- 0 = Disable pullup resistor function
- 1 = Enable pullup resistor function

### **RDPT** — Timer Drive Reduction Bit

This bit reduces the effective output driver size which can reduce power supply current and generated noise depending upon pin loading.

0 = Normal output drive capability

1 = Enable output drive reduction function

## TCRE — Timer Counter Reset Enable Bit

This bit allows the timer counter to be reset by a successful output compare 7 event.

0 = Counter reset inhibited and counter free runs

1 = Counter reset by a successful output compare 7

If TC7 = \$0000 and TCRE = 1, TCNT stays at \$0000 continuously. If TC7 = \$FFFF and TCRE = 1, TOF never gets set even though TCNT counts from \$0000 through \$FFFF.

#### PR2, PR1, and PR0 — Timer Prescaler Select Bits

These three bits specify the number of ÷2 stages that are to be inserted between the module clock and the timer counter. See Table 12-3.

| PR2 | PR1 | PR0 | Prescale Factor |
|-----|-----|-----|-----------------|
| 0   | 0   | 0   | 1               |
| 0   | 0   | 1   | 2               |
| 0   | 1   | 0   | 4               |
| 0   | 1   | 1   | 8               |
| 1   | 0   | 0   | 16              |
| 1   | 0   | 1   | 32              |
| 1   | 1   | 0   | Reserved        |
| 1   | 1   | 1   | Reserved        |

| <b>Fable 12-3</b> . | Prescaler | Selection |
|---------------------|-----------|-----------|
|---------------------|-----------|-----------|

The newly selected prescale factor will not take effect until the next synchronized edge where all prescale counter stages equal 0.



**Timer Registers** 



Figure 13-4. 16-Bit Pulse Accumulators Block Diagram

#### **Timer Registers**







Figure 13-20. Main Timer Interrupt Flag 2 (TFLG2)

Read: Anytime

Write: Used in clearing mechanism (set bits cause corresponding bits to be cleared). Any access to TCNT will clear the TFLG2 register, if the TFFCA bit in the TSCR register is set.

TFLG2 indicates when interrupt conditions have occurred. To clear a bit in the flag register, set the bit to 1.

#### **TOF** — Timer Overflow Flag

TOF is set when the 16-bit free-running timer overflows from \$FFFF to \$0000. This bit is cleared automatically by a write to the TFLG2 register with bit 7 set. See the explanation of the TCRE control bit in 13.4.8 Timer Interrupt Mask Registers.)

## 13.4.10 Timer Input Capture/Output Compare Registers



Figure 13-21. Timer Input Capture/Output Compare Register 0 (TC0)



Serial Interface

### **RSRC** — Receiver Source Bit

When LOOPS = 1, the RSRC bit determines the internal feedback path for the receiver.

- 0 = Receiver input connected to the transmitter internally (not TXD pin)
- 1 = Receiver input connected to the TXD pin

## M — Mode Bit (select character format)

0 = One start, eight data, one stop bit

1 = One start, eight data, ninth data, one stop bit

## WAKE — Wakeup by Address Mark/Idle Bit

0 = Wakeup by IDLE line recognition

1 = Wakeup by address mark (last data bit set)

## ILT — Idle Line Type Bit

This bit determines which of two types of idle line detection is used by the SCI receiver.

- 0 = Short idle line mode enabled
- 1 = Long idle line mode detected

In short mode, the SCI circuitry begins counting 1s in the search for the idle line condition immediately after the start bit. This means that the stop bit and any bits that were 1s before the stop bit could be counted in that string of 1s, resulting in earlier recognition of an idle line.

In long mode, the SCI circuitry does not begin counting 1s in the search for the idle line condition until a stop bit is received. Therefore, the last byte's stop bit and preceding 1 bits do not affect how quickly an idle line condition can be detected.

### PE — Parity Enable Bit

0 = Parity disabled

1 = Parity enabled

## PT — Parity Type Bit

If parity is enabled, this bit determines even or odd parity for both the receiver and the transmitter. An even number of 1s in the data character causes the parity bit to be 0 and an odd number of 1s causes the parity bit to be 1.

0 = Even parity selected

1 = Odd parity selected





#### **OR** — Overrun Error Flag

New byte is ready to be transferred from the receive shift register to the receive data register and the receive data register is already full (RDRF bit is set). Data transfer is inhibited until this bit is cleared.

- 0 = No overrun
- 1 = Overrun detected

### NF — Noise Error Flag

Set during the same cycle as the RDRF bit but not set in the case of an overrun (OR).

0 = Unanimous decision

1 = Noise on a valid start bit, any of the data bits, or on the stop bit

#### **FE** — Framing Error Flag

Set when a 0 is detected where a stop bit was expected. Clear the FE flag by reading SC0SR1 with FE set and then reading SC0DR.

0 =Stop bit detected

1 = Zero detected rather than a stop bit

#### PF — Parity Error Flag

Indicates if received data's parity matches parity bit. This feature is active only when parity is enabled. The type of parity tested for is determined by the PT (parity type) bit in SC0CR1.

0 = Parity correct

1 = Incorrect parity detected

#### 14.2.3.5 SCI Status Register 2



Figure 14-8. SCI Status Register 2 (SC0SR2)

#### Read: Anytime

Write: Has no meaning or effect

#### **RAF** — Receiver Active Flag

This bit is controlled by the receiver front end. It is set during the RT1 time period of the start bit search. It is cleared when an idle state is detected or when the receiver circuitry detects a false start bit (generally due to noise or baud rate mismatch).

0 =Character is not being received.

1 = Character is being received.



Byte Data Link Communications (BDLC)



Figure 15-1. BDLC Block Diagram

## 15.4 BDLC Operating Modes

The BDLC has five main modes of operation which interact with the power supplies, pins, and rest of the MCU as shown in Figure 15-2.



Figure 15-2. BDLC Operating Modes State Diagram





Figure 15-9. J1850 VPW Received BREAK Symbol Times

## 15.7.4.11 Valid BREAK Symbol

In Figure 15-9, if the next active-to-passive received transition does not occur until after **E**, the current symbol is considered a valid BREAK symbol. A BREAK symbol should be followed by a start-of-frame (SOF) symbol beginning the next message to be transmitted onto the J1850 bus. See 15.7.2 J1850 Frame Format for BDLC response to BREAK symbols.

## 15.7.5 Message Arbitration

Message arbitration on the J1850 bus is accomplished in a non-destructive manner, allowing the message with the highest priority to be transmitted, while any transmitters which lose arbitration simply stop transmitting and wait for an idle bus to begin transmitting again.

If the BDLC wants to transmit onto the J1850 bus, but detects that another message is in progress, it waits until the bus is idle. However, if multiple nodes begin to transmit in the same synchronization window, message arbitration occurs beginning with the first bit after the SOF symbol and continues with each bit thereafter. If a write to the BDR (for instance, to initiate transmission) occurred on or before 104 • t<sub>BDLC</sub> from the received rising edge, then the BDLC transmits and arbitrates for the bus. If a CPU write to the BDR occurred after

104 • t<sub>BDLC</sub> from the detection of the rising edge, then the BDLC does not transmit, but waits for the next IFS period to expire before attempting to transmit the byte.

The variable pulse-width modulation (VPW) symbols and J1850 bus electrical characteristics are chosen carefully so that a logic 0 (active or passive type) always dominates over a logic 1 (active or passive type) simultaneously transmitted. Hence, logic 0s are said to be dominant and logic 1s are said to be recessive.

When a node detects a dominant bit on BDRxD when it transmitted a recessive bit, it loses arbitration and immediately stops transmitting. This is known as bitwise arbitration (see Figure 15-10).

Since a logic 0 dominates a logic 1, the message with the lowest value has the highest priority and always wins arbitration. For instance, a message with priority 000 wins arbitration over a message with priority 011.

This method of arbitration works no matter how many bits of priority encoding are contained in the message.

During arbitration, or even throughout the transmitting message, when an opposite bit is detected, transmission is stopped immediately unless it occurs on the eighth bit of a byte. In this case, the BDLC automatically appends up to two extra logic 1 bits and then stops transmitting. These two extra bits are arbitrated normally and thus do not interfere with another message. The second logic 1 bit is not sent if



#### msCAN12 Controller

- 2. Four identifier acceptance filters, each to be applied to:
  - a. 11 bits of the identifier and the RTR bit of CAN 2.0A messages, or
  - b. 14 most significant bits of the identifier of CAN 2.0B messages

Figure 16-4 shows how the first 32-bit filter bank (CIDAR0–CIDAR3, CIDMR0–CIDMR3) produces filter 0 and 1 hit. Similarly, the second filter bank (CIDAR4–CUIDAR7, CIDMR4–CIDMR7) produces filter 2 and three hits.



## Figure 16-4. 16-Bit Maskable Acceptance Filters

- 3. Eight identifier acceptance filters, each to be applied to the first eight bits of the identifier. This mode implements eight independent filters for the first eight bits of a CAN 2.0A compliant standard identifier or of a CAN 2.0B compliant extended identifier. Figure 16-5 shows how the first 32-bit filter bank (CIDAR0–CIDAR3, CIDMR0–CIDMR3) produces filter 0 to three hits. Similarly, the second filter bank (CIDAR4–CUIDAR7, CIDMR4–CIDMR7) produces filter 4 to seven hits.
- 4. Closed filter. No CAN message will be copied into the foreground buffer RxFG, and the RXF flag will never be set.





## 16.10 Memory Map

The msCAN12 occupies 128 bytes in the CPU12 memory space. The background receive buffer can be read only in test mode.

| CONTROL REGISTERS        |
|--------------------------|
| 9 BYTES                  |
| RESERVED                 |
| 5 BYTES                  |
| ERROR COUNTERS           |
| 2 BYTES                  |
| IDENTIFIER FILTER        |
| 16 BYTES                 |
| RESERVED                 |
| 29 BYTES                 |
| PORT CAN REGISTERS       |
| 3 BYTES                  |
|                          |
| RECEIVE BOFFER (RXFG)    |
|                          |
| THANSIVIT BUFFER 0 (120) |
|                          |
| HANSIVIII BUFFER I (IXI) |
|                          |
| INANOWII DUFFEN Z (182)  |
|                          |

Figure 16-9. msCAN12 Memory Map

## 16.11 Programmer's Model of Message Storage

This subsection details the organization of the receive and transmit message buffers and the associated control registers.

## 16.11.1 Message Buffer Organization

Figure 16-10 shows the organization of a single message buffer. For reasons of programmer interface simplification, the receive and transmit message buffers have the same register organization. Each message buffer allocates 16 bytes in the memory map containing:

- 13-byte data structure which includes an identifier section (IDRn), a data section (DSRn), and the data length register (DLR)
- Transmit buffer priority register (TBPR) which is only applicable for transmit buffers. See 16.11.5 Transmit Buffer Priority Register
- Two unused bytes

All bits of the 13-byte data structure are undefined out of reset.

## NOTE

The receive buffer can be read anytime but cannot be written. The transmit buffers can be read or written anytime.

#### msCAN12 Controller

| Address: | \$0114  |           |            |             |            |            |         |       |
|----------|---------|-----------|------------|-------------|------------|------------|---------|-------|
|          | Bit 7   | 6         | 5          | 4           | 3          | 2          | 1       | Bit 0 |
| Read:    | AM7     | AM6       | AM5        | AM4         | AM3        | AM2        | AM1     | AM0   |
| Write:   |         |           |            |             |            |            |         |       |
| Reset:   |         |           |            | Unaffecte   | d by reset |            |         |       |
| Address: | \$0115  |           |            |             |            |            |         |       |
|          | Bit 7   | 6         | 5          | 4           | 3          | 2          | 1       | Bit 0 |
| Read:    | ΔM7     | AM6       | ΔM5        | ΔM4         | ΔM3        | ΔM2        | ΔΜ1     | ΔΜΟ   |
| Write:   | 7 (1017 | 7 11/10   | 7100       | 7 1111-1    | 71110      | 7 (1912    | / \\\\  | 71110 |
| Reset:   |         |           |            | Unaffecte   | d by reset |            |         |       |
| Address: | \$0116  |           |            |             |            |            |         |       |
|          | Bit 7   | 6         | 5          | 4           | 3          | 2          | 1       | Bit 0 |
| Read:    | AN/7    | AM6       | AM5        | AM4         | AM2        | AMO        | AM1     | AMO   |
| Write:   |         | AINIO     | AIVIJ      |             | AIVIO      | AIVIZ      |         | Alvio |
| Reset:   |         |           |            | Unaffecte   | d by reset |            |         |       |
| Address: | \$0117  |           |            |             |            |            |         |       |
|          | Bit 7   | 6         | 5          | 4           | 3          | 2          | 1       | Bit 0 |
| Read:    | ΔМ7     | AM6       | ΔM5        | <b>Δ</b> Μ4 | ΔM3        | ΔM2        | ΔΜ1     | AMO   |
| Write:   | 7 (1017 | 7 110     | 7100       | 7 (191-     | 71110      | 7 (11)2    | 7 (1911 | 7100  |
| Reset:   |         |           |            | Unaffecte   | d by reset |            |         |       |
|          | Figu    | ure 16-29 | . First Ba | ank msC     | AN12 Ide   | entifier N | lask    |       |

Registers (CIDMR0–CIDMR3)



Figure 16-30. Second Bank msCAN12 Identifier Mask Registers (CIDMR4–CIDMR7)



#### Analog-to-Digital Converter (ATD)

Clearing these bits causes the prescale value to default to 1 which results in a divide-by-two prescale factor. This signal is then fed into the divide-by-two logic. The reset state divides the P clock by a total of four and is appropriate for nominal operation at a bus rate of between 2 MHz and 8 MHz. Table 17-3 shows the divide-by operation and the appropriate range of system clock frequencies.

| Prescale Value | Total Divisor | Max P Clock <sup>(1)</sup> | Min P Clock <sup>(2)</sup> |  |
|----------------|---------------|----------------------------|----------------------------|--|
| 00000          | 2             | 4 MHz                      | 1 MHz                      |  |
| 00001          | 4             | 8 MHz                      | 2 MHz                      |  |
| 00010          | 6             | 8 MHz                      | 3 MHz                      |  |
| 00011          | 8             | 8 MHz                      | 4 MHz                      |  |
| 00100          | 10            | 8 MHz                      | 5 MHz                      |  |
| 00101          | 12            | 8 MHz                      | 6 MHz                      |  |
| 00110          | 14            | 8 MHz                      | 7 MHz                      |  |
| 00111          | 16            | 8 MHz                      | 8 MHz                      |  |
| 01xxx          |               |                            |                            |  |
| 1xxxx          |               |                            |                            |  |

#### Table 17-3. Clock Prescaler Values

1. Maximum conversion frequency is 2 MHz. Maximum P clock divisor value becomes maximum conversion rate that can be used on this ATD module.

2. Minimum conversion frequency is 500 kHz. Minimum P clock divisor value becomes minimum conversion rate that this ATD can perform.

## 17.3.6 ATD Control Register 5



Figure 17-7. ATD Control Register 5 (ATDCTL5)

#### Read: Anytime

Write: Anytime

The ATD control register 5 is used to select the conversion modes, the conversion channel(s), and initiate conversions.

A write to ATDCTL5 initiates a new conversion sequence. If a conversion sequence is in progress when a write occurs, that sequence is aborted and the SCF and CCF bits are reset.

#### S8CM — Select 8 Channel Mode Bit

- 0 = Conversion sequence consists of four conversions.
- 1 = Conversion sequence consists of eight conversions.



## 19.10 ATD AC Operating Characteristics (Operating)

| Characteristic <sup>(1)</sup>                                                                         | Symbol                                     | Min        | Max      | Unit         |
|-------------------------------------------------------------------------------------------------------|--------------------------------------------|------------|----------|--------------|
| MCU clock frequency (p-clock)                                                                         | f <sub>PCLK</sub>                          | 2.0        | 8.0      | MHz          |
| ATD operating clock frequency                                                                         | f <sub>ATDCLK</sub>                        | 0.5        | 2.0      | MHz          |
| ATD 8-bit conversion period<br>ATD clock cycles <sup>(2)</sup><br>ATD conversion time <sup>(3)</sup>  | n <sub>conv8</sub><br>t <sub>conv8</sub>   | 18<br>9    | 32<br>16 | Cycles<br>μs |
| ATD 10-bit conversion period<br>ATD clock cycles <sup>(2)</sup><br>ATD conversion time <sup>(3)</sup> | n <sub>CONV10</sub><br><sup>t</sup> CONV10 | 20<br>10.0 | 34<br>17 | Cycles<br>µs |
| Stop and ATD power-up recovery time <sup>(4)</sup> $V_{\text{DDA}} = 5.0 \text{ V}$                   | t <sub>SR</sub>                            | _          | 10       | μs           |

1.  $V_{DD}$  = 5.0 Vdc ± 10%,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_L$  to  $T_H$ , ATD clock = 2 MHz, unless otherwise noted 2. The minimum time assumes a final sample period of 2 ATD clock cycles while the maximum time assumes a final sample period of 16 ATD clocks.

3. This assumes an ATD clock frequency of 2.0 MHz.

4. From the time ADPU is asserted until the time an ATD conversion can begin

## **19.11 EEPROM Characteristics**

| Characteristic <sup>(1)</sup>                                | Symbol              | Min    | Тур | Мах                   | Unit   |
|--------------------------------------------------------------|---------------------|--------|-----|-----------------------|--------|
| Minimum programming clock frequency <sup>(2)</sup>           | f <sub>PROG</sub>   | 1.0    |     |                       | MHz    |
| Programming time                                             | t <sub>PROG</sub>   | 10.0   |     | 10.5                  | ms     |
| Clock recovery time, following STOP, to continue programming | t <sub>CRSTOP</sub> |        |     | t <sub>PROG</sub> + 1 | ms     |
| Erase time                                                   | t <sub>ERASE</sub>  | 10.0   |     | 10.5                  | ms     |
| Write/erase endurance                                        | —                   | 10,000 |     |                       | Cycles |
| Data retention                                               | _                   | 10     |     |                       | Years  |

1.  $V_{DD}$  = 5.0 Vdc ± 10%,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_L$  to  $T_H$ , unless otherwise noted 2. RC oscillator must be enabled if programming is desired and  $f_{SYS}$  <  $f_{PROG}$ .



**Electrical Specifications** 

## 19.16 Multiplexed Expansion Bus Timing

NOTE

Use of the multiplexed expansion bus at 8 MHz is discouraged due to TAD delay factors.

| Num | Characteristic <sup>(1), (2), (3), (4), (5)</sup>                                                               | Delay | Symbol            | 8 MHz |      | 2 MHz |     | Unit |
|-----|-----------------------------------------------------------------------------------------------------------------|-------|-------------------|-------|------|-------|-----|------|
|     |                                                                                                                 |       |                   | Min   | Max  | Min   | Max | Unit |
| —   | Frequency of operation (E-clock frequency)                                                                      | —     | f <sub>o</sub>    | dc    | 8.0  | dc    | 8.0 | MHz  |
| 1   | Cycle timet <sub>cyc</sub> = $1/f_o$                                                                            | _     | t <sub>cyc</sub>  | 125   | —    | 500   | —   | ns   |
| 2   | Pulse width, E lowPW <sub>EL</sub> = $t_{cyc}/2$ + delay                                                        | -4    | PW <sub>EL</sub>  | 59    | —    | 246   | _   | ns   |
| 3   | Pulse width, E high <sup>(6)</sup> PW <sub>EH</sub> = $t_{cyc}/2$ + delay                                       | -2    | PW <sub>EH</sub>  | 59    | —    | 248   | —   | ns   |
| 5   | Address delay timet <sub>AD</sub> = $t_{cyc}/4$ + delay                                                         | 27    | t <sub>AD</sub>   | —     | 67.5 | _     | 152 | ns   |
| 7   | Address valid time to ECLK riset <sub>AV</sub> = $PW_{EL} - t_{AD}$                                             | —     | t <sub>AV</sub>   | -6.2  | —    | 94    |     | ns   |
| 8   | Multiplexed address hold timet <sub>MAH</sub> = $t_{cyc}/4$ + delay                                             | -18   | t <sub>MAH</sub>  | 13    |      | 107   |     | ns   |
| 9   | Address hold to data valid                                                                                      | _     | t <sub>AHDS</sub> | 30    | —    | 20    |     | ns   |
| 10  | Data hold to high impedancet $_{DHZ} = t_{AD} - 20$                                                             | _     | t <sub>DHZ</sub>  | —     | 45.2 | _     | 132 | ns   |
| 11  | Read data setup time                                                                                            | —     | t <sub>DSR</sub>  | 31.2  | —    | 25    | _   | ns   |
| 12  | Read data hold time                                                                                             | —     | t <sub>DHR</sub>  | 0     | —    | 0     | _   | ns   |
| 13  | Write data delay time                                                                                           | _     | t <sub>DDW</sub>  |       | 62.5 |       | 165 | ns   |
| 14  | Write data hold time                                                                                            | _     | t <sub>DHW</sub>  | 25    | _    | 20    | _   | ns   |
| 15  | Write data setup time <sup>(6)</sup> $t_{DSW} = PW_{EH} - t_{DDW}$                                              | _     | t <sub>DSW</sub>  | 5.8   | —    | 83    | —   | ns   |
| 16  | Read/write delay timet <sub>RWD</sub> = $t_{cyc}/4 + delay$                                                     | 18    | t <sub>RWD</sub>  | —     | 57.5 | _     | 143 | ns   |
| 17  | Read/write valid time to E riset <sub>RWV</sub> = $PW_{EL} - t_{RWD}$                                           | _     | t <sub>RWV</sub>  | 3.8   |      | 103   |     | ns   |
| 18  | Read/write hold time                                                                                            | _     | t <sub>RWH</sub>  | 25    |      | 20    |     | ns   |
| 19  | Low strobe <sup>(7)</sup> delay timet <sub>LSD</sub> = $t_{cyc}/4$ + delay                                      | 18    | t <sub>LSD</sub>  |       | 57.5 |       | 143 | ns   |
| 20  | Low strobe <sup>(7)</sup> valid time to E riset <sub>LSV</sub> = $PW_{EL} - t_{LSD}$                            | _     | t <sub>LSV</sub>  | 3.8   |      | 103   |     | ns   |
| 21  | Low strobe <sup>(7)</sup> hold time                                                                             |       | t <sub>LSH</sub>  | 25    |      | 20    |     | ns   |
| 22  | Address access time <sup>(6)</sup> $t_{ACCA} = t_{cyc} - t_{AD} - t_{DSR}$                                      | _     | t <sub>ACCA</sub> |       | 27.6 | _     | 323 | ns   |
| 23  | Access time from E rise <sup>(6)</sup> $t_{ACCE} = PW_{EH} - t_{DSR}$                                           | —     | t <sub>ACCE</sub> |       | 27.8 |       | 223 | ns   |
| 24  | $\overline{\text{DBE}}$ delay from ECLK rise <sup>(6)</sup> $t_{\text{DBED}} = t_{\text{cyc}}/4 + \text{delay}$ | 8     | t <sub>DBED</sub> | _     | 57.5 | _     | 133 | ns   |
| 25  | DBE valid timet <sub>DBE</sub> = PW <sub>EH</sub> - t <sub>DBED</sub>                                           | —     | t <sub>DBE</sub>  | 11.8  |      | 115   |     | ns   |
| 26  | DBE hold time from ECLK fall                                                                                    | —     | t <sub>DBEH</sub> | -3    | 10   | -3    | 10  | ns   |

1.  $V_{DD} = 5.0 \text{ Vdc} \pm 10\%$ ,  $V_{SS} = 0 \text{ Vdc}$ ,  $T_A = T_L$  to  $T_H$ , unless otherwise noted 2. All timings are calculated for normal port drives. 3. Crystal input is required to be within 45% to 55% duty.

4. Reduced drive must be off to meet these timings.

5. Unequalled loading of pins will affect relative timing numbers.

6. This characteristic is affected by clock stretch.

Add N  $\times$   $t_{cyc}$  where N = 0, 1, 2, or 3, depending on the number of clock stretches. 7. Without TAG enabled