Data Sheet, Dec. 2000

## C505

C505C
C505A
C505CA
8-Bit-Single-Chip Microcontroller

Microcontrollers

Edition 2000-12
Published by Infineon Technologies AG, St.-Martin-Strasse 53, D-81541 München, Germany
© Infineon Technologies AG 2000.
All Rights Reserved.

## Attention please!

The information herein is given to describe certain components and shall not be considered as warranted characteristics.
Terms of delivery and rights to technical change reserved.
We hereby disclaim any and all warranties, including but not limited to warranties of non-infringement, regarding circuits, descriptions and charts stated herein.
Infineon Technologies is an approved CECC manufacturer.

## Information

For further information on technology, delivery terms and conditions and prices please contact your nearest Infineon Technologies Office in Germany or our Infineon Technologies Representatives worldwide (see address list).

## Warnings

Due to technical requirements components may contain dangerous substances. For information on the types in question please contact your nearest Infineon Technologies Office.
Infineon Technologies Components may only be used in life-support devices or systems with the express written approval of Infineon Technologies, if a failure of such components can reasonably be expected to cause the failure of that life-support device or system, or to affect the safety or effectiveness of that device or system. Life support devices or systems are intended to be implanted in the human body, or to support and/or maintain and sustain and/or protect human life. If they fail, it is reasonable to assume that the health of the user or other persons may be endangered.

## C505

C505C
C505A
C505CA
8-Bit Single-Chip Microcontroller

## Microcontrollers

| C505/C505C/C505A/C505CA <br> Revision History : |  | Data Sheet <br> Current Version : 2000-12 |
| :--- | :--- | :--- |
| Previous Releases : | 08.00, 06.00, 07.99, 12.97 |  |
| Page <br> (in previous <br> version | Page <br> (in current <br> version) | Subjects (major changes since last revision) |
| 24 | 24 | Version register VR2 for C505A-4R/C505CA-4R BB step is updated. |
|  |  |  |
|  |  |  |

## Controller Area Network (CAN): License of Robert Bosch GmbH

## We Listen to Your Comments

Any information within this document that you feel is wrong, unclear or missing at all? Your feedback will help us to continuously improve the quality of this document. Please send your proposal (including a reference to this document) to: mcdocu.comments@infineon.com


## 8-Bit Single-Chip Microcontroller C500 Family

## Advance Information

- Fully compatible to standard 8051 microcontroller
- Superset of the 8051 architecture with 8 datapointers
- Up to 20 MHz operating frequency
- 375 ns instruction cycle time @16 MHz
- 300 ns instruction cycle time @20 MHz (50 \% duty cycle)
- On-chip program memory (with optional memory protection)
- C505(C)(A)-2R : 16K byte on-chip ROM
- C505A-4R/C505CA-4R: 32K byte on-chip ROM
- C505A-4E/C505CA-4E: 32K byte on-chip OTP
- alternatively up to 64 k byte external program memory
- 256 byte on-chip RAM
- On-chip XRAM
- C505/C505C : 256 byte
- C505A/C505CA : 1K byte
(more features on next page)


Figure 1
C505 Functional Units

Features (continued) :

- 32 + 2 digital I/O lines
- Four 8-bit digital I/O ports
- One 2-bit digital I/O port (port 4)
- Port 1 with mixed analog/digital I/O capability
- Three 16-bit timers/counters
- Timer 0 / 1 (C501 compatible)
- Timer 2 with 4 channels for 16-bit capture/compare operation
- Full duplex serial interface with programmable baudrate generator (USART)
- Full CAN Module, version 2.0 B compliant (C505C and C505CA only)
- 256 register/data bytes located in external data memory area
- 1 MBaud CAN baudrate when operating frequency is equal to or above 8 MHz
- internal CAN clock prescaler when input frequency is over 10 MHz
- On-chip A/D Converter
- up to 8 analog inputs
- C505/C505C : 8-bit resolution
- C505A/C505CA: 10-bit resolution
- Twelve interrupt sources with four priority levels
- On-chip emulation support logic (Enhanced Hooks Technology ${ }^{\text {TM }}$ )
- Programmable 15-bit watchdog timer
- Oscillator watchdog
- Fast power on reset
- Power Saving Modes
- Slow-down mode
- Idle mode (can be combined with slow-down mode)
- Software power-down mode with wake up capability through P3.2/INT0 or P4.1/RXDC pin
- P-MQFP-44 package
- Pin configuration is compatible to C501, C504, C511/C513-family
- Temperature ranges:

SAB-C505 versions
SAF-C505 versions
SAH-C505 versions
SAK-C505 versions
$T_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C}$
$T_{\mathrm{A}}=-40$ to $85^{\circ} \mathrm{C}$
$T_{\mathrm{A}}=-40$ to $110^{\circ} \mathrm{C}$
$T_{\text {A }}=-40$ to $125^{\circ} \mathrm{C}$

Table 1
Differences in Functionality of the C505 MCUs

| Device | Internal Program Memory |  | XRAM Size | A/D Converter Resolution | CAN Controller |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | ROM | OTP |  |  |  |
| C505-2R | 16K byte | - | 256 byte | 8 Bit | - |
| C505-L | - | - | 256 byte | 8 Bit | - |
| C505C-2R | 16K byte | - | 256 byte | 8 Bit | $\checkmark$ |
| C505C-L | - | - | 256 byte | 8 Bit | $\checkmark$ |
| C505A-4R | 32K byte | - | 1K byte | 10 Bit | - |
| C505A-2R | 16K byte | - | 1K byte | 10 Bit | - |
| C505A-L | - | - | 1K byte | 10 Bit | - |
| C505CA-4R | 32K byte | - | 1K byte | 10 Bit | $\checkmark$ |
| C505CA-2R | 16K byte | - | 1K byte | 10 Bit | $\checkmark$ |
| C505CA-L | - | - | 1K byte | 10 Bit | $\checkmark$ |
| C505A-4E | - | 32K byte | 1K byte | 10 Bit | - |
| C505CA-4E | - | 32K byte | 1K byte | 10 Bit | $\checkmark$ |

Note: The term C505 refers to all versions described within this document unless otherwise noted. However the term C505 may also be restricted by the context to refer to only CAN-less derivatives with 8-Bit ADC which are C505-2R and C505-L in this document.
Note: The term C505(C)(A)-2R, for simplicity, is used to stand for C505 16K byte ROM versions within this document which are C505-2R, C505C-2R, C505A-2R and C505CA-2R.

## Ordering Information

The ordering code for Infineon Technologies' microcontrollers provides an exact reference to the required product. This ordering code identifies:

- the derivative itself, i.e. its function set
- the specificed temperature rage
- the package and the type of delivery

For the available ordering codes for the C505 please refer to the "Product information Microcontrollers", which summarizes all available microcontroller variants.


Figure 2

## Logic Symbol

Note: The ordering codes for the Mask-ROM versions are defined for each product after verification of the respective ROM code.


Figure 3
C505 Pin Configuration P-MQFP-44 Package (Top View)

Table 2
Pin Definitions and Functions

| Symbol | Pin Number | $\begin{aligned} & \text { I/O } \\ & \text { *) } \end{aligned}$ | Function |
| :---: | :---: | :---: | :---: |
| P1.0-P1.7 | 40-44,1-3 | I/O | Port 1 <br> is an 8-bit quasi-bidirectional port with internal pull-up arrangement. Port 1 pins can be used for digital input/output or as analog inputs of the A/D converter. Port 1 pins that have 1's written to them are pulled high by internal pull-up transistors and in that state can be used as inputs. As inputs, port 1 pins being externally pulled low will source current ( $I_{\mathrm{IL}}$, in the DC characteristics) because of the internal pullup transistors. Port 1 pins are assigned to be used as analog inputs via the register P1ANA. <br> As secondary digital functions, port 1 contains the interrupt, timer, clock, capture and compare pins. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate (except for compare functions). The secondary functions are assigned to the pins of port 1 as follows: <br> P1.0 / AN0 / $\overline{\mathrm{NT} 3} / \mathrm{CCO}$ Analog input channel 0 interrupt 3 input / capture/compare channel 0 I/O <br> P1.1 / AN1 / INT4 / CC1 Analog input channel 1/ interrupt 4 input / capture/compare channel 1 I/O <br> P1.2 / AN2 / INT5 / CC2 Analog input channel 2 / interrupt 5 input / capture/compare channel 2 I/O <br> P1.3 / AN3 / INT6 / CC3 Analog input channel 3 interrupt 6 input / capture/compare channel 3 I/O <br> P1.4 / AN4 <br> P1.5 / AN5 / T2EX <br> P1.6 / AN6 / CLKOUT <br> P1.7 / AN7 / T2 <br> Analog input channel 4 <br> Analog input channel 5 / Timer 2 external reload / trigger input Analog input channel 6 / system clock output Analog input channel 7 / counter 2 input <br> Port 1 is used for the low-order address byte during program verification of the C505 ROM versions (i.e. C505(C)(A)-2R/ C505A-4R/C505CA-4R). |
|  | 40 41 |  |  |
|  | 42 |  |  |
|  | 43 |  |  |
|  | 44 |  |  |
|  | 1 |  |  |
|  | 2 |  |  |
|  | 3 |  |  |

[^0]Table 2
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | $\begin{aligned} & \text { I/O } \\ & \left.{ }^{*}\right) \end{aligned}$ | Function |
| :---: | :---: | :---: | :---: |
| RESET | 4 | I | RESET <br> A high level on this pin for two machine cycle while the oscillator is running resets the device. An internal diffused resistor to $V_{\text {SS }}$ permits power-on reset using only an external capacitor to $V_{\mathrm{DD}}$. |
| P3.0-P3.7 | 5, 7-13 | I/O | Port 3 <br> is an 8-bit quasi-bidirectional port with internal pull-up arrangement. Port 3 pins that have 1's written to them are pulled high by the internal pull-up transistors and in that state can be used as inputs. As inputs, port 3 pins being externally pulled low will source current ( $I_{\mathrm{IL}}$, in the DC characteristics) because of the internal pullup transistors. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate (except for TxD and $\overline{W R}$ ). The secondary functions are assigned to the pins of port 3 as follows: |
|  | 5 |  | $\begin{array}{ll}\text { P3.0 / RxD } & \begin{array}{l}\text { Receiver data input (asynch.) or data } \\ \text { input/output (synch.) of serial interface }\end{array}\end{array}$ |
|  | 7 |  | P3.1 / TxD $\quad \begin{aligned} & \text { Transmitter data output (asynch.) or } \\ & \text { clock output (synch.) of serial interface }\end{aligned}$ |
|  | 8 |  | P3.2 / $\overline{\text { INTO }} \quad \begin{aligned} & \text { External interrupt } 0 \text { input / timer } 0 \text { gate } \\ & \text { control input }\end{aligned}$ |
|  | 9 |  | P3.3 / INT1 External interrupt 1 input / timer 1 gate <br> control input |
|  | 10 |  | P3.4 / T0 Timer 0 counter input |
|  | 11 |  | P3.5 / T1 Timer 1 counter input |
|  | 12 |  | P3.6 / $\overline{\mathrm{WR}}$ $\overline{\mathrm{WR}}$ control output; latches the data <br> byte from port 0 into the external data <br> memory <br>   |
|  | 13 |  | P3.7 / $\overline{\mathrm{RD}} \quad \begin{aligned} & \overline{\mathrm{RD}} \text { control output; enables the external } \\ & \text { data memory }\end{aligned}$ |

[^1]Table 2
Pin Definitions and Functions (cont'd)


Table 2
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | I/O <br> *) | Function <br> P2.0-P2.7 <br> $18-25$ <br> I/OPort 2 <br> is a an 8-bit quasi-bidirectional I/O port with internal pullup <br> resistors. Port 2 pins that have 1's written to them are pulled <br> high by the internal pullup resistors, and in that state can be <br> used as inputs. As inputs, port 2 pins being externally pulled <br> low will source current (IIL, in the DC characteristics) <br> because of the internal pullup resistors. Port 2 emits the <br> high-order address byte during fetches from external <br> program memory and during accesses to external data <br> memory that use 16-bit addresses (MOVX @DPTR). In this <br> application it uses strong internal pullup transistors when <br> issuing 1s. During accesses to external data memory that <br> use 8-bit addresses (MOVX @Ri), port 2 issues the <br> contents of the P2 special function register and uses only <br> the internal pullup resistors. |
| :--- | :--- | :--- | :--- |
| $\overline{\text { PSEN }}$ | 26 | O | The Program Store Enable <br> output is a control signal that enables the external program <br> memory to the bus during external fetch operations. It is <br> activated every three oscillator periods except during <br> external data memory accesses. Remains high during <br> internal program execution. This pin should not be driven <br> during reset operation. |
| ALE | 27 | O | The Address Latch Enable <br> output is used for latching the low-byte of the address into <br> external memory during normal operation. It is activated <br> every three oscillator periods except during an external data <br> memory access. When instructions are executed from <br> internal ROM or OTP (EA=1) the ALE generation can be <br> disabled by bit EALE in SFR SYSCON. <br> ALE should not be driven during reset operation. |

[^2]Table 2
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | $\begin{aligned} & \text { I/O } \\ & \text { *) } \end{aligned}$ | Function |
| :---: | :---: | :---: | :---: |
| $\overline{\overline{E A}}$ | 29 | I | External Access Enable <br> When held at high level, instructions are fetched from the internal program memory when the PC is less than $4000_{\mathrm{H}}$ (C505(C)(A)-2R) or 8000H (C505A-4R/C505CA-4R/C505A$4 \mathrm{E} / \mathrm{C} 505 \mathrm{CA}-4 \mathrm{E})$. When held at low level, the C505 fetches all instructions from external program memory. <br> For the C505 romless versions (i.e. C505-L, C505C-L, C505A-L and C505CA-L) this pin must be tied low. For the ROM protection version $\overline{E A}$ pin is latched during reset. |
| P0.0-P0.7 | 37-30 | I/O | Port 0 <br> is an 8-bit open-drain bidirectional I/O port. Port 0 pins that have 1's written to them float, and in that state can be used as high-impendance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external program or data memory. In this application it uses strong internal pullup transistors when issuing 1 's. <br> Port 0 also outputs the code bytes during program verification in the C505 ROM versions. External pullup resistors are required during program verification. |
| $V_{\text {AREF }}$ | 38 | - | Reference voltage for the A/D converter. |
| $V_{\text {AGND }}$ | 39 | - | Reference ground for the A/D converter. |
| $V_{\text {SS }}$ | 16 | - | Ground (0V) |
| $V_{\text {DD }}$ | 17 | - | Power Supply (+5V) |

[^3]$\mathrm{O}=$ Output

C505/C505C/C505A/C505CA


C505C/C505CA only. 1) Please refer to Table 1 for device specific configuration.

Figure 4
Block Diagram of the C505/C505C/C505A/C505CA

## CPU

The C505 is efficient both as a controller and as an arithmetic processor. It has extensive facilities for binary and BCD arithmetic and excels in its bit-handling capabilities. Efficient use of program memory results from an instruction set consisting of $44 \%$ one-byte, $41 \%$ two-byte, and $15 \%$ threebyte instructions. With a 16 MHz crystal, $58 \%$ of the instructions are executed in $375 \mathrm{~ns}(20 \mathrm{MHz}$ : 300 ns ).

Special Function Register PSW (Address $\mathrm{DO}_{\mathrm{H}}$ )
Reset Value : $\mathbf{0 0}_{\mathrm{H}}$

Bit No. MSB LSB


| Bit | Function |  |  |
| :---: | :---: | :---: | :---: |
| CY | Carry Flag <br> Used by arithmetic instruction. |  |  |
| AC | Auxiliary Carry Flag <br> Used by instructions which execute BCD operations. |  |  |
| F0 | General Purpose Flag |  |  |
| $\begin{aligned} & \text { RS1 } \\ & \text { RS0 } \end{aligned}$ | Register Bank Select Control Bits <br> These bits are used to select one of the four register banks. |  |  |
|  | RS1 | RS0 | Function |
|  | 0 | 0 | Bank 0 selected, data address $00^{-}{ }^{-07} \mathrm{H}$ |
|  | 0 | 1 | Bank 1 selected, data address $08 \mathrm{H}^{-0 \mathrm{~F}_{\mathrm{H}}}$ |
|  | 1 | 0 | Bank 2 selected, data address $10 \mathrm{H}^{-17} \mathrm{H}$ |
|  | 1 | 1 | Bank 3 selected, data address $18 \mathrm{H}^{-1 \mathrm{~F}_{\mathrm{H}}}$ |
| OV | Overflow Flag Used by arithmetic instruction. |  |  |
| F1 | General Purpose Flag |  |  |
| P | Parity Flag <br> Set/cleared by hardware after each instruction to indicate an odd/even number of "one" bits in the accumulator, i.e. even parity. |  |  |

## Memory Organization

The C505 CPU manipulates operands in the following four address spaces:

- On-chip program memory :16K byte ROM (C505(C)(A)-2R) or 32 K byte ROM (C505A-4R/C505CA-4R) or 32K byte OTP (C505A-4E/C505CA-4E)
- Totally up to 64 K byte internal/external program memory
- up to 64 Kbyte of external data memory
- 256 bytes of internal data memory
- Internal XRAM data memory :256 byte (C505/C505C) 1K byte (C505A/C505CA)
- a 128 byte special function register area

Figure 5 illustrates the memory address spaces of the C505 versions.


Figure 5
C505 Memory Map Memory Map

## Reset and System Clock

The reset input is an active high input at pin RESET. Since the reset is synchronized internally, the RESET pin must be held high for at least two machine cycles (12 oscillator periods) while the oscillator is running. A pulldown resistor is internally connected to $V_{\text {SS }}$ to allow a power-up reset with an external capacitor only. An automatic reset can be obtained when $V_{\mathrm{DD}}$ is applied by connecting the RESET pin to $V_{D D}$ via a capacitor. Figure 6 shows the possible reset circuitries.


Figure 6

## Reset Circuitries

Figure 7 shows the recommended oscillator circuits for crystal and external clock operation.


Figure 7
Recommended Oscillator Circuitries

## Multiple Datapointers

As a functional enhancement to the standard 8051 architecture, the C505 contains eight 16-bit datapointers instead of only one datapointer. The instruction set uses just one of these datapointers at a time. The selection of the actual datapointer is done in the special function regsiter DPSEL. Figure 8 illustrates the datapointer addressing mechanism.


Figure 8
External Data Memory Addressing using Multiple Datapointers

C505/C505C/C505A/C505CA

## Enhanced Hooks Emulation Concept

The Enhanced Hooks Emulation Concept of the C500 microcontroller family is a new, innovative way to control the execution of C500 MCUs and to gain extensive information on the internal operation of the controllers. Emulation of on-chip ROM based programs is possible, too.
Each production chip has built-in logic for the supprt of the Enhanced Hooks Emulation Concept. Therefore, no costly bond-out chips are necessary for emulation. This also ensure that emulation and production chips are identical.
The Enhanced Hooks Technology ${ }^{\text {™ }}{ }^{1}$, which requires embedded logic in the C500 allows the C500 together with an EH-IC to function similar to a bond-out chip. This simplifies the design and reduces costs of an ICE-system. ICE-systems using an EH-IC and a compatible C500 are able to emulate all operating modes of the different versions of the C500 microcontrollers. This includes emulation of ROM, ROM with code rollover and ROMless modes of operation. It is also able to operate in single step mode and to read the SFRs after a break.


Figure 9

## Basic C500 MCU Enhanced Hooks Concept Configuration

Port 0, port 2 and some of the control lines of the C500 based MCU are used by Enhanced Hooks Emulation Concept to control the operation of the device during emulation and to transfer informations about the programm execution and data transfer between the external emulation hardware (ICE-system) and the C500 MCU.

[^4]
## Special Function Registers

The registers, except the program counter and the four general purpose register banks, reside in the special function register area. The special function register area consists of two portions : the standard special function register area and the mapped special function register area. Five special function register of the C505 (PCON1,P1ANA, VR0, VR1, VR2) are located in the mapped special function register area. For accessing the mapped special function register area, bit RMAP in special function register SYSCON must be set. All other special function registers are located in the standard special function register area which is accessed when RMAP is cleared ("0").
The registers and data locations of the CAN controller (CAN-SFRs) are located in the external data memory area at addresses $\mathrm{F}^{700} \mathrm{H}_{\mathrm{H}}$ to $\mathrm{F}_{\mathrm{FFF}}^{\mathrm{H}}$.

Special Function Register SYSCON (Address B1H) (C505CA only)

Reset Value : XX100X01B
Reset Value : XX100001B


The functions of the shaded bits are not described here.

1) This bit is only available in the C505CA.

| Bit | Function |
| :--- | :--- |
| RMAP | Special function register map bit <br> RMAP $=0:$ The access to the non-mapped (standard) special function register <br> area is enabled. |
|  | RMAP $=1:$ The access to the mapped special function register area is enabled. |
| CSWO | CAN Controller switch-off bit <br> CSWO $=0:$ CAN Controller is enabled (default after reset). <br> CSWO $=1:$ CAN Controller is switched off. |

As long as bit RMAP is set, mapped special function register area can be accessed. This bit is not cleared by hardware automatically. Thus, when non-mapped/mapped registers are to be accessed, the bit RMAP must be cleared/set respectively by software.

All SFRs with addresses where address bits $0-2$ are $0\left(e . g .80_{H}, 88_{H}, 90_{H}, 98_{H}, \ldots, 8_{H}, F_{H}\right)$ are bitaddressable.

The 52 special function registers (SFRs) in the standard and mapped SFR area include pointers and registers that provide an interface between the CPU and the other on-chip peripherals. The SFRs of the C505 are listed in Table 3 and Table 4. In Table 3 they are organized in groups which refer to the functional blocks of the C505. The CAN-SFRs (applicable for the C505C and C505CA only) are also included in Table 3. Table 4 illustrates the contents of the SFRs in numeric order of their addresses. Table 5 list the CAN-SFRs in numeric order of their addresses.

Table 3
Special Function Registers - Functional Blocks

| Block | Symbol | Name | Address | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| CPU | ACC <br> B <br> DPH <br> DPL <br> DPSEL <br> PSW <br> SP <br> SYSCON ${ }^{2}$ <br> VRO ${ }^{4)}$ <br> VR1 ${ }^{4)}$ <br> VR2 ${ }^{4)}$ | Accumulator <br> B-Register <br> Data Pointer, High Byte <br> Data Pointer, Low Byte <br> Data Pointer Select Register <br> Program Status Word Register <br> Stack Pointer <br> System Control Register <br> Version Register 0 <br> Version Register 1 <br> Version Register 2 | $\begin{array}{\|l} \hline \mathrm{EO}_{\mathbf{H}}{ }^{1)} \\ \mathrm{FO}_{\mathbf{H}^{1)}} \\ 83_{\mathrm{H}} \\ 82_{\mathrm{H}} \\ 92_{\mathrm{H}} \\ \mathrm{DO}_{\mathbf{H}}{ }^{1)} \\ 81_{\mathrm{H}} \\ \mathrm{Br}_{\mathrm{H}} \\ \\ \mathrm{FC}_{\mathrm{H}} \\ \mathrm{FD}_{\mathrm{H}} \\ \mathrm{FE} \\ \hline \end{array}$ | ```\({ }^{00} \mathrm{H}\) \({ }^{00} \mathrm{H}\) \({ }^{00} \mathrm{H}\) \({ }^{00} \mathrm{H}\) XXXXX000 \({ }^{3)}\) \({ }^{00} \mathrm{H}\) \({ }^{07} \mathrm{H}\) XX100X01 \({ }^{3 \text { 3) }}{ }^{6}\) XX100001 \({ }^{3 \text { 3) }}\) \(\mathrm{C}^{\mathrm{C}} \mathrm{H}\) \({ }^{05} \mathrm{H}\) 5)``` |
| A/DConverter | ADCONO ${ }^{2)}$ <br> ADCON1 <br> ADDAT <br> ADST <br> ADDATH <br> ADDATL <br> P1ANA ${ }^{2)}$ 4) | A/D Converter Control Register 0 <br> A/D Converter Control Register 1 <br> A/D Converter Data Reg. (C505/C505C) <br> A/D Converter Start Reg. (C505/C505C) <br> A/D Converter High Byte Data Register <br> (C505A/C505CA) <br> A/D Converter Low Byte Data Register <br> (C505A/C505CA) <br> Port 1 Analog Input Selection Register | $\begin{aligned} & \text { D8 }_{H}{ }^{1)} \\ & \text { DC }_{H} \\ & \text { D9 }{ }_{H} \\ & D A_{H} \\ & D 9_{H} \\ & D A_{H} \\ & 90_{H} \\ & \hline \end{aligned}$ |  |
| Interrupt System | IENO ${ }^{2)}$ <br> IEN1 ${ }^{2)}$ <br> IPO ${ }^{2)}$ <br> IP1 <br> TCON ${ }^{2)}$ <br> T2CON ${ }^{2)}$ <br> SCON ${ }^{2)}$ <br> IRCON | Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Priority Register 0 Interrupt Priority Register 1 Timer Control Register Timer 2 Control Register Serial Channel Control Register Interrupt Request Control Register |  | $\begin{aligned} & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & \mathrm{XXO} 00000_{\mathrm{B}}{ }^{3)} \\ & 00_{\mathrm{H}} \\ & 00 \mathrm{X}^{3} 00000_{\mathrm{B}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & \hline \end{aligned}$ |
| XRAM | XPAGE <br> SYSCON ${ }^{2}$ | Page Address Register for Extended on-chip XRAM and CAN Controller <br> System Control Register | $\begin{aligned} & { }^{91} \mathrm{H} \\ & \mathrm{~B} 1_{\mathrm{H}} \end{aligned}$ | $\begin{aligned} & 00 \mathrm{H} \\ & \mathrm{XX100X01} \mathrm{~B}^{3)}{ }^{6)} \\ & \mathrm{XX100001} \mathrm{~B}^{3) 7} \end{aligned}$ |

[^5]C505/C505C/C505A/C505CA

Table 3
Special Function Registers - Functional Blocks (cont'd)

| Block | Symbol | Name | Address | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| Ports | $\begin{aligned} & \text { P0 } \\ & \text { P1 } \\ & \text { P1ANA 2) 4) } \\ & \text { P2 } \\ & \text { P3 } \\ & \text { P4 } \end{aligned}$ | Port 0 <br> Port 1 <br> Port 1 Analog Input Selection Register <br> Port 2 <br> Port 3 <br> Port 4 |  | $\begin{aligned} & \mathrm{FF} \mathrm{~F}_{\mathrm{H}} \\ & \mathrm{FF} \mathrm{H}_{\mathrm{H}} \\ & \mathrm{FF} \\ & \mathrm{H} \\ & \mathrm{FF} \\ & \mathrm{H} \\ & \mathrm{FF} \\ & \mathrm{H} \\ & \mathrm{XXXXXX11} \end{aligned}$ |
| Serial Channel | $\begin{aligned} & \text { ADCONO }{ }^{2)} \\ & \text { PCON }{ }^{2)} \\ & \text { SBUF } \\ & \text { SCON } \\ & \text { SRELL } \\ & \text { SRELH } \end{aligned}$ | A/D Converter Control Register 0 <br> Power Control Register <br> Serial Channel Buffer Register <br> Serial Channel Control Register <br> Serial Channel Reload Register, low byte <br> Serial Channel Reload Register, high byte | D8 ${ }^{1}{ }^{1)}$ <br> ${ }^{87} \mathrm{H}$ <br> ${ }^{99} \mathrm{H}$ <br> $9^{98} \mathrm{H}^{1)}$ <br> $\mathrm{AA}_{\mathrm{H}}$ <br> $\mathrm{BA}_{\mathrm{H}}$ | $\begin{aligned} & 00 \mathrm{XO}^{00000_{\mathrm{B}}{ }^{3)}} \\ & 00_{\mathrm{H}} \\ & \mathrm{XX}_{\mathrm{H}}{ }^{3)} \\ & 00_{\mathrm{H}} \\ & \mathrm{D} 9_{\mathrm{H}} \\ & \mathrm{XXXXX11} \end{aligned}{ }^{3)}$ |
| Timer 0/ Timer 1 | $\begin{array}{\|l\|} \hline \text { TCON } \\ \text { TH0 } \\ \text { TH1 } \\ \text { TLO } \\ \text { TL1 } \\ \text { TMOD } \\ \hline \end{array}$ | Timer 0/1 Control Register <br> Timer 0, High Byte <br> Timer 1, High Byte <br> Timer 0, Low Byte <br> Timer 1, Low Byte <br> Timer Mode Register | $\begin{array}{\|l} \hline 88_{\mathrm{H}}{ }^{1)} \\ 8 \mathrm{C}_{\mathrm{H}} \\ 8 \mathrm{D}_{\mathrm{H}} \\ 8 \mathrm{~A}_{\mathrm{H}} \\ 8 \mathrm{~B}_{\mathrm{H}} \\ 89_{\mathrm{H}} \end{array}$ | $\begin{aligned} & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \end{aligned}$ |
| Compare/ <br> Capture <br> Unit / <br> Timer 2 | CCEN CCH1 CCH 2 CCH 3 CCL 1 $\mathrm{CCL2}$ CCL 3 CRCH CRCL TH2 TL2 T2CON IENO | Comp./Capture Enable Reg. <br> Comp./Capture Reg. 1, High Byte Comp./Capture Reg. 2, High Byte Comp./Capture Reg. 3, High Byte Comp./Capture Reg. 1, Low Byte Comp./Capture Reg. 2, Low Byte Comp./Capture Reg. 3, Low Byte Reload Register High Byte Reload Register Low Byte Timer 2, High Byte Timer 2, Low Byte Timer 2 Control Register Interrupt Enable Register 0 Interrupt Enable Register 1 |  | $00 \mathrm{H}^{3)}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} 0_{\mathrm{H}}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> $00 \mathrm{X} 00000_{\mathrm{B}}{ }^{3)}$ <br> $0^{00} \mathrm{H}$ <br> $0^{00} \mathrm{H}$ |
| Watchdog | WDTREL IENO ${ }^{\text {2) }}$ <br> IEN1 ${ }^{\text {2) }}$ <br> IPO ${ }^{2)}$ | Watchdog Timer Reload Register Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Priority Register 0 | $\begin{aligned} & 86_{H} \\ & \mathbf{A 8}_{\mathbf{H}}{ }^{11} \\ & \text { B8 }_{H^{11}} \\ & \mathrm{~A}_{\mathrm{H}} \\ & \hline \end{aligned}$ | $\begin{array}{\|l} \hline 00_{\mathrm{H}} \\ 00_{\mathrm{H}} \\ 00_{\mathrm{H}} \\ 00_{\mathrm{H}} \\ \hline \end{array}$ |
| Pow. Save Modes | $\begin{array}{\|l\|} \hline \text { PCON }{ }^{2)} \\ \text { PCON1 }{ }^{4)} \end{array}$ | Power Control Register Power Control Register 1 | $\begin{array}{\|l} 87 \\ \mathrm{H} \\ 88 \\ \mathbf{8 B}^{1)} \end{array}$ | $\begin{aligned} & 00_{\mathrm{H}} \\ & 0^{\prime X X O X X X}{ }^{3)} \end{aligned}$ |

1) Bit-addressable special function registers
2) This special function register is listed repeatedly since some bits of it also belong to other functional blocks.
3) " $X$ " means that the value is undefined and the location is reserved
4) SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set.

Table 3
Special Function Registers - Functional Blocks (cont'd)

| Block | Symbol | Name | Address | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| CAN | CR | Control Register | $\mathrm{F}^{700} \mathrm{H}$ | 01 |
| Controller | SR | Status Register | $\mathrm{F}^{701} \mathrm{H}$ | $\mathrm{XX}_{\mathrm{H}}{ }^{\text {3) }}$ |
|  | IR | Interrupt Register | ${ }^{7} 702 \mathrm{H}$ | $X X^{\text {H) }}$ |
| (C505C/ | BTR0 | Bit Timing Register Low | ${ }^{5} 704 \mathrm{H}$ | $\mathrm{UU}_{\mathrm{H}^{3)}}$ |
| $\begin{aligned} & \text { C505CA } \\ & \text { only) } \end{aligned}$ | BTR1 | Bit Timing Register High | F705H | OUUUUUUU ${ }_{\text {B }}{ }^{3}$ |
|  | GMS0 | Global Mask Short Register Low | ${ }^{\mathrm{F} 706} \mathrm{H}$ | $\mathrm{UU}_{\mathrm{H}^{3)}}$ |
|  | GMS1 | Global Mask Short Register High | $\mathrm{F}^{7} 07 \mathrm{H}$ | UUU11111 ${ }_{\text {B }}{ }^{3 /}$ |
|  | UGMLO | Upper Global Mask Long Register Low | F708H | $\mathrm{UU}_{\mathrm{H}}{ }^{3 /}$ |
|  | UGML1 | Upper Global Mask Long Register High | ${ }^{\mathrm{F} 709} \mathrm{H}$ | $\mathrm{UU}_{\mathrm{H}^{3)}}$ |
|  | LGML0 | Lower Global Mask Long Register Low | $\mathrm{F}^{\text {7 }}$ A ${ }_{\mathrm{H}}$ | $\mathrm{UU}_{\mathrm{H}^{3 /}}$ |
|  | LGML1 | Lower Global Mask Long Register High | $\mathrm{F}^{\text {70B }}$ H | UUUUU000 ${ }_{\text {B }}{ }^{3)}$ |
|  | UMLMO | Upper Mask of Last Message Register Low | $\mathrm{F}^{\text {70C }} \mathrm{H}$ | $\mathrm{UU}_{\mathrm{H}^{3)}}$ |
|  | UMLM1 | Upper Mask of Last Message Register High | $\mathrm{F}^{\text {70D }} \mathrm{H}$ | $\mathrm{UU}_{\mathrm{H}^{3)}}$ |
|  | LMLMO | Lower Mask of Last Message Register Low | $\mathrm{F}^{\text {70E }} \mathrm{H}$ | $\mathrm{UU}_{\mathrm{H}^{3)}}$ |
|  | LMLM1 | Lower Mask of Last Message Register High Message Object Registers : | $\mathrm{F}^{\text {70F }} \mathrm{H}$ | UUUUU000 ${ }_{\text {B }}{ }^{3)}$ |
|  | MCR0 | Message Control Register Low | $\mathrm{F}_{7 \mathrm{nO}}^{\mathrm{H}}{ }^{5}$ | $\mathrm{UU}_{\mathrm{H}^{3)}}$ |
|  | MCR1 | Message Control Register High | F7n1 ${ }^{\text {5 }}$ ) | $U U_{H}{ }^{3 /}$ |
|  | UAR0 | Upper Arbitration Register Low | F7n2 ${ }^{5}{ }^{5}$ | $\mathrm{UU}_{\mathrm{H}^{3)}}$ |
|  | UAR1 | Upper Arbitration Register High | F7n3 ${ }^{5}{ }^{5}$ | $\mathrm{UU}_{\mathrm{H}^{3)}}$ |
|  | LAR0 | Lower Arbitration Register Low | F7n4 ${ }^{5}{ }^{5}$ | $U U_{H^{3}}$ |
|  | LAR1 | Lower Arbitration Register High | F7n5 ${ }^{\text {5 }}$ | UUUUU000 ${ }_{\text {B }}{ }^{3)}$ |
|  | MCFG | Message Configuration Register | F7n6 ${ }^{\text {5) }}$ | UUUUUU00 ${ }^{3}{ }^{3}$ |
|  | DB0 | Message Data Byte 0 | F7n7 ${ }^{\text {5) }}$ | $\mathrm{XX}_{\mathrm{H}^{3)}}$ |
|  | DB1 | Message Data Byte 1 | F7n8 ${ }^{\text {5) }}$ | $X X_{H}{ }^{\text {3) }}$ |
|  | DB2 | Message Data Byte 2 | F7n9 ${ }^{\text {5) }}$ | $\mathrm{XX}_{\mathrm{H}^{3)}}$ |
|  | DB3 | Message Data Byte 3 | ${ }^{\text {F7nA }}{ }^{\text {5 }}$ | $\mathrm{XX}_{\mathrm{H}^{3)}}$ |
|  | DB4 | Message Data Byte 4 | $\mathrm{F}_{7 \mathrm{nB}}^{\mathrm{H}}{ }^{5}$ | $X X_{H}{ }^{3)}$ |
|  | DB5 | Message Data Byte 5 | $\mathrm{F7nC}_{\mathrm{H}^{5}}{ }^{\text {) }}$ | $\mathrm{XX}_{\mathrm{H}^{3)}}$ |
|  | DB6 | Message Data Byte 6 | $\mathrm{F7nD}^{5}{ }^{\text {5 }}$ | $\mathrm{XX}_{\mathrm{H}^{3)}}$ |
|  | DB7 | Message Data Byte 7 | $\mathrm{F}_{\mathrm{nE}}^{\mathrm{H}}{ }^{5)}$ | $X X_{H}{ }^{3)}$ |

[^6]C505/C505C/C505A/C505CA

Table 4
Contents of the SFRs, SFRs in numeric order of their addresses

| Addr | Register | Content after Reset ${ }^{1)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $80^{\text {H) }}$ | P0 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| ${ }^{81} \mathrm{H}$ | SP | $0^{07}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| ${ }^{82} \mathrm{H}$ | DPL | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| ${ }^{83} \mathrm{H}$ | DPH | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| ${ }^{86} \mathrm{H}$ | WDTREL | ${ }^{00} \mathrm{H}$ | WDT PSEL | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| ${ }^{87} \mathrm{H}$ | PCON | ${ }^{00} \mathrm{H}$ | SMOD | PDS | IDLS | SD | GF1 | GFO | PDE | IDLE |
| $88 \mathrm{H}^{2)}$ | TCON | ${ }^{00} \mathrm{H}$ | TF1 | TR1 | TFO | TRO | IE1 | IT1 | IE0 | ITO |
| $88 \mathrm{H}^{3)}$ | PCON1 | $\begin{aligned} & 0 X X 0- \\ & \text { XXXX }_{B} \end{aligned}$ | EWPD | - | - | WS | - | - | - | - |
| $89^{\text {H }}$ | TMOD | ${ }^{00} \mathrm{H}$ | GATE | C/T | M1 | M0 | GATE | C/T | M1 | M0 |
| $8 \mathrm{~A}_{\mathrm{H}}$ | TL0 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $8{ }^{8 B_{H}}$ | TL1 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $8 \mathrm{C}_{\mathrm{H}}$ | TH0 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $8 \mathrm{D}_{\mathrm{H}}$ | TH1 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $90 \mathrm{H}^{2)}$ | P1 | $\mathrm{FF}_{\mathrm{H}}$ | T2 | $\begin{aligned} & \text { CLK- } \\ & \text { OUT } \end{aligned}$ | T2EX | . 4 | INT6 | INT5 | INT4 | INT3 |
| $90 \mathrm{H}^{3)}$ | P1ANA | $\mathrm{FF}_{\mathrm{H}}$ | EAN7 | EAN6 | EAN5 | EAN4 | EAN3 | EAN2 | EAN1 | EANO |
| ${ }^{91} \mathrm{H}$ | XPAGE | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| 92 H | DPSEL | $\begin{array}{\|l} \hline \mathrm{XXXX}- \\ \mathrm{XOOO}_{\mathrm{B}} \\ \hline \end{array}$ | - | - | - | - | - | . 2 | . 1 | . 0 |
| $98 \mathrm{H}^{2)}$ | SCON | ${ }^{00} \mathrm{H}$ | SM0 | SM1 | SM2 | REN | TB8 | RB8 | TI | RI |
| ${ }^{99}{ }_{\mathrm{H}}$ | SBUF | $\mathrm{XX}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{AO}^{\text {H) }}$ | P2 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{ABH}^{2)}$ | IENO | ${ }^{00} \mathrm{H}$ | EA | WDT | ET2 | ES | ET1 | EX1 | ETO | EXO |
| ${ }^{\text {A9 }} \mathrm{H}$ | IP0 | ${ }^{00} \mathrm{H}$ | OWDS | WDTS | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{AA}_{\mathrm{H}}$ | SRELL | $\mathrm{D9}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |

1) $X$ means that the value is undefined and the location is reserved
2) Bit-addressable special function registers
3) SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set.

Table 4
Contents of the SFRs, SFRs in numeric order of their addresses (cont'd)

| Addr | Register | Content after <br> Reset ${ }^{1)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{BO}^{\text {2) }}$ | P3 | $\mathrm{FF}_{\mathrm{H}}$ | $\overline{\mathrm{RD}}$ | $\overline{\mathrm{WR}}$ | T1 | T0 | $\overline{\text { INT1 }}$ | $\overline{\text { INTO }}$ | TxD | RxD |
| $\mathrm{B1}_{\mathrm{H}}$ | SYSCON 3) | $\begin{array}{\|l\|} \hline \mathrm{XX10-} \\ 0 \times 01_{\mathrm{B}} \end{array}$ | - | - | EALE | RMAP | CMOD | - | XMAP1 | XMAP0 |
| $\overline{\mathrm{B1}} \mathrm{H}$ | SYSCON | $\begin{array}{\|l\|l\|} \hline \mathrm{XX10} \\ 0001_{\mathrm{B}} \\ \hline \end{array}$ | - | - | EALE | RMAP | CMOD | CSWO | XMAP1 | XMAP0 |
| $\mathrm{B8}^{\text {H }}{ }^{2)}$ | IEN1 | ${ }^{00} \mathrm{H}$ | EXEN2 | SWDT | EX6 | EX5 | EX4 | EX3 | ECAN | EADC |
| ${ }^{B 9} \mathrm{H}$ | IP1 | $\begin{array}{\|l\|} \hline \mathrm{XXOO}- \\ 0000_{\mathrm{B}} \end{array}$ | - | - | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{BA}_{\mathrm{H}}$ | SRELH | $\begin{array}{\|l\|} \hline \mathrm{XXXX} \\ \mathrm{XX11} \\ \hline \end{array}$ | - | - | - | - | - | - | . 1 | . 0 |
| $\mathrm{COH}^{2)}$ | IRCON | ${ }^{00} \mathrm{H}$ | EXF2 | TF2 | IEX6 | IEX5 | IEX4 | IEX3 | SWI | IADC |
| $\mathrm{C1}_{\mathrm{H}}$ | CCEN | ${ }^{00} \mathrm{H}$ | $\begin{array}{\|l\|l\|} \hline \text { COCA } \\ \text { H3 } \end{array}$ | $\begin{array}{\|l\|} \hline \text { COCAL } \\ 3 \end{array}$ | $\begin{aligned} & \text { COCA } \\ & \text { H2 } \end{aligned}$ | $\begin{aligned} & \text { COCAL } \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { COCA } \\ & \mathrm{H} 1 \end{aligned}$ | $\begin{aligned} & \text { COCAL } \\ & 1 \end{aligned}$ | $\begin{array}{\|l} \text { COCA } \\ \text { H0 } \\ \hline \end{array}$ | COCAL $0$ |
| C 2 H | CCL1 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C3}_{\mathrm{H}}$ | CCH1 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C} 4_{\mathrm{H}}$ | CCL2 | ${ }^{00} \mathrm{H}$ | . 7 | 6 | . 5 | . 4 | 3 | . 2 | . 1 | . 0 |
| $\mathrm{C}^{\mathrm{H}} \mathrm{H}$ | CCH 2 | ${ }^{00} \mathrm{H}$ | . 7 | 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{Cb}_{\mathrm{H}}$ | CCL3 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C7}_{\mathrm{H}}$ | CCH 3 | ${ }^{00} \mathrm{H}$ | . 7 | 6 | . 5 | . 4 | 3 | . 2 | . 1 | . 0 |
| C8H ${ }^{2}$ | T2CON | $\begin{aligned} & 00 \times \mathrm{XO}- \\ & 0000_{\mathrm{B}} \\ & \hline \end{aligned}$ | T2PS | I3FR | - | T2R1 | T2R0 | T2CM | T211 | T210 |
| $\mathrm{CA}_{\mathrm{H}}$ | CRCL | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{CB}_{\mathrm{H}}$ | CRCH | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{CCH}_{\mathrm{H}}$ | TL2 | ${ }^{00} \mathrm{H}$ | . 7 | 6 | . 5 | . 4 | 3 | . 2 | . 1 | . 0 |
| $\mathrm{CD}_{\mathrm{H}}$ | TH2 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{DOH}^{2}$ | PSW | ${ }^{00} \mathrm{H}$ | CY | AC | F0 | RS1 | RS0 | OV | F1 | P |
| D8 $\mathrm{H}^{2)}$ | ADCON0 | $\begin{aligned} & 00 \times 0- \\ & 0000_{\mathrm{B}} \end{aligned}$ | BD | CLK | - | BSY | ADM | MX2 | MX1 | MXO |

[^7]Table 4
Contents of the SFRs, SFRs in numeric order of their addresses (cont'd)

| Addr | Register | Content after Reset ${ }^{1)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D9H | ADDAT ${ }^{6}$ | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{D}^{\mathrm{H}}$ | ADDATH | $0^{00}$ | . 9 | . 8 | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 |
| $\overline{D A}_{H}$ | ADST ${ }^{6)}$ | $\begin{aligned} & \mathrm{XXXX}- \\ & \text { XXXX }_{\mathrm{B}} \\ & \hline \end{aligned}$ | - | - | - | - | - | - | - | - |
| $\mathrm{DA}_{\mathrm{H}}$ | ADDATL 7) | $\begin{aligned} & 00 X X- \\ & \text { XXXX }_{B} \end{aligned}$ | . 1 | . 0 | - | - | - | - | - | - |
| $\mathrm{DC}_{\mathrm{H}}$ | ADCON1 | $\begin{array}{\|l\|} \hline 01 \mathrm{XX}- \\ \mathrm{X} 000_{\mathrm{B}} \\ \hline \end{array}$ | ADCL1 | ADCL0 | - | - | - | MX2 | MX1 | MXO |
| $\mathrm{EOH}^{2)}$ | ACC | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | 0 |
| $\mathrm{EBH}^{2)}$ | P4 | $\begin{aligned} & \mathrm{XXXX}- \\ & \mathrm{XX11} \mathrm{~B} \end{aligned}$ | - | - | - | - | - | - | RXDC | TXDC |
| $\mathrm{FO}^{(2)}$ | B | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{FC}^{3 / 44}$ | VR0 | ${ }^{\mathrm{C} 5} \mathrm{H}$ | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 |
| $\mathrm{FD}^{3 / 44}$ | VR1 | ${ }^{05} \mathrm{H}$ | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 |
| $\mathrm{FE}^{3 / 4)}$ | VR2 ${ }^{5}$ | $\begin{aligned} & 01 \mathrm{H}^{8)} \\ & 12 \mathrm{H}^{91} \\ & 33 \mathrm{H}^{10)} \end{aligned}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |

1) $X$ means that the value is undefined and the location is reserved
2) Bit-addressable special function registers
3) SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set.
4) These are read-only registers
5) The content of this SFR varies with the actual of the step C505 (eg. $01_{\mathrm{H}}$ or $11_{\mathrm{H}}$ or $21_{\mathrm{H}}$ for the first step)
6) C505 / C505C only
7) C505A / C505CA only
8) C505 / C505C AB step only
9) C505A-4E / C505CA-4E BA step only ( $11_{H}$ for the AA step)
10) C505A-4R / C505CA-4R BB step only ( $32_{H}$ for the BA step)

Table 5
Contents of the CAN Registers in numeric order of their addresses (C505C/C505CA only)

| Addr. $n=1-F_{H}$ 1) | Register | Content after <br> Reset ${ }^{2)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\underline{\mathrm{F} 700_{\mathrm{H}}}$ | CR | ${ }^{01} \mathrm{H}$ | TEST | CCE | 0 | 0 | EIE | SIE | IE | INIT |
| F701H | SR | $X X_{H}$ | BOFF | EWRN | - | RXOK | TXOK | LEC2 | LEC1 | LEC0 |
| ${ }^{\text {F702H }}$ | IR | $\mathrm{XX}_{\mathrm{H}}$ | INTID |  |  |  |  |  |  |  |
| ${ }^{\text {F704 }} \mathrm{H}$ | BTR0 | $\mathrm{UU}_{\mathrm{H}}$ | SJW |  | BRP |  |  |  |  |  |
| F705H | BTR1 | OUUU. $\mathrm{UUUU}_{B}$ | 0 TSEG2 |  |  |  | TSEG1 |  |  |  |
| F706H | GMS0 | $\mathrm{UU}_{\mathrm{H}}$ | ID28-21 |  |  |  |  |  |  |  |
| F707H | GMS1 | $\begin{aligned} & \text { UUU1. } \\ & 1111_{\mathrm{B}} \end{aligned}$ | ID20-18 |  |  | 1 | 1 | 1 | 1 | 1 |
| $\mathrm{F708}_{\mathrm{H}}$ | UGMLO | $\mathrm{UU}_{\mathrm{H}}$ | ID28-21 |  |  |  |  |  |  |  |
| $\underline{\mathrm{F709}}{ }_{\mathrm{H}}$ | UGML1 | $\mathrm{UU}_{\mathrm{H}}$ | ID20-13 |  |  |  |  |  |  |  |
| $\mathrm{F70A}_{\mathrm{H}}$ | LGMLO | $\mathrm{UU}_{\mathrm{H}}$ | ID12-5 |  |  |  |  |  |  |  |
| $\mathrm{F}^{\text {70B }} \mathrm{H}$ | LGML1 | $\begin{aligned} & \text { UUUU. } \\ & \text { UOOO }_{\mathrm{B}} \end{aligned}$ | ID4-0 |  |  |  |  | 0 | 0 | 0 |
| ${\overline{\mathrm{F} 70 C_{H}}}^{\text {l }}$ | UMLM0 | $\mathrm{UU}_{\mathrm{H}}$ | ID28-21 |  |  |  |  |  |  |  |
| $\mathrm{F70D}_{\mathrm{H}}$ | UMLM1 | $\mathrm{UU}_{\mathrm{H}}$ | ID20-18 |  |  | ID17-13 |  |  |  |  |
| $\mathrm{F70E}_{\mathrm{H}}$ | LMLM0 | $\mathrm{UU}_{\mathrm{H}}$ | ID12-5 |  |  |  |  |  |  |  |
| $\mathrm{F}^{\text {70F }} \mathrm{H}$ | LMLM1 | $\begin{aligned} & \text { UUUU. } \\ & \text { UOOO }_{\mathrm{B}} \end{aligned}$ | ID4-0 |  |  |  |  | 0 | 0 | 0 |
| $\underline{\mathrm{F7n0}} \mathrm{H}$ | MCR0 | $\mathrm{UU}_{\mathrm{H}}$ | MS | GVAL | TXIE |  | RXIE |  | INTPND |  |
| $\mathrm{F}^{\text {nn1 }} \mathrm{H}$ | MCR1 | $\mathrm{UU}_{\mathrm{H}}$ | RM | PND | TXRQ |  | MSGLST CPUUPD |  | NEWDAT |  |
| $\underline{\text { F7n2 }}$ H | UAR0 | $\mathrm{UU}_{\mathrm{H}}$ | ID28-21 |  |  |  |  |  |  |  |
| ${ }^{\mathrm{F} 7 \mathrm{n} 3} \mathrm{H}$ | UAR1 | $\mathrm{UU}_{\mathrm{H}}$ | ID20-18 |  |  | ID17-13 |  |  |  |  |
| $\underline{\text { F7n4 }} \mathrm{H}$ | LAR0 | $\mathrm{UU}_{\mathrm{H}}$ | ID12-5 |  |  |  |  |  |  |  |
| F7n5H | LAR1 | UUUU. U000 ${ }_{B}$ | ID4-0 |  |  |  |  | 0 | 0 | 0 |

[^8]C505/C505C/C505A/C505CA

Table 5
Contents of the CAN Registers in numeric order of their addresses (cont'd) (C505C/C505CA only)

| Addr. $\mathrm{n}=1-\mathrm{F}_{\mathrm{H}}$ 1) | Register | Content after Reset ${ }^{2)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| F7n6 ${ }_{\text {H }}$ | MCFG | UUUU. UU00B | DLC |  |  |  | DIR | XTD | 0 | 0 |
| F7n7H | DB0 | XX ${ }_{\text {H }}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\underline{\text { F7n8H }}$ | DB1 | $X X_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| F7n9H | DB2 | XX ${ }_{\text {H }}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F7nA}_{\mathrm{H}}$ | DB3 | $X X_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F}_{7 \mathrm{nB}}^{\mathrm{H}}$ | DB4 | $X X_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F7nC}_{\mathrm{H}}$ | DB5 | $X X_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F7nD}_{\mathrm{H}}$ | DB6 | $X X_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F7nE}_{\mathrm{H}}$ | DB7 | $X X_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |

1) The notation " $n$ " ( $n=1$ to $F$ ) in the address definition defines the number of the related message object.
2) " $X$ " means that the value is undefined and the location is reserved. " $U$ " means that the value is unchanged by a reset operation. "U" values are undefined (as "X") after a power-on reset operation

## I/O Ports

The C505 has four 8-bit I/O ports and one 2-bit I/O port. Port 0 is an open-drain bidirectional I/O port, while ports 1 to 4 are quasi-bidirectional I/O ports with internal pullup resistors. That means, when configured as inputs, ports 1 to 4 will be pulled high and will source current when externally pulled low. Port 0 will float when configured as input.

The output drivers of port 0 and 2 and the input buffers of port 0 are also used for accessing external memory. In this application, port 0 outputs the low byte of the external memory address, time multiplexed with the byte being written or read. Port 2 outputs the high byte of the external memory address when the address is 16 bits wide. Otherwise, the port 2 pins continue emitting the P2 SFR contents. In this function, port 0 is not an open-drain port, but uses a strong internal pullup FET .
Port 4 is 2-bit I/O port with CAN controller specific alternate functions. The eight analog input lines are realized as mixed digital/analog inputs. The 8 analog inputs, ANO-AN7, are located at the port 1 pins P1.0 to P1.7. After reset, all analog inputs are disabled and the related pins of port 1 are configured as digital inputs. The analog function of a specific port 1 pin is enabled by bits in the SFR P1ANA. Writing a 0 to a bit position of P1ANA assigns the corresponding pin to operate as analog input.
Note : P1ANA is a mapped SFR and can be only accessed if bit RMAP in SFR SYSCON is set.

## Timer / Counter 0 and 1

Timer/Counter 0 and 1 can be used in four operating modes as listed in Table 6 :
Table 6
Timer/Counter 0 and 1 Operating Modes

| Mode | Description | TMOD |  | Input Clock |  |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | M1 | M0 | internal | external (max) |
| 0 | 8-bit timer/counter with a <br> divide-by-32 prescaler | 0 | 0 | $f_{\text {osc }} / 6 \times 32$ | $f_{\text {osc }} / 12 \times 32$ |
| 1 | 16-bit timer/counter | 0 | 1 |  |  |
| 2 | 8-bit timer/counter with <br> 8-bit autoreload | 1 | 0 | $f_{\text {osc }} / 6$ | $f_{\text {osd }} / 12$ |
| 3 | Timer/counter 0 used as one <br> 8-bit timer/counter and one <br> 8-bit timer <br> Timer 1 stops | 1 | 1 |  |  |

In the "timer" function ( $\mathrm{C} / \overline{\mathrm{T}}=$ ' 0 ') the register is incremented every machine cycle. Therefore the count rate is $f_{\text {OsC }} / 6$.

In the "counter" function the register is incremented in response to a 1-to-0 transition at its corresponding external input pin (P3.4/T0, P3.5/T1). Since it takes two machine cycles to detect a falling edge the max. count rate is $f_{\text {osc }} / 12$. External inputs $\overline{\mathrm{NT} T 0}$ and $\overline{\mathrm{INT} 1}$ (P3.2, P3.3) can be programmed to function as a gate to facilitate pulse width measurements. Figure 10 illustrates the input clock logic.


Figure 10
Timer/Counter 0 and 1 Input Clock Logic

## Timer/Counter 2 with Compare/Capture/Reload

The timer 2 of the C505 provides additional compare/capture/reload features. which allow the selection of the following operating modes:

- Compare : up to 4 PWM signals with 16-bit/300 ns resolution (@ 20 MHz clock)
- Capture : up to 4 high speed capture inputs with 300 ns resolution
- Reload : modulation of timer 2 cycle time

The block diagram in Figure 11 shows the general configuration of timer 2 with the additional compare/capture/reload registers. The I/O pins which can used for timer 2 control are located as multifunctional port functions at port 1.


Figure 11
Timer 2 Block Diagram

## Timer 2 Operating Modes

The timer 2, which is a 16-bit-wide register, can operate as timer, event counter, or gated timer. A roll-over of the count value in TL2/TH2 from all 1's to all 0's sets the timer overflow flag TF2 in SFR IRCON, which can generate an interrupt. The bits in register T2CON are used to control the timer 2 operation.

Timer Mode : In timer function, the count rate is derived from the oscillator frequency. A prescaler offers the possibility of selecting a count rate of $1 / 6$ or $1 / 12$ of the oscillator frequency.
Gated Timer Mode : In gated timer function, the external input pin T2 (P1.7) functions as a gate to the input of timer 2. If T2 is high, the internal clock input is gated to the timer. $\mathrm{T} 2=0$ stops the counting procedure. This facilitates pulse width measurements. The external gate signal is sampled once every machine cycle.
Event Counter Mode : In the event counter function. the timer 2 is incremented in response to a 1 -to-0 transition at its corresponding external input pin T2 (P1.7). In this function, the external input is sampled every machine cycle. Since it takes two machine cycles (12 oscillator periods) to recognize a 1 -to-0 transition, the maximum count rate is $1 / 6$ of the oscillator frequency. There are no restrictions on the duty cycle of the external input signal, but to ensure that a given level is sampled at least once before it changes, it must be held for at least one full machine cycle.
Reload of Timer 2: Two reload modes are selectable:
In mode 0, when timer 2 rolls over from all 1's to all 0's, it not only sets TF2 but also causes the timer 2 registers to be loaded with the 16-bit value in the CRC register, which is preset by software.
In mode 1, a 16-bit reload from the CRC register is caused by a negative transition at the corresponding input pin P1.5/T2EX. This transition will also set flag EXF2 if bit EXEN2 in SFR IEN1 has been set.

## Timer 2 Compare Modes

The compare function of a timer/register combination operates as follows : the 16-bit value stored in a compare or compare/capture register is compared with the contents of the timer register; if the count value in the timer register matches the stored value, an appropriate output signal is generated at a corresponding port pin and an interrupt can be generated.

## Compare Mode 0

In compare mode 0, upon matching the timer and compare register contents, the output signal changes from low to high. It goes back to a low level on timer overflow. As long as compare mode 0 is enabled, the appropriate output pin is controlled by the timer circuit only and writing to the port will have no effect. Figure 12 shows a functional diagram of a port circuit when used in compare mode 0 . The port latch is directly controlled by the timer overflow and compare match signals. The input line from the internal bus and the write-to-latch line of the port latch are disconnected when compare mode 0 is enabled.


Figure 12
Port Latch in Compare Mode 0

C505/C505C/C505A/C505CA

## Compare Mode 1

If compare mode 1 is enabled and the software writes to the appropriate output latch at the port, the new value will not appear at the output pin until the next compare match occurs. Thus, it can be choosen whether the output signal has to make a new transition (1-to-0 or 0-to-1, depending on the actual pin-level) or should keep its old value at the time when the timer value matches the stored compare value.

In compare mode 1 (see Figure 13) the port circuit consists of two separate latches. One latch (which acts as a "shadow latch") can be written under software control, but its value will only be transferred to the port latch (and thus to the port pin) when a compare match occurs.


Figure 13
Compare Function in Compare Mode 1

## Timer 2 Capture Modes

Each of the compare/capture registers CC1 to CC3 and the CRC register can be used to latch the current 16 -bit value of the timer 2 registers TL2 and TH2. Two different modes are provided for this function.

In mode 0, the external event causing a capture is :

- for CC registers 1 to 3 : a positive transition at pins CC1 to CC3 of port 1
- for the CRC register: a positive or negative transition at the corresponding pin, depending on the status of the bit I3FR in SFR T2CON.

In mode 1 a capture occurs in response to a write instruction to the low order byte of a capture register. The write-to-register signal (e.g. write-to-CRCL) is used to initiate a capture. The timer 2 contents will be latched into the appropriate capture register in the cycle following the write instruction. In this mode no interrupt request will be generated.

## Serial Interface (USART)

The serial port is full duplex and can operate in four modes (one synchronous mode, three asynchronous modes) as illustrated in Table 7.
Table 7
USART Operating Modes

| Mode | SCON |  | Description |
| :--- | :---: | :---: | :--- |
|  | SM0 | SM1 |  |
| 0 | 0 | 0 | Shift register mode, fixed baud rate <br> Serial data enters and exits through $R \times D ; T \times D$ outputs the shift <br> clock; 8-bit are transmitted/received (LSB first) |
| 1 | 0 | 1 | 8 -bit UART, variable baud rate <br> 10 bits are transmitted (through $\mathrm{T} \times \mathrm{D}$ ) or received (at $\mathrm{R} \times \mathrm{D}$ ) |
| 2 | 1 | 0 | 9-bit UART, fixed baud rate <br> 11 bits are transmitted (through $\mathrm{T} \times \mathrm{D}$ ) or received (at $\mathrm{R} \times \mathrm{D}$ ) |
| 3 | 1 | 1 | 9-bit UART, variable baud rate <br> Like mode 2 |

For clarification some terms regarding the difference between "baud rate clock" and "baud rate" should be mentioned. In the asynchronous modes the serial interfaces require a clock rate which is 16 times the baud rate for internal synchronization. Therefore, the baud rate generators/timers have to provide a "baud rate clock" (output signal in Figure 14 to the serial interface which - there divided by 16 - results in the actual "baud rate". Further, the abbrevation $\mathrm{f}_{\mathrm{osc}}$ refers to the oscillator frequency (crystal or external clock operation).

The variable baud rates for modes 1 and 3 of the serial interface can be derived either from timer 1 or from a decdicated baud rate generator (see Figure 14).


Note: The switch configuration shows the reset state.
MCS02733

Figure 14
Block Diagram of Baud Rate Generation for the Serial Interface
Table 8 below lists the values/formulas for the baud rate calculation of the serial interface with its dependencies of the control bits BD and SMOD.
Table 8
Serial Interface - Baud Rate Dependencies

| Serial Interface Operating Modes | Active Control Bits |  | Baud Rate Calculation |
| :---: | :---: | :---: | :---: |
|  | BD | SMOD |  |
| Mode 0 (Shift Register) | - | - | $f_{\text {osc }} / 6$ |
| Mode 1 (8-bit UART) <br> Mode 3 (9-bit UART) | 0 | X | Controlled by timer 1 overflow : (2 $2^{\text {SMOD }} \times$ timer 1 overflow rate) / 32 |
|  | 1 | X | Controlled by baud rate generator $\left(2^{\text {SMOD }} \times f_{\text {OSC }}\right) /$ <br> ( $32 \times$ baud rate generator overflow rate) |
| Mode 2 (9-bit UART) | - | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & f_{\text {osc }} / 32 \\ & f_{\text {osc }} / 16 \end{aligned}$ |

## CAN Controller (C505C and C505CA only)

The on-chip CAN controller, compliant to version 2.0B, is the functional heart which provides all resources that are required to run the standard CAN protocol (11-bit identifiers) as well as the extended CAN protocol (29-bit identifiers). It provides a sophisticated object layer to relieve the CPU of as much overhead as possible when controlling many different message objects (up to 15). This includes bus arbitration, resending of garbled messages, error handling, interrupt generation, etc. In order to implement the physical layer, external components have to be connected to the C505C/C505CA.

The internal bus interface connects the on-chip CAN controller to the internal bus of the microcontroller. The registers and data locations of the CAN interface are mapped to a specific 256 byte wide address range of the external data memory area ( $\mathrm{F7OO}_{\mathrm{H}}$ to $\mathrm{F}_{\mathrm{FFF}}^{\mathrm{H}}$ ) and can be accessed using MOVX instructions. Figure 15 shows a block diagram of the on-chip CAN controller.

The TX/RX Shift Register holds the destuffed bit stream from the bus line to allow the parallel access to the whole data or remote frame for the acceptance match test and the parallel transfer of the frame to and from the Intelligent Memory.
The Bit Stream Processor (BSP) is a sequencer controlling the sequential data stream between the TX/RX Shift Register, the CRC Register, and the bus line. The BSP also controls the EML and the parallel data stream between the TX/RX Shift Register and the Intelligent Memory such that the processes of reception, arbitration, transmission, and error signalling are performed according to the CAN protocol. Note that the automatic retransmission of messages which have been corrupted by noise or other external error conditions on the bus line is handled by the BSP.

The Cyclic Redundancy Check Register (CRC) generates the Cyclic Redundancy Check code to be transmitted after the data bytes and checks the CRC code of incoming messages. This is done by dividing the data stream by the code generator polynomial.
The Error Management Logic (EML) is responsible for the fault confinement of the CAN device. Its counters, the Receive Error Counter and the Transmit Error Counter, are incremented and decremented by commands from the Bit Stream Processor. According to the values of the error counters, the CAN controller is set into the states error active, error passive and busoff.

The Bit Timing Logic (BTL) monitors the busline input RXDC and handles the busline related bit timing according to the CAN protocol. The BTL synchronizes on a recessive to dominant busline transition at Start of Frame (hard synchronization) and on any further recessive to dominant busline transition, if the CAN controller itself does not transmit a dominant bit (resynchronization). The BTL also provides programmable time segments to compensate for the propagation delay time and for phase shifts and to define the position of the Sample Point in the bit time. The programming of the BTL depends on the baudrate and on external physical delay times.

The Intelligent Memory (CAM/RAM array) provides storage for up to 15 message objects of maximum 8 data bytes length. Each of these objects has a unique identifier and its own set of control and status bits. After the initial configuration, the Intelligent Memory can handle the reception and transmission of data without further microcontroller actions.


Figure 15
CAN Controller Block Diagram

## CAN Controller Software Initialization

The very first step of the initialization is the CAN controller input clock selection. A divide-by-2 prescaler is enabled by default after reset (Figure 16). Setting bit CMOD (SYSCON.3) disables the prescaler. The purpose of the prescaler selection is:

- to ensure that the CAN controller is operable when $\mathrm{f}_{\text {osc }}$ is over 10 MHz (bit CMOD $=0$ )
- to achieve the maximum CAN baudrate of 1 Mbaud when $\mathrm{f}_{\mathrm{osc}}$ is 8 MHz (bit CMOD=1)


| Frequency (MHz) |  | $\begin{array}{c}\text { CMOD } \\ \text { (SYSCON.3) }\end{array}$ | $\begin{array}{c}\text { BRP } \\ \text { (BTR0.0-5) }\end{array}$ | $\begin{array}{c}\text { CAN } \\ \text { baudrate } \\ \text { (Mbaud/sec) }\end{array}$ |
| :---: | :---: | :---: | :---: | :---: |
| 8 | $\mathbf{f}_{\text {CAN }}$ |  | 1 | $000000_{\mathrm{B}}$ |$] 1$.

Note : The switch configuration shows the reset state of bit CMOD.

Figure 16
CAN controller Input Clock Selection

C505/C505C/C505A/C505CA

## 8-Bit A/D Converter (C505 and C505C only)

The C505/C505C includes a high performance / high speed 8-bit A/D converter (ADC) with 8 analog input channels. It operates with a successive approximation technique and provides the following features:

- 8 multiplexed input channels (port 1), which can also be used as digital outputs/inputs
- 8 -bit resolution
- Internal start-of-conversion trigger
- Interrupt request generation after each conversion
- Single or continuous conversion mode

The 8-bit ADC uses two clock signals for operation : the conversion clock $f_{\text {ADC }}\left(=1 / t_{\text {ADC }}\right)$ and the input clock $\mathrm{f}_{\mathrm{IN}}\left(1 / \mathrm{t}_{\mathrm{IN}}\right) \cdot \mathrm{f}_{\text {ADC }}$ is derived from the C505 system clock $\mathrm{f}_{\mathrm{OSC}}$ which is applied at the XTAL pins via the ADC clock prescaler as shown in Figure 17. The input clock is equal to fosc. The conversion clock $\mathrm{f}_{\mathrm{ADC}}$ is limited to a maximum frequency of 1.25 MHz . Therefore, the ADC clock prescaler must be programmed to a value which assures that the conversion clock does not exceed 1.25 MHz . The prescaler ratio is selected by the bits ADCL1 and ADCL0 of SFR ADCON1.


Figure 17
8-Bit A/D Converter Clock Selection

C505/C505C/C505A/C505CA


Figure 18
Block Diagram of the 8-Bit A/D Converter

C505/C505C/C505A/C505CA

## 10-Bit A/D Converter (C505A and C505CA only)

The C505A/C505CA includes a high performance / high speed 10-bit A/D-Converter (ADC) with 8 analog input channels. It operates with a successive approximation technique and uses self calibration mechanisms for reduction and compensation of offset and linearity errors. The A/D converter provides the following features:

- 8 multiplexed input channels (port 1), which can also be used as digital inputs/outputs
- 10-bit resolution
- Single or continuous conversion mode
- Internal start-of-conversion trigger capability
- Interrupt request generation after each conversion
- Using successive approximation conversion technique via a capacitor array
- Built-in hidden calibration of offset and linearity errors

The 10-bit ADC uses two clock signals for operation : the conversion clock $\mathrm{f}_{\mathrm{ADC}}\left(=1 / \mathrm{t}_{\mathrm{ADC}}\right)$ and the input clock $f_{I N}\left(=1 / \mathrm{t}_{\mathrm{IN}}\right) \cdot \mathrm{f}_{\text {ADC }}$ is derived from the C505 system clock $\mathrm{f}_{\text {OSC }}$ which is applied at the XTAL pins. The input clock $f_{I N}$ is equal to $f_{O S C}$ The conversion $f_{A D C}$ clock is limited to a maximum frequency of 2 MHz . Therefore, the ADC clock prescaler must be programmed to a value which assures that the conversion clock does not exceed 2 MHz . The prescaler ratio is selected by the bits ADCL1 and ADCL0 of SFR ADCON1.


Figure 19

## 10-Bit A/D Converter Clock Selection

C505/C505C/C505A/C505CA


Figure 20
Block Diagram of the 10-Bit A/D Converter

## Interrupt System

The C505 provides 12 interrupt vectors with four priority levels. Five interrupt requests can be generated by the on-chip peripherals (timer 0, timer 1, timer 2, serial interface, A/D converter). One interrupt can be generated by the CAN controller (C505C and C505CA only) or by a software setting and in this case the interrupt vector is the same. Six interrupts may be triggered externally (P3.2/ $\overline{\mathrm{INT0}}, \mathrm{P} 3.3 / \overline{\mathrm{INT} 1}, \mathrm{P} 1.0 / \mathrm{AN0} / \overline{\mathrm{NT} 3} / \mathrm{CC} 0, \mathrm{P} 1.1 / \mathrm{AN} 1 / \mathrm{INT} 4 / \mathrm{CC} 1, \mathrm{P} 1.2 / \mathrm{AN} 2 / \mathrm{INT} 5 / \mathrm{CC} 2, ~ P 1.3 / \mathrm{AN} 3 / \mathrm{INT} 6 /$ CC3). Additionally, the P1.5/AN5/T2EX can trigger an interrupt. The wake-up from power-down mode interrupt has a special functionality which allows to exit from the software power-down mode by a short low pulse at either pin P3.2/INT0 or the pin P4.1/RXDC.
Figure 21 to Figure 23 give a general overview of the interrupt sources and illustrate the request and the control flags which are described in the next sections. Table 9 lists all interrupt sources with their request flags and interrupt vector addresses.
Table 9
Interrupt Source and Vectors

| Interrupt Source | Interrupt Vector Address | Interrupt Request Flags |
| :--- | :--- | :--- |
| External Interrupt 0 | $0003_{\mathrm{H}}$ | IE0 |
| Timer 0 Overflow | $000 \mathrm{~B}_{\mathrm{H}}$ | TF0 |
| External Interrupt 1 | $0013_{\mathrm{H}}$ | IE1 |
| Timer 1 Overflow | $001 \mathrm{~B}_{\mathrm{H}}$ | TF1 |
| Serial Channel | $0023_{\mathrm{H}}$ | RI / TI |
| Timer 2 Overflow / Ext. Reload | $002 \mathrm{~B}_{\mathrm{H}}$ | TF2 / EXF2 |
| A/D Converter | $0043_{\mathrm{H}}$ | IADC |
| CAN Controller / Software Interrupt | $004 \mathrm{~B}_{\mathrm{H}}$ | - / SWI |
| External interrupt 3 | $0053_{\mathrm{H}}$ | IEX3 |
| External Interrupt 4 | $005 \mathrm{~B}_{\mathrm{H}}$ | IEX4 |
| External Interrupt 5 | $0063_{\mathrm{H}}$ | IEX5 |
| External interrupt 6 | $006 \mathrm{~B}_{\mathrm{H}}$ | IEX6 |
| Wake-up from power-down mode | $007 \mathrm{~B}_{\mathrm{H}}$ | - |



Figure 21
Interrupt Structure, Overview Part 1
Note: Each of the 15 CAN controller message objects (C505C and C505CA only), shown in the shaded area of Figure 21 provides the bits/flags.

C505/C505C/C505A/C505CA


Figure 22
Interrupt Structure, Overview Part 2

C505/C505C/C505A/C505CA


Figure 23
Interrupt Structure, Overview Part 3

## Fail Save Mechanisms

The C505 offers enhanced fail safe mechanisms, which allow an automatic recovery from software upset or hardware failure :

- a programmable watchdog timer (WDT), with variable time-out period from $192 \mu \mathrm{~s}$ up to approx. 393.2 ms at 16 MHz ( 314.5 ms at 20 MHz ).
- an oscillator watchdog (OWD) which monitors the on-chip oscillator and forces the microcontroller into reset state in case the on-chip oscillator fails; it also provides the clock for a fast internal reset after power-on.
The watchdog timer in the C505 is a 15 -bit timer, which is incremented by a count rate of $f_{\text {osc }} / 12$ upto $f_{\text {osc }} / 192$. The system clock of the C505 is divided by two prescalers, a divide-by-two and a divide-by-16 prescaler. For programming of the watchdog timer overflow rate, the upper 7 bits of the watchdog timer can be written. Figure 24 shows the block diagram of the watchdog timer unit.


Figure 24

## Block Diagram of the Programmable Watchdog Timer

The watchdog timer can be started by software (bit SWDT in SFR IEN1) but it cannot be stopped during active mode of the device. If the software fails to refresh the running watchdog timer an internal reset will be initiated on watchdog timer overflow. For refreshing of the watchdog timer the content of the SFR WDTREL is transfered to the upper 7-bit of the watchdog timer. The refresh sequence consists of two consequtive instructions which set the bits WDT and SWDT each. The reset cause (external reset or reset caused by the watchdog) can be examined by software (flag WDTS). It must be noted, however, that the watchdog timer is halted during the idle mode and power down mode of the processor.

## Oscillator Watchdog

The oscillator watchdog unit serves for three functions:

- Monitoring of the on-chip oscillator's function

The watchdog supervises the on-chip oscillator's frequency; if it is lower than the frequency of the auxiliary RC oscillator in the watchdog unit, the internal clock is supplied by the RC oscillator and the device is brought into reset; if the failure condition disappears (i.e. the onchip oscillator has a higher frequency than the RC oscillator), the part, in order to allow the oscillator to stabilize, executes a final reset phase of typ. 1 ms ; then the oscillator watchdog reset is released and the part starts program execution from address $0000_{\mathrm{H}}$ again.

- Fast internal reset after power-on The oscillator watchdog unit provides a clock supply for the reset before the on-chip oscillator has started. The oscillator watchdog unit also works identically to the monitoring function.
- Control of external wake-up from software power-down mode

When the power-down mode is left by a low level at the P3.2/INT0 pin or the P4.1/RXDC pin, the oscillator watchdog unit assures that the microcontroller resumes operation (execution of the power-down wake-up interrupt) with the nominal clock rate. In the power-down mode the RC oscillator and the on-chip oscillator are stopped. Both oscillators are started again when power-down mode is released. When the on-chip oscillator has a higher frequency than the RC oscillator, the microcontroller starts program execution by processing a power down interrupt after a final delay of typ. 1 ms in order to allow the on-chip oscillator to stabilize.

C505/C505C/C505A/C505CA


Figure 25
Functional Block Diagram of the Oscillator Watchdog

## Power Saving Modes

The C505 provides two basic power saving modes, the idle mode and the power down mode. Additionally, a slow down mode is available. This power saving mode reduces the internal clock rate in normal operating mode and it can be also used for further power reduction in idle mode.

- Idle mode

In the idle mode the main oscillator of the C505 continues to run, but the CPU is gated off from the clock signal. All peripheral units are further provided with the clock. The CPU status is preserved in its entirety. The idle mode can be terminated by any enabled interrupt of a peripheral unit or by a hardware reset.

- Power down mode

The operation of the C505 is completely stopped and the oscillator is turned off. This mode is used to save the contents of the internal RAM with a very low standby current. Power down mode is entered by software and can be left by reset or by a short low pulse at pin P3.2/ INT0. or P4.1/RXDC.

- Slow down mode

The controller keeps up the full operating functionality, but its normal clock frequency is internally divided by 32. This slows down all parts of the controller, the CPU and all peripherals, to $1 / 32$-th of their normal operating frequency. Slowing down the frequency significantly reduces power consumption.

In the power down mode of operation, $V_{\mathrm{DD}}$ can be reduced to minimize power consumption. It must be ensured, however, that $V_{\mathrm{DD}}$ is not reduced before the power down mode is invoked, and that $V_{\mathrm{DD}}$ is restored to its normal operating level, before the power down mode is terminated. Table 10 gives a general overview of the entry and exit procedures of the power saving modes.

Table 10
Power Saving Modes Overview

| Mode | Entering <br> (Instruction <br> Example) | Leaving by | Remarks |
| :--- | :--- | :--- | :--- |
| Idle Mode | ORL PCON, \#01H <br> ORL PCON, \#20H | Ocurrence of an <br> interrupt from a <br> peripheral unit | CPU clock is stopped; <br> CPU maintains their data; <br> peripheral units are active (if <br> enabled) and provided with <br> clock |
|  | Hardware Reset |  |  |

## OTP Memory Operation (C505A-4E and C505CA-4E only)

The C505A-4E/C505CA-4E contains a 32K byte one-time programmable (OTP) program memory. With the C505A-4E/C505CA-4E fast programming cycles are achieved ( 1 byte in $100 \mu \mathrm{sec}$ ). Also several levels of OTP memory protection can be selected.

For programming of the device, the C505A-4E/C505CA-4E must be put into the programming mode. This typically is done not in-system but in a special programming hardware. In the programming mode the C505A-4E/C505CA-4E operates as a slave device similar as an EPROM standalone memory device and must be controlled with address/data information, control lines, and an external 11.5 V programming voltage. Figure 26 shows the pins of the C505A-4E/C505CA-4E which are required for controlling of the OTP programming mode.


Figure 26
Programming Mode Configuration

## Pin Configuration in Programming Mode



Figure 27
P-MQFP-44 Pin Configuration of the C505A-4E/C505CA-4E in Programming Mode (Top View)

The following Table 11 contains the functional description of all C505A-4E/C505CA-4E pins which are required for OTP memory programming.

Table 11
Pin Definitions and Functions in Programming Mode

| Symbol | Pin Number | $\begin{aligned} & \text { I/O } \\ & \text { *) } \end{aligned}$ | Function |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RESET | 4 | 1 | Reset <br> This input must be at static "1" (active) level during the whole programming mode. |  |  |
| PMSELO <br> PMSEL1 | $\begin{aligned} & 5 \\ & 7 \end{aligned}$ | $\begin{aligned} & \hline 1 \\ & 1 \end{aligned}$ | Programming mode selection pins <br> These pins are used to select the different access modes in programming mode. PMSEL1,0 must satisfy a setup time to the rising edge of PALE. When the logic level of PMSEL1,0 is changed, PALE must be at low level. |  |  |
|  |  |  | PMSEL1 | PMSELO | Access Mode |
|  |  |  | 0 | 0 | Reserved |
|  |  |  | 0 | 1 | Read version bytes |
|  |  |  | 1 | 0 | Program/read lock bits |
|  |  |  | 1 | 1 | Program/read OTP memory byte |
| $\overline{\overline{\text { PSEL }}}$ | 8 | I | Basic programming mode select This input is used for the basic programming mode selection and must be switched according Figure 28. |  |  |
| $\overline{\text { PRD }}$ | 9 | I | Programming mode read strobe This input is used for read access control for OTP memory read, Version Register read, and lock bit read operations. |  |  |
| PALE | 10 | I | Programming address latch enable <br> PALE is used to latch the high address lines. The high address lines must satisfy a setup and hold time to/from the falling edge of PALE. PALE must be at low level when the logic level of PMSEL1,0 is changed. |  |  |
| XTAL2 | 14 | 0 | XTAL2 <br> Output of the inverting oscillator amplifier. |  |  |
| XTAL1 | 15 | I | XTAL1 <br> Input to the oscillator amplifier. |  |  |
| $\mathrm{V}_{\text {SS }}$ | 16 | - | Circuit ground potential must be applied in programming mode. |  |  |
| $\overline{\mathrm{V}} \mathrm{DD}$ | 17 | - | Power supply terminal must be applied in programming mode. |  |  |

*) I = Input
$\mathrm{O}=$ Output

Table 11
Pin Definitions and Functions in Programming Mode (cont'd)

| Symbol | Pin Number | $\begin{aligned} & \text { I/O } \\ & \text { *) } \end{aligned}$ | Function |
| :---: | :---: | :---: | :---: |
| P2.0-7 | 18-25 | I | Address lines <br> P2.0-7 are used as multiplexed address input lines A0-A7 and A8-A14. A8-A14 must be latched with PALE. |
| $\overline{\overline{P S E N}}$ | 26 | I | Program store enable <br> This input must be at static "0" level during the whole programming mode. |
| $\overline{\text { PROG }}$ | 27 | I | Programming mode write strobe <br> This input is used in programming mode as a write strobe for OTP memory program, and lock bit write operations During basic programming mode selection a low level must be applied to PROG. |
| $\overline{\mathrm{EA}} / \mathrm{V}_{\mathrm{PP}}$ | 29 | - | External Access / Programming voltage <br> This pin must be at $11.5 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{PP}}\right)$ voltage level during programming of an OTP memory byte or lock bit. During an OTP memory read operation this pin must be at $\mathrm{V}_{\mathbb{H}}$ high level. This pin is also used for basic programming mode selection. At basic programming mode selection a low level must be applied to $\overline{\mathrm{EA}} / \mathrm{V}_{\mathrm{PP}}$. |
| D7-0 | 30-37 | I/O | Data lines 0-7 <br> During programming mode, data bytes are transferred via the bidirectional port 0 data lines. |
| N.C. | $\begin{aligned} & \text { 1-3, 6, 11-13, } \\ & 28,38-44 \end{aligned}$ | - | Not Connected <br> These pins should not be connected in programming mode. |
| $\begin{aligned} * \end{aligned} \quad \begin{aligned} & 1 \\ & =\text { Input } \\ & O \end{aligned}=\text { Output }$ |  |  |  |

C505/C505C/C505A/C505CA

## Basic Programming Mode Selection

The basic programming mode selection scheme is shown in Figure 28.


Figure 28
Basic Programming Mode Selection

Table 12
Access Modes Selection

| Access Mode | $\begin{aligned} & \overline{\mathrm{EA}} / \\ & \mathrm{V}_{\mathrm{PP}} \end{aligned}$ | $\overline{\text { PROG }}$ | $\overline{\text { PRD }}$ | PMSEL |  | Address (Port 2) | $\begin{aligned} & \text { Data } \\ & \text { (Port 0) } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 1 | 0 |  |  |
| Program OTP memory byte | $V_{\text {PP }}$ | ఒ | H | H | H | $\begin{gathered} \text { A0-7 } \\ \text { A8-14 } \end{gathered}$ | D0-7 |
| Read OTP memory byte | $\mathrm{V}_{\mathrm{IH}}$ | H | 乙 |  |  |  |  |
| Program OTP lock bits | $V_{\text {PP }}$ | L | H | H | L | - | D1,D0 see <br> Table 13 |
| Read OTP lock bits | $\mathrm{V}_{\mathrm{IH}}$ | H | $\square$ |  |  |  |  |
| Read OTP version byte | $\mathrm{V}_{\mathrm{IH}}$ | H | ఒ | L | H | Byte addr. of sign. byte | D0-7 |

## Lock Bits Programming / Read

The C505A-4E/C505CA-4E has two programmable lock bits which, when programmed according to Table 13, provide four levels of protection for the on-chip OTP code memory. The state of the lock bits can also be read.
Table 13
Lock Bit Protection Types

| Lock Bits at D1,D0 |  | Protection <br> Level | Protection Type |
| :--- | :--- | :--- | :--- |
| D1 | D0 | Level 0 | The OTP lock feature is disabled. During normal operation of <br> the C505A-4E/C505CA-4E, the state of the EA pin is not <br> latched on reset. |
| 1 | 1 | 0 | Level 1 |
| 1 | During normal operation of the C505A-4E/C505CA-4E, MOVC <br> instructions executed from external program memory are <br> disabled from fetching code bytes from internal memory. $\overline{\text { EA }}$ is <br> sampled and latched on reset. An OTP memory read operation <br> is only possible using the ROM/OTP verification mode 2 for <br> protection level 1. Further programming of the OTP memory is <br> disabled (reprogramming security). |  |  |
| 0 | 1 | Level 2 | Same as level 1, but also OTP memory read operation using <br> OTP verification mode is disabled. |
| 0 | 0 | Level 3 | Same as level 2; but additionally external code execution by <br> setting $\overline{\text { EA }}=$ low during normal operation of the C505A-4E/ <br> C505CA-4E is no more possible. <br> External code execution, which is initiated by an internal <br> program (e.g. by an internal jump instruction above the ROM <br> boundary), is still possible. |

## Absolute Maximum Ratings

| Parameter | Symbol | Limit Values |  | Unit | Notes |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | min. | max. |  |  |
| Storage temperature | $T_{\mathrm{ST}}$ | -65 | 150 | ${ }^{\circ} \mathrm{C}$ | - |
| Voltage on $V_{\mathrm{DD}}$ pins with respect <br> to ground $\left(V_{\mathrm{SS}}\right)$ | $V_{\mathrm{DD}}$ | -0.5 | 6.5 | V | - |
| Voltage on any pin with respect <br> to ground $\left(V_{\mathrm{SS}}\right)$ | $V_{\mathrm{IN}}$ | -0.5 | $V_{D D}+0.5$ | V | - |
| Input current on any pin during <br> overload condition |  | -10 | 10 | mA | - |
| Absolute sum of all input currents <br> during overload condition |  |  | $\|100 \mathrm{~mA}\|$ | mA | - |
| Power dissipation | $P_{\mathrm{DISS}}$ |  | 1 | W | - |

Note: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage of the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for longer periods may affect device reliability. During absolute maximum rating overload conditions ( $V_{I N}>V_{D D}$ or $V_{I N}<V_{S S}$ ) the voltage on $V_{D D}$ pins with respect to ground ( $V_{S S}$ ) must not exceed the values defined by the absolute maximum ratings.

## Operating Conditions

| Parameter | Symbol | Limit Values |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |  |
| Supply voltage | $V_{\text {DD }}$ | 4.25 | 5.5 | V | Active mode, $\mathrm{f}_{\text {osc } \max }=20 \mathrm{MHz}$ |
|  |  | 2 | 5.5 | V | PowerDown mode |
| Ground voltage | $V_{\text {SS }}$ | 0 |  | V | Reference voltage |
| Ambient temperature <br> SAB-C505 <br> SAF-C505 <br> SAH-C505 <br> SAK-C505 | $\begin{aligned} & T_{\mathrm{A}} \\ & T_{\mathrm{A}} \\ & T_{\mathrm{A}} \\ & T_{\mathrm{A}} \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 0 \\ -40 \\ -40 \\ -40 \\ \hline \end{array}$ | $\begin{aligned} & 70 \\ & 85 \\ & 110 \\ & 125 \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ | - |
| Analog reference voltage | $V_{\text {AREF }}$ | 4 | $V_{D D}+0.1$ | V | - |
| Analog ground voltage | $V_{\text {AGND }}$ | $V_{S S}-0.1$ | $V_{S S}+0.2$ | V | - |
| Analog input voltage | $V_{\text {AIN }}$ | $V_{\text {AGND }}-0.2$ | $V_{\text {AREF }}+0.2$ | V | - |
| XTAL clock | $\mathrm{f}_{\text {osc }}$ | 2 | 20 <br> (with 50\% duty cycle) | MHz | 1) |

1) For the extended temperature range $-40^{\circ} \mathrm{C}$ to $110^{\circ} \mathrm{C}(\mathrm{SAH})$ and $-40^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}(\mathrm{SAK})$, the devices C505-2R, C505-L, C505C-2R and C505C-L have the max. operating frequency of 16 MHz with $50 \%$ clock duty cycle.

## Parameter Interpretation

The parameters listed in the following partly represent the characteristics of the C505 and partly its demands on the system. To aid in interpreting the parameters right, when evaluating them for a design, they are marked in column "Symbol":
CC (Controller Characteristics):
The logic of the C505 will provide signals with the respective characteristics.
SR (System Requirement):
The external system must provide signals with the respective characteristics to the C505.

## DC Characteristics

(Operating Conditions apply)

| Parameter | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |  |
| Input low voltages all except $\overline{\mathrm{EA}}$, RESET EA pin RESET pin | $\begin{aligned} & V_{\mathrm{lL}} \\ & V_{\mathrm{lL} 1} \\ & V_{\mathrm{LL} 2} \end{aligned}$ | $\begin{aligned} & -0.5 \\ & -0.5 \\ & -0.5 \end{aligned}$ | $\begin{aligned} & 0.2 V_{\mathrm{DD}}-0.1 \\ & 0.2 V_{\mathrm{DD}}-0.3 \\ & 0.2 V_{\mathrm{DD}}+0.1 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | $-$ |
| Input high voltages <br> all except XTAL1, RESET <br> XTAL1 pin <br> RESET pin | $\begin{aligned} & V_{\mathrm{IH}} \\ & V_{\mathrm{IH} 1} \\ & V_{\mathrm{IH} 2} \end{aligned}$ | $\begin{aligned} & 0.2 V_{\mathrm{DD}}+0.9 \\ & 0.7 V_{\mathrm{DD}} \\ & 0.6 V_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & V_{\mathrm{DD}}+0.5 \\ & V_{\mathrm{DD}}+0.5 \\ & V_{\mathrm{DD}}+0.5 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ |
| Output low voltages <br> Ports 1, 2, 3, 4 <br> Port 0, ALE, $\overline{\text { PSEN }}$ | $\begin{aligned} & V_{\mathrm{OL}} \\ & V_{\mathrm{OL1}} \end{aligned}$ | - | $\begin{aligned} & 0.45 \\ & 0.45 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & I_{\mathrm{OL}}=1.6 \mathrm{~mA}^{1)} \\ & I_{\mathrm{OL}}=3.2 \mathrm{~mA}^{1)} \end{aligned}$ |
| Output high voltages <br> Ports 1, 2, 3, 4 <br> Port 0 in external bus mode, ALE, PSEN | $\left\lvert\, \begin{aligned} & V_{\mathrm{OH}} \\ & V_{\mathrm{OH} 2} \end{aligned}\right.$ | $\begin{aligned} & 2.4 \\ & 0.9 V_{\mathrm{DD}} \\ & 2.4 \\ & 0.9 V_{\mathrm{DD}} \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & I_{\mathrm{OH}}=-80 \mu \mathrm{~A} \\ & I_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & I_{\mathrm{OH}}=-800 \mu \mathrm{~A} \\ & I_{\mathrm{OH}}=-80 \mu \mathrm{~A}{ }^{2)} \end{aligned}$ |
| Logic 0 input current Ports 1, 2, 3, 4 | $I_{\text {IL }}$ | -10 | -70 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0.45 \mathrm{~V}$ |
| Logical 1-to-0 transition current Ports 1, 2, 3, 4 | $I_{\text {TL }}$ | -65 | -650 | $\mu \mathrm{A}$ | $V_{\text {IN }}=2 \mathrm{~V}$ |
| Input leakage current <br> Port 0, ANO-7 (Port 1), EA | $I_{\text {LI }}$ | - | $\pm 1$ | $\mu \mathrm{A}$ | $0.45<V_{\text {IN }}<V_{\text {DD }}$ |
| Input high current to RESET | $I_{1+}$ | 5 | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { 14) } \\ & 0.6 V_{\mathrm{DD}}<V_{\mathrm{IN}}<V_{\mathrm{DD}} \end{aligned}$ |
| Pin capacitance | $C_{\text {10 }}$ | - | 10 | pF | $\begin{aligned} & f_{\mathrm{c}}=1 \mathrm{MHz}, \\ & T_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Overload current | $I_{\text {OV }}$ | - | $\pm 5$ | mA | 3) 4) |
| Programming voltage | $V_{\text {PP }}$ | 10.9 | 12.1 | V | $11.5 \mathrm{~V} \pm 5 \%{ }^{5}$ |
| Supply current at $\overline{\mathrm{EA}} / \mathrm{V}_{\text {PP }}$ |  |  | 30 | mA | ${ }^{6}$ |

Notes see Page 60

C505/C505C/C505A/C505CA

## Power Supply Currents

| Parameter |  |  | Symbol | Limit Values |  |  | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | typ. ${ }^{12)}$ | max. ${ }^{13}$ |  |  |
| $\begin{aligned} & \text { C505 / } \\ & \text { C505C } \end{aligned}$ | Active Mode | $\begin{aligned} & 12 \mathrm{MHz} \\ & 20 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & I_{\mathrm{DD}} \\ & I_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 19.3 \\ & 31.3 \end{aligned}$ | $\begin{gathered} 27.0 \\ 39 \end{gathered}$ | mA | 7) |
|  | Idle Mode | $\begin{aligned} & 12 \mathrm{MHz} \\ & 20 \mathrm{MHz} \end{aligned}$ | $\begin{aligned} & I_{\mathrm{DD}} \\ & I_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 10.3 \\ & 16.2 \end{aligned}$ | $\begin{aligned} & 13.0 \\ & 21.0 \end{aligned}$ | mA | 8) |
|  | Active Mode with slow-down enabled | $\begin{array}{\|l\|} \hline 12 \mathrm{MHz} \\ 20 \mathrm{MHz} \end{array}$ | $\begin{aligned} & I_{\mathrm{DD}} \\ & I_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 3.9 \\ & 4.8 \end{aligned}$ | $\begin{aligned} & 5.5 \\ & 7.5 \end{aligned}$ | mA | 9) |
|  | Idle Mode with slow-down enabled | $\begin{aligned} & 12 \mathrm{MHz} \\ & 20 \mathrm{MHz} \end{aligned}$ | $\begin{aligned} & I_{\mathrm{DD}} \\ & I_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 3.2 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & 5.0 \\ & 7.0 \end{aligned}$ | mA | 10) |
|  | Power down mode |  | $I_{\text {PD }}$ | 10 | 50 | $\mu \mathrm{A}$ | $V_{\mathrm{DD}}=2 . .5 .5 \mathrm{~V}^{11)}$ |
| $\begin{aligned} & \text { C505A-4E } \\ & \text { /C505CA-4E } \end{aligned}$ | Active Mode | $16 \mathrm{MHz}$ $20 \mathrm{MHz}$ | $\begin{aligned} & I_{\mathrm{DD}} \\ & I_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 28.7 \\ & 35.2 \end{aligned}$ | $\begin{aligned} & 30.7 \\ & 37.6 \end{aligned}$ | mA | 7) |
|  | Idle Mode | $\begin{aligned} & 16 \mathrm{MHz} \\ & 20 \mathrm{MHz} \end{aligned}$ | $\begin{aligned} & I_{\mathrm{DD}} \\ & I_{\mathrm{DD}} \\ & \hline \end{aligned}$ | $\begin{aligned} & 14.9 \\ & 17.7 \end{aligned}$ | $\begin{aligned} & 15.9 \\ & 18.9 \\ & \hline \end{aligned}$ | mA | 8) |
|  | Active Mode with slow-down enabled | $\begin{aligned} & 16 \mathrm{MHz} \\ & 20 \mathrm{MHz} \end{aligned}$ | $\begin{array}{\|l} I_{\mathrm{DD}} \\ I_{\mathrm{DD}} \\ \hline \end{array}$ | $\begin{gathered} \hline 9.9 \\ 12.3 \\ \hline \end{gathered}$ | $\begin{aligned} & \hline 12.8 \\ & 15.6 \\ & \hline \end{aligned}$ | mA | 9) |
|  | Idle Mode with slow-down enabled | $16 \mathrm{MHz}$ $20 \mathrm{MHz}$ | $\begin{aligned} & I_{\mathrm{DD}} \\ & I_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 5.1 \\ & 6.3 \end{aligned}$ | $\begin{aligned} & 5.6 \\ & 6.8 \end{aligned}$ | mA | 10) |
|  | Power down mode |  | $I_{P D}$ | 5.6 | 20 | $\mu \mathrm{A}$ | $V_{\mathrm{DD}}=2 . .5 .5 \mathrm{~V}^{11)}$ |
| C505A-4R / <br> C505CA-4R <br> /C505A-2R / <br> C505CA-2R <br> /C505A-L / <br> C505CA-L | Active Mode | $\begin{aligned} & 16 \mathrm{MHz} \\ & 20 \mathrm{MHz} \end{aligned}$ | $\begin{aligned} & I_{\mathrm{DD}} \\ & I_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & \hline 22.8 \\ & 27.6 \end{aligned}$ | $\begin{aligned} & 29.2 \\ & 35.3 \end{aligned}$ | mA | ${ }^{7)}$ |
|  | Idle Mode | 16 MHz 20 MHz | $\begin{aligned} & \hline I_{\mathrm{DD}} \\ & I_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 12.7 \\ & 15.0 \end{aligned}$ | $\begin{aligned} & 16.3 \\ & 19.3 \end{aligned}$ | mA | 8) |
|  | Active Mode with slow-down enabled | $16 \mathrm{MHz}$ $20 \mathrm{MHz}$ | $\begin{aligned} & I_{\mathrm{DD}} \\ & I_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 6.6 \\ & 7.3 \end{aligned}$ | $\begin{aligned} & 8.2 \\ & 9.3 \end{aligned}$ | mA | 9) |
|  | Idle Mode with slow-down enabled | $16 \mathrm{MHz}$ $20 \mathrm{MHz}$ | $\begin{aligned} & I_{\mathrm{DD}} \\ & I_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 5.0 \\ & 5.3 \end{aligned}$ | $\begin{aligned} & 5.9 \\ & 6.5 \end{aligned}$ | mA | 10) |
|  | Power down mode |  | $I_{\text {PD }}$ | 5.3 | 30 | $\mu \mathrm{A}$ | $V_{\mathrm{DD}}=2 . .5 .5 \mathrm{~V}^{11)}$ |

## Notes see Page 60

## Note:

1) Capacitive loading on ports 0 and 2 may cause spurious noise pulses to be superimposed on the $V_{\text {OL }}$ of ALE and port 3 . The noise is due to external bus capacitance discharging into the port 0 and port 2 pins when these pins make 1 -to- 0 transitions during bus operation. In the worst case (capacitive loading > 100 pF ), the noise pulse on ALE line may exceed 0.8 V . In such cases it may be desirable to qualify ALE with a schmitt-trigger, or use an address latch with a schmitt-trigger strobe input.
2) Capacitive loading on ports 0 and 2 may cause the $V_{\text {OH }}$ on ALE and PSEN to momentarily fall below the $0.9 V_{\mathrm{DD}}$ specification when the address lines are stabilizing.
3) Overload conditions under operating conditions occur if the voltage on the respective pin exceeds the specified operating range (i.e. $V_{\mathrm{OV}}>V_{\mathrm{DD}}+0.5 \mathrm{~V}$ or $V_{\mathrm{OV}}<V_{\mathrm{SS}}-0.5 \mathrm{~V}$ ). The absolute sum of input currents on all port pins may not exceed 50 mA . The supply voltage $V_{\mathrm{DD}}$ and $V_{\mathrm{SS}}$ must remain within the specified limits.
4) Not $100 \%$ tested, guaranteed by design characterization.
5) Only valid for C505A-4E and C505CA-4E.
6) Only valid for C505A-4E and C505CA-4E in programming mode.
7) $I_{\mathrm{DD}}$ (active mode) is measured with:

XTAL1 driven with $t_{\mathrm{R}}, t_{\mathrm{F}}=5 \mathrm{~ns}, 50 \%$ duty cycle , $V_{\mathrm{IL}}=V_{\mathrm{SS}}+0.5 \mathrm{~V}, V_{\mathrm{IH}}=V_{\mathrm{DD}}-0.5 \mathrm{~V} ; \mathrm{XTAL} 2=\mathrm{N} . \mathrm{C}$.; $\mathrm{EA}=$ Port $0=$ RESET $=V_{D D} ;$ all other pins are disconnected.
8) $I_{\mathrm{DD}}$ (idle mode) is measured with all output pins disconnected and with all peripherals disabled;

XTAL 1 driven with $t_{\mathrm{R}}, t_{\mathrm{F}}=5 \mathrm{~ns}, 50 \%$ duty cycle, $V_{\mathrm{IL}}=V_{\mathrm{SS}}+0.5 \mathrm{~V}, V_{\mathrm{H}}=V_{\mathrm{DD}}-0.5 \mathrm{~V} ; \mathrm{XTAL2}=\mathrm{N} . \mathrm{C} . ;$
RESET $=\overline{\mathrm{EA}}=V_{\mathrm{SS}} ;$ Port0 $=V_{\mathrm{DD}} ;$ all other pins are disconnected; the microcontroller is put into idle mode by software;
9) $I_{\mathrm{DD}}$ (active mode with slow-down mode) is measured with all output pins disconnected and with all peripherals disabled;
XTAL 1 driven with $t_{\mathrm{R}}, t_{\mathrm{F}}=5 \mathrm{~ns}, 50 \%$ duty cycle, $V_{\mathrm{IL}}=V_{\mathrm{SS}}+0.5 \mathrm{~V}, V_{\mathrm{H}}=V_{\mathrm{DD}}-0.5 \mathrm{~V} ; \mathrm{XTAL2}=\mathrm{N} . \mathrm{C} . ;$
RESET $=\mathrm{EA}=V_{\text {SS }}$; all other pins are disconnected; the microcontroller is put into slow-down mode by software;
10) $I_{\mathrm{DD}}$ (idle mode with slow-down mode) is measured with all output pins disconnected and with all peripherals disabled;
XTAL1 driven with $t_{\mathrm{R}}, t_{\mathrm{F}}=5 \mathrm{~ns}, 50 \%$ duty cycle, $V_{\mathrm{IL}}=V_{\mathrm{SS}}+0.5 \mathrm{~V}, V_{\mathrm{IH}}=V_{\mathrm{DD}}-0.5 \mathrm{~V} ; \mathrm{XTAL2}=\mathrm{N} . \mathrm{C} . ;$
RESET $=\overline{E A}=V_{S S} ;$ Port0 $=V_{D D} ;$ all other pins are disconnected; the microcontroller is put into idle mode with slow-down enabled by software;
11) $I_{\mathrm{PD}}$ (power-down mode) is measured under following conditions:

Port $0=\overline{\mathrm{EA}}=V_{\mathrm{DD}} ; \operatorname{RESET}=V_{\mathrm{SS}} ; \mathrm{XTAL2}=\mathrm{N} . \mathrm{C} . ; \mathrm{XTAL1}=V_{\mathrm{SS}} ; V_{\mathrm{AGND}}=V_{\mathrm{SS}} ; V_{\text {AREF }}=V_{\mathrm{DD}} ;$
all other pins are disconnected.
12) The typical $I_{\mathrm{DD}}$ values are periodically measured at $T_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ but not $100 \%$ tested.
13) The maximum $I_{\mathrm{DD}}$ values are measured under worst case conditions ( $T_{\mathrm{A}}=0^{\circ} \mathrm{C}$ or $-40^{\circ} \mathrm{C}$ and $V_{\mathrm{DD}}=5.5 \mathrm{~V}$ )
14) The values are valid for C505CA-4R, C505CA-2R, C505CA-L, C505A-4R, C505A-2R and C505A-L only.


Figure 29
IDD Diagram of C505 and C505C

## C505/C505C : Power Supply Current Calculation Formulas

| Parameter | Symbol | Formula |
| :--- | :--- | :--- |
| Active mode | $I_{\mathrm{DD} \text { typ }}$ | $1.5 * f_{\mathrm{OSC}}+1.3$ |
|  | $I_{\mathrm{DD} \text { max }}$ | $1.5 * f_{\mathrm{OSC}}+9.0$ |
| Idle mode | $I_{\mathrm{DD} \text { typ }}$ | $0.74 * f_{\mathrm{OSC}}+1.4$ |
|  | $I_{\mathrm{DD} \text { max }}$ | $1.0 * f_{\mathrm{OSC}}+1.0$ |
| Active mode with | $I_{\mathrm{DD} \text { typ }}$ | $0.11 * f_{\mathrm{OSC}}+2.6$ |
| $\quad$ slow-down enabled | $I_{\mathrm{DD} \text { max }}$ | $0.25 * f_{\mathrm{OSC}}+2.5$ |
| Idle mode with | $I_{\mathrm{DD} \text { typ }}$ | $0.1 * f_{\mathrm{OSC}}+2.0$ |
| $\quad$ slow-down enabled | $I_{\mathrm{DD} \text { max }}$ | $0.25 * f_{\mathrm{OSC}}+2.0$ |

Note: $\quad f_{\text {osc }}$ is the oscillator frequency in MHz . $I_{\mathrm{DD}}$ values are given in mA .


Figure 30
IDD Diagram of C505A-4E and C505CA-4E

C505A-4E/C505CA-4E : Power Supply Current Calculation Formulas

| Parameter | Symbol | Formula |
| :--- | :--- | :--- |
| Active mode | $I_{\mathrm{DD} \text { typ }}$ | $1.63 * f_{\mathrm{OSC}}+2.6$ |
|  | $I_{\mathrm{DD} \text { max }}$ | $1.74 * f_{\mathrm{OSC}}+2.8$ |
| Idle mode | $I_{\mathrm{DD} \text { typ }}$ | $0.69 * f_{\mathrm{OSC}}+3.9$ |
|  | $I_{\mathrm{DD} \text { max }}$ | $0.74 * f_{\mathrm{OSC}}+4.1$ |
| Active mode with | $I_{\mathrm{DD} \text { typ }}$ | $0.6 * f_{\mathrm{OSC}}+0.3$ |
| slow-down enabled | $I_{\mathrm{DD} \text { max }}$ | $0.7 * f_{\mathrm{OSC}}+1.6$ |
| Idle mode with | $I_{\mathrm{DD} \text { typ }}$ | $0.3 * f_{\mathrm{OSC}}+0.3$ |
| $\quad$ slow-down enabled | $I_{\mathrm{DD} \text { max }}$ | $0.3 * f_{\mathrm{OSC}}+0.8$ |

Note: $f_{\text {osc }}$ is the oscillator frequency in MHz . $I_{\mathrm{DD}}$ values are given in mA .


Figure 31
IDD Diagram of C505A-4R/C505A-2R/C505A-L/C505CA-4R/C505CA-2R/C505CA-L

C505A-4R/C505A-2R/C505A-L/C505CA-4R/C505CA-2R/C505CA-L :
Power Supply Current Calculation Formulas

| Parameter | Symbol | Formula |
| :--- | :--- | :--- |
| Active mode | $I_{\mathrm{DD} \text { typ }}$ | $1.19 * f_{\mathrm{OSC}}+3.77$ |
|  | $I_{\mathrm{DD} \text { max }}$ | $1.54 * f_{\mathrm{OSC}}+4.47$ |
| Idle mode | $I_{\mathrm{DD} \text { typ }}$ | $0.57 * f_{\mathrm{OSC}}+3.55$ |
|  | $I_{\mathrm{DD}} \max$ | $0.75 * f_{\mathrm{OSC}}+4.26$ |
| Active mode with | $I_{\mathrm{DD} \text { typ }}$ | $0.18 * f_{\mathrm{OSC}}+3.74$ |
| $\quad$ slow-down enabled | $I_{\mathrm{DD}} \max$ | $0.28 * f_{\mathrm{OSC}}+3.67$ |
| Idle mode with | $I_{\mathrm{DD} \text { typ }}$ | $0.07 * f_{\mathrm{OSC}}+3.91$ |
| $\quad$ slow-down enabled | $I_{\mathrm{DD}} \max$ | $0.14 * f_{\mathrm{OSC}}+3.64$ |

Note: $\quad f_{\text {osc }}$ is the oscillator frequency in $\mathrm{MHz} . I_{\mathrm{DD}}$ values are given in mA .

C505/C505C/C505A/C505CA

## A/D Converter Characteristics of C505 and C505C

(Operating Conditions apply)

| Parameter | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |  |
| Analog input voltage | $V_{\text {AIN }}$ | $\begin{array}{\|l} V_{\mathrm{AGND}}- \\ 0.2 \end{array}$ | $\begin{aligned} & V_{\text {AREF }}+ \\ & 0.2 \end{aligned}$ | V | 1) |
| Sample time | $t_{\text {s }}$ | - | $\begin{array}{r} 64 \times t_{\mathbb{N}} \\ 32 \times t_{\mathbb{N}} \\ 16 \times t_{\mathbb{N}} \\ 8 \times t_{\mathbb{N}} \end{array}$ | ns | $\begin{aligned} & \text { Prescaler } \div 32 \\ & \text { Prescaler } \div 16 \\ & \text { Prescaler } \div 8 \\ & \text { Prescaler } \div 4^{2} \end{aligned}$ |
| Conversion cycle time | $t_{\text {ADCC }}$ | - | $\begin{array}{r} 320 \times t_{\mathbb{I N}} \\ 160 \times t_{\mathbb{N}} \\ 80 \times t_{\mathbb{N}} \\ 40 \times t_{\mathbb{I N}} \end{array}$ | ns | $\begin{aligned} & \text { Prescaler } \div 32 \\ & \text { Prescaler } \div 16 \\ & \text { Prescaler } \div 8 \\ & \text { Prescaler } \div 4 \end{aligned}$ |
| Total unadjusted error | $T_{\text {UE }}$ | - | $\pm 2$ | LSB | $\mathrm{V}_{\mathrm{SS}}+0.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{AIN}} \leq V_{\mathrm{DD}}-0.5 \mathrm{~V}^{4)}$ |
| Internal resistance of reference voltage source | $R_{\text {AREF }}$ | - | $\begin{aligned} & t_{\mathrm{ADC}} / 500 \\ & -1 \end{aligned}$ | $\mathrm{k} \Omega$ | $t_{\text {ADC }}$ in [ns] ${ }^{5 / 6)}$ |
| Internal resistance of analog source | $R_{\text {ASRC }}$ | - | $\begin{array}{\|l} \hline t_{\mathrm{s}} / 500 \\ -1 \end{array}$ | $\mathrm{k} \Omega$ | $t_{\mathrm{S}} \mathrm{in}[\mathrm{ns}]^{2)}{ }^{6)}$ |
| ADC input capacitance | $C_{\text {AIN }}$ | - | 50 | pF | 6) |

Notes see next page.

## Clock calculation table :

| Clock Prescaler Ratio | ADCL1, 0 |  | ${ }^{\text {t }}$ ADC | ${ }^{\text {t }}$ | ${ }^{\text {t }}$ ADCC |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\div 32$ | 1 | 1 | $32 \times \mathrm{t}_{\mathrm{I}}$ | $64 \times \mathrm{t}_{\mathrm{I}}$ | $320 \times \mathrm{t}_{\text {IN }}$ |
| $\div 16$ | 1 | 0 | $16 \times \mathrm{t}_{\mathrm{I}}$ | $32 \times \mathrm{t}_{\mathrm{I}}$ | $160 \times \mathrm{t}_{\mathrm{IN}}$ |
| $\div 8$ | 0 | 1 | $8 \times \mathrm{t}_{\mathrm{IN}}$ | $16 \times \mathrm{t}_{\mathrm{IN}}$ | $80 \times \mathrm{t}_{\mathrm{IN}}$ |
| $\div 4$ | 0 | 0 | $4 \times \mathrm{t}_{\mathrm{IN}}$ | $8 \times \mathrm{t}_{\mathrm{IN}}$ | $40 \times \mathrm{t}_{\mathrm{IN}}$ |

Further timing conditions : $\mathrm{t}_{\mathrm{ADC}} \mathrm{min}=800 \mathrm{~ns}$

$$
\mathrm{t}_{\mathrm{IN}}=1 / \mathrm{f} \mathrm{OSC}=\mathrm{t}_{\mathrm{CLP}}
$$

## Note:

1) $V_{\text {AIN }}$ may exeed $V_{\text {AGND }}$ or $V_{\text {AREF }}$ up to the absolute maximum ratings. However, the conversion result in these cases will be $00_{\mathrm{H}}$ or $\mathrm{FF}_{\mathrm{H}}$, respectively.
2) During the sample time the input capacitance $\mathrm{C}_{\text {AIN }}$ must be charged/discharged by the external source. The internal resistance of the analog source must allow the capacitance to reach their final voltage level within ts. After the end of the sample time ts, changes of the analog input voltage have no effect on the conversion result.
3) This parameter includes the sample time $\mathrm{t}_{\mathrm{s}}$, the time for determining the digital result. Values for the conversion clock $\mathrm{t}_{\mathrm{ADC}}$ depend on programming and can be taken from the table on the previous page.
4) $\mathrm{T}_{\mathrm{UE}}$ (max.) is tested at $-40 \leq T_{\mathrm{A}} \leq 125^{\circ} \mathrm{C} ; V_{\mathrm{DD}} \leq 5.5 \mathrm{~V} ; \mathrm{V}_{\text {AREF }} \leq V_{\mathrm{DD}}+0.1 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{SS}} \leq \mathrm{V}_{\mathrm{AGND}}$. It is guaranteed by design characterization for all other voltages within the defined voltage range.
If an overload condition occurs on maximum 2 unused analog input pins and the absolute sum of input overload currents on all analog input pins does not exceed 10 mA , an additional conversion error of $1 / 2$ LSB is permissible.
5) During the conversion the ADC's capacitance must be repeatedly charged or discharged. The internal resistance of the reference source must allow the capacitance to reach their final voltage level within the indicated time. The maximum internal resistance results from the programmed conversion timing.
6) Not $100 \%$ tested, but guaranteed by design characterization.

C505/C505C/C505A/C505CA

## A/D Converter Characteristics of C505A and C505CA

(Operating Conditions apply)

| Parameter | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |  |
| Analog input voltage | $V_{\text {AIN }}$ | $V_{\text {AGND }}$ | $V_{\text {AREF }}$ | V | 1) |
| Sample time | $t_{\text {s }}$ | - | $\begin{array}{r} 64 \times t_{\mathbb{N}} \\ 32 \times t_{\mathbb{N}} \\ 16 \times t_{\mathbb{N}} \\ 8 \times t_{t_{\mathbb{N}}} \end{array}$ | ns | Prescaler $\div 32$ <br> Prescaler $\div 16$ <br> Prescaler $\div 8$ <br> Prescaler $\div 4{ }^{\text {2) }}$ |
| Conversion cycle time | $t_{\text {ADCC }}$ | - | $\begin{array}{r} 384 \times t_{\mathbb{N}} \\ 192 \times t_{\mathbb{N}} \\ 96 \times t_{\mathbb{N}} \\ 48 \times t_{\mathbb{N}} \end{array}$ | ns | Prescaler $\div 32$ <br> Prescaler $\div 16$ <br> Prescaler $\div 8$ <br> Prescaler $\div 4{ }^{3}$ |
| Total unadjusted error | $T_{\text {UE }}$ | - | $\pm 2$ | LSB | $\mathrm{V}_{\text {SS }}+0.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{AIN}} \leq V_{\mathrm{DD}}-0.5 \mathrm{~V}^{4)}$ |
|  |  | - | $\pm 4$ | LSB | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}<\mathrm{V}_{\mathrm{AIN}}<V_{\mathrm{DD}}+0.5 \mathrm{~V} \\ & V_{\mathrm{DD}}-0.5 \mathrm{~V}<\mathrm{V}_{\mathrm{AIN}}<V_{\mathrm{DD}}{ }^{4)} \end{aligned}$ |
| Internal resistance of reference voltage source | $R_{\text {AREF }}$ | - | $\begin{array}{\|l} \mid t_{\mathrm{ADC}} / 250 \\ -0.25 \end{array}$ | $\mathrm{k} \Omega$ | $t_{\text {ADC }}$ in [ns] ${ }^{5) 6)}$ |
| Internal resistance of analog source | $R_{\text {ASRC }}$ | - | $\begin{array}{\|l} \hline t_{\mathrm{s}} / 500 \\ -0.25 \end{array}$ | k ת | $t_{\text {S }}$ in [ns] ${ }^{2 / 6)}$ |
| ADC input capacitance | $C_{\text {AIN }}$ | - | 50 | pF | 6) |

Notes see next page.

## Clock calculation table :

| Clock Prescaler Ratio | ADCL1, 0 |  | ${ }^{\text {t }}$ ADC | $\mathrm{t}_{s}$ | $\mathrm{t}_{\text {ADCC }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\div 32$ | 1 | 1 | $32 \times \mathrm{t}_{\mathrm{IN}}$ | $64 \times \mathrm{t}_{\mathrm{IN}}$ | $384 \times \mathrm{t}_{\mathrm{IN}}$ |
| $\div 16$ | 1 | 0 | $16 \times \mathrm{t}_{\mathrm{I}}$ | $32 \times \mathrm{t}_{\mathrm{I}}$ | $192 \times \mathrm{t}_{\mathrm{IN}}$ |
| $\div 8$ | 0 | 1 | $8 \times \mathrm{t}_{\mathrm{IN}}$ | $16 \times \mathrm{t}_{\mathrm{IN}}$ | $96 \times \mathrm{t}_{\mathrm{I}}$ |
| $\div 4$ | 0 | 0 | $4 \times \mathrm{t}_{\mathrm{IN}}$ | $8 \times \mathrm{t}_{\mathrm{IN}}$ | $48 \times \mathrm{t}_{\mathrm{IN}}$ |

Further timing conditions : $\mathrm{t}_{\mathrm{ADC}} \mathrm{min}=500 \mathrm{~ns}$

$$
\mathrm{t}_{\mathrm{IN}}=1 / \mathrm{f} \mathrm{OSC}=\mathrm{t}_{\mathrm{CLP}}
$$

## Note:

1) $V_{\text {AIN }}$ may exeed $V_{\text {AGND }}$ or $V_{\text {AREF }}$ up to the absolute maximum ratings. However, the conversion result in these cases will be $\mathrm{X} 000_{\mathrm{H}}$ or $\mathrm{X} 3 \mathrm{FF}_{\mathrm{H}}$, respectively.
2) During the sample time the input capacitance $\mathrm{C}_{\text {AIN }}$ must be charged/discharged by the external source. The internal resistance of the analog source must allow the capacitance to reach their final voltage level within ts. After the end of the sample time ts, changes of the analog input voltage have no effect on the conversion result.
3) This parameter includes the sample time ts, the time for determining the digital result and the time for the calibration. Values for the conversion clock $\mathrm{t}_{\mathrm{ADC}}$ depend on programming and can be taken from the table on the previous page.
4) $\mathrm{T}_{\text {UE }}$ is tested at $\mathrm{V}_{\text {AREF }}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {AGND }}=0 \mathrm{~V}, V_{\mathrm{DD}}=4.9 \mathrm{~V}$. It is guaranteed by design characterization for all other voltages within the defined voltage range.
If an overload condition occurs on maximum 2 unused analog input pins and the absolute sum of input overload currents on all analog input pins does not exceed 10 mA , an additional conversion error of $1 / 2 \mathrm{LSB}$ is permissible.
5) During the conversion the ADC's capacitance must be repeatedly charged or discharged. The internal resistance of the reference source must allow the capacitance to reach their final voltage level within the indicated time. The maximum internal resistance results from the programmed conversion timing.
6) Not $100 \%$ tested, but guaranteed by design characterization.

## AC Characteristics ( $\mathbf{1 6 ~ M H z , ~} 0.4$ to 0.6 Duty Cycle)

(Operating Conditions apply)
( $C_{\mathrm{L}}$ for port 0, ALE and $\overline{\mathrm{PSEN}}$ outputs $=100 \mathrm{pF} ; C_{\mathrm{L}}$ for all other outputs $=80 \mathrm{pF}$ )
Program Memory Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 16-MHz clock Duty Cycle 0.4 to 0.6 |  | Variable Clock <br> $1 / C L P=2 \mathrm{MHz}$ to 16 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| ALE pulse width | $t_{\text {LHLL }}$ | 48 | - | CLP - 15 | - | ns |
| Address setup to ALE | $t_{\text {AVLL }}$ | 10 | - | TCL ${ }_{\text {Hmin }}-15$ | - | ns |
| Address hold after ALE | $t_{\text {LLAX }}$ | 10 | - | TCL ${ }_{\text {H } \text { min }}-15$ | - | ns |
| ALE to valid instruction in | $t_{\text {LIIV }}$ | - | 75 | - | 2 CLP - 50 | ns |
| ALE to $\overline{\text { PSEN }}$ | $t_{\text {LLPL }}$ | 10 | - | TCL ${ }_{\text {Lmin }}-15$ | - | ns |
| PSEN pulse width | $t_{\text {PLPH }}$ | 73 | - | $\begin{aligned} & \text { CLP+ } \\ & \text { TCL }_{\text {Hin }}-15 \end{aligned}$ | - | ns |
| $\overline{\text { PSEN }}$ to valid instruction in | $t_{\text {PLIV }}$ | - | 38 | - | $\begin{aligned} & \text { CLP+ } \\ & \text { TCL }_{\text {Hmin }} 50 \end{aligned}$ | ns |
| Input instruction hold after $\overline{\text { PSEN }}$ | $t_{\text {PXIX }}$ | 0 | - | 0 | - | ns |
| Input instruction float after $\overline{\text { PSEN }}$ | $t_{\text {PXIZ }}{ }^{*}$ | - | 15 | - | TCL ${ }_{\text {Lmin }}-10$ | ns |
| Address valid after PSEN | $t_{\text {PXAV }}{ }^{\text {a }}$ | 20 | - | $\mathrm{TCL}_{\mathrm{Lmin}}-5$ | - | ns |
| Address to valid instruction in | $t_{\text {AVIV }}$ | - | 95 | - | $\begin{aligned} & 2 \text { CLP + } \\ & \text { TCL }_{\text {Hin }}-55 \end{aligned}$ | ns |
| Address float to PSEN | $t_{\text {AZPL }}$ | -5 | - | -5 | - | ns |

*) Interfacing the C505 to devices with float times up to 20 ns is permissible. This limited bus contention will not cause any damage to port 0 drivers.

AC Characteristics ( $16 \mathrm{MHz}, 0.4$ to 0.6 Duty Cycle, cont'd)

## External Data Memory Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 16-MHz clockDuty Cycle0.4 to 0.6 |  | Variable Clock 1/CLP= 2 MHz to 16 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| $\overline{\mathrm{RD}}$ pulse width | $t_{\text {RLRH }}$ | 158 | - | 3 CLP - 30 | - | ns |
| $\overline{\text { WR pulse width }}$ | $t_{\text {WLWH }}$ | 158 | - | 3 CLP - 30 | - | ns |
| Address hold after ALE | $t_{\text {LLAX2 }}$ | 48 | - | CLP - 15 | - | ns |
| $\overline{\mathrm{RD}}$ to valid data in | $t_{\text {RLDV }}$ | - | 100 | - | $\begin{aligned} & 2 \text { CLP }_{+} \\ & \text {TCL }_{\text {H } \text { min }}-50 \end{aligned}$ | ns |
| Data hold after $\overline{\mathrm{RD}}$ | $t_{\text {RHDX }}$ | 0 | - | 0 | - | ns |
| Data float after $\overline{\mathrm{RD}}$ | $t_{\text {RHDZ }}$ | - | 51 | - | CLP - 12 | ns |
| ALE to valid data in | $t_{\text {LLIV }}$ | - | 200 | - | 4 CLP - 50 | ns |
| Address to valid data in | $t_{\text {AvDV }}$ | - | 200 | - | $\begin{array}{\|l\|} \hline 4 \mathrm{CLP}+ \\ \mathrm{TCL}_{\text {Hin }}-75 \\ \hline \end{array}$ | ns |
| $\overline{\mathrm{ALE}}$ to $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ | $t_{\text {LLWL }}$ | 73 | 103 | $\begin{array}{\|l\|l} \hline \mathrm{CLP}_{+} \\ \mathrm{TCL}_{\mathrm{Lmin}}-15 \\ \hline \end{array}$ | $\begin{array}{\|l\|l} \hline \text { CLP }_{+} \\ \text {TCL }_{\text {Lmin }}+15 \\ \hline \end{array}$ | ns |
| Address valid to $\overline{\mathrm{WR}}$ | $t_{\text {AVWL }}$ | 95 | - | 2 CLP - 30 | - | ns |
| $\overline{\overline{W R}}$ or $\overline{\mathrm{RD}}$ high to ALE high | $t_{\text {WHLH }}$ | 10 | 40 | TCL ${ }_{\text {Hmin }}-15$ | $\mathrm{TCL}_{\text {Hmin }}+15$ | ns |
| Data valid to $\overline{W R}$ transition | $t_{\text {Qvwx }}$ | 5 | - | TCL $L_{\text {Lmin }}-20$ | - | ns |
| Data setup before $\overline{\mathrm{WR}}$ | $t_{\text {Qvwh }}$ | 163 | - | $\begin{aligned} & 3 C L P+ \\ & \text { TCL }_{L \min }-50 \end{aligned}$ | - | ns |
| Data hold after $\overline{\mathrm{WR}}$ | $t_{\text {WHax }}$ | 5 | - | TCL ${ }_{\text {Hmin }}-20$ | - | ns |
| Address float after $\overline{\mathrm{RD}}$ | $t_{\text {RLAZ }}$ | - | 0 | - | 0 | ns |

AC Characteristics ( $16 \mathrm{MHz}, 0.4$ to 0.6 Duty Cycle, cont'd)

## External Clock Drive Characteristics

| Parameter | Symbol | CPU Clock = 16 MHz <br> Duty Cycle 0.4 to 0.6 |  | Variable CPU Clock 1/CLP = 2 to 16 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. |  |
| Oscillator period | CLP | 62.5 | 62.5 | 62.5 | 500 | ns |
| High time | TCL ${ }_{\text {H }}$ | 25 | - | 25 | CLP - TCL | ns |
| Low time | TCL ${ }_{\text {L }}$ | 25 | - | 25 | CLP - TCL ${ }_{\text {H }}$ | ns |
| Rise time | $t_{\text {R }}$ | - | 10 | - | 10 | ns |
| Fall time | $t_{\mathrm{F}}$ | - | 10 | - | 10 | ns |
| Oscillator duty cycle | DC | 0.4 | 0.6 | 25 / CLP | 1-25 / CLP | - |
| Clock cycle | TCL | 25 | 37.5 | CLP * DC ${ }_{\text {min }}$ | CLP * DC ${ }_{\text {max }}$ | ns |

Note: The 16 MHz values in the tables are given as an example for a typical duty cycle variation of the oscillator clock from 0.4 to 0.6 .

C505/C505C/C505A/C505CA

## AC Characteristics ( $20 \mathrm{MHz}, 0.5$ Duty Cycle)

(Operating Conditions apply)
( $C_{\mathrm{L}}$ for port 0, ALE and $\overline{\text { PSEN }}$ outputs $=100 \mathrm{pF} ; C_{\mathrm{L}}$ for all other outputs $=80 \mathrm{pF}$ )
Program Memory Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 20 MHz clock 0.5 Duty Cycle |  | Variable Clock 1/CLP = 2 MHz to 20 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| ALE pulse width | $t_{\text {LHLL }}$ | 35 | - | CLP - 15 | - | ns |
| Address setup to ALE | $t_{\text {AvLL }}$ | 10 | - | CLP/2-15 | - | ns |
| Address hold after ALE | $t_{\text {LLAX }}$ | 10 | - | CLP/2-15 | - | ns |
| ALE to valid instruction in | $t_{\text {LLIV }}$ | - | 55 | - | 2 CLP - 45 | ns |
| ALE to PSEN | $t_{\text {LLPL }}$ | 10 | - | CLP/2-15 | - | ns |
| $\overline{\text { PSEN }}$ pulse width | $t_{\text {PLPH }}$ | 60 | - | $\begin{array}{\|l\|} \hline 3 / 2 \text { CLP } \\ -15 \end{array}$ | - | ns |
| $\overline{\text { PSEN }}$ to valid instruction in | $t_{\text {PLIV }}$ | - | 25 | - | $\begin{aligned} & \text { 3/2 CLP } \\ & -50 \end{aligned}$ | ns |
| Input instruction hold after $\overline{\text { PSEN }}$ | $t_{\text {PXIX }}$ | 0 | - | 0 | - | ns |
| Input instruction float after $\overline{\text { PSEN }}$ | $t_{\text {PXIZ }}{ }^{\text {a }}$ | - | 20 | - | CLP/2-5 | ns |
| Address valid after PSEN | $t_{\text {PXAV }}{ }^{*}$ | 20 | - | CLP/2-5 | - | ns |
| Address to valid instruction in | $t_{\text {Aviv }}$ | - | 65 | - | $\begin{aligned} & \text { 5/2 CLP } \\ & -60 \end{aligned}$ | ns |
| Address float to $\overline{\text { PSEN }}$ | $t_{\text {AZPL }}$ | - 5 | - | - 5 | - | ns |

*) Interfacing the C 505 to devices with float times up to 20 ns is permissible. This limited bus contention will not cause any damage to port 0 drivers.

AC Characteristics (20 MHz, 0.5 Duty Cycle, cont'd)

## External Data Memory Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 20 MHz clock 0.5 Duty Cycle |  | Variable Clock$\text { 1/CLP = } 2 \text { MHz to } 20 \mathrm{MHz}$ |  |  |
|  |  | min. | max. | min. | max. |  |
| $\overline{\overline{R D}}$ pulse width | $t_{\text {RLRH }}$ | 120 | - | 3 CLP - 30 | - | ns |
| $\overline{\overline{W R}}$ pulse width | $t_{\text {WLWH }}$ | 120 | - | 3 CLP - 30 | - | ns |
| Address hold after ALE | $t_{\text {LLAX2 }}$ | 35 | - | CLP - 15 | - | ns |
| $\overline{\overline{R D}}$ to valid data in | $t_{\text {RLDV }}$ | - | 75 | - | 5/2 CLP- 50 | ns |
| Data hold after $\overline{\mathrm{RD}}$ | $t_{\text {RHDX }}$ | 0 | - | 0 | - | ns |
| Data float after $\overline{\mathrm{RD}}$ | $t_{\text {RHDZ }}$ | - | 38 | - | CLP - 12 | ns |
| ALE to valid data in | $t_{\text {LLDV }}$ | - | 150 | - | 4 CLP - 50 | ns |
| Address to valid data in | $t_{\text {AVDV }}$ | - | 150 | - | 9/2 CLP - 75 | ns |
| ALE to $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ | $t_{\text {LLWL }}$ | 60 | 90 | 3/2 CLP - 15 | 3/2 CLP + 15 | ns |
| Address valid to $\overline{\mathrm{WR}}$ | $t_{\text {AVWL }}$ | 70 | - | 2 CLP - 30 | - | ns |
| $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ high to ALE high | $t_{\text {WHLH }}$ | 10 | 40 | CLP/2-15 | CLP/2 + 15 | ns |
| Data valid to $\overline{W R}$ transition | $t_{\text {Qvwx }}$ | 5 | - | CLP/2-20 | - | ns |
| Data setup before $\overline{\mathrm{WR}}$ | $t_{\text {QVWH }}$ | 125 | - | 7/2 CLP - 50 | - | ns |
| Data hold after $\overline{\mathrm{WR}}$ | $t_{\text {WHax }}$ | 5 | - | CLP/2-20 | - | ns |
| Address float after $\overline{\mathrm{RD}}$ | $t_{\text {RLAZ }}$ | - | 0 | - | 0 | ns |

## External Clock Drive Characteristics

| Parameter | Symbol |  | Values | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Variable Clock <br> Freq. $=\mathbf{2 ~ M H z}$ to $\mathbf{2 0 ~ M H z}$ |  |  |
|  |  | min. | max. |  |
| Oscillator period | CLP | 50 | 500 | ns |
| High time | TCL ${ }_{\text {H }}$ | 15 | CLP-TCL ${ }_{\text {L }}$ | ns |
| Low time | TCL ${ }_{\text {L }}$ | 15 | CLP-TCL ${ }_{\text {H }}$ | ns |
| Rise time | $t_{\mathrm{R}}$ | - | 10 | ns |
| Fall time | $t_{\text {F }}$ | - | 10 | ns |
| Oscillator duty cycle | DC | 0.5 | 0.5 | - |



Figure 32
Program Memory Read Cycle


Figure 33
Data Memory Read Cycle


Figure 34
Data Memory Write Cycle


Figure 35

## External Clock Drive on XTAL1

## AC Characteristics of Programming Mode (C505A-4E and C505CA-4E only)

$V_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \% ; V_{\mathrm{PP}}=11.5 \mathrm{~V} \pm 5 \% ; \quad T_{\mathrm{A}}=25^{\circ} \mathrm{C} \pm 10^{\circ} \mathrm{C}$

| Parameter | Symbol | Limit Values |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |
| PALE pulse width | $t_{\text {PaW }}$ | 35 | - | ns |
| PMSEL setup to PALE rising edge | $t_{\text {PMS }}$ | 10 | - |  |
| Address setup to PALE, $\overline{\text { PROG }}$, or $\overline{\text { PRD }}$ falling edge | $t_{\text {PAS }}$ | 10 | - | ns |
| Address hold after PALE, $\overline{\text { PROG }}$, or $\overline{\text { PRD }}$ falling edge | $t_{\text {PAH }}$ | 10 | - | ns |
| Address, data setup to $\overline{\text { PROG }}$ or $\overline{\text { PRD }}$ | $t_{\text {PCS }}$ | 100 | - | ns |
| Address, data hold after $\overline{\text { PROG }}$ or $\overline{\text { PRD }}$ | $t_{\text {PCH }}$ | 0 | - | ns |
| PMSEL setup to $\overline{\text { PROG }}$ or $\overline{\text { PRD }}$ | $t_{\text {PMS }}$ | 10 | - | ns |
| PMSEL hold after $\overline{\text { PROG }}$ or $\overline{\text { PRD }}$ | $t_{\text {PMH }}$ | 10 | - | ns |
| $\overline{\text { PROG }}$ pulse width | $t_{\text {PWW }}$ | 100 | - | $\mu \mathrm{S}$ |
| $\overline{\text { PRD pulse width }}$ | $t_{\text {PRW }}$ | 100 | - | ns |
| Address to valid data out | $t_{\text {PAD }}$ | - | 75 | ns |
| $\overline{\text { PRD }}$ to valid data out | $t_{\text {PRD }}$ | - | 20 | ns |
| Data hold after $\overline{\text { PRD }}$ | $t_{\text {PDH }}$ | 0 | - | ns |
| Data float after $\overline{\text { PRD }}$ | $t_{\text {PDF }}$ | - | 20 | ns |
| $\overline{\overline{\mathrm{PROG}} \text { high between two consecutive } \overline{\mathrm{PROG}}}$ low pulses | $t_{\text {PWH }}$ | 1 | - | $\mu \mathrm{S}$ |
| $\overline{\text { PRD }}$ high between two consecutive $\overline{\text { PRD }}$ low pulses | $t_{\text {PWH2 }}$ | 100 |  | ns |
| XTAL clock period | $t_{\text {CLKP }}$ | 83.3 | 500 | ns |

C505/C505C/C505A/C505CA


Notes: $\overline{\text { PRD }}$ must be high during a programming write cycle.

Figure 36
Programming Code Byte - Write Cycle Timing


Figure 37
Verify Code Byte - Read Cycle Timing


Note: PALE should be low during a lock bit read / write cycle.

Figure 38
Lock Bit Access Timing


Note: $\overline{\text { PROG }}$ must be high during a programming read cycle.

Figure 39
Version Byte Read Timing

C505/C505C/C505A/C505CA

ROM/OTP Verification Characteristics for C505
ROM Verification Mode 1 (C505(C)(A)-2R and C505(C)A-4R only)

| Parameter | Symbol | Limit Values |  | Unit |
| :--- | :--- | :--- | :--- | :--- |
|  |  | min. | max. |  |
| Address to valid data | $t_{\text {AVQV }}$ | - | 5 CLP | ns |



Figure 40
ROM Verification Mode 1

C505/C505C/C505A/C505CA

ROM/OTP Verification Characteristics for C505 (cont'd)
ROM/OTP Verification Mode 2

| Parameter | Symbol | Limit Values |  |  | Unit |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | min. | typ | max. |  |
| ALE pulse width | $t_{\mathrm{AWD}}$ | - | CLP | - | ns |
| ALE period | $t_{\mathrm{ACY}}$ | - | 6 CLP | - | ns |
| Data valid after ALE | $t_{\mathrm{DVA}}$ | - | - | 2 CLP | ns |
| Data stable after ALE | $t_{\mathrm{DSA}}$ | 4 CLP | - | - | ns |
| P3.5 setup to ALE low | $t_{\mathrm{AS}}$ | - | $t_{\mathrm{CL}}$ | - | ns |
| Oscillator frequency | $1 / \mathrm{CLP}$ | 4 | - | 6 | MHz |



Figure 41
ROM/OTP Verification Mode 2


AC Inputs during testing are driven at $V_{\mathrm{DD}}-0.5 \mathrm{~V}$ for a logic '1' and 0.45 V for a logic ' 0 '. Timing measurements are made at $V_{\text {IHmin }}$ for a logic '1' and $V_{\text {LLmax }}$ for a logic '0'.

Figure 42
AC Testing: Input, Output Waveforms


MCT00038
For timing purposes a port pin is no longer floating when a 100 mV change from load voltage occurs and begins to float when a 100 mV change from the loaded $V_{\mathrm{OH}} / V_{\mathrm{OL}}$ level occurs.
$I_{\mathrm{OL}} / I_{\mathrm{OH}} \geq \pm 20 \mathrm{~mA}$
Figure 43

## AC Testing : Float Waveforms



Figure 44
Recommended Oscillator Circuits for Crystal Oscillator

## P-MQFP-44-2 (SMD)

(Plastic Metric Quad Flat Package)


1) Does not include plastic or metal protrusion of 0.25 max. per side

Figure 45

## P-MQFP-44 Package Outline

Sorts of Packing
Package outlines for tubes, trays etc. are contained in our
Data Book "Package Information"
SMD = Surface Mounted Device

## Infineon goes for Business Excellence

"Business excellence means intelligent approaches and clearly defined processes, which are both constantly under review and ultimately lead to good operating results.
Better operating results and business excellence mean less idleness and wastefulness for all of us, more professional success, more accurate information, a better overview and, thereby, less frustration and more satisfaction."

Dr. Ulrich Schumacher
http://www.infineon.com


[^0]:    *) I = Input
    $\mathrm{O}=$ Output

[^1]:    *) I = Input
    $\mathrm{O}=$ Output

[^2]:    *) I = Input
    $\mathrm{O}=$ Output

[^3]:    *) I = Input

[^4]:    1) "Enhanced Hooks Technology" is a trademark and patent of Metalink Corporation licensed to Infineon Technologies.
[^5]:    1) Bit-addressable special function registers
    2) This special function register is listed repeatedly since some bits of it also belong to other functional blocks.
    3) " $X$ " means that the value is undefined and the location is reserved
    4) This SFR is a mapped SFR. For accessing this SFR, bit RMAP in SFR SYSCON must be set.
    5) The content of this SFR varies with the actual step of the C505 (eg. 01 H for the first step)
    6) C505 / C505A/C505C only
    7) C505CA only
[^6]:    1) Bit-addressable special function registers
    2) This special function register is listed repeatedly since some bits of it also belong to other functional blocks.
    3) " $X$ " means that the value is undefined and the location is reserved. " $U$ " means that the value is unchanged by a reset operation. "U" values are undefined (as "X") after a power-on reset operation
    4) SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set.
    5) The notation " $n$ " ( $n=1$ to $F$ ) in the message object address definition defines the number of the related message object.
[^7]:    1) $X$ means that the value is undefined and the location is reserved
    2) Bit-addressable special function registers
    3) C505 /C505C/C505A only
    4) C505CA only
[^8]:    1) The notation " $n$ " ( $n=1$ to $F$ ) in the address definition defines the number of the related message object.
    2) " $X$ " means that the value is undefined and the location is reserved. " $U$ " means that the value is unchanged by a reset operation. "U" values are undefined (as "X") after a power-on reset operation
