



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Obsolete                                                                 |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | AVR                                                                      |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 12MHz                                                                    |
| Connectivity               | SPI                                                                      |
| Peripherals                | POR, WDT                                                                 |
| Number of I/O              | 15                                                                       |
| Program Memory Size        | 1KB (512 x 16)                                                           |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | 64 x 8                                                                   |
| RAM Size                   | -                                                                        |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 6V                                                                  |
| Data Converters            | -                                                                        |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Through Hole                                                             |
| Package / Case             | 20-DIP (0.300", 7.62mm)                                                  |
| Supplier Device Package    | 20-PDIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/at90s1200-12pi |

Email: info@E-XFL.COM

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

### Program and Data Addressing Modes

The AT90S1200 AVR RISC Microcontroller supports powerful and efficient addressing modes. This section describes the different addressing modes supported in the AT90S1200. In the figures, OP means the operation code part of the instruction word. To simplify, not all figures show the exact location of the addressing bits.

Register Direct, Single Register Rd Figure 6. Direct Single Register Addressing



The operand is contained in register d (Rd).

**Register Indirect** 

Figure 7. Indirect Register Addressing



The register accessed is the one pointed to by the Z-register (R30).

| <b>Register Direct, Two Registers</b> | Figure 8. | Direct Register | Addressing, | Two Registers |
|---------------------------------------|-----------|-----------------|-------------|---------------|
| Rd and Rr                             |           |                 |             |               |







Operands are contained in register r (Rr) and d (Rd). The result is stored in register d (Rd).

I/O Direct

Figure 9. I/O Direct Addressing



Operand address is contained in 6 bits of the instruction word. n is the destination or source register address.

Relative Program Addressing, RJMP and RCALL Figure 10. Relative Program Memory Addressing



Program execution continues at address PC + k + 1. The relative address k is -2048 to 2047.

**Subroutine and Interrupt Hardware Stack** The AT90S1200 uses a 3 level deep hardware stack for subroutines and interrupts. The hardware stack is 9 bits wide and stores the Program Counter (PC) return address while subroutines and interrupts are executed.

RCALL instructions and interrupts push the PC return address onto stack level 0, and the data in the other stack levels 1 - 2 are pushed one level deeper in the stack. When a RET or RETI instruction is executed the returning PC is fetched from stack level 0, and the data in the other stack levels 1 - 2 are popped one level in the stack.

If more than three subsequent subroutine calls or interrupts are executed, the first values written to the stack are overwritten.

8



#### MCU Control Register – MCUCR

The MCU Control Register contains general microcontroller control bits for general MCU control functions.

| Bit           | 7 | 6 | 5   | 4   | 3 | 2 | 1     | 0     | _     |
|---------------|---|---|-----|-----|---|---|-------|-------|-------|
| \$35          | - | - | SE  | SM  | - | - | ISC01 | ISC00 | MCUCR |
| Read/Write    | R | R | R/W | R/W | R | R | R/W   | R/W   | •     |
| Initial Value | 0 | 0 | 0   | 0   | 0 | 0 | 0     | 0     |       |

#### • Bits 7, 6 - Res: Reserved Bits

These bits are reserved bits in the AT90S1200 and always read as zero.

#### • Bit 5 – SE: Sleep Enable

The SE bit must be set (one) to make the MCU enter the Sleep mode when the SLEEP instruction is executed. To avoid the MCU entering the Sleep mode unless it is the programmers purpose, it is recommended to set the Sleep Enable SE bit just before the execution of the SLEEP instruction.

#### • Bit 4 – SM: Sleep Mode

This bit selects between the two available sleep modes. When SM is cleared (zero), Idle mode is selected as sleep mode. When SM is set (one), Power-down mode is selected as sleep mode. For details, refer to the paragraph "Sleep Modes" on the following page.

#### • Bits 3, 2 - Res: Reserved Bits

These bits are reserved bits in the AT90S1200 and always read as zero.

#### • Bits 1, 0 – ISC01, ISC00: Interrupt Sense Control 0 Bit 1 and Bit 0

The External Interrupt 0 is activated by the external pin INT0 if the SREG I-flag and the corresponding interrupt mask in the GIMSK register is set. The level and edges on the external INT0 pin that activate the interrupt are defined in Table 4.

| ISC01 | ISC00 | Description                                             |  |  |  |  |
|-------|-------|---------------------------------------------------------|--|--|--|--|
| 0     | 0     | The low level of INTO generates an interrupt request.   |  |  |  |  |
| 0     | 1     | Reserved                                                |  |  |  |  |
| 1     | 0     | he falling edge of INT0 generates an interrupt request. |  |  |  |  |
| 1     | 1     | The rising edge of INT0 generates an interrupt request. |  |  |  |  |

Table 4. Interrupt 0 Sense Control

The value on the INT0 pin is sampled before detecting edges. If edge interrupt is selected, pulses with a duration longer than one CPU clock period will generate an interrupt. Shorter pulses are not guaranteed to generate an interrupt. If low level interrupt is selected, the low level must be held until the completion of the currently executing instruction to generate an interrupt. If enabled, a level triggered interrupt will generate an interrupt request as long as the pin is held low.

| Sleep Modes     | To enter the sleep modes, the SE bit in MCUCR must be set (one) and a SLEEP instruc-<br>tion must be executed. If an enabled interrupt occurs while the MCU is in a sleep mode,<br>the MCU awakes, executes the interrupt routine, and resumes execution from the<br>instruction following SLEEP. The contents of the register file and the I/O memory are<br>unaltered. If a Reset occurs during sleep mode, the MCU wakes up and executes from<br>the Reset Vector.                                                                                                                                                                                                               |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ldle Mode       | When the SM bit is cleared (zero), the SLEEP instruction makes the MCU enter the Idle mode, stopping the CPU but allowing Timer/Counters, Watchdog and the interrupt system to continue operating. This enables the MCU to wake up from external triggered interrupts as well as internal ones like Timer Overflow interrupt and Watchdog Reset. If wakeup from the Analog Comparator interrupt is not required, the Analog Comparator can be powered down by setting the ACD-bit in the Analog Comparator Control and Status Register (ACSR). This will reduce power consumption in Idle mode. When the MCU wakes up from Idle mode, the CPU starts program execution immediately. |
| Power-down Mode | When the SM bit is set (one), the SLEEP instruction makes the MCU enter Power-down mode. In this mode, the External Oscillator is stopped while the External Interrupts and the Watchdog (if enabled) continue operating. Only an External Reset, a Watchdog Reset (if enabled), an external level interrupt on INT0 can wake up the MCU.                                                                                                                                                                                                                                                                                                                                           |
|                 | Note that when a level triggered interrupt is used for wake-up from Power-down, the low level must be held for a time longer than the reset delay time-out period t <sub>TOUT</sub> . Otherwise, the device will not wake up.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |





The 8-bit Timer/Counter0 can select clock source from CK, prescaled CK or an external pin. In addition it can be stopped as described in the specification for the Timer/Counter0 Control Register (TCCR0). The overflow status flag is found in the Timer/Counter Interrupt Flag Register (TIFR). Control signals are found in the Timer/Counter0 Control Register (TCCR0). The interrupt enable/disable settings for Timer/Counter0 are found in the Timer/Counter Interrupt Mask Register (TIMSK).

When Timer/Counter0 is externally clocked, the external signal is synchronized with the oscillator frequency of the CPU. To assure proper sampling of the external clock, the minimum time between two external clock transitions must be at least one internal CPU clock period. The external clock signal is sampled on the rising edge of the internal CPU clock.

The 8-bit Timer/Counter0 features both a high-resolution and a high-accuracy usage with the lower prescaling opportunities. Similarly, the high prescaling opportunities make the Timer/Counter0 useful for lower speed functions or exact timing functions with infrequent actions.





#### Bits 7..3 – Res: Reserved Bits

These bits are reserved bits in the AT90S1200 and always read as zero.





| WDP2 | WDP1 | WDP0 | Number of WDTTypical Time-outWDP0Oscillator Cyclesat $V_{CC} = 3.0V$ |        | Typical Time-out<br>at V <sub>CC</sub> = 5.0V |
|------|------|------|----------------------------------------------------------------------|--------|-----------------------------------------------|
| 0    | 0    | 0    | 16K cycles                                                           | 47 ms  | 15 ms                                         |
| 0    | 0    | 1    | 32K cycles                                                           | 94 ms  | 30 ms                                         |
| 0    | 1    | 0    | 64K cycles                                                           | 0.19 s | 60 ms                                         |
| 0    | 1    | 1    | 128K cycles                                                          | 0.38 s | 0.12 s                                        |
| 1    | 0    | 0    | 256K cycles                                                          | 0.75 s | 0,24 s                                        |
| 1    | 0    | 1    | 512K cycles                                                          | 1.5 s  | 0.49 s                                        |
| 1    | 1    | 0    | 1,024K cycles                                                        | 3.0 s  | 0.97 s                                        |
| 1    | 1    | 1    | 2,048K cycles                                                        | 6.0 s  | 1.9 s                                         |

Table 6. Watchdog Timer Prescale Select

Note: The frequency of the Watchdog Oscillator is voltage dependent as shown in "Typical Characteristics" on page 51.

The WDR (Watchdog Reset) instruction should always be executed before the Watchdog Timer is enabled. This ensures that the reset period will be in accordance with the Watchdog Timer prescale settings. If the Watchdog Timer is enabled without Reset, the Watchdog Timer may not start to count from zero.

To avoid unintentional MCU resets, the Watchdog Timer should be disabled or reset before changing the Watchdog Timer Prescale Select.

### EEPROM Read/Write Access

The EEPROM access registers are accessible in the I/O space.

The write access time is in the range of 2.5 - 4 ms, depending on the V<sub>CC</sub> voltages. A self-timing function, however, lets the user software detect when the next byte can be written. If the user code contains code that writes the EEPROM, some precaution must be taken. In heavily filtered power supplies, V<sub>CC</sub> is likely to rise or fall slowly on Power-up/down. This causes the device for some period of time to run at a voltage lower than specified as minimum for the clock frequency used. CPU operation under these conditions is likely cause the program counter to perform unintentional jumps and eventually execute the EEPROM write code. To secure EEPROM integrity, the user is advised to use an external under-voltage reset circuit in this case.

In order to prevent unintentional EEPROM writes, a specific write procedure must be followed. Refer to "EEPROM Control Register – EECR" on page 25 for details on this.

When the EEPROM is read or written, the CPU is halted for two clock cycles before the next instruction is executed.

#### EEPROM Address Register – EEAR

| Bit           | 7 | 6 | 5     | 4     | 3     | 2     | 1     | 0     |      |
|---------------|---|---|-------|-------|-------|-------|-------|-------|------|
| \$1E          | - | - | EEAR5 | EEAR4 | EEAR3 | EEAR2 | EEAR1 | EEAR0 | EEAR |
| Read/Write    | R | R | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |      |
| Initial Value | 0 | 0 | 0     | 0     | 0     | 0     | 0     | 0     |      |

#### • Bit 7, 6 - Res: Reserved Bits

These bits are reserved bits in the AT90S1200 and will always read as zero.

#### Bits 5..0 – EEAR5..0: EEPROM Address

The EEPROM Address Register (EEAR5..0) specifies the EEPROM address in the 64byte EEPROM space. The EEPROM data bytes are addressed linearly between 0 and 63.

#### EEPROM Data Register – EEDR



#### • Bits 7..0 – EEDR7..0: EEPROM Data

For the EEPROM write operation, the EEDR register contains the data to be written to the EEPROM in the address given by the EEAR register. For the EEPROM read operation, the EEDR contains the data read out from the EEPROM at the address given by EEAR.

# EEPROM Control Register – EECR

| Bit           | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    |      |
|---------------|---|---|---|---|---|---|------|------|------|
| \$1C          | - | - | - | - | - | - | EEWE | EERE | EECR |
| Read/Write    | R | R | R | R | R | R | R/W  | R/W  |      |
| Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    |      |

#### • Bits 7..2 - Res: Reserved Bits

These bits are reserved bits in the AT90S1200 and will always be read as zero.





#### • Bit 1 – EEWE: EEPROM Write Enable

The EEPROM Write Enable Signal (EEWE) is the write strobe to the EEPROM. When address and data are correctly set up, the EEWE bit must be set to write the value into the EEPROM. When the write access time (typically 2.5 ms at  $V_{CC}$  = 5V and 4 ms at  $V_{CC}$  = 2.7V) has elapsed, the EEWE bit is cleared (zero) by hardware. The user software can poll this bit and wait for a zero before writing the next byte. When EEWE has been set, the CPU is halted for two cycles before the next instruction is executed. Bit 0 – EERE: EEPROM Read Enable The EEPROM Read Enable Signal (EERE) is the read strobe to the EEPROM. When the correct address is set up in the EEAR register, the EERE bit must be set. When the EERE bit is cleared (zero) by hardware, requested data is found in the EEDR register. The EEPROM read access takes one instruction and there is no need to poll the EERE bit. When EERE has been set, the CPU is halted for four cycles before the next instruction is executed. Caution: If an interrupt routine accessing the EEPROM is interrupting another EEPROM access, the EEAR or EEDR register will be modified, causing the interrupted EEPROM access to fail. It is recommended to have the global interrupt flag cleared during EEPROM write operation to avoid these problems. Prevent EEPROM During periods of low  $V_{CC}$ , the EEPROM data can be corrupted because the supply volt-Corruption age is too low for the CPU and the EEPROM to operate properly. These issues are the same as for board-level systems using the EEPROM, and the same design solutions should be applied. An EEPROM data corruption can be caused by two situations when the voltage is too low. First, a regular write sequence to the EEPROM requires a minimum voltage to operate correctly. Secondly, the CPU itself can execute instructions incorrectly, if the supply voltage for executing instructions is too low. EEPROM data corruption can easily be avoided by following these design recommendations (one is sufficient): 1. Keep the AVR RESET active (low) during periods of insufficient power supply voltage. This is best done by an external low V<sub>CC</sub> Reset Protection circuit, often referred to as a Brown-out Detector (BOD). Please refer to application note AVR 180 for design considerations regarding power-on reset and low-voltage detection. 2. Keep the AVR core in Power-down Sleep mode during periods of low  $V_{CC}$ . This will prevent the CPU from attempting to decode and execute instructions, effectively protecting the EEPROM registers from unintentional writes. 3. Store constants in Flash memory if the ability to change memory contents from software is not required. Flash memory cannot be updated by the CPU, and will not be subject to corruption.



Figure 23. Port B Schematic Diagram (Pins PB2, PB3, and PB4)



Figure 24. Port B Schematic Diagram (Pin PB5)





Port D

Three I/O memory address locations are allocated for Port D, one each for the Data Register – PORTD (\$12), Data Direction Register – DDRD (\$11), and the Port D Input Pins – PIND (\$10). The Port D Input Pins address is read-only, while the Data Register and the Data Direction Register are read/write.

Port D has seven bi-directional I/O pins with internal pull-up resistors, PD6..PD0. The Port D output buffers can sink 20 mA. As inputs, Port D pins that are externally pulled low will source current if the pull-up resistors are activated.

Some Port D pins have alternate functions as shown in Table 10.

| Table 10 | Port D Pin | Alternate | Functions  |
|----------|------------|-----------|------------|
|          |            | Allemale  | i unctions |

| Port Pin | Alternate Function                  |  |  |  |
|----------|-------------------------------------|--|--|--|
| PD2      | NT0 (External Interrupt 0 input)    |  |  |  |
| PD4      | T0 (Timer/Counter 0 external input) |  |  |  |

#### Port D Data Register - PORTD

| •                              |                                            |           |           |          |         |           |         |          |          |          |
|--------------------------------|--------------------------------------------|-----------|-----------|----------|---------|-----------|---------|----------|----------|----------|
|                                | Bit                                        | 7         | 6         | 5        | 4       | 3         | 2       | 1        | 0        |          |
|                                | \$12                                       | -         | PORTD6    | PORTD5   | PORTD4  | PORTD3    | PORTD2  | PORTD1   | PORTD0   | PORTD    |
|                                | Read/Write                                 | R         | R/W       | R/W      | R/W     | R/W       | R/W     | R/W      | R/W      |          |
|                                | Initial Value                              | 0         | 0         | 0        | 0       | 0         | 0       | 0        | 0        |          |
| Port D Data Direction Register |                                            |           |           |          |         |           |         |          |          |          |
| – DDRD                         | Bit                                        | 7         | 6         | 5        | 4       | 3         | 2       | 1        | 0        |          |
|                                | \$11                                       | _         | DDD6      | DDD5     | DDD4    | DDD3      | DDD2    | DDD1     | DDD0     | DDRD     |
|                                | Read/Write                                 | R         | R/W       | R/W      | R/W     | R/W       | R/W     | R/W      | R/W      |          |
|                                | Initial Value                              | 0         | 0         | 0        | 0       | 0         | 0       | 0        | 0        |          |
| Port D Input Pins Address –    |                                            |           |           |          |         |           |         |          |          |          |
| PIND                           | Bit                                        | 7         | 6         | 5        | 4       | 3         | 2       | 1        | 0        |          |
|                                | \$10                                       | -         | PIND6     | PIND5    | PIND4   | PIND3     | PIND2   | PIND1    | PIND0    | PIND     |
|                                | Read/Write                                 | R         | R         | R        | R       | R         | R       | R        | R        |          |
|                                | Initial Value                              | 0         | N/A       | N/A      | N/A     | N/A       | N/A     | N/A      | N/A      |          |
|                                | The Port D<br>to the physi<br>is read; and | ical valu | ie on eac | h Port D | pin. Wh | en readii | ng PORT | D, the F | ort D Da | ta Latch |
| Port D as General Digital I/O  | PDn, gener<br>pin. If DDD                  |           |           |          |         |           |         |          |          |          |

PDn, general I/O pin: The DDDn bit in the DDRD Register selects the direction of this pin. If DDDn is set (one), PDn is configured as an output pin. If DDDn is cleared (zero), PDn is configured as an input pin. If PORTDn is set (one) when DDDn is configured as an input pin, the MOS pull-up resistor is activated. To switch the pull-up resistor off, the PORTDn bit has to be cleared (zero) or the pin has to be configured as an output pin. The Port D pins are tri-stated when a reset condition becomes active, even if the clock is not active.



the self-timed write instruction in the Serial Programming mode. During programming, the supply voltage must be in accordance with Table 13.

 Table 13.
 Supply Voltage during Programming

| Part      | Serial Programming | Parallel Programming |  |  |  |  |
|-----------|--------------------|----------------------|--|--|--|--|
| AT90S1200 | 2.7 - 6.0V         | 4.5 - 5.5V           |  |  |  |  |

**Parallel Programming** This section describes how to parallel program and verify Flash program memory, EEPROM data memory, Lock bits and Fuse bits in the AT90S1200.

Figure 30. Parallel Programming



#### **Signal Names**

In this section, some pins of the AT90S1200 are referenced by signal names describing their function during parallel programming rather than their pin names, see Figure 30 and Table 14. Pins not described in Table 14 are referenced by pin names.

The XA1/XA0 pins determines the action executed when the XTAL1 pin is given a positive pulse. The coding is shown in Table 15.

When pulsing  $\overline{WR}$  or  $\overline{OE}$ , the command loaded determines the action executed. The command is a byte where the different bits are assigned functions as shown in Table 16.

Table 14. Pin Name Mapping

| Signal Name in<br>Programming Mode | Pin Name | I/O | Function                                                            |
|------------------------------------|----------|-----|---------------------------------------------------------------------|
| RDY/BSY                            | PD1      | 0   | 0: Device is busy programming, 1: Device is ready for new command   |
| ŌĒ                                 | PD2      | Ι   | Output Enable (Active low)                                          |
| WR                                 | PD3      | Ι   | Write Pulse (Active low)                                            |
| BS                                 | PD4      | Ι   | Byte Select ("0" selects low byte, "1" selects high byte)           |
| XA0                                | PD5      | Ι   | XTAL Action Bit 0                                                   |
| XA1                                | PD6      | Ι   | XTAL Action Bit 1                                                   |
| DATA                               | PB0-7    | I/O | Bi-directional Data Bus (Output when $\overline{\text{OE}}$ is low) |

## AT90S1200



#### Figure 32. Programming the Flash Waveforms (Continued)



#### **Reading the Flash**

The algorithm for reading the Flash memory is as follows (refer to "Programming the Flash" for details on command and address loading):

- 1. A: Load Command "0000 0010".
- 2. B: Load Address High Byte (\$00 \$01).
- 3. C: Load Address Low Byte (\$00 \$FF).
- 4. Set  $\overline{OE}$  to "0", and BS to "0". The Flash word low byte can now be read at DATA.
- 5. Set BS to "1". The Flash word high byte can now be read from DATA.
- 6. Set OE to "1".



#### **Reading the Signature Bytes**

**Parallel Programming** 

**Characteristics** 

The algorithm for reading the signature bytes is as follows (refer to "Programming the Flash" on page 39 for details on command and address loading):

- 1. A: Load Command "0000 1000".
- 2. C: Load Address Low Byte (\$00 \$02).

Set  $\overline{OE}$  to "0", and BS to "0". The selected signature byte can now be read at DATA. Set OE to "1".

Figure 33. Parallel Programming Timing



| Symbol                | Parameter                                        | Min  | Тур  | Max   | Units |
|-----------------------|--------------------------------------------------|------|------|-------|-------|
| V <sub>PP</sub>       | Programming Enable Voltage                       | 11.5 |      | 12.5  | V     |
| I <sub>PP</sub>       | Programming Enable Current                       |      |      | 250.0 | μA    |
| t <sub>DVXH</sub>     | Data and Control Setup before XTAL1 High         | 67.0 |      |       | ns    |
| t <sub>XHXL</sub>     | XTAL1 Pulse Width High                           | 67.0 |      |       | ns    |
| t <sub>XLDX</sub>     | Data and Control Hold after XTAL1 Low            | 67.0 |      |       | ns    |
| t <sub>XLWL</sub>     | XTAL1 Low to WR Low                              | 67.0 |      |       | ns    |
| t <sub>BVWL</sub>     | BS Valid to WR Low                               | 67.0 |      |       | ns    |
| t <sub>RHBX</sub>     | BS Hold after RDY/BSY High                       | 67.0 |      |       | ns    |
| t <sub>wLWH</sub>     | WR Pulse Width Low <sup>(1)</sup>                | 67.0 |      |       | ns    |
| t <sub>WHRL</sub>     | WR High to RDY/BSY Low <sup>(2)</sup>            |      | 20.0 |       | ns    |
| t <sub>WLRH</sub>     | WR Low to RDY/BSY High <sup>(2)</sup>            | 0.5  | 0.7  | 0.9   | ms    |
| t <sub>xLOL</sub>     | XTAL1 Low to OE Low                              | 67.0 |      |       | ns    |
| t <sub>OLDV</sub>     | OE Low to DATA Valid                             |      | 20.0 |       | ns    |
| t <sub>OHDZ</sub>     | OE High to DATA Tri-stated                       |      |      | 20.0  | ns    |
| t <sub>WLWH_CE</sub>  | WR Pulse Width Low for Chip Erase                | 5.0  | 10.0 | 15.0  | ms    |
| t <sub>wLWH_PFB</sub> | WR Pulse Width Low for Programming the Fuse Bits | 1.0  | 1.5  | 1.8   | ms    |

Notes:



### **DC Characteristics**

| Symbol            | Parameter                                  | Condition                            | Min   | Тур            | Max  | Units |
|-------------------|--------------------------------------------|--------------------------------------|-------|----------------|------|-------|
| V <sub>ACIO</sub> | Analog Comparator<br>Input Offset Voltage  | $V_{CC} = 5V$<br>$V_{in} = V_{CC}/2$ |       |                | 40.0 | mV    |
| I <sub>ACLK</sub> | Analog Comparator<br>Input Leakage Current | $V_{CC} = 5V$<br>$V_{in} = V_{CC}/2$ | -50.0 |                | 50.0 | nA    |
| t <sub>ACPD</sub> | Analog Comparator<br>Propagation Delay     | $V_{CC} = 2.7V$ $V_{CC} = 4.0V$      |       | 750.0<br>500.0 |      | ns    |

 $T_A = -40 \times C$  to  $85 \times C$ ,  $V_{CC} = 2.7V$  to 6.0V (unless otherwise noted) (Continued)

Notes: 1. "Max" means the highest value where the pin is guaranteed to be read as low.

2. "Min" means the lowest value where the pin is guaranteed to be read as high.

Although each I/O port can sink more than the test conditions (20 mA at V<sub>CC</sub> = 5V, 10 mA at V<sub>CC</sub> = 3V) under steady state conditions (non-transient), the following must be observed:

1] The sum of all  $I_{OL}$ , for all ports, should not exceed 200 mA.

2] The sum of all  $I_{OL}$ , for port D0 - D5 and XTAL2, should not exceed 100 mA.

3] The sum of all  $I_{OL}$ , for ports B0 - B7 and D6, should not exceed 100 mA.

If  $I_{OL}$  exceeds the test condition,  $V_{OL}$  may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test condition.

Although each I/O port can source more than the test conditions (3 mA at V<sub>CC</sub> = 5V, 1.5 mA at V<sub>CC</sub> = 3V) under steady state conditions (non-transient), the following must be observed:

1] The sum of all  $\rm I_{OH},$  for all ports, should not exceed 200 mA.

2] The sum of all  $I_{OH}$ , for port D0 - D5 and XTAL2, should not exceed 100 mA.

3] The sum of all  $I_{OH}$ , for ports B0 - B7 and D6, should not exceed 100 mA.

If  $I_{OH}$  exceeds the test condition,  $V_{OH}$  may exceed the related specification. Pins are not guaranteed to source current greater than the listed test condition.

5. Minimum  $V_{CC}$  for power-down is 2V.





Figure 41. Idle Supply Current vs. Frequency









Figure 45. Power-down Supply Current vs.  $V_{\text{CC}},$  Watchdog Timer Enabled





INTERNAL RC OSCILLATOR FREQUENCY vs.  $\rm V_{cc}$ 













60 **AT90S1200** 



## AT90S1200 Register Summary

| Address                                                  | Name                                                                  | Bit 7  | Bit 6          | Bit 5          | Bit 4          | Bit 3          | Bit 2          | Bit 1          | Bit 0          | Page                                     |
|----------------------------------------------------------|-----------------------------------------------------------------------|--------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|------------------------------------------|
| \$3F                                                     | SREG                                                                  | 1      | Т              | Н              | S              | V              | N              | Z              | С              | page 1                                   |
| \$3E                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$3D                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$3C                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$3B                                                     | GIMSK                                                                 | -      | INT0           | -              | -              | -              | -              | -              | -              | page 1                                   |
| \$3A                                                     | Reserved                                                              |        |                |                |                |                |                |                | -              |                                          |
| \$39                                                     | TIMSK                                                                 | -      | -              | -              | -              | -              | -              | TOIE0          | -              | page 16                                  |
| \$38                                                     | TIFR                                                                  | -      | -              | -              | -              | -              | -              | TOV0           | -              | page 16                                  |
| \$37                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$36                                                     | Reserved                                                              |        |                |                |                |                |                |                | -              |                                          |
| \$35                                                     | MCUCR                                                                 | -      | -              | SE             | SM             | -              | -              | ISC01          | ISC00          | page 18                                  |
| \$34                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$33                                                     | TCCR0                                                                 | -      | -              | -              | -              | -              | CS02           | CS01           | CS00           | page 2                                   |
| \$32                                                     | TCNT0                                                                 |        |                |                | Timer/Cou      | nter0 (8 Bits) |                |                |                | page 22                                  |
| \$31                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$30                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$2F                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$2E                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$2D                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$2C                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$2B                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$2A                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$29                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$28                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$27                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$26                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$25                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$24                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$23                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$22                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$21                                                     | WDTCR                                                                 | -      | -              | -              | -              | WDE            | WDP2           | WDP1           | WDP0           | page 23                                  |
| \$20                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$1F                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$1E                                                     | EEAR                                                                  | -      |                |                | EEP            | ROM Address R  | egister        |                |                | page 25                                  |
| \$1D                                                     | EEDR                                                                  |        |                |                | EEPROM         | Data Register  |                |                |                | page 25                                  |
| \$1C                                                     | EECR                                                                  | -      | -              | -              | -              | -              | -              | EEWE           | EERE           | page 25                                  |
| \$1B                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$1A                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$19                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$18                                                     | PORTB                                                                 | PORTB7 | PORTB6         | PORTB5         | PORTB4         | PORTB3         | PORTB2         | PORTB1         | PORTB0         | page 29                                  |
| \$17                                                     | DDRB                                                                  | DDB7   | DDB6           | DDB5           | DDB4           | DDB3           | DDB2           | DDB1           | DDB0           | page 29                                  |
|                                                          | PINB                                                                  | PINB7  | PINB6          | PINB5          | PINB4          | PINB3          | PINB2          | PINB1          | PINB0          | page 29                                  |
| \$16                                                     |                                                                       |        |                |                |                |                |                |                |                | -                                        |
| \$16<br>\$15                                             | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
|                                                          | Reserved<br>Reserved                                                  |        |                |                |                |                |                |                |                |                                          |
| \$15                                                     | Reserved                                                              |        |                |                |                |                |                |                |                |                                          |
| \$15<br>\$14<br>\$13                                     | Reserved<br>Reserved                                                  |        | PORTD6         | PORTD5         | PORTD4         | PORTD3         | PORTD2         | PORTD1         | PORTD0         | page 34                                  |
| \$15<br>\$14<br>\$13<br>\$12                             | Reserved                                                              | -<br>- | PORTD6<br>DDD6 | PORTD5<br>DDD5 | PORTD4<br>DDD4 | PORTD3<br>DDD3 | PORTD2<br>DDD2 | PORTD1<br>DDD1 | PORTD0<br>DDD0 |                                          |
| \$15<br>\$14<br>\$13<br>\$12<br>\$11                     | Reserved<br>Reserved<br>PORTD<br>DDRD                                 |        | DDD6           | DDD5           | DDD4           | DDD3           | DDD2           | DDD1           | DDD0           | page 34                                  |
| \$15<br>\$14<br>\$13<br>\$12<br>\$11<br>\$10             | Reserved<br>Reserved<br>PORTD<br>DDRD<br>PIND                         | -      |                |                |                |                |                |                | 1              | page 34                                  |
| \$15<br>\$14<br>\$13<br>\$12<br>\$11<br>\$10<br>\$0F     | Reserved<br>Reserved<br>PORTD<br>DDRD<br>PIND<br>Reserved             | -      | DDD6           | DDD5           | DDD4           | DDD3           | DDD2           | DDD1           | DDD0           | page 34                                  |
| \$15<br>\$14<br>\$13<br>\$12<br>\$11<br>\$10<br>\$0F<br> | Reserved<br>Reserved<br>PORTD<br>DDRD<br>PIND<br>Reserved<br>Reserved | -      | DDD6           | DDD5           | DDD4           | DDD3           | DDD2           | DDD1           | DDD0           | page 34                                  |
| \$15<br>\$14<br>\$13<br>\$12<br>\$11<br>\$10<br>\$0F     | Reserved<br>Reserved<br>PORTD<br>DDRD<br>PIND<br>Reserved             | -      | DDD6           | DDD5           | DDD4           | DDD3           | DDD2           | DDD1           | DDD0           | page 34<br>page 34<br>page 34<br>page 27 |

Notes: 1. For compatibility with future devices, reserved bits should be written to zero if accessed. Reserved I/O memory addresses should never be written.

2. Some of the status flags are cleared by writing a logical "1" to them. Note that the CBI and SBI instructions will operate on all bits in the I/O register, writing a "1" back into any flag read as set, thus clearing the flag. The CBI and SBI instructions work with registers \$00 to \$1F only.

## Ordering Information<sup>(1)</sup>

| Speed (MHz) | Power Supply | Ordering Code  | Package | Operation Range |
|-------------|--------------|----------------|---------|-----------------|
| 4           | 2.7 - 6.0V   | AT90S1200-4PC  | 20P3    | Commercial      |
|             |              | AT90S1200-4SC  | 20S     | (0°C to 70°C)   |
|             |              | AT90S1200-4YC  | 20Y     |                 |
|             |              | AT90S1200-4PI  | 20P3    | Industrial      |
|             |              | AT90S1200-4SI  | 20S     | (-40°C to 85°C) |
|             |              | AT90S1200-4YI  | 20Y     |                 |
| 12          | 4.0 - 6.0V   | AT90S1200-12PC | 20P3    | Commercial      |
|             |              | AT90S1200-12SC | 20S     | (0°C to 70°C)   |
|             |              | AT90S1200-12YC | 20Y     |                 |
|             |              | AT90S1200-12PI | 20P3    | Industrial      |
|             |              | AT90S1200-12SI | 20S     | (-40°C to 85°C) |
|             |              | AT90S1200-12YI | 20Y     |                 |

Note: 1. Order AT90S1200A-XXX for devices with the RCEN Fuse programmed.

|      | Package Type                                                      |
|------|-------------------------------------------------------------------|
| 20P3 | 20-lead, 0.300" Wide, Plastic Dual Inline Package (PDIP)          |
| 20S  | 20-lead, 0.300" Wide, Plastic Gull Wing Small Outline (SOIC)      |
| 20Y  | 20-lead, 5.3 mm Wide, Plastic Shrink Small Outline Package (SSOP) |





20Y, 20-lead Plastic Shrink Small Outline (SSOP), 5.3mm body Width. Dimensions in Millimeters and (inches)\*



\*Controlling dimension: millimeters

REV. A 04/11/2001

20Y