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 - Microcontrollers</u>" | Details | | |----------------------------|-----------------------------------------------------------------------| | Product Status | Active | | Core Processor | HCS12 | | Core Size | 16-Bit | | Speed | 32MHz | | Connectivity | CANbus, SCI, SPI | | Peripherals | LVD, POR, PWM, WDT | | Number of I/O | 49 | | Program Memory Size | 64KB (64K x 8) | | Program Memory Type | FLASH | | EEPROM Size | 4K x 8 | | RAM Size | 4K x 8 | | Voltage - Supply (Vcc/Vdd) | 1.72V ~ 5.5V | | Data Converters | A/D 10x12b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 125°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 64-LQFP | | Supplier Device Package | 64-LQFP (10x10) | | Purchase URL | https://www.e-xfl.com/product-detail/nxp-semiconductors/s9s12p64j0mlh | | | Chapter 2 | | |-----|----------------------------------------------------------------|----| | 2.1 | Port Integration Module (S12PPIMV1) | 40 | | 2.1 | Introduction 2.1.1 Overview | | | | 2.1.2 Features | | | 2.2 | External Signal Description | | | 2.3 | Memory Map and Register Definition | | | 2.5 | 2.3.1 Memory Map | | | | 2.3.2 Register Descriptions | 61 | | | 2.3.3 Port A Data Register (PORTA) | | | | 2.3.4 Port B Data Register (PORTB) | | | | 2.3.5 Port A Data Direction Register (DDRA) | | | | 2.3.6 Port B Data Direction Register (DDRB) | | | | 2.3.7 PIM Reserved Register | | | | 2.3.8 Port E Data Register (PORTE) | 65 | | | 2.3.9 Port E Data Direction Register (DDRE) | | | | 2.3.10 Ports A, B, E, BKGD pin Pull-up Control Register (PUCR) | | | | 2.3.11 Ports A, B, E Reduced Drive Register (RDRIV) | | | | 2.3.12 ECLK Control Register (ECLKCTL) | | | | 2.3.13 PIM Reserved Register | | | | 2.3.14 IRQ Control Register (IRQCR) | | | | 2.3.15 PIM Reserved Register | 70 | | | 2.3.16 Port T Data Register (PTT) | 71 | | | 2.3.17 Port T Input Register (PTIT) | 72 | | | 2.3.18 Port T Data Direction Register (DDRT) | | | | 2.3.19 Port T Reduced Drive Register (RDRT) | | | | 2.3.20 Port T Pull Device Enable Register (PERT) | | | | 2.3.21 Port T Polarity Select Register (PPST) | | | | 2.3.22 PIM Reserved Register | | | | 2.3.23 Port T Routing Register (PTTRR) | | | | 2.3.24 Port S Data Register (PTS) | | | | 2.3.25 Port S Input Register (PTIS) | | | | 2.3.26 Port S Data Direction Register (DDRS) | | | | 2.3.27 Port S Reduced Drive Register (RDRS) | | | | 2.3.28 Port S Pull Device Enable Register (PERS) | | | | 2.3.29 Port S Polarity Select Register (PPSS) | | | | 2.3.30 Port S Wired-Or Mode Register (WOMS) | | | | 2.3.31 PIM Reserved Register | 81 | | | 2.3.32 Port M Data Register (PTM) | 81 | | | 2.3.33 Port M Input Register (PTIM) | | | | 2.3.34 Port M Data Direction Register (DDRM) | | | | 2.3.35 Port M Reduced Drive Register (RDRM) | | | | 2.3.36 Port M Pull Device Enable Register (PERM) | 85 | | | | | S12P-Family Reference Manual, Rev. 1.13 Freescale Semiconductor 2.4 2.5 3.1 | Port M Polarity Select Register (PPSM) | | |----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | | | 1 | | | | | | | | | | | | ± | | | | | | Port Data and Data Direction Register writes | 106 | | Chapter 2 | | | <u>.</u> | | | • • • • • • • • • • • • • • • • • • • • | | | | | | | | | Overview | | | Features | | | Modes of Operation | | | Block Diagram | 108 | | | | | | 3 Port M Wired-Or Mode Register (WOMM) 9 PIM Reserved Register 9 Port P Data Register (PTP) 1 Port P Input Register (PTIP) 2 Port P Data Direction Register (DDRP) 3 Port P Reduced Drive Register (PDRP) 4 Port P Pull Device Enable Register (PERP) 5 Port P Polarity Select Register (PEPP) 6 Port P Interrupt Enable Register (PIEP) 7 Port P Interrupt Enable Register (PIEP) 8 PORT J Data Register (PTI) 9 Port J Data Register (PTI) 1 Port J Data Direction Register (DDRJ) 2 Port J Input Register (PTI) 9 Port J Data Direction Register (PEDI) 5 Port J Polarity Select Register (PEDI) 6 Port J Polarity Select Register (PEDI) 7 Port J Polarity Select Register (PEDI) 8 Port J Polarity Select Register (PEDI) 9 Port J Polarity Select Register (PEDI) 9 Port AD Data Register (PTIAD) 9 Port AD Data Register (PTIAD) 9 Port AD Data Direction Register (DDROAD) 9 Port AD Data Direction Register (DDROAD) 9 Port AD Data Direction Register (DDROAD) 9 Port AD Data Direction Register (RDROAD) 1 Port AD Reduced Drive Register (RDROAD) 9 Port AD Reduced Drive Register (RDROAD) 1 Port AD Reduced Drive Register (RDROAD) 9 Port AD Reduced Drive Register (RDROAD) 1 Port AD Reduced Drive Register (RDROAD) 9 Port AD Pull Up Enable Register (PERIAD) 1 Port AD Pull Up Enable Register (PERIAD) 5 PIM Reserved Registers 1 Port AD Reduced Drive Register (RDROAD) 1 Port AD Pull Up Enable Register (PERIAD) 5 PIM Reserved Registers 1 Port AD Pull Up Enable Register (PERIAD) 5 PIM Reserved Registers 1 Port AD Reduced Drive Register (PERIAD) 5 PIM Reserved Registers 1 Port AD Reduced Drive Register (PERIAD) 5 PIM Reserved Registers 1 Port AD Reduced Drive Register (PERIAD) 5 PIM Reserved Registers 5 Pins and Ports 6 PORT AD Pull Up Enable Register (PERIAD) 7 Port AD Pull Up Enable Register (PERIAD) 7 PORT AD Pull Up Enable Register (PERIAD) 8 PORT AD PULL Up Enable Register (PERIAD) 8 PORT AD PULL Up Enable Register (PERIAD) 9 PORT AD PULL Up Enable Register (PERIAD) 9 PORT AD PULL Up Enable Register (PERIAD) 9 PORT AD PULL Up Enable Register (PERIAD) 9 POR | S12P-Family Reference Manual, Rev. 1.13 | 3.2 | External Signal Description | 109 | |-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | 3.3 | Memory Map and Registers | 109 | | | 3.3.1 Module Memory Map | 109 | | | 3.3.2 Register Descriptions | | | 3.4 | Functional Description | 113 | | | 3.4.1 MCU Operating Modes | | | | 3.4.2 Memory Map Scheme | | | 3.5 | Implemented Memory in the System Memory Architecture | | | | 3.5.1 Chip Bus Control | | | | 3.5.2 Interrupts | | | 3.6 | Initialization/Application Information | | | 5.0 | 3.6.1 CALL and RTC Instructions | | | | | | | | Chapter 4 | | | | Interrupt Module (S12SINTV1) | | | 4.1 | Introduction | | | | 4.1.1 Glossary | | | | 4.1.2 Features | | | | 4.1.3 Modes of Operation | | | 4.0 | 4.1.4 Block Diagram | | | 4.2 | External Signal Description | | | 4.3 | Memory Map and Register Definition | | | | 4.3.1 Register Descriptions | | | 4.4 | Functional Description | | | | 4.4.1 S12S Exception Requests | | | | 4.4.2 Interrupt Prioritization | | | | 4.4.3 Reset Exception Requests | | | | 4.4.4 Exception Priority | | | 4.5 | Initialization/Application Information | | | | 4.5.1 Initialization | | | | 4.5.2 Interrupt Nesting | | | | 4.5.3 Wake Up from Stop or Wait Mode | 128 | | | Chapter 5 | | | | Background Debug Module (S12SBDMV1) | | | 5.1 | Introduction | 131 | | | 5.1.1 Features | | | | 5.1.2 Modes of Operation | | | | 5.1.3 Block Diagram | | | 5.2 | External Signal Description | | | 5.3 | Memory Map and Register Definition | | | | 5.3.1 Module Memory Map | | | | 5.3.2 Register Descriptions | | | | 5.3.3 Family ID Assignment | | | | tions Taming in Thompsine Control of the | 130 | S12P-Family Reference Manual, Rev. 1.13 Table 1-12. Interrupt Vector Locations (Sheet 2 of 3) | Vector Address <sup>(1)</sup> | Interrupt Source | CCR<br>Mask | Local Enable | Wake up from STOP | Wakeup<br>from WAIT | |------------------------------------------------|----------------------------------|-------------|-------------------------------------|-------------------|---------------------| | Vector base+ \$F0 | RTI timeout interrupt | I bit | CPMUINT (RTIE) | 7.6 Interrupts | | | Vector base+ \$EE | TIM timer channel 0 | I bit | TIE (C0I) | No | Yes | | Vector base + \$EC | TIM timer channel 1 | I bit | TIE (C1I) | No | Yes | | Vector base+ \$EA | TIM timer channel 2 | I bit | TIE (C2I) | No | Yes | | Vector base+ \$E8 | TIM timer channel 3 | I bit | TIE (C3I) | No | Yes | | Vector base+ \$E6 | TIM timer channel 4 | I bit | TIE (C4I) | No | Yes | | Vector base+ \$E4 | TIM timer channel 5 | I bit | TIE (C5I) | No | Yes | | Vector base + \$E2 | TIM timer channel 6 | I bit | TIE (C6I) | No | Yes | | Vector base+ \$E0 | TIM timer channel 7 | I bit | TIE (C7I) | No | Yes | | Vector base+ \$DE | TIM timer overflow | I bit | TSRC2 (TOF) | No | Yes | | Vector base+ \$DC | TIM Pulse accumulator A overflow | I bit | PACTL (PAOVI) | No | Yes | | Vector base + \$DA | TIM Pulse accumulator input edge | I bit | PACTL (PAI) | No | Yes | | Vector base + \$D8 | SPI | I bit | SPICR1 (SPIE, SPTIE) | No | Yes | | Vector base+ \$D6 | SCI | I bit | SCICR2<br>(TIE, TCIE, RIE, ILIE) | Yes | Yes | | Vector base + \$D4 | /ector base + \$D4 | | Reserved | | | | Vector base + \$D2 | ATD | I bit | ATDCTL2 (ASCIE) | Yes | Yes | | Vector base + \$D0 | Vector base + \$D0 Re | | Reserved | | | | Vector base + \$CE | Port J | I bit | PIEJ (PIEJ7-PIEJ6, PIEJ2-<br>PIEJ0) | Yes | Yes | | Vector base + \$CC<br>to<br>Vector base + \$CA | | | Reserved | | | | Vector base + \$C8 | Oscillator status interrupt | I bit | CPMUINT (OSCIE) | No | No | | Vector base + \$C6 | PLL lock interrupt | I bit | CPMUINT (LOCKIE) | No | No | | Vector base + \$C4<br>to<br>Vector base + \$BC | | | Reserved | | | | Vector base + \$BA | FLASH error | I bit | FERCNFG (SFDIE, DFDIE) | No | No | | Vector base + \$B8 | FLASH command | I bit | FCNFG (CCIE) | No | Yes | | Vector base + \$B6 | CAN wake-up | I bit | CANRIER (WUPIE) | | | | Vector base + \$B4 | CAN errors | I bit | CANRIER (CSCIE, OVRIE) | 0 4 7 154 | orrunto | | Vector base + \$B2 | CAN receive | I bit | CANRIER (RXFIE) | - 8.4.7 Int | erruptS | | Vector base + \$B0 | CAN transmit | I bit | CANTIER (TXEIE[2:0]) | | | #### Port S Data Register (PTS) 2.3.24 | Address 0x0248 | | | Access: User read/write <sup>(1)</sup> | | | | | | |---------------------|---|---|----------------------------------------|---|------|------|------|------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | R | 0 | 0 | 0 | 0 | DTCO | DTCO | DTC4 | DTCo | | w | | | | | PTS3 | PTS2 | PTS1 | PTS0 | | Altern.<br>Function | _ | _ | _ | _ | | _ | TXD | RXD | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 2-22. Port S Data Register (PTS) 1. Read: Anytime The data source is depending on the data direction value. Write: Anytime Table 2-21. PTS Register Field Descriptions | Field | Description | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3-2<br>PTS | Port S general purpose input/output data—Data Register When not used with the alternative function, the associated pin can be used as general purpose I/O. In general purpose output mode the register bit value is driven to the pin. If the associated data direction bit is set to 1, a read returns the value of the port register bit, otherwise the buffered pin input state is read. | | 1<br>PTS | Port S general purpose input/output data—Data Register, SCI TXD output When not used with the alternative function, the associated pin can be used as general purpose I/O. In general purpose output mode the register bit value is driven to the pin. If the associated data direction bit is set to 1, a read returns the value of the port register bit, otherwise the buffered pin input state is read. | | 0<br>PTS | The SCI function takes precedence over the general purpose I/O function if enabled. Port S general purpose input/output data—Data Register, SCI RXD input When not used with the alternative function, the associated pin can be used as general purpose I/O. In general purpose output mode the register bit value is driven to the pin. If the associated data direction bit is set to 1, a read returns the value of the port register bit, otherwise the buffered pin input state is read. | | | The SCI function takes precedence over the general purpose I/O function if enabled. | #### 2.3.25 **Port S Input Register (PTIS)** Figure 2-23. Port S Input Register (PTIS) S12P-Family Reference Manual, Rev. 1.13 ## 2.3.44 Port P Pull Device Enable Register (PERP) Figure 2-42. Port P Pull Device Enable Register (PERP) 1. Read: Anytime Write: Anytime Table 2-39. PERP Register Field Descriptions | Field | Description | |---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7,5-0<br>PERP | Port P pull device enable—Enable pull device on input pin This bit controls whether a pull device on the associated port input pin is active. If a pin is used as output this bit has no effect. The polarity is selected by the related polarity select register bit. | | | 1 Pull device enabled<br>0 Pull device disabled | # 2.3.45 Port P Polarity Select Register (PPSP) Figure 2-43. Port P Polarity Select Register (PPSP) 1. Read: Anytime Write: Anytime Table 2-40. PPSP Register Field Descriptions | Field | Description | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7,5-0<br>PPSP | Port P pull device select—Configure pull device and pin interrupt edge polarity on input pin This bit selects a pull-up or a pull-down device if enabled on the associated port input pin. This bit also selects the polarity of the active pin interrupt edge. | | | 1 A pull-down device is selected; rising edge selected 0 A pull-up device is selected; falling edge selected | ## 2.3.50 Port J Input Register (PTIJ) Figure 2-48. Port J Input Register (PTIJ) 1. Read: Anytime Write: Never, writes to this register have no effect. **Table 2-44. PTIJ Register Field Descriptions** | Field | Description | | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 7-6, 2-0<br>PTIJ | Port J input data— A read always returns the buffered input state of the associated pin. It can be used to detect overload or short circuit conditions on output pins. | | ### 2.3.51 Port J Data Direction Register (DDRJ) Figure 2-49. Port J Data Direction Register (DDRJ) Read: Anytime Write: Anytime **Table 2-45. DDRJ Register Field Descriptions** | Field | Description | |------------------|----------------------------------------------------------------------------------------------| | 7-6, 2-0<br>DDRJ | Port J data direction— This bit determines whether the associated pin is an input or output. | | | Associated pin is configured as output Associated pin is configured as input | Freescale Semiconductor 93 S12P-Family Reference Manual, Rev. 1.13 ## 2.3.60 Port AD Data Direction Register (DDR1AD) Figure 2-58. Port AD Data Direction Register (DDR1AD) 1. Read: Anytime Write: Anytime #### Table 2-54. DDR1AD Register Field Descriptions | Field | Description | | | | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 7-0<br>DDR1AD | Port AD data direction— This bit determines whether the associated pin is an input or output. To use the digital input function the ATD Digital Input Enable Register (ATDDIEN) has to be set to logic level "1". | | | | | | Associated pin is configured as output Associated pin is configured as input | | | | # 2.3.61 Port AD Reduced Drive Register (RDR0AD) Figure 2-59. Port AD Reduced Drive Register (RDR0AD) 1. Read: Anytime Write: Anytime Table 2-55. RDR0AD Register Field Descriptions | Field | Description | ] | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---| | 1-0<br>RDR0AD | Port AD reduced drive—Select reduced drive for output pin This bit configures the drive strength of the associated output pin as either full or reduced. If a pin is used as input this bit has no effect. The reduced drive function is independent of which function is being used on a particular pin. | | | | 1 Reduced drive selected (approx. 1/5 of the full drive strength) 0 Full drive strength enabled | | S12P-Family Reference Manual, Rev. 1.13 #### 6.4.2.2.2 Outside Range (address < CompA\_Addr or address > CompB\_Addr) In the Outside Range comparator mode, comparator pair A and B can be configured for range comparisons. A single match condition on either of the comparators is recognized as valid. An aligned word access which straddles the range boundary is valid only if the aligned address is outside the range. Outside range mode in combination with tagging can be used to detect if the opcode fetches are from an unexpected range. In forced match mode the outside range match would typically be activated at any interrupt vector fetch or register access. This can be avoided by setting the upper range limit to \$3FFFF or lower range limit to \$00000 respectively. ### 6.4.3 Match Modes (Forced or Tagged) Match modes are used as qualifiers for a state sequencer change of state. The Comparator control register TAG bits select the match mode. The modes are described in the following sections. #### 6.4.3.1 Forced Match When configured for forced matching, a comparator channel match can immediately initiate a transition to the next state sequencer state whereby the corresponding flags in DBGSR are set. The state control register for the current state determines the next state. Forced matches are typically generated 2-3 bus cycles after the final matching address bus cycle, independent of comparator RWE/RW settings. Furthermore since opcode fetches occur several cycles before the opcode execution a forced match of an opcode address typically precedes a tagged match at the same address. ### 6.4.3.2 Tagged Match If a CPU taghit occurs a transition to another state sequencer state is initiated and the corresponding DBGSR flags are set. For a comparator related taghit to occur, the DBG must first attach tags to instructions as they are fetched from memory. When the tagged instruction reaches the execution stage of the instruction queue a taghit is generated by the CPU. This can initiate a state sequencer transition. ## 6.4.3.3 Immediate Trigger Independent of comparator matches it is possible to initiate a tracing session and/or breakpoint by writing to the TRIG bit in DBGC1. If configured for begin aligned tracing, this triggers the state sequencer into the Final State, if configured for end alignment, setting the TRIG bit disarms the module, ending the session and issues a forced breakpoint request to the CPU. It is possible to set both TRIG and ARM simultaneously to generate an immediate trigger, independent of the current state of ARM. #### 6.4.3.4 Channel Priorities In case of simultaneous matches the priority is resolved according to Table 6-36. The lower priority is suppressed. It is thus possible to miss a lower priority match if it occurs simultaneously with a higher priority. The priorities described in Table 6-36 dictate that in the case of simultaneous matches, the match pointing to final state has highest priority followed by the lower channel number (0,1,2). S12P-Family Reference Manual, Rev. 1.13 Table 7-9. RTI Frequency Divide Rates for RTDEC = 0 | | | RTR[6:4] = | | | | | | | | | | | |------------|------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|--|--|--|--| | RTR[3:0] | 000<br>(OFF) | 001<br>(2 <sup>10</sup> ) | 010<br>(2 <sup>11</sup> ) | 011<br>(2 <sup>12</sup> ) | 100<br>(2 <sup>13</sup> ) | 101<br>(2 <sup>14</sup> ) | 110<br>(2 <sup>15</sup> ) | 111<br>(2 <sup>16</sup> ) | | | | | | 0000 (÷1) | OFF <sup>1</sup> | 2 <sup>10</sup> | 2 <sup>11</sup> | 2 <sup>12</sup> | 2 <sup>13</sup> | 2 <sup>14</sup> | 2 <sup>15</sup> | 2 <sup>16</sup> | | | | | | 0001 (÷2) | OFF | 2x2 <sup>10</sup> | 2x2 <sup>11</sup> | 2x2 <sup>12</sup> | 2x2 <sup>13</sup> | 2x2 <sup>14</sup> | 2x2 <sup>15</sup> | 2x2 <sup>16</sup> | | | | | | 0010 (÷3) | OFF | 3x2 <sup>10</sup> | 3x2 <sup>11</sup> | 3x2 <sup>12</sup> | 3x2 <sup>13</sup> | 3x2 <sup>14</sup> | 3x2 <sup>15</sup> | 3x2 <sup>16</sup> | | | | | | 0011 (÷4) | OFF | 4x2 <sup>10</sup> | 4x2 <sup>11</sup> | 4x2 <sup>12</sup> | 4x2 <sup>13</sup> | 4x2 <sup>14</sup> | 4x2 <sup>15</sup> | 4x2 <sup>16</sup> | | | | | | 0100 (÷5) | OFF | 5x2 <sup>10</sup> | 5x2 <sup>11</sup> | 5x2 <sup>12</sup> | 5x2 <sup>13</sup> | 5x2 <sup>14</sup> | 5x2 <sup>15</sup> | 5x2 <sup>16</sup> | | | | | | 0101 (÷6) | OFF | 6x2 <sup>10</sup> | 6x2 <sup>11</sup> | 6x2 <sup>12</sup> | 6x2 <sup>13</sup> | 6x2 <sup>14</sup> | 6x2 <sup>15</sup> | 6x2 <sup>16</sup> | | | | | | 0110 (÷7) | OFF | 7x2 <sup>10</sup> | 7x2 <sup>11</sup> | 7x2 <sup>12</sup> | 7x2 <sup>13</sup> | 7x2 <sup>14</sup> | 7x2 <sup>15</sup> | 7x2 <sup>16</sup> | | | | | | 0111 (÷8) | OFF | 8x2 <sup>10</sup> | 8x2 <sup>11</sup> | 8x2 <sup>12</sup> | 8x2 <sup>13</sup> | 8x2 <sup>14</sup> | 8x2 <sup>15</sup> | 8x2 <sup>16</sup> | | | | | | 1000 (÷9) | OFF | 9x2 <sup>10</sup> | 9x2 <sup>11</sup> | 9x2 <sup>12</sup> | 9x2 <sup>13</sup> | 9x2 <sup>14</sup> | 9x2 <sup>15</sup> | 9x2 <sup>16</sup> | | | | | | 1001 (÷10) | OFF | 10x2 <sup>10</sup> | 10x2 <sup>11</sup> | 10x2 <sup>12</sup> | 10x2 <sup>13</sup> | 10x2 <sup>14</sup> | 10x2 <sup>15</sup> | 10x2 <sup>1</sup> | | | | | | 1010 (÷11) | OFF | 11x2 <sup>10</sup> | 11x2 <sup>11</sup> | 11x2 <sup>12</sup> | 11x2 <sup>13</sup> | 11x2 <sup>14</sup> | 11x2 <sup>15</sup> | 11x2 <sup>1</sup> | | | | | | 1011 (÷12) | OFF | 12x2 <sup>10</sup> | 12x2 <sup>11</sup> | 12x2 <sup>12</sup> | 12x2 <sup>13</sup> | 12x2 <sup>14</sup> | 12x2 <sup>15</sup> | 12x2 <sup>1</sup> | | | | | | 1100 (÷13) | OFF | 13x2 <sup>10</sup> | 13x2 <sup>11</sup> | 13x2 <sup>12</sup> | 13x2 <sup>13</sup> | 13x2 <sup>14</sup> | 13x2 <sup>15</sup> | 13x2 <sup>1</sup> | | | | | | 1101 (÷14) | OFF | 14x2 <sup>10</sup> | 14x2 <sup>11</sup> | 14x2 <sup>12</sup> | 14x2 <sup>13</sup> | 14x2 <sup>14</sup> | 14x2 <sup>15</sup> | 14x2 <sup>1</sup> | | | | | | 1110 (÷15) | OFF | 15x2 <sup>10</sup> | 15x2 <sup>11</sup> | 15x2 <sup>12</sup> | 15x2 <sup>13</sup> | 15x2 <sup>14</sup> | 15x2 <sup>15</sup> | 15x2 <sup>1</sup> | | | | | | 1111 (÷16) | OFF | 16x2 <sup>10</sup> | 16x2 <sup>11</sup> | 16x2 <sup>12</sup> | 16x2 <sup>13</sup> | 16x2 <sup>14</sup> | 16x2 <sup>15</sup> | 16x2 <sup>1</sup> | | | | | <sup>&</sup>lt;sup>1</sup> Denotes the default value out of reset. This value should be used to disable the RTI to ensure future backwards compatibility. ### 7.3.2.18 Reserved Register CPMUTEST3 ### **NOTE** This reserved register is designed for factory test purposes only, and is not intended for general user access. Writing to this register when in special mode can alter the S12CPMU's functionality. Figure 7-23. Reserved Register (CPMUTEST3) Read: Anytime Write: Only in special mode Several examples of PLL divider settings are shown in Table 7-23. The following rules help to achieve optimum stability and shortest lock time: - Use lowest possible $f_{VCO}$ / $f_{REF}$ ratio (SYNDIV value). - Use highest possible REFCLK frequency f<sub>REF</sub>. Table 7-23. Examples of PLL Divider Settings | f <sub>osc</sub> | REFDIV[3:0] | f <sub>REF</sub> | REFFRQ[1:0] | SYNDIV[5:0] | f <sub>VCO</sub> | VCOFRQ[1:0] | POSTDIV[4:0] | f <sub>PLL</sub> | f <sub>bus</sub> | |------------------|-------------|------------------|-------------|-------------|------------------|-------------|--------------|------------------|------------------| | off | \$00 | 1MHz | 00 | \$1F | 64MHz | 01 | \$03 | 16MHz | 8MHz | | off | \$00 | 1MHz | 00 | \$1F | 64MHz | 01 | \$00 | 64MHz | 32MHz | | off | \$00 | 1MHz | 00 | \$0F | 32MHz | 00 | \$00 | 32MHz | 16MHz | | 4MHz | \$00 | 4MHz | 01 | \$03 | 32MHz | 01 | \$00 | 32MHz | 16MHz | The phase detector inside the PLL compares the feedback clock (FBCLK = VCOCLK/(SYNDIV+1)) with the reference clock (REFCLK = IRC1M or OSCCLK/REFDIV+1)). Correction pulses are generated based on the phase difference between the two signals. The loop filter alters the DC voltage on the internal filter capacitor, based on the width and direction of the correction pulse, which leads to a higher or lower VCO frequency. The user must select the range of the REFCLK frequency (REFFRQ[1:0] bits) and the range of the VCOCLK frequency (VCOFRQ[1:0] bits) to ensure that the correct PLL loop bandwidth is set. The lock detector compares the frequencies of the FBCLK and the REFCLK. Therefore the speed of the lock detector is directly proportional to the reference clock frequency. The circuit determines the lock condition based on this comparison. If PLL LOCK interrupt requests are enabled, the software can wait for an interrupt request and for instance check the LOCK bit. If interrupt requests are disabled, software can poll the LOCK bit continuously (during PLL start-up) or at periodic intervals. In either case, only when the LOCK bit is set, the VCOCLK will have stabilized to the programmed frequency. - The LOCK bit is a read-only indicator of the locked state of the PLL. - The LOCK bit is set when the VCO frequency is within the tolerance $\Delta_{Lock}$ and is cleared when the VCO frequency is out of the tolerance $\Delta_{unl}$ . - Interrupt requests can occur if enabled (LOCKIE = 1) when the lock condition changes, toggling the LOCK bit. For microcontrollers without a clock and reset generator (CRG), CANCLK is driven from the crystal oscillator (oscillator clock). A programmable prescaler generates the time quanta (Tq) clock from CANCLK. A time quantum is the atomic unit of time handled by the MSCAN. $$Tq = \frac{f_{CANCLK}}{(Prescaler value)}$$ A bit time is subdivided into three segments as described in the Bosch CAN specification. (see Figure 8-44): - SYNC\_SEG: This segment has a fixed length of one time quantum. Signal edges are expected to happen within this section. - Time Segment 1: This segment includes the PROP\_SEG and the PHASE\_SEG1 of the CAN standard. It can be programmed by setting the parameter TSEG1 to consist of 4 to 16 time quanta. - Time Segment 2: This segment represents the PHASE\_SEG2 of the CAN standard. It can be programmed by setting the TSEG2 parameter to be 2 to 8 time quanta long. Eqn. 8-3 Bit Rate= $$\frac{f_{Tq}}{(number of Time Quanta)}$$ Figure 8-44. Segments within the Bit Time | Address | Name | _ | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | |---------|--------------------|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|----------------|--------------------------------|----------|---------| | 0x0003 | ATDCTL3 | R<br>W | DJM | S8C | S4C | S2C | S1C | FIFO | FRZ1 | FRZ0 | | 0x0004 | ATDCTL4 | R<br>W | SMP2 | SMP1 | SMP0 | | | PRS[4:0] | | | | 0x0005 | ATDCTL5 | R<br>W | 0 | SC | SCAN | MULT | CD | СС | СВ | CA | | 0x0006 | ATDSTAT0 | R<br>W | SCF | 0 | ETORF | FIFOR | CC3 | CC2 | CC1 | CC0 | | 0x0007 | Unimple-<br>mented | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0008 | ATDCMPEH | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | CMPI | E[9:8] | | 0x0009 | ATDCMPEL | R<br>W | | | | СМ | PE[7:0] | | | | | 0x000A | ATDSTAT2H | R | 0 | 0 | 0 | 0 | 0 | 0 | CCF | [9:8] | | | | W<br>R | | | | CC | <br> | | | | | 0x000B | ATDSTAT2L | W | | | | | [] | | | | | 0x000C | ATDDIENH | R<br>W | 0 | 0 | 0 | 0 | 0 | 0 | IEN | [9:8] | | 0x000D | ATDDIENL | R | | | | l IF | l<br>N[7:0] | | | | | 0,,000 | / <b></b> | W<br>R | 0 | 0 | 0 | 0 | 0 | 0 | | | | 0x000E | ATDCMPHTH | W | | | | | | | CMPH | IT[9:8] | | 0x000F | ATDCMPHTL | R<br>W | | | | CMF | PHT[7:0] | | | | | 0x0010 | ATDDR0 | R<br>W | | | | | | sult Data (Doesult Data (D | | | | 0x0012 | ATDDR1 | R<br>W | | | | | | sult Data (Doesult Data (D | | | | 0x0014 | ATDDR2 | R<br>W | | | | | | sult Data (Doesult Data (D | , | | | 0x0016 | ATDDR3 | R<br>W | | | | | | sult Data (D.<br>esult Data (D | | | | 0x0018 | ATDDR4 | R<br>W | | See | Section 9.3. | 2.12.1, "Lef | t Justified Re | sult Data (D.<br>esult Data (D | JM=0)" | | | 0x001A | ATDDR5 | R<br>W | | See | Section 9.3. | 2.12.1, "Lef | t Justified Re | sult Data (D.<br>esult Data (D | JM=0)" | | | 0x001C | ATDDR6 | R<br>W | | See | Section 9.3. | 2.12.1, "Lef | t Justified Re | sult Data (D. | JM=0)" | | | 0x001E | ATDDR7 | R<br>W | | and Section 9.3.2.12.2, "Right Justified Result Data (DJM=1)" See Section 9.3.2.12.1, "Left Justified Result Data (DJM=0)" and Section 9.3.2.12.2, "Right Justified Result Data (DJM=1)" | | | | | | | | | | [ | | , | mented or R | | | | <u> </u> | | Figure 9-2. ADC12B10C Register Summary (Sheet 2 of 3) S12P-Family Reference Manual, Rev. 1.13 Read: anytime Write: anytime (causes the scale counter to load the PWMSCLA value) ### 10.3.2.10 PWM Scale B Register (PWMSCLB) PWMSCLB is the programmable scale value used in scaling clock B to generate clock SB. Clock SB is generated by taking clock B, dividing it by the value in the PWMSCLB register and dividing that by two. Clock SB = Clock B / (2 \* PWMSCLB) #### **NOTE** When PWMSCLB = 0x0000, PWMSCLB value is considered a full scale value of 256. Clock B is thus divided by 512. Any value written to this register will cause the scale counter to load the new scale value (PWMSCLB). Figure 10-12. PWM Scale B Register (PWMSCLB) Read: anytime Write: anytime (causes the scale counter to load the PWMSCLB value). ## 10.3.2.11 Reserved Registers (PWMSCNTx) The registers PWMSCNTA and PWMSCNTB are reserved for factory testing of the PWM module and are not available in normal modes. Figure 10-13. Reserved Register (PWMSCNTA) ### 12.3.2.5 SPI Data Register (SPIDR = SPIDRH:SPIDRL) | Module Ba | ase +0x0004^ | ^^^^ | ^^^^ | ^^^^ | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | ^^^^ | ^^^^ | ······································ | |-----------|--------------|------|------|------|----------------------------------------|------|------|----------------------------------------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | R | R15 | R14 | R13 | R12 | R11 | R10 | R9 | R8 | | W | T15 | T14 | T13 | T12 | T11 | T10 | Т9 | Т8 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 12-7. SPI Data Register High (SPIDRH) | | | | | | | | | *************************************** | |-------|----|----|----|----|----|----|----|-----------------------------------------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | R | R7 | R6 | R5 | R4 | R3 | R2 | R1 | R0 | | W | T7 | T6 | T5 | T4 | T3 | T2 | T1 | T0 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 12-8. SPI Data Register Low (SPIDRL) Read: Anytime; read data only valid when SPIF is set Write: Anytime The SPI data register is both the input and output register for SPI data. A write to this register allows data to be queued and transmitted. For an SPI configured as a master, queued data is transmitted immediately after the previous transmission has completed. The SPI transmitter empty flag SPTEF in the SPISR register indicates when the SPI data register is ready to accept new data. Received data in the SPIDR is valid when SPIF is set. If SPIF is cleared and data has been received, the received data is transferred from the receive shift register to the SPIDR and SPIF is set. If SPIF is set and not serviced, and a second data value has been received, the second received data is kept as valid data in the receive shift register until the start of another transmission. The data in the SPIDR does not change. If SPIF is set and valid data is in the receive shift register, and SPIF is serviced before the start of a third transmission, the data in the receive shift register is transferred into the SPIDR and SPIF remains set (see Figure 12-9). If SPIF is set and valid data is in the receive shift register, and SPIF is serviced after the start of a third transmission, the data in the receive shift register has become invalid and is not transferred into the SPIDR (see Figure 12-10). #### 13.1.2 Features #### 13.1.2.1 P-Flash Features - 128 Kbytes of P-Flash memory composed of one 128 Kbyte Flash block divided into 256 sectors of 512 bytes - Single bit fault correction and double bit fault detection within a 32-bit double word during read operations - Automated program and erase algorithm with verify and generation of ECC parity bits - Fast sector erase and phrase program operation - Ability to read the P-Flash memory while programming a word in the D-Flash memory - Flexible protection scheme to prevent accidental program or erase of P-Flash memory #### 13.1.2.2 D-Flash Features - 4 Kbytes of D-Flash memory composed of one 4 Kbyte Flash block divided into 16 sectors of 256 bytes - Single bit fault correction and double bit fault detection within a word during read operations - Automated program and erase algorithm with verify and generation of ECC parity bits - Fast sector erase and word program operation - Protection scheme to prevent accidental program or erase of D-Flash memory - Ability to program up to four words in a burst sequence #### 13.1.2.3 Other Flash Module Features - No external high-voltage power supply required for Flash memory program and erase operations - Interrupt generation on Flash command completion and Flash error detection - Security mechanism to prevent unauthorized access to the Flash memory ## 13.1.3 Block Diagram The block diagram of the Flash module is shown in Figure 13-1. Figure 13-16. Flash Common Command Object High Register (FCCOBHI) Figure 13-17. Flash Common Command Object Low Register (FCCOBLO) #### 13.3.2.11.1 FCCOB - NVM Command Mode NVM command mode uses the indexed FCCOB register to provide a command code and its relevant parameters to the Memory Controller. The user first sets up all required FCCOB fields and then initiates the command's execution by writing a 1 to the CCIF bit in the FSTAT register (a 1 written by the user clears the CCIF command completion flag to 0). When the user clears the CCIF bit in the FSTAT register all FCCOB parameter fields are locked and cannot be changed by the user until the command completes (as evidenced by the Memory Controller returning CCIF to 1). Some commands return information to the FCCOB register array. The generic format for the FCCOB parameter fields in NVM command mode is shown in Table 13-23. The return values are available for reading after the CCIF flag in the FSTAT register has been returned to 1 by the Memory Controller. Writes to the unimplemented parameter fields (CCOBIX = 110 and CCOBIX = 111) are ignored with reads from these fields returning 0x0000. Table 13-23 shows the generic Flash command format. The high byte of the first word in the CCOB array contains the command code, followed by the parameters for this specific Flash command. For details on the FCCOB settings required by each command, see the Flash command descriptions in Section 13.4.5. | CCOBIX[2:0] | Byte | FCCOB Parameter Fields (NVM Command Mode) | |-------------|------|-------------------------------------------| | 000 | HI | FCMD[7:0] defining Flash command | | 000 | LO | 6'h0, Global address [17:16] | | 001 | HI | Global address [15:8] | | 001 | LO | Global address [7:0] | | 010 | HI | Data 0 [15:8] | | 010 | LO | Data 0 [7:0] | Table 13-23. FCCOB - NVM Command Mode (Typical Usage) ## A.2.3.1 ATD Accuracy Definitions For the following definitions see also Figure A-1. Differential non-linearity (DNL) is defined as the difference between two adjacent switching steps. $$DNL(i) = \frac{V_i - V_{i-1}}{1LSB} - 1$$ The integral non-linearity (INL) is defined as the sum of all DNLs: $$INL(n) = \sum_{i=1}^{n} DNL(i) = \frac{V_n - V_0}{1LSB} - n$$