



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             | Not For New Designs                                                     |
|----------------------------|-------------------------------------------------------------------------|
| Core Processor             | HCS12X                                                                  |
| Core Size                  | 16-Bit                                                                  |
| Speed                      | 80MHz                                                                   |
| Connectivity               | CANbus, EBI/EMI, I <sup>2</sup> C, IrDA, LINbus, SCI, SPI               |
| Peripherals                | LCD, Motor control PWM, POR, PWM, WDT                                   |
| Number of I/O              | 117                                                                     |
| Program Memory Size        | 512KB (512K x 8)                                                        |
| Program Memory Type        | FLASH                                                                   |
| EEPROM Size                | 4K x 8                                                                  |
| RAM Size                   | 32K x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 2.35V ~ 5.5V                                                            |
| Data Converters            | A/D 16x8/10b                                                            |
| Oscillator Type            | External                                                                |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                      |
| Mounting Type              | Surface Mount                                                           |
| Package / Case             | 144-LQFP                                                                |
| Supplier Device Package    | 144-LQFP (20x20)                                                        |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/s912xhz512f1mag |

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 (S12XHZPIMV1)

#### 2.3.7.2 Port L Input Register (PTIL)

Module Base + 0x0031



## Figure 2-28. Port L Input Register (PTIL)

Read: Anytime. Write: Never, writes to this register have no effect.

If the LCD frontplane driver of an associated I/O pin is enabled (and LCD module is enabled) or the associated ATDDIEN0 bit is set to 0 (digital input buffer is disabled), a read returns a 1.

If the LCD frontplane driver of an associated I/O pin is disabled (or LCD module is disabled) and the associated ATDDIEN0 bit is set to 1 (digital input buffer is enabled), a read returns the status of the associated pin.

#### 2.3.7.3 Port L Data Direction Register (DDRL)



Module Base + 0x0032

Figure 2-29. Port L Data Direction Register (DDRL)

Read: Anytime. Write: Anytime.

This register configures port pins PL[7:0] as either input or output.

If a LCD frontplane driver is enabled (and LCD module is enabled), it outputs an analog signal to the corresponding pin and the associated Data Direction Register bit has no effect. If a LCD frontplane driver is disabled (or LCD module is disabled), the corresponding Data Direction Register bit reverts to control the I/O direction of the associated pin.

| Table | 2-21. | DDRL | Field | Descriptions |
|-------|-------|------|-------|--------------|
|-------|-------|------|-------|--------------|

| Field     | Description                               |
|-----------|-------------------------------------------|
| 7:0       | Data Direction Port L                     |
| DDRL[7:0] | 0 Associated pin is configured as input.  |
|           | 1 Associated pin is configured as output. |

I





Figure 3-1. FTX512K4 Block Diagram

# 3.2 External Signal Description

The Flash module contains no signals that connect off-chip.



#### Chapter 3 512 Kbyte Flash Module (S12XFTX512K4V3)





MC9S12XHZ512 Data Sheet, Rev. 1.06



Chapter 5 XGATE (S12XGATEV2)

Figure 5-22 gives an example of the typical usage of the XGATE hardware semaphores.

Two concurrent threads are running on the system. One is running on the S12X\_CPU and the other is running on the RISC core. They both have a critical section of code that accesses the same system resource. To guarantee that the system resource is only accessed by one thread at a time, the critical code sequence must be embedded in a semaphore lock/release sequence as shown.



Figure 5-22. Algorithm for Locking and Releasing Semaphores

# 5.4.5 Software Error Detection

The XGATE module will immediately terminate program execution after detecting an error condition caused by erratic application code. There are three error conditions:

- Execution of an illegal opcode
- Illegal vector or opcode fetches
- Illegal load or store accesses

All opcodes which are not listed in section 5.8, "Instruction Set" are illegal opcodes. Illegal vector and opcode fetches as well as illegal load and store accesses are defined on chip level. Refer to the **S12X\_MMC Section** for a detailed information.



#### Chapter 5 XGATE (S12XGATEV2)

# **BFFO**

**Bit Field Find First One** 



## Operation

FirstOne (RS)  $\Rightarrow$  RD;

Searches the first "1" in register RS (from MSB to LSB) and writes the bit position into the destination register RD. The upper bits of RD are cleared. In case the content of RS is equal to \$0000, RD will be cleared and the carry flag will be set. This is used to distinguish a "1" in position 0 versus no "1" in the whole RS register at all.

## **CCR Effects**

| Ν | Z | V | С |
|---|---|---|---|
| 0 | Δ | 0 | Δ |

N: 0; cleared.

- Z: Set if the result is \$0000; cleared otherwise.
- V: 0; cleared.
- C: Set if  $RS = $0000^{1}$ ; cleared otherwise.

<sup>1</sup> Before executing the instruction

## Code and CPU Cycles

| Source Form | Address<br>Mode |   |   |   |   |   | Machin | e Code |   |   |   |   |   | Cycles |
|-------------|-----------------|---|---|---|---|---|--------|--------|---|---|---|---|---|--------|
| BFFO RD, RS | DYA             | 0 | 0 | 0 | 0 | 1 | RD     | RS     | 1 | 0 | 0 | 0 | 0 | Р      |





# CMPL

Compare Immediate 8 bit Constant (Low Byte)



## Operation

 $RS.L - IMM8 \Rightarrow NONE$ , only condition code flags get updated

Subtracts the 8 bit constant IMM8 contained in the instruction code from the low byte of the source register RS.L using binary subtraction and updates the condition code register accordingly.

Remark: There is no equivalent operation using triadic addressing. Comparing the values of two registers can be performed by using the subtract instruction with R0 as destination register.

# **CCR Effects**



- N: Set if bit 7 of the result is set; cleared otherwise.
- Z: Set if the 8 bit result is \$00; cleared otherwise.
- V: Set if a two's complement overflow resulted from the 8 bit operation; cleared otherwise. RS[7] &  $\overline{IMM8[7]}$  &  $\overline{result[7]} | \overline{RS[7]}$  & IMM8[7] & result[7]
- C: Set if there is a carry from the Bit 7 to Bit 8 of the result; cleared otherwise.  $\overline{RS[7]}$  & IMM8[7] |  $\overline{RS[7]}$  & result[7] | IMM8[7] & result[7]

## **Code and CPU Cycles**

| Source Form    | Address<br>Mode |   | Machine Code |   |   |   |  |    |      | Cycles |
|----------------|-----------------|---|--------------|---|---|---|--|----|------|--------|
| CMPL RS, #IMM8 | IMM8            | 1 | 1            | 0 | 1 | 0 |  | RS | IMM8 | Р      |



The clock generator creates the clocks used in the MCU (see Figure 7-17). The gating condition placed on top of the individual clock gates indicates the dependencies of different modes (STOP, WAIT) and the setting of the respective configuration bits.

The peripheral modules use the bus clock. Some peripheral modules also use the oscillator clock. The memory blocks use the bus clock. If the MCU enters self clock mode (see Section 7.4.2.2, "Self Clock Mode") oscillator clock source is switched to PLLCLK running at its minimum frequency  $f_{SCM}$ . The bus clock is used to generate the clock visible at the ECLK pin. The core clock signal is the clock for the CPU. The core clock is twice the bus clock as shown in Figure 7-18. But note that a CPU cycle corresponds to one bus clock.

PLL clock mode is selected with PLLSEL bit in the CLKSEL registerr. When selected, the PLL output clock drives SYSCLK for the main system including the CPU and peripherals. The PLL cannot be turned off by clearing the PLLON bit, if the PLL clock is selected. When PLLSEL is changed, it takes a maximum of 4 OSCCLK plus 4 PLLCLK cycles to make the transition. During the transition, all clocks freeze and CPU activity ceases.



# 7.4.1.3 Clock Monitor (CM)

If no OSCCLK edges are detected within a certain time, the clock monitor within the oscillator block generates a clock monitor fail event. The CRG then asserts self clock mode or generates a system reset depending on the state of SCME bit. If the clock monitor is disabled or the presence of clocks is detected no failure is indicated by the oscillator block. The clock monitor function is enabled/disabled by the CME control bit.

# 7.4.1.4 Clock Quality Checker

The clock monitor performs a coarse check on the incoming clock signal. The clock quality checker provides a more accurate check in addition to the clock monitor.

A clock quality check is triggered by any of the following events:

- Power on reset (*POR*)
- Low voltage reset (*LVR*)
- Wake-up from full stop mode (*exit full stop*)
- Clock monitor fail indication (CM fail)

A time window of 50,000 VCO clock cycles<sup>1</sup> is called *check window*.

<sup>1.</sup> VCO clock cycles are generated by the PLL when running at minimum frequency f<sub>SCM</sub>.



# 7.6.2 PLL Lock Interrupt

The CRG generates a PLL Lock interrupt when the LOCK condition of the PLL has changed, either from a locked state to an unlocked state or vice versa. Lock interrupts are locally disabled by setting the LOCKIE bit to 0. The PLL Lock interrupt flag (LOCKIF) is set to1 when the LOCK condition has changed, and is cleared to 0 by writing a 1 to the LOCKIF bit.

# 7.6.3 Self Clock Mode Interrupt

The CRG generates a self clock mode interrupt when the SCM condition of the system has changed, either entered or exited self clock mode. SCM conditions can only change if the self clock mode enable bit (SCME) is set to 1. SCM conditions are caused by a failing clock quality check after power on reset (POR) or low voltage reset (LVR) or recovery from full stop mode (PSTP = 0) or clock monitor failure. For details on the clock quality check refer to Section 7.4.1.4, "Clock Quality Checker". If the clock monitor is enabled (CME = 1) a loss of external clock will also cause a SCM condition (SCME = 1).

SCM interrupts are locally disabled by setting the SCMIE bit to 0. The SCM interrupt flag (SCMIF) is set to1 when the SCM condition has changed, and is cleared to 0 by writing a 1 to the SCMIF bit.



# 12.2 External Signal Description

Each SSD signal is the output pin of a half bridge, designed to source or sink current. The H-bridge pins drive the sine and cosine coils of a stepper motor to provide four-quadrant operation. The SSD is capable of multiplexing between stepper motor A and stepper motor B if two motors are connected.

| Pin Name | Node  | Coil |
|----------|-------|------|
| COSxM    | Minus | COSx |
| COSxP    | Plus  |      |
| SINxM    | Minus | SINx |
| SINxP    | Plus  |      |

|       |       |     | 4      |
|-------|-------|-----|--------|
| Table | 12-1. | Pin | Table' |

<sup>1</sup> x = A or B indicating motor A or motor B

# 12.2.1 COSxM/COSxP — Cosine Coil Pins for Motor x

These pins interface to the cosine coils of a stepper motor to measure the back EMF for calibration of the pointer reset position.

# 12.2.2 SINxM/SINxP — Sine Coil Pins for Motor x

These pins interface to the sine coils of a stepper motor to measure the back EMF for calibration of the pointer reset position.





Figure 14-33. Identifier Register 3 — Standard Mapping

# 14.3.3.2 Data Segment Registers (DSR0-7)

The eight data segment registers, each with bits DB[7:0], contain the data to be transmitted or received. The number of bytes to be transmitted or received is determined by the data length code in the corresponding DLR register.

Module Base + 0x00X4 to Module Base + 0x00XB

| _      | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
| R<br>W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |
| Reset: | х   | х   | х   | х   | x   | х   | х   | х   |

Figure 14-34. Data Segment Registers (DSR0–DSR7) — Extended Identifier Mapping

| Table 14-33. | DSR0-DSR7 | <b>Register Field</b> | Descriptions |
|--------------|-----------|-----------------------|--------------|
|              |           | riogiotor i lora      | Dooonphono   |

| Field          | Description   |
|----------------|---------------|
| 7-0<br>DB[7:0] | Data bits 7-0 |



Figure 15-26 shows a burst of noise near the beginning of the start bit that resets the RT clock. The sample after the reset is low but is not preceded by three high samples that would qualify as a falling edge. Depending on the timing of the start bit search and on the data, the frame may be missed entirely or it may set the framing error flag.



In Figure 15-27, a noise burst makes the majority of data samples RT8, RT9, and RT10 high. This sets the noise flag but does not reset the RT clock. In start bits only, the RT8, RT9, and RT10 data samples are ignored.



# 15.4.6.4 Framing Errors

If the data recovery logic does not detect a logic 1 where the stop bit should be in an incoming frame, it sets the framing error flag, FE, in SCI status register 1 (SCISR1). A break character also sets the FE flag because a break character has no stop bit. The FE flag is set at the same time that the RDRF flag is set.

MC9S12XHZ512 Data Sheet, Rev. 1.06



Chapter 16 Serial Peripheral Interface (S12SPIV4)

# 16.2.3 SS — Slave Select Pin

This pin is used to output the select signal from the SPI module to another peripheral with which a data transfer is to take place when it is configured as a master and it is used as an input to receive the slave select signal when the SPI is configured as slave.

# 16.2.4 SCK — Serial Clock Pin

In master mode, this is the synchronous output clock. In slave mode, this is the synchronous input clock.

# 16.3 Memory Map and Register Definition

This section provides a detailed description of address space and registers used by the SPI.

# 16.3.1 Module Memory Map

The memory map for the SPI is given in Figure 16-2. The address listed for each register is the sum of a base address and an address offset. The base address is defined at the SoC level and the address offset is defined at the module level. Reads from the reserved bits return zeros and writes to the reserved bits have no effect.

| Register<br>Name   |        | Bit 7 | 6          | 5            | 4      | 3       | 2    | 1       | Bit 0 |
|--------------------|--------|-------|------------|--------------|--------|---------|------|---------|-------|
| 0x0000<br>SPICR1   | R<br>W | SPIE  | SPE        | SPTIE        | MSTR   | CPOL    | СРНА | SSOE    | LSBFE |
| 0x0001<br>SPICR2   | R<br>W | 0     | 0          | 0            | MODFEN | BIDIROE | 0    | SPISWAI | SPC0  |
| 0x0002<br>SPIBR    | R<br>W | 0     | SPPR2      | SPPR1        | SPPR0  | 0       | SPR2 | SPR1    | SPR0  |
| 0x0003<br>SPISR    | R<br>W | SPIF  | 0          | SPTEF        | MODF   | 0       | 0    | 0       | 0     |
| 0x0004<br>Reserved | R<br>W |       |            |              |        |         |      |         |       |
| 0x0005<br>SPIDR    | R<br>W | Bit 7 | 6          | 5            | 4      | 3       | 2    | 1       | Bit 0 |
| 0x0006<br>Reserved | R<br>W |       |            |              |        |         |      |         |       |
| 0x0007<br>Reserved | R<br>W |       |            |              |        |         |      |         |       |
|                    |        |       | = Unimplem | ented or Res | erved  |         |      |         |       |



MC9S12XHZ512 Data Sheet, Rev. 1.06



#### Chapter 17 Periodic Interrupt Timer (S12PIT24B4CV1)

PIT operation in wait mode is controlled by the PITSWAI bit located in the PITCFLMT register. In wait mode, if the bus clock is globally enabled and if the PITSWAI bit is clear, the PIT operates like in run mode. In wait mode, if the PITSWAI bit is set, the PIT module is stalled.

• Stop mode

In full stop mode or pseudo stop mode, the PIT module is stalled.

• Freeze mode

PIT operation in freeze mode is controlled by the PITFRZ bit located in the PITCFLMT register. In freeze mode, if the PITFRZ bit is clear, the PIT operates like in run mode. In freeze mode, if the PITFRZ bit is set, the PIT module is stalled.

# 17.1.4 Block Diagram

Figure 17-1 shows a block diagram of the PIT.



Figure 17-1. PIT Block Diagram

# 17.2 External Signal Description

The PIT module has no external pins.



## Table 19-7. TSCR1 Field Descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5<br>TSFRZ | <ul> <li>Timer and Modulus Counter Stop While in Freeze Mode</li> <li>Allows the timer and modulus counter to continue running while in freeze mode.</li> <li>Disables the timer and modulus counter whenever the MCU is in freeze mode. This is useful for emulation. The pulse accumulators do not stop in freeze mode.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4<br>TFFCA | <ul> <li>Timer Fast Flag Clear All</li> <li>Allows the timer flag clearing to function normally.</li> <li>A read from an input capture or a write to the output compare channel registers causes the corresponding channel flag, CxF, to be cleared in the TFLG1 register. Any access to the TCNT register clears the TOF flag in the TFLG2 register. Any access to the PACN3 and PACN2 registers clears the PAOVF and PAIF flags in the PAFLG register. Any access to the PACN1 and PACN0 registers clears the PBOVF flag in the PBFLG register. Any access to the MCCN1 register clears the MCZF flag in the MCFLG register. This has the advantage of eliminating software overhead in a separate clear sequence. Extra care is required to avoid accidental flag clearing due to unintended accesses.</li> <li>Note: The flags cannot be cleared via the normal flag clearing mechanism (writing a one to the flag) when TFFCA = 1.</li> </ul> |
| 3<br>PRNT  | <ul> <li>Precision Timer</li> <li>0 Enables legacy timer. Only bits DLY0 and DLY1 of the DLYCT register are used for the delay selection of the delay counter. PR0, PR1, and PR2 bits of the TSCR2 register are used for timer counter prescaler selection. MCPR0 and MCPR1 bits of the MCCTL register are used for modulus down counter prescaler selection.</li> <li>1 Enables precision timer. All bits in the DLYCT register are used for the delay selection, all bits of the PTPSR register are used for Precision Timer Prescaler Selection, and all bits of PTMCPSR register are used for the prescaler Precision Timer Modulus Counter Prescaler selection.</li> </ul>                                                                                                                                                                                                                                                                    |

# **19.3.2.7** Timer Toggle On Overflow Register 1 (TTOV)

Module Base + 0x0007



Read or write: Anytime

All bits reset to zero.

## Table 19-8. TTOV Field Descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0<br>TOV[7:0] | <ul> <li>Toggle On Overflow Bits — TOV97:0] toggles output compare pin on timer counter overflow. This feature only takes effect when in output compare mode. When set, it takes precedence over forced output compare but not channel 7 override events.</li> <li>0 Toggle output compare pin on overflow feature disabled.</li> <li>1 Toggle output compare pin on overflow feature enabled.</li> </ul> |

MC9S12XHZ512 Data Sheet Rev. 1.06



# Chapter 20 Voltage Regulator (S12VREG3V3V5) Revision History

| Version<br>Number | Revision<br>Date | Effective<br>Date | Author | Description of Changes                                                                  |
|-------------------|------------------|-------------------|--------|-----------------------------------------------------------------------------------------|
| V 5.03            | 09 Sep<br>2004   | 09 Sep<br>2004    |        | Corrected Typos.                                                                        |
| V 5.04            | 24 Nov<br>2004   | 24 Nov<br>2004    |        | Updated Section 20.4.7 & Table 20-6 to be easier understood                             |
| V 5.05            | 1 Apr<br>2005    | 1 Apr<br>2005     |        | Corrected Section regarding the non usage of VSSR. For info on VSSR see Section 20.2.1. |

# 20.1 Introduction

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

# 20.1.1 Features

Module VREG\_3V3 includes these distinctive features:

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

# 20.1.2 Modes of Operation

There are three modes VREG\_3V3 can operate in:

1. Full performance mode (FPM) (MCU is not in stop mode)



#### Table 22-16. CDCM Encoding

| CDCM | Description                                                              |  |  |  |  |  |  |  |  |
|------|--------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 00   | Match2 mapped to comparator C match Match3 mapped to comparator D match. |  |  |  |  |  |  |  |  |
| 01   | Match2 mapped to comparator C/D inside range Match3 disabled.            |  |  |  |  |  |  |  |  |
| 10   | Match2 mapped to comparator C/D outside range Match3 disabled.           |  |  |  |  |  |  |  |  |
| 11   | Reserved <sup>(1)</sup>                                                  |  |  |  |  |  |  |  |  |

1. Currently defaults to Match2 mapped to comparator C : Match3 mapped to comparator D

#### Table 22-17. ABCM Encoding

| Description                                                              |
|--------------------------------------------------------------------------|
| Match0 mapped to comparator A match Match1 mapped to comparator B match. |
| Match 0 mapped to comparator A/B inside range Match1 disabled.           |
| Match 0 mapped to comparator A/B outside range Match1 disabled.          |
| Reserved <sup>(1)</sup>                                                  |
|                                                                          |

1. Currently defaults to Match0 mapped to comparator A : Match1 mapped to comparator B

# 22.3.2.5 Debug Trace Buffer Register (DBGTBH:DBGTBL)

Address: 0x0024, 0x0025

|                 | 15     | 14     | 13     | 12     | 11     | 10     | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-----------------|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| R<br>W          | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| POR             | Х      | Х      | Х      | Х      | Х      | Х      | Х     | Х     | Х     | Х     | Х     | Х     | Х     | Х     | Х     | Х     |
| Other<br>Resets | _      | _      | _      | _      | _      | _      | _     | _     |       | _     | _     | _     |       | _     | _     | _     |

## Figure 22-7. Debug Trace Buffer Register (DBGTB)

Read: Only when unlocked AND not secured AND not armed AND with a TSOURCE bit set.

Write: Aligned word writes when disarmed unlock the trace buffer for reading but do not affect trace buffer contents.

## Table 22-18. DBGTB Field Descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–0<br>Bit[15:0] | <b>Trace Buffer Data Bits</b> — The Trace Buffer Register is a window through which the 64-bit wide data lines of the Trace Buffer may be read 16 bits at a time. Each valid read of DBGTB increments an internal trace buffer pointer which points to the next address to be read. When the ARM bit is written to 1 the trace buffer is locked to prevent reading. The trace buffer can only be unlocked for reading by writing to DBGTB with an aligned word write when the module is disarmed. The DBGTB register can be read only as an aligned word, any byte reads or misaligned access of these registers will return 0 and will not cause the trace buffer pointer to increment to the next trace buffer address. The same is true for word reads while the debugger is armed. The POR state is undefined Other resets do not affect the trace buffer contents. |



\_\_\_\_\_

Chapter 23 External Bus Interface (S12XEBIV3)



# 25.3.2.4 Direct Page Register (DIRECT)

Address: 0x0011



Read: Anytime

Write: anytime in special modes, one time only in other modes.

This register determines the position of the 256 Byte direct page within the memory map. It is valid for both global and local mapping scheme.

| Table 25-9 | DIRECT | Field | Descriptions |
|------------|--------|-------|--------------|
|------------|--------|-------|--------------|

| Field           | Description                                                                                                                                                                                                   |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>DP[15:8] | <b>Direct Page Index Bits 15–8</b> — These bits are used by the CPU when performing accesses using the direct addressing mode. The bits from this register form bits [15:8] of the address (see Figure 25-9). |

## CAUTION

XGATE write access to this register during an CPU access which makes use of this register could lead to unexpected results.



Figure 25-9. DIRECT Address Mapping

Bits [22:16] of the global address will be formed by the GPAGE[6:0] bits in case the CPU executes a global instruction in direct addressing mode or by the appropriate local address to the global address expansion (refer to Section 25.4.2.1.1, "Expansion of the Local Address Map).

| MOVB | #0x80,DIRECT | ;Set DIRECT register to 0x80. Write once only.<br>;Global data accesses to the range 0xXX_80XX can be direct.<br>;Logical data accesses to the range 0x80XX are direct.         |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LDY  | <00          | ;Load the Y index register from 0x8000 (direct access).<br>;< operator forces direct access on some assemblers but in<br>;many cases assemblers are "direct page aware" and can |



#### Chapter 25 Memory Mapping Control (S12XMMCV3)

• Normal expanded mode

The external bus interface is configured as an up to 23-bit address bus, 8 or 16-bit data bus with dedicated bus control and status signals. This mode allows 8 or 16-bit external memory and peripheral devices to be interfaced to the system. The fastest external bus rate is half of the internal bus rate. An external signal can be used in this mode to cause the external bus to wait as desired by the external logic.

- Emulation expanded mode Tool vendors use this mode for emulation systems in which the user's target application is normal expanded mode.
- Special test mode

This mode is an expanded mode for factory test.

# 25.4.2 Memory Map Scheme

## 25.4.2.1 CPU and BDM Memory Map Scheme

The BDM firmware lookup tables and BDM register memory locations share addresses with other modules; however they are not visible in the memory map during user's code execution. The BDM memory resources are enabled only during the READ\_BD and WRITE\_BD access cycles to distinguish between accesses to the BDM memory area and accesses to the other modules. (Refer to BDM Block Guide for further details).

When the MCU enters active BDM mode, the BDM firmware lookup tables and the BDM registers become visible in the local memory map in the range 0xFF00-0xFFFF (global address 0x7F\_FF00 - 0x7F\_FFFF) and the CPU begins execution of firmware commands or the BDM begins execution of hardware commands. The resources which share memory space with the BDM module will not be visible in the memory map during active BDM mode.

Please note that after the MCU enters active BDM mode the BDM firmware lookup tables and the BDM registers will also be visible between addresses 0xBF00 and 0xBFFF if the PPAGE register contains value of 0xFF.



Appendix E Detailed Register Map

## 0x0288–0x028F Stepper Stall Detector (SSD0) Map (continued)

| Address | Name        |        | Bit 7       | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2 | Bit 1 | Bit 0 |  |
|---------|-------------|--------|-------------|-------|-------|-------|---------|-------|-------|-------|--|
| 0x028D  | MDC0CNT(lo) | R<br>W | MDCCNT[7:0] |       |       |       |         |       |       |       |  |
| 0x028E  | ITG0ACC(hi) | R      |             |       |       | ITGAC | C[15:8] |       |       |       |  |
|         |             | W      |             |       |       |       |         |       |       |       |  |
| 0x028F  | ITG0ACC(lo) | R      |             |       |       | ITGAC | C[7:0]  |       |       |       |  |
|         |             | W      |             |       |       |       |         |       |       |       |  |

# 0x0290–0x0297 Stepper Stall Detector (SSD1) Map

| Address | Name        |          | Bit 7        | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------------|----------|--------------|-------|--------|-------|-------|-------|-------|-------|
| 0x0290  | RTZ1CTL     | R<br>W   | ITG          | DCOIL | RCIR   | POL   | 0     | 0     | STEP  |       |
|         |             |          |              |       |        |       |       |       |       |       |
| 0x0291  | MDC1CTL     | R<br>W   | MCZIE        | MODMC | RDMCL  | PRE   | 0     | MCEN  | 0     | AOVIE |
|         |             |          |              |       |        |       | FLMC  |       |       |       |
| 0x0292  | SSD1CTL     | R<br>W   | RTZE         | SDCPU | SSDWAI | FTST  | 0     | 0     | ACLKS |       |
|         |             |          |              |       |        |       |       |       |       |       |
| 0x0293  | SSD1FLG     | R<br>W   | MCZIF        | 0     | 0      | 0     | 0     | 0     | 0     | AOVIF |
|         |             |          |              |       |        |       |       |       |       |       |
| 0x0294  | MDC1CNT(hi) | , R<br>W | MDCCNT[15:8] |       |        |       |       |       |       |       |
|         |             |          |              |       |        |       |       |       |       |       |
| W       |             |          |              |       |        |       |       |       |       |       |
| 0x0296  | ITG1ACC(hi) | R<br>W   | ITGACC[15:8] |       |        |       |       |       |       |       |
|         |             |          |              |       |        |       |       |       |       |       |
| 0x0297  | ITG1ACC(lo) | R        | ITGACC[7:0]  |       |        |       |       |       |       |       |
|         |             | W        |              |       |        |       |       |       |       |       |

## 0x0298–0x029F Stepper Stall Detector (SSD2) Map

| Address | Name        |        | Bit 7        | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0  |  |
|---------|-------------|--------|--------------|-------|--------|-------|-------|-------|-------|--------|--|
| 0x0298  | RTZ2CTL     | R<br>W | ITG          | DCOIL | RCIR   | POL   | 0     | 0     | STEP  |        |  |
|         |             |        |              |       |        |       |       |       |       |        |  |
| 0x0299  | MDC2CTL     | R<br>W | MCZIE        | MODMC | RDMCL  | PRE   | 0     | MCEN  | 0     | AOVIE  |  |
|         |             |        |              |       |        |       | FLMC  |       |       |        |  |
| 0x029A  | SSD2CTL     | R<br>W | RTZE         | SDCPU | SSDWAI | FTST  | 0     | 0     | ACLKS |        |  |
|         |             |        |              |       |        |       |       |       |       |        |  |
| 0x029B  | SSD2FLG     | R<br>W | MCZIF        | 0     | 0      | 0     | 0     | 0     | 0     |        |  |
|         |             |        |              |       |        |       |       |       |       | /.0/11 |  |
| 0x029C  | MDC2CNT(hi) | R      | MDCCNT[15:8] |       |        |       |       |       |       |        |  |
|         |             | W      |              |       |        |       |       |       |       |        |  |
| 0x029D  | MDC2CNT(lo) | R      | MDCCNT[7:0]  |       |        |       |       |       |       |        |  |
|         |             | W      |              |       |        |       |       |       |       |        |  |
| 0x029E  | ITG2ACC(hi) | R      | ITGACC[15:8] |       |        |       |       |       |       |        |  |
|         |             | W      |              |       |        |       |       |       |       |        |  |
| 0x029F  | ITG2ACC(lo) | R      | ITGACC[7:0]  |       |        |       |       |       |       |        |  |
|         |             | W      |              |       |        |       |       |       |       |        |  |

MC9S12XHZ512 Data Sheet, Rev. 1.06