



Welcome to E-XFL.COM

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

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

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

#### Details

| Details                    |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                    |
| Core Processor             | C251                                                                        |
| Core Size                  | 8/16-Bit                                                                    |
| Speed                      | 24MHz                                                                       |
| Connectivity               | EBI/EMI, I <sup>2</sup> C, Microwire, SPI, UART/USART                       |
| Peripherals                | POR, PWM, WDT                                                               |
| Number of I/O              | 32                                                                          |
| Program Memory Size        | -                                                                           |
| Program Memory Type        | ROMIess                                                                     |
| EEPROM Size                | -                                                                           |
| RAM Size                   | 1K x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                                 |
| Data Converters            | -                                                                           |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 44-LCC (J-Lead)                                                             |
| Supplier Device Package    | 44-PLCC (16.6x16.6)                                                         |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/tsc80251g2d-24ibr |

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

## **Block Diagram**







# **Pin Description**

Pinout

Figure 1. TSC80251G2D 40-pin DIP package







## Table 7. System Management SFRs

| Mnemonic | Name             |
|----------|------------------|
| PCON     | Power Control    |
| POWM     | Power Management |

| Mnemonic | Name                                     |
|----------|------------------------------------------|
| CKRL     | Clock Reload                             |
| WCON     | Synchronous Real-Time Wait State Control |

## Table 8. Interrupt SFRs

| Mnemonic | Name                              |
|----------|-----------------------------------|
| IE0      | Interrupt Enable Control 0        |
| IE1      | Interrupt Enable Control 1        |
| IPH0     | Interrupt Priority Control High 0 |

| Table 9. Keyb | oard Interface | SFRs |
|---------------|----------------|------|
|---------------|----------------|------|

| Mnemonic | Name                          |
|----------|-------------------------------|
| P1IE     | Port 1 Input Interrupt Enable |
| P1F      | Port 1 Flag                   |

| IPH1 | Interrupt Priority Control High 1 |
|------|-----------------------------------|
| IPL1 | Interrupt Priority Control Low 1  |
|      |                                   |
|      |                                   |

Interrupt Priority Control Low 0

Mnemonic Name

IPL0

| Mnemonic | Name                   |
|----------|------------------------|
| P1LS     | Port 1 Level Selection |





# **Table 11.** Configuration Byte 0UCONFIG0

| 7          | 6               | 5                                                                                                                                                                                                                               | 4                                                       | 3                                                          | 2                                             | 1              | 0              |  |
|------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------|-----------------------------------------------|----------------|----------------|--|
| -          | WSA1#           | WSA0#                                                                                                                                                                                                                           | XALE#                                                   | RD1                                                        | RD0                                           | PAGE#          | SRC            |  |
| Bit Number | Bit<br>Mnemonic | Descriptio                                                                                                                                                                                                                      | Description                                             |                                                            |                                               |                |                |  |
| 7          | -               | Reserved<br>Set this bit                                                                                                                                                                                                        | when writing                                            | to UCONFIG0                                                | ).                                            |                |                |  |
| 6          | WSA1#           | Wait State                                                                                                                                                                                                                      |                                                         |                                                            |                                               |                | fan ar fam al  |  |
| 5          | WSA0#           |                                                                                                                                                                                                                                 | cesses (all re<br><u>VSA0#</u> <u>Nu</u><br>3<br>2<br>1 | it states for RL<br>gions except (<br><u>umber of Wait</u> | ,                                             | -SEN# signals  | s for external |  |
| 4          | XALE#           |                                                                                                                                                                                                                                 | tend the dura                                           |                                                            | E pulse from T<br>E pulse to 1·T <sub>o</sub> |                |                |  |
| 3          | RD1             | -                                                                                                                                                                                                                               | gnal Select                                             |                                                            |                                               |                |                |  |
| 2          | RD0             |                                                                                                                                                                                                                                 |                                                         | s (see Table 1                                             | al address bu<br>3).                          | s and the usag | ge of RD#,     |  |
| 1          | PAGE#           | Page Mode Select bit <sup>(1)</sup><br>Clear to select the faster Page mode with A15:8/D7:0 on Port 2 and A7:0 on<br>Port 0.<br>Set to select the non-Page mode <sup>(2)</sup> with A15:8 on Port 2 and A7:0/D7:0 on Port<br>0. |                                                         |                                                            |                                               |                |                |  |
| 0          | SRC             | Source Mode/Binary Mode Select bit<br>Clear to select the binary mode.<br>Set to select the source mode.                                                                                                                        |                                                         |                                                            |                                               |                |                |  |

Notes: 1. UCONFIG0 is fetched twice so it can be properly read both in Page or Non-Page modes. If P2.1 is cleared during the first data fetch, a Page mode configuration is used, otherwise the subsequent fetches are performed in Non-Page mode.

2. This selection provides compatibility with the standard 80C51 hardware which is multiplexing the address LSB and the data on Port 0.

# **Table 12.** Configuration Byte 1UCONFIG1

| 7             | 6                         | 5                | 4                                                                                                                                                                                                                                                                        | 3              | 2       | 1     | 0             |  |
|---------------|---------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------|-------|---------------|--|
| CSIZE         |                           |                  | INTR                                                                                                                                                                                                                                                                     | WSB            | WSB1#   | WSB0# | EMAP#         |  |
| Bit<br>Number | Bit Mnem                  | nonic De         | Description                                                                                                                                                                                                                                                              |                |         |       |               |  |
| 7             | CSIZE<br>TSC87251G2D<br>7 |                  | On-Chip Code Memory Size bit <sup>(1)</sup><br>Clear to select 16 KB of on-chip code memory (TSC87251G1D<br>product).<br>Set to select 32 KB of on-chip code memory (TSC87251G2D product).                                                                               |                |         |       |               |  |
|               | TSC8025<br>TSC8325        |                  | eserved<br>et this bit when                                                                                                                                                                                                                                              | writing to UCC | ONFIG1. |       |               |  |
| 6             | -                         |                  | eserved<br>et this bit when                                                                                                                                                                                                                                              | writing to UCC | ONFIG1. |       |               |  |
| 5             | -                         |                  | Reserved<br>Set this bit when writing to UCONFIG1.                                                                                                                                                                                                                       |                |         |       |               |  |
| 4             | INTF                      | Cl<br>R by<br>Se | Interrupt Mode bit <sup>(2)</sup><br>Clear so that the interrupts push two bytes onto the stack (the two lower<br>bytes of the PC register).<br>Set so that the interrupts push four bytes onto the stack (the three bytes<br>of the PC register and the PSW1 register). |                |         |       |               |  |
| 3             | WSE                       | B CI             | Wait State B bit <sup>(3)</sup><br>Clear to generate one wait state for memory region 01:.<br>Set for no wait states for memory region 01:.                                                                                                                              |                |         |       |               |  |
| 2             | WSB                       |                  | ait State B bit                                                                                                                                                                                                                                                          |                |         |       | # ciencle for |  |
| 1             | WSB                       | ex<br><u>W</u>   | 0 1 2<br>1 0 1                                                                                                                                                                                                                                                           |                |         |       |               |  |
| 0             | EMAF                      | P# FF<br>Se      | On-Chip Code Memory Map bit<br>Clear to map the upper 16 KB of on-chip code memory (at FF:4000h-<br>FF:7FFFh) to the data space (at 00:C000h-00:FFFFh).<br>Set not to map the upper 16 KB of on-chip code memory (at FF:4000h-<br>FF:7FFFh) to the data space.           |                |         |       |               |  |

Notes: 1. The CSIZE is only available on EPROM/OTPROM products.

2. Two or four bytes are transparently popped according to INTR when using the RETI instruction. INTR must be set if interrupts are used with code executing outside region FF:.

3. Use only for Step A compatibility; set this bit when WSB1:0# are used.





#### Table 16. Notation for Immediate Addressing

| Immediate<br>Address | Description                                                                                                                           | C251 | C51 |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------|------|-----|
| #data                | An 8-bit constant that is immediately addressed in an instruction                                                                     | 3    | 3   |
| #data16              | A 16-bit constant that is immediately addressed in an instruction                                                                     | 3    | -   |
| #0data16<br>#1data16 | A 32-bit constant that is immediately addressed in an instruction. The upper word is filled with zeros (#0data16) or ones (#1data16). | 3    | _   |
| #short               | A constant, equal to 1, 2, or 4, that is immediately addressed in an instruction.                                                     | 3    | _   |

#### Table 17. Notation for Bit Addressing

| Direct<br>Address | Description                                                                                                                                                                                                                                                            | C251 | C51 |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|
| bit51             | A directly addressed bit (bit number = 00h-FFh) in memory or an SFR. Bits 00h-7Fh are the 128 bits in byte locations 20h-2Fh in the on-chip RAM. Bits 80h-FFh are the 128 bits in the 16 SFRs with addresses that end in 0h or 8h, S:80h, S:88h, S:90h,, S:F0h, S:F8h. | _    | 3   |
| bit               | A directly addressed bit in memory locations 00:0020h-00:007Fh or in any defined SFR.                                                                                                                                                                                  | 3    |     |

#### Table 18. Notation for Destination in Control Instructions

| Direct<br>Address | Description                                                                                                                              | C251 | C51 |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------|------|-----|
| rel               | A signed (two's complement) 8-bit relative address. The destination is -128 to +127 bytes relative to the next instruction's first byte. | 3    | 3   |
| addr11            | An 11-bit target address. The target is in the same 2-Kbyte block of memory as the next instruction's first byte.                        | _    | 3   |
| addr16            | A 16-bit target address. The target can be anywhere within the same 64-Kbyte region as the next instruction's first byte.                | _    | 3   |
| addr24            | A 24-bit target address. The target can be anywhere within the 16-<br>Mbyte address space.                                               | 3    | -   |

| Register                                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | C251 | C51 |
|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|
| at Ri                                                       | A memory location (00h-FFh) addressed indirectly via byte registers<br>R0 or R1                                                                                                                                                                                                                                                                                                                                                                                                                                                  | _    | 3   |
| Rn<br>n                                                     | Byte register R0-R7 of the currently selected register bank<br>Byte register index: n = 0-7                                                                                                                                                                                                                                                                                                                                                                                                                                      | _    | 3   |
| Rm<br>Rmd<br>Rms<br>m, md, ms                               | Byte register R0-R15 of the currently selected register file<br>Destination register<br>Source register<br>Byte register index: m, md, ms = 0-15                                                                                                                                                                                                                                                                                                                                                                                 | 3    | -   |
| WRj<br>WRjd<br>WRjs<br>at WRj<br>at WRj +dis16<br>j, jd, js | Word register WR0, WR2,, WR30 of the currently selected register<br>file<br>Destination register<br>Source register<br>A memory location (00:0000h-00:FFFFh) addressed indirectly<br>through word register WR0-WR30, is the target address for jump<br>instructions.<br>A memory location (00:0000h-00:FFFFh) addressed indirectly<br>through word register (WR0-WR30) + 16-bit signed (two's<br>complement) displacement value<br>Word register index: j, jd, js = 0-30                                                         | 3    | _   |
| DRk<br>DRkd<br>DRks<br>at DRk<br>at DRk +dis16<br>k, kd, ks | Dword register DR0, DR4,, DR28, DR56, DR60 of the currently<br>selected register file<br>Destination register<br>Source register<br>A memory location (00:0000h-FF:FFFFh) addressed indirectly<br>through dword register DR0-DR28, DR56 and DR60, is the target<br>address for jump instruction<br>A memory location (00:0000h-FF:FFFFh) addressed indirectly<br>through dword register (DR0-DR28, DR56, DR60) + 16-bit (two's<br>complement) signed displacement value<br>Dword register index: k, kd, ks = 0, 4, 8, 28, 56, 60 | 3    | _   |

#### Table 19. Notation for Register Operands





#### Table 25. Summary of Move Instructions (1/3)

| Move to High wordMOVH <dest>, <src>dest opnd<sub><math>31:16 \leftarrow src opnd</math></sub></src></dest>                          |
|-------------------------------------------------------------------------------------------------------------------------------------|
| Move with Sign extensionMOVS <dest>, <src>dest opnd <math>\leftarrow</math> src opnd with sign extend</src></dest>                  |
| Move with Zero extensionMOVZ <dest>, <src>dest opnd <math display="inline">\leftarrow</math> src opnd with zero extend</src></dest> |
| Move CodeMOVC A, $<$ src>(A) $\leftarrow$ src opnd                                                                                  |
|                                                                                                                                     |

Move eXtendedMOVX <dest>, <src>dest opnd  $\leftarrow$  src opnd

|          | dosta                                        | Binary Mode                                             |       | Mode             | Source Mode |                  |
|----------|----------------------------------------------|---------------------------------------------------------|-------|------------------|-------------|------------------|
| Mnemonic | <dest>,<br/><src><sup>(2)</sup></src></dest> | Comments                                                | Bytes | States           | Bytes       | States           |
| MOVH     | DRk, #data16                                 | 16-bit immediate data into upper word of dword register | 5     | 3                | 4           | 2                |
| MOVS     | WRj, Rm                                      | Byte register to word register with sign extension      | 3     | 2                | 2           | 1                |
| MOVZ     | WRj, Rm                                      | Byte register to word register with zeros extension     | 3     | 2                | 2           | 1                |
| MOVC     | A, at A +DPTR                                | Code byte relative to DPTR to ACC                       | 1     | 6 <sup>(3)</sup> | 1           | 6 <sup>(3)</sup> |
|          | A, at A +PC                                  | Code byte relative to PC to ACC                         | 1     | 6 <sup>(3)</sup> | 1           | 6 <sup>(3)</sup> |
|          | A, at Ri                                     | Extended memory (8-bit address) to ACC <sup>(2)</sup>   | 1     | 4                | 1           | 5                |
| MOVX     | A, at DPTR                                   | Extended memory (16-bit address) to ACC <sup>(2)</sup>  | 1     | 3 <sup>(4)</sup> | 1           | 3 <sup>(4)</sup> |
| WOVX     | at Ri, A                                     | ACC to extended memory (8-bit address) <sup>(2)</sup>   | 1     | 4                | 1           | 4                |
|          | at DPTR, A                                   | ACC to extended memory (16-bit address) <sup>(2)</sup>  | 1     | 4 <sup>(3)</sup> | 1           | 4 <sup>(3)</sup> |

Notes: 1. A shaded cell denotes an instruction in the C51 Architecture.

2. Extended memory addressed is in the region specified by DPXL (reset value = 01h).

- 3. If this instruction addresses external memory location, add N+1 to the number of states (N: number of wait states).
- 4. If this instruction addresses external memory location, add N+2 to the number of states (N: number of wait states).

|          |                                              |                                                    | Binary | Mode             | Source | e Mode           |
|----------|----------------------------------------------|----------------------------------------------------|--------|------------------|--------|------------------|
| Mnemonic | <dest>,<br/><src><sup>(1)</sup></src></dest> | Comments                                           | Bytes  | States           | Bytes  | State            |
|          | A, Rn                                        | ACC and register                                   | 1      | 3                | 2      | 4                |
| ХСН      | A, dir8                                      | ACC and direct address (on-chip RAM or SFR)        | 2      | 3 <sup>(3)</sup> | 2      | 3 <sup>(3)</sup> |
|          | A, at Ri                                     | ACC and indirect address                           | 1      | 4                | 2      | 5                |
| XCHD     | A, at Ri                                     | ACC low nibble and indirect address (256 bytes)    | 1      | 4                | 2      | 5                |
|          | dir8                                         | Push direct address onto stack                     | 2      | 2 <sup>(2)</sup> | 2      | 2(2              |
|          | #data                                        | Push immediate data onto stack                     | 4      | 4                | 3      | 3                |
|          | #data16                                      | Push 16-bit immediate data onto stack              | 5      | 5                | 4      | 5                |
| PUSH     | Rm                                           | Push byte register onto stack                      | 3      | 4                | 2      | 3                |
|          | WRj                                          | Push word register onto stack                      | 3      | 5                | 2      | 4                |
|          | DRk                                          | Push double word register onto stack               | 3      | 9                | 2      | 8                |
|          | dir8                                         | Pop direct address (on-chip RAM or SFR) from stack | 2      | 3 <sup>(2)</sup> | 2      | 3(2              |
| POP      | Rm                                           | Pop byte register from stack                       | 3      | 3                | 2      | 2                |
|          | WRj                                          | Pop word register from stack                       | 3      | 5                | 2      | 4                |
|          | DRk                                          | Pop double word register from stack                | 3      | 9                | 2      | 8                |

#### Table 28. Summary of Exchange, Push and Pop Instructions

Exchange bytesXCH A, <src>(A)  $\leftrightarrow$  src opnd

Notes: 1. A shaded cell denotes an instruction in the C51 Architecture.

2. If this instruction addresses an I/O Port (Px, x = 0-3), add 1 to the number of states. Add 2 if it addresses a Peripheral SFR.

3. If this instruction addresses an I/O Port (Px, x = 0-3), add 2 to the number of states. Add 3 if it addresses a Peripheral SFR.





## Programming and Verifying Non-volatile Memory

### Internal Features

The internal non-volatile memory of the TSC80251G2D derivatives contains five different areas:

- Code Memory
- Configuration Bytes
- Lock Bits
- Encryption Array
- Signature Bytes

# **EPROM/OTPROM Devices** All the internal non-volatile memory but the Signature Bytes of the TSC87251G2D products are made of EPROM cells. The Signature Bytes of the TSC87251G2D products are made of Mask ROM.

The TSC87251G2D products are programmed and verified in the same manner as Atmel's TSC87251G1A, using a SINGLE-PULSE algorithm, which programs at  $V_{PP}$  = 12.75V using only one 100µs pulse per byte. This results in a programming time of less than 10 seconds for the 32 kilobytes on-chip code memory.

The EPROM of the TSC87251G2D products in Window package is erasable by Ultra-Violet radiation<sup>(1)</sup> (UV). UV erasure set all the EPROM memory cells to one and allows reprogramming. The quartz window must be covered with an opaque label<sup>(2)</sup> when the device is in operation. This is not so much to protect the EPROM array from inadvertent erasure, as to protect the RAM and other on-chip logic. Allowing light to impinge on the silicon die during device operation may cause a logical malfunction.

The TSC87251G2D products in plastic packages are One Time Programmable (OTP). An EPROM cell cannot be reset by UV once programmed to zero.

- Notes: 1. The recommended erasure procedure is exposure to ultra-violet light (at 2537 Å) to an integrated dose of at least 20 W-sec/cm<sup>2</sup>. Exposing the EPROM to an ultra-violet lamp of 12000 μW/cm<sup>2</sup> rating for 30 minutes should be sufficient.
  - 2. Erasure of the EPROM begins to occur when the chip is exposed to light wavelength shorter than 4000 Å. Since sunlight and fluorescent light have wavelength in this range, exposure to these light sources over an extended time (1 week in sunlight or 3 years in room-level fluorescent lighting) could cause inadvertent erasure.
- Mask ROM DevicesAll the internal non-volatile memory of TSC83251G2D products is made of Mask ROM<br/>cells. They can only be verified by the user, using the same algorithm as the<br/>EPROM/OTPROM devices.

**ROMIess Devices**The TSC80251G2D products do not include on-chip Configuration Bytes, Code Memory<br/>and Encryption Array. They only include Signature Bytes made of Mask ROM cells<br/>which can be read using the same algorithm as the EPROM/OTPROM devices.

- **Security Features** In some microcontroller applications, it is desirable that the user's program code be secured from unauthorized access. The TSC83251G2D and TSC87251G2D offer two kinds of protection for program code stored in the on-chip array:
  - Program code in the on-chip Code Memory is encrypted when read out for verification if the Encryption Array isprogrammed.
  - A three-level lock bit system restricts external access to the on-chip code memory.

#### Lock Bit System

The TSC87251G2D products implement 3 levels of security for User's program as described in Table 33. The TSC83251G2D products implement only the first level of security.

Level 0 is the level of an erased part and does not enable any security features.

Level 1 locks the programming of the User's internal Code Memory, the Configuration Bytes and the Encryption Array.

Level 2 locks the verifying of the User's internal Code Memory. It is always possible to verify the Configuration Bytes and the Lock Bits. It is not possible to verify the Encryption Array.

Level 3 locks the external execution.

| Level | Lock bits<br>LB[2:0] | Internal<br>Execution | External<br>Execution | Verification          | Programming | External<br>PROM read<br>(MOVC) |
|-------|----------------------|-----------------------|-----------------------|-----------------------|-------------|---------------------------------|
| 0     | 000                  | Enable                | Enable                | Enable <sup>(1)</sup> | Enable      | Enable <sup>(2)</sup>           |
| 1     | 001                  | Enable                | Enable                | Enable <sup>(1)</sup> | Disable     | Disable                         |
| 2     | 01x <sup>(3)</sup>   | Enable                | Enable                | Disable               | Disable     | Disable                         |
| 3     | 1xx <sup>(3)</sup>   | Enable                | Disable               | Disable               | Disable     | Disable                         |

Table 33. Lock Bits Programming

Notes: 1. Returns encrypted data if Encryption Array is programmed.

2. Returns non encrypted data.

3. x means don't care. Level 2 always enables level 1, and level 3 always enables levels 1 and 2.

The security level may be verified according to Table 34.

#### Table 34. Lock Bits Verifying

| Level | Lock bits Data <sup>(1)</sup> |
|-------|-------------------------------|
| 0     | xxxxx000                      |
| 1     | xxxxx001                      |
| 2     | xxxxx01x                      |
| 3     | xxxxx1xx                      |

Note: 1. x means don't care.

#### **Encryption Array**

The TSC83251G2D and TSC87251G2D products include a 128-byte Encryption Array located in non-volatile memory outside the memory address space. During verification of the on-chip code memory, the seven low-order address bits also address the Encryption Array. As the byte of the code memory is read, it is exclusive-NOR'ed (XNOR) with the key byte from the Encryption Array. If the Encryption Array is not programmed (still all 1s), the user program code is placed on the data bus in its original, unencrypted form. If the Encryption Array is programmed with key bytes, the user program code is encrypted and cannot be used without knowledge of the key byte sequence.





To preserve the secrecy of the encryption key byte sequence, the Encryption Array can not be verified.

- Notes: 1. When a MOVC instruction is executed, the content of the ROM is not encrypted. In order to fully protect the user program code, the lock bit level 1 (see Table 33) must always be set when encryption is used.
  - 2. If the encryption feature is implemented, the portion of the on-chip code memory that does not contain program code should be filled with "random" byte values to prevent the encryption key sequence from being revealed.

**Signature Bytes** The TSC80251G2D derivatives contain factory-programmed Signature Bytes. These bytes are located in non-volatile memory outside the memory address space at 30h, 31h, 60h and 61h. To read the Signature Bytes, perform the procedure described in section Verify Algorithm, using the verify signature mode (see Table 37). Signature byte values are listed in Table 35.

|              |                                    | Signature Address | Signature Data |
|--------------|------------------------------------|-------------------|----------------|
| Vendor       | Atmel                              | 30h               | 58h            |
| Architecture | C251                               | 31h               | 40h            |
| Memory       | 32 kilobytes EPROM or<br>OTPROM    | 60h               |                |
| Niemory      | 32 kilobytes MaskROM<br>or ROMless |                   | 77h            |
| Revision     | TSC80251G2D<br>derivative          | 61h               | FDh            |

Table 35. Signature Bytes (Electronic ID)

# **Programming Algorithm** Figure 6 shows the hardware setup needed to program the TSC87251G2D EPROM/OTPROM areas:

- The chip has to be put under reset and maintained in this state until completion of the programming sequence.
- PSEN# and the other control signals (ALE and Port 0) have to be set to a high level.
- Then PSEN# has to be to forced to a low level after two clock cycles or more and it
  has to be maintained in this state until the completion of the programming sequence
  (see below).
- The voltage on the EA# pin must be set to V<sub>DD</sub>.
- The programming mode is selected according to the code applied on Port 0 (see Table 36). It has to be applied until the completion of this programming operation.
- The programming address is applied on Ports 1 and 3 which are respectively the Most Significant Byte (MSB) and the Least Significant Byte (LSB) of the address.
- The programming data are applied on Port 2.
- The EPROM Programming is done by raising the voltage on the EA# pin to V<sub>PP</sub>, then by generating a low level pulse on ALE/PROG# pin.
- The voltage on the EA# pin must be lowered to V<sub>DD</sub> before completing the programming operation.
- It is possible to alternate programming and verifying operation (See Paragraph Verify Algorithm). Please make sure the voltage on the EA# pin has actually been lowered to V<sub>DD</sub> before performing the verifying operation.

## **AC Characteristics - Commercial & Industrial**

## **AC Characteristics - External Bus Cycles**

**Definition of Symbols** 

Table 38. External Bus Cycles Timing Symbol Definitions

| Signals   |
|-----------|
| Address   |
| Data In   |
| ALE       |
| Data Out  |
| RD#/PSEN# |
| WR#       |
|           |

| Conditions      |  |  |  |  |  |  |
|-----------------|--|--|--|--|--|--|
| High            |  |  |  |  |  |  |
| Low             |  |  |  |  |  |  |
| Valid           |  |  |  |  |  |  |
| No Longer Valid |  |  |  |  |  |  |
| Floating        |  |  |  |  |  |  |
|                 |  |  |  |  |  |  |

Timings

Test conditions: capacitive load on all pins = 50 pF.

Table 39 and Table 40 list the AC timing parameters for the TSC80251G2D derivatives with no wait states. External wait states can be added by extending PSEN#/RD#/WR# and or by extending ALE. In these tables, Note 2 marks parameters affected by one ALE wait state, and Note 3 marks parameters affected by PSEN#/RD#/WR# wait states.

Figure 8 to Figure 13 show the bus cycles with the timing parameters.



|                                  |                                            | 12  | MHz | 16 I | MHz |                      |
|----------------------------------|--------------------------------------------|-----|-----|------|-----|----------------------|
| Symbol                           | Parameter                                  | Min | Max | Min  | Max | Unit                 |
| T <sub>osc</sub>                 | 1/F <sub>osc</sub>                         | 83  |     | 62   |     | ns                   |
| T <sub>LHLL</sub>                | ALE Pulse Width                            | 72  |     | 52   |     | ns <sup>(2)</sup>    |
| T <sub>AVLL</sub>                | Address Valid to ALE Low                   | 71  |     | 51   |     | ns <sup>(2)</sup>    |
| T <sub>LLAX</sub>                | Address hold after ALE Low                 | 14  |     | 6    |     | ns                   |
| T <sub>RLRH</sub> <sup>(1)</sup> | RD#/PSEN# Pulse Width                      | 163 |     | 121  |     | ns <sup>(3)</sup>    |
| T <sub>WLWH</sub>                | WR# Pulse Width                            | 165 |     | 124  |     | ns <sup>(3)</sup>    |
| T <sub>LLRL</sub> <sup>(1)</sup> | ALE Low to RD#/PSEN# Low                   | 17  |     | 11   |     | ns                   |
| T <sub>LHAX</sub>                | ALE High to Address Hold                   | 90  |     | 57   |     | ns <sup>(2)</sup>    |
| T <sub>RLDV</sub> <sup>(1)</sup> | RD#/PSEN# Low to Valid Data                |     | 133 |      | 92  | ns <sup>(3)</sup>    |
| T <sub>RHDX</sub> <sup>(1)</sup> | Data Hold After RD#/PSEN# High             | 0   |     | 0    |     | ns                   |
| T <sub>RHAX</sub> <sup>(1)</sup> | Address Hold After RD#/PSEN# High          | 0   |     | 0    |     | ns                   |
| T <sub>RLAZ</sub> <sup>(1)</sup> | RD#/PSEN# Low to Address Float             |     | 0   |      | 0   | ns                   |
| T <sub>RHDZ1</sub>               | Instruction Float After RD#/PSEN# High     |     | 59  |      | 48  | ns                   |
| T <sub>RHDZ2</sub>               | Data Float After RD#/PSEN# High            |     | 225 |      | 175 | ns                   |
| T <sub>RHLH1</sub>               | RD#/PSEN# high to ALE High (Instruction)   | 60  |     | 47   |     | ns                   |
| T <sub>RHLH2</sub>               | RD#/PSEN# high to ALE High (Data)          | 226 |     | 172  |     | ns                   |
| T <sub>WHLH</sub>                | WR# High to ALE High                       | 226 |     | 172  |     | ns                   |
| T <sub>AVDV1</sub>               | Address (P0) Valid to Valid Data In        |     | 289 |      | 160 | ns <sup>(2)(3)</sup> |
| T <sub>AVDV2</sub>               | Address (P2) Valid to Valid Data In        |     | 296 |      | 211 | ns <sup>(2)(3)</sup> |
| T <sub>AVDV3</sub>               | Address (P0) Valid to Valid Instruction In |     | 144 |      | 98  | ns <sup>(3)</sup>    |
| T <sub>AXDX</sub>                | Data Hold after Address Hold               | 0   |     | 0    |     | ns                   |
| T <sub>AVRL</sub> <sup>(1)</sup> | Address Valid to RD# Low                   | 111 |     | 64   |     | ns <sup>(2)</sup>    |
| T <sub>AVWL1</sub>               | Address (P0) Valid to WR# Low              | 111 |     | 64   |     | ns <sup>(2)</sup>    |
| T <sub>AVWL2</sub>               | Address (P2) Valid to WR# Low              | 158 |     | 116  |     | ns <sup>(2)</sup>    |
| T <sub>WHQX</sub>                | Data Hold after WR# High                   | 82  |     | 66   |     | ns                   |
| T <sub>QVWH</sub>                | Data Valid to WR# High                     | 135 |     | 103  |     | ns <sup>(3)</sup>    |
| T <sub>WHAX</sub>                | WR# High to Address Hold                   | 168 |     | 125  |     | ns                   |

Table 40. Bus Cycles AC Timings;  $V_{DD}$  = 2.7 to 5.5 V,  $T_A$  = -40 to 85°C

Notes: 1. Specification for PSEN# are identical to those for RD#.

2. If a wait state is added by extending ALE, add  $2 \cdot T_{OSC}$ . 3. If wait states are added by extending RD#/PSEN#/WR#, add  $2N \cdot T_{OSC}$  (N = 1..3).





## AC Characteristics - Real-Time Asynchronous Wait State

#### **Definition of Symbols**

**Table 43.** Real-Time Asynchronous Wait Timing Symbol Definitions

|   | Signals       |
|---|---------------|
| S | PSEN#/RD#/WR# |
| Y | AWAIT#        |

| Conditions |                 |  |  |  |
|------------|-----------------|--|--|--|
| L          | Low             |  |  |  |
| V          | Valid           |  |  |  |
| х          | No Longer Valid |  |  |  |

#### Timings

**Table 44.** Real-Time Asynchronous Wait AC Timings;  $V_{DD}$  = 2.7 to 5.5 V,  $T_A$  = -40 to 85°C

| Symbol            | Parameter                         | Min                          | Мах                   | Unit              |
|-------------------|-----------------------------------|------------------------------|-----------------------|-------------------|
| T <sub>SLYV</sub> | PSEN#/RD#/WR# Low to Wait Set-up  |                              | T <sub>OSC</sub> - 10 | ns                |
| T <sub>SLYX</sub> | Wait Hold after PSEN#/RD#/WR# Low | (2N-1)·T <sub>OSC</sub> + 10 |                       | ns <sup>(1)</sup> |

Note: 1. N is the number of wait states added (N $\geq$  1).

Waveforms

#### Figure 16. Real-time Asynchronous Wait State Timings



## AC Characteristics - Serial Port in Shift Register Mode

**Definition of Symbols** 

#### Table 45. Serial Port Timing Symbol Definitions

| Signals |          |  |  |  |
|---------|----------|--|--|--|
| D       | Data In  |  |  |  |
| Q       | Data Out |  |  |  |
| Х       | Clock    |  |  |  |

| Conditions |                 |  |  |  |  |
|------------|-----------------|--|--|--|--|
| Н          | High            |  |  |  |  |
| L          | Low             |  |  |  |  |
| V          | Valid           |  |  |  |  |
| Х          | No Longer Valid |  |  |  |  |

#### Timings

**Table 46.** Serial Port AC Timing -Shift Register Mode;  $V_{DD}$  = 2.7 to 5.5 V,  $T_A$  = -40 to 85°C

|                   |                                             | 12 MHz |     | 16 MHz |     | 24 MHz <sup>(1)</sup> |     |      |
|-------------------|---------------------------------------------|--------|-----|--------|-----|-----------------------|-----|------|
| Symbol            | Parameter                                   | Min    | Max | Min    | Max | Min                   | Max | Unit |
| T <sub>XLXL</sub> | Serial Port Clock Cycle Time                | 998    |     | 749    |     | 500                   |     | ns   |
| T <sub>QVXH</sub> | Output Data Setup to Clock Rising<br>Edge   | 833    |     | 625    |     | 417                   |     | ns   |
| T <sub>XHQX</sub> | Output Data hold after Clock Rising<br>Edge | 165    |     | 124    |     | 82                    |     | ns   |
| T <sub>XHDX</sub> | Input Data Hold after Clock Rising<br>Edge  | 0      |     | 0      |     | 0                     |     | ns   |
| T <sub>XHDV</sub> | Clock Rising Edge to Input Data<br>Valid    |        | 974 |        | 732 |                       | 482 | ns   |

Note: 1. For high speed versions only.

#### Waveforms





Note: 1. TI and RI are set during S1P1 of the peripheral cycle following the shift of the eight bit.



#### Timings

| Symbol            | Parameter                          | Min  | Мах | Unit             |
|-------------------|------------------------------------|------|-----|------------------|
| T <sub>osc</sub>  | XTAL1 Period                       | 83.5 | 250 | ns               |
| T <sub>AVGL</sub> | Address Setup to PROG# low         | 48   |     | T <sub>OSC</sub> |
| T <sub>GHAX</sub> | Address Hold after PROG# low       | 48   |     | T <sub>OSC</sub> |
| T <sub>DVGL</sub> | Data Setup to PROG# low            | 48   |     | T <sub>OSC</sub> |
| T <sub>GHDX</sub> | Data Hold after PROG#              | 48   |     | T <sub>osc</sub> |
| T <sub>ELSH</sub> | ENABLE High to V <sub>PP</sub>     | 48   |     | T <sub>osc</sub> |
| T <sub>SHGL</sub> | V <sub>PP</sub> Setup to PROG# low | 10   |     | μs               |
| T <sub>GHSL</sub> | V <sub>PP</sub> Hold after PROG#   | 10   |     | μs               |
| T <sub>SLEH</sub> | ENABLE Hold after V <sub>PP</sub>  | 0    |     | ns               |
| T <sub>GLGH</sub> | PROG# Width                        | 90   | 110 | μs               |

## Table 51. EPROM Programming AC timings; $V_{DD}$ = 4.5 to 5.5 V, $T_A$ = 0 to 40°C

**Table 52.** EPROM Verifying AC timings;  $V_{DD}$  = 4.5 to 5.5 V,  $V_{DD}$  = 2.7 to 5.5 V,  $T_A$  = 0 to 40°C

| Symbol            | Parameter                | Min  | Мах | Unit             |
|-------------------|--------------------------|------|-----|------------------|
| T <sub>osc</sub>  | XTAL1 Period             | 83.5 | 250 | ns               |
| T <sub>AVQV</sub> | Address to Data Valid    |      | 48  | T <sub>osc</sub> |
| T <sub>AXQX</sub> | Address to Data Invalid  | 0    |     | ns               |
| T <sub>ELQV</sub> | ENABLE low to Data Valid | 0    | 48  | T <sub>osc</sub> |
| T <sub>EHQZ</sub> | Data Float after ENABLE  | 0    | 48  | T <sub>osc</sub> |

#### Waveforms











Note: 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 loading  $V_{OH}/V_{OL}$  level occurs with  $I_{OL}/I_{OH} = \pm 20$  mA.

Figure 27. Float Waveforms







Maximum Total IOL for all:Output Pins71 mA

If IOL exceeds the test conditions, VOL may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test conditions.

- 2. Capacitive loading on Ports 0 and 2 may cause spurious noise pulses above 0.4 V on the low-level outputs of ALE and Ports 1, 2, and 3. The noise is due to external bus capacitance discharging into the Port 0 and Port 2 pins when these pins change from high to low. In applications where capacitive loading exceeds 100 pF, the noise pulses on these signals may exceed 0.8 V. It may be desirable to qualify ALE or other signals with a Schmitt Trigger or CMOS-level input logic.
- Capacitive loading on Ports 0 and 2 causes the V<sub>OH</sub> on ALE and PSEN# to drop below the specification when the address lines are stabilizing.
- 4. Typical values are obtained using  $V_{DD}$  = 3 V and  $T_A$  = 25°C. They are not tested and there is not guarantee on these values.
- The input threshold voltage of SCL and SDA meets the TWI specification, so an input voltage below 0.3 V<sub>DD</sub> will be recognized as a logic 0 while an input voltage above 0.7 V<sub>DD</sub> will be recognized as a logic 1.





Note: 1.The clock prescaler is not used:  $F_{OSC} = F_{XTAL}$ .

## $I_{DD}$ , $I_{DL}$ and $I_{PD}$ Test Conditions





Figure 31.  $I_{DL}$  Test Condition, Idle Mode



Figure 32.  $I_{PD}$  Test Condition, Power-Down Mode



