

## **Description**

The AT90S2313 is a low-power CMOS 8-bit microcontroller based on the AVR RISC architecture. By executing powerful instructions in a single clock cycle, the AT90S2313 achieves throughputs approaching 1 MIPS per MHz allowing the system designer to optimize power consumption versus processing speed.

The AVR core combines a rich instruction set with 32 general purpose working registers. All the 32 registers are directly connected to the Arithmetic Logic Unit (ALU), allowing two independent registers to be accessed in one single instruction executed in one clock cycle. The resulting architecture is more code efficient while achieving throughputs up to ten times faster than conventional CISC microcontrollers.

Figure 1. The AT90S2313 Block Diagram



The AT90S2313 provides the following features: 2K bytes of In-System Programmable Flash, 128 bytes EEPROM, 128 bytes SRAM, 15 general purpose I/O lines, 32 general purpose working registers, flexible Timer/Counters with compare modes, internal and external interrupts, a programmable serial UART, programmable Watchdog Timer with internal Oscillator, an SPI serial port for Flash memory downloading and two software

selectable power-saving modes. The Idle mode stops the CPU while allowing the SRAM, Timer/Counters, SPI port and interrupt system to continue functioning. The Power-down mode saves the register contents but freezes the Oscillator, disabling all other chip functions until the next external interrupt or Hardware Reset.

The device is manufactured using Atmel's high-density non-volatile memory technology. The On-chip In-System Programmable Flash allows the Program memory to be reprogrammed in-system through an SPI serial interface or by a conventional non-volatile memory programmer. By combining an enhanced RISC 8-bit CPU with In-System Programmable Flash on a monolithic chip, the Atmel AT90S2313 is a powerful microcontroller that provides a highly flexible and cost-effective solution to many embedded control applications.

The AT90S2313 AVR is supported with a full suite of program and system development tools including: C compilers, macro assemblers, program debugger/simulators, In-Circuit Emulators and evaluation kits.

### **Pin Descriptions**

VCC Supply voltage pin.

**GND** Ground pin.

Port B (PB7..PB0)

Port B is an 8-bit bi-directional I/O port. Port pins can provide internal pull-up resistors (selected for each bit). PB0 and PB1 also serve as the positive input (AIN0) and the negative input (AIN1), respectively, of the On-chip Analog Comparator. The Port B output buffers can sink 20 mA and can drive LED displays directly. When pins PB0 to PB7 are used as inputs and are externally pulled low, they will source current if the internal pull-up resistors are activated. The Port B pins are tri-stated when a reset condition becomes active, even if the clock is not active.

Port B also serves the functions of various special features of the AT90S2313 as listed on page 51.

Port D (PD6..PD0)

Port D has seven bi-directional I/O ports 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. The Port D pins are tri-stated when a reset condition becomes active, even if the clock is not active.

Port D also serves the functions of various special features of the AT90S2313 as listed on page 56.

**RESET** 

Reset input. A low level on this pin for more than 50 ns will generate a Reset, even if the clock is not running. Shorter pulses are not guaranteed to generate a Reset.

XTAL1

Input to the inverting Oscillator amplifier and input to the internal clock operating circuit.

XTAL2

Output from the inverting Oscillator amplifier.





## **Register Summary**

| Address                    | Name                 | Bit 7   | Bit 6  | Bit 5   | Bit 4           | Bit 3             | Bit 2    | Bit 1  | Bit 0  | Page    |
|----------------------------|----------------------|---------|--------|---------|-----------------|-------------------|----------|--------|--------|---------|
| \$3F (\$5F)                | SREG                 | ı       | Т      | Н       | s               | V                 | N        | Z      | С      | page 16 |
| \$3E (\$5E)                | Reserved             |         |        |         |                 |                   | •        | •      |        | ļ. s.g. |
| \$3D (\$5D)                | SPL                  | SP7     | SP6    | SP5     | SP4             | SP3               | SP2      | SP1    | SP0    | page 17 |
| \$3C (\$5C)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$3B (\$5B)                | GIMSK                | INT1    | INT0   | _       | _               | _                 | _        | _      | _      | page 22 |
| \$3A (\$5A)                | GIFR                 | INTF1   | INTF0  |         |                 |                   |          |        |        | page 23 |
| \$39 (\$59)                | TIMSK                | TOIE1   | OCIE1A | _       | _               | TICIE1            | _        | TOIE0  | _      | page 23 |
| \$38 (\$58)                | TIFR                 | TOV1    | OCF1A  | _       | _               | ICF1              | _        | TOV0   | _      | page 24 |
| \$37 (\$57)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$36 (\$56)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$35 (\$55)                | MCUCR                | _       | -      | SE      | SM              | ISC11             | ISC10    | ISC01  | ISC00  | page 25 |
| \$34 (\$54)                | Reserved             |         | 1      |         | ,               |                   |          | 1      | 1      |         |
| \$33 (\$53)                | TCCR0                | -       | -      | _       | -               | -                 | CS02     | CS01   | CS00   | page 29 |
| \$32 (\$52)                | TCNT0                |         |        |         | Timer/Cou       | nter0 (8 Bits)    |          |        |        | page 29 |
| \$31 (\$51)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$30 (\$50)                | Reserved             |         | 1      | 1       |                 | 1                 |          | 1      | 1      |         |
| \$2F (\$4F)                | TCCR1A               | COM1A1  | COM1A0 | -       | -               | _                 | _        | PWM11  | PWM10  | page 31 |
| \$2E (\$4E)                | TCCR1B               | ICNC1   | ICES1  |         | -               | CTC1              | CS12     | CS11   | CS10   | page 32 |
| \$2D (\$4D)                | TCNT1H               |         |        |         |                 | unter Register Hi |          |        |        | page 33 |
| \$2C (\$4C)                | TCNT1L               |         |        |         |                 | unter Register Lo |          |        |        | page 33 |
| \$2B (\$4B)                | OCR1AH               |         |        |         |                 | npare Register H  |          |        |        | page 34 |
| \$2A (\$4A)                | OCR1AL               |         |        | Timer   | /Counter1 – Con | npare Register L  | ow Byte  |        |        | page 34 |
| \$29 (\$49)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$28 (\$48)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$27 (\$47)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$26 (\$46)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$25 (\$45)                | ICR1H                |         |        |         |                 | Capture Register  |          |        |        | page 34 |
| \$24 (\$44)                | ICR1L                |         |        | Timer/C | ounter1 – Input | Capture Register  | Low Byte |        |        | page 34 |
| \$23 (\$43)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$22 (\$42)                | Reserved             |         |        |         | WDTOE           | WDE               | WDDO     | WDP1   | WDDO   | 2000 07 |
| \$21 (\$41)                | WDTCR                |         |        | _       | WDTOE           | WDE               | WDP2     | WDPI   | WDP0   | page 37 |
| \$20 (\$40)<br>\$1F (\$3F) | Reserved<br>Reserved |         |        |         |                 |                   |          |        |        |         |
| \$1E (\$3E)                | EEAR                 | _       |        |         | FED             | ROM Address R     | agistar  |        |        | page 39 |
| \$1D (\$3D)                | EEDR                 | _       | I      |         |                 | Data Register     | egistei  |        |        | page 39 |
| \$1C (\$3C)                | EECR                 | _       | _      | _       | _               | Data Hegister     | EEMWE    | EEWE   | EERE   | page 40 |
| \$1B (\$3B)                | Reserved             |         |        |         | <u> </u>        |                   | LLIVIVVL | LLVVL  | LLIIL  | page 40 |
| \$1A (\$3A)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$19 (\$39)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$18 (\$38)                | PORTB                | PORTB7  | PORTB6 | PORTB5  | PORTB4          | PORTB3            | PORTB2   | PORTB1 | PORTB0 | page 50 |
| \$17 (\$37)                | DDRB                 | DDB7    | DDB6   | DDB5    | DDB4            | DDB3              | DDB2     | DDB1   | DDB0   | page 50 |
| \$16 (\$36)                | PINB                 | PINB7   | PINB6  | PINB5   | PINB4           | PINB3             | PINB2    | PINB1  | PINB0  | page 50 |
| \$15 (\$35)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$14 (\$34)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$13 (\$33)                | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$12 (\$32)                | PORTD                |         | PORTD6 | PORTD5  | PORTD4          | PORTD3            | PORTD2   | PORTD1 | PORTD0 | page 56 |
| \$11 (\$31)                | DDRD                 | -       | DDD6   | DDD5    | DDD4            | DDD3              | DDD2     | DDD1   | DDD0   | page 56 |
| \$10 (\$30)                | PIND                 | -       | PIND6  | PIND5   | PIND4           | PIND3             | PIND2    | PIND1  | PIND0  | page 56 |
|                            | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$0C (\$2C)                | UDR                  |         |        |         | UART I/O I      | Data Register     |          |        |        | page 45 |
| \$0B (\$2B)                | USR                  | RXC     | TXC    | UDRE    | FE              | OR                | -        | -      | _      | page 45 |
| \$0A (\$2A)                | UCR                  | RXCIE   | TXCIE  | UDRIE   | RXEN            | TXEN              | CHR9     | RXB8   | TXB8   | page 46 |
| \$09 (\$29)                | UBRR                 |         |        | 1       | UART Baud       | Rate Register     | •        | 1      | •      | page 48 |
| \$08 (\$28)                | ACSR                 | ACD     | _      | ACO     | ACI             | ACIE              | ACIC     | ACIS1  | ACIS0  | page 48 |
|                            | Reserved             |         |        |         |                 |                   |          |        |        |         |
| \$00 (\$20)                | Reserved             | itle ft |        |         | المانيم ماميدة  |                   |          | D      |        |         |

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.

## **Instruction Set Summary**

| Mnemonic       | Operands           | Description                            | Operation                                             | Flags     | # Clocks |
|----------------|--------------------|----------------------------------------|-------------------------------------------------------|-----------|----------|
| ARITHMETIC AND | LOGIC INSTRUCTIONS |                                        |                                                       |           |          |
| ADD            | Rd, Rr             | Add Two Registers                      | $Rd \leftarrow Rd + Rr$                               | Z,C,N,V,H | 1        |
| ADC            | Rd, Rr             | Add with Carry Two Registers           | $Rd \leftarrow Rd + Rr + C$                           | Z,C,N,V,H | 1        |
| ADIW           | Rdl, K             | Add Immediate to Word                  | Rdh:Rdl ← Rdh:Rdl + K                                 | Z,C,N,V,S | 2        |
| SUB            | Rd, Rr             | Subtract Two Registers                 | $Rd \leftarrow Rd - Rr$                               | Z,C,N,V,H | 1        |
| SUBI           | Rd, K              | Subtract Constant from Register        | $Rd \leftarrow Rd - K$                                | Z,C,N,V,H | 1        |
| SBIW           | Rdl, K             | Subtract Immediate from Word           | Rdh:Rdl ← Rdh:Rdl – K                                 | Z,C,N,V,S | 2        |
| SBC            | Rd, Rr             | Subtract with Carry Two Registers      | $Rd \leftarrow Rd - Rr - C$                           | Z,C,N,V,H | 1        |
| SBCI           | Rd, K              | Subtract with Carry Constant from Reg. | $Rd \leftarrow Rd - K - C$                            | Z,C,N,V,H | 1        |
| AND            | Rd, Rr             | Logical AND Registers                  | $Rd \leftarrow Rd \bullet Rr$                         | Z,N,V     | 1        |
| ANDI           | Rd, K              | Logical AND Register and Constant      | $Rd \leftarrow Rd \bullet K$                          | Z,N,V     | 1        |
| OR             | Rd, Rr             | Logical OR Registers                   | $Rd \leftarrow Rd v Rr$                               | Z,N,V     | 1        |
| ORI            | Rd, K              | Logical OR Register and Constant       | $Rd \leftarrow Rd \vee K$                             | Z,N,V     | 1        |
| EOR            | Rd, Rr             | Exclusive OR Registers                 | $Rd \leftarrow Rd \oplus Rr$                          | Z,N,V     | 1        |
| COM            | Rd                 | One's Complement                       | $Rd \leftarrow \$FF - Rd$                             | Z,C,N,V   | 1        |
| NEG            | Rd                 | Two's Complement                       | Rd ← \$00 – Rd                                        | Z,C,N,V,H | 1        |
| SBR            | Rd, K              | Set Bit(s) in Register                 | $Rd \leftarrow Rd \vee K$                             | Z,N,V     | 1        |
| CBR            | Rd, K              | Clear Bit(s) in Register               | $Rd \leftarrow Rd \bullet (\$FF - K)$                 | Z,N,V     | 1        |
| INC            | Rd                 | Increment                              | Rd ← Rd + 1                                           | Z,N,V     | 1        |
| DEC            | Rd                 | Decrement                              | $Rd \leftarrow Rd - 1$                                | Z,N,V     | 1        |
| TST            | Rd                 | Test for Zero or Minus                 | $Rd \leftarrow Rd \bullet Rd$                         | Z,N,V     | 1        |
| CLR            | Rd                 | Clear Register                         | $Rd \leftarrow Rd \oplus Rd$                          | Z,N,V     | 1        |
| SER            | Rd                 | Set Register                           | Rd ← \$FF                                             | None      | 1        |
| BRANCH INSTRUC | TIONS              |                                        |                                                       |           |          |
| RJMP           | k                  | Relative Jump                          | PC ← PC + k + 1                                       | None      | 2        |
| IJMP           |                    | Indirect Jump to (Z)                   | PC ← Z                                                | None      | 2        |
| RCALL          | k                  | Relative Subroutine Call               | PC ← PC + k + 1                                       | None      | 3        |
| ICALL          |                    | Indirect Call to (Z)                   | PC ← Z                                                | None      | 3        |
| RET            |                    | Subroutine Return                      | PC ← STACK                                            | None      | 4        |
| RETI           |                    | Interrupt Return                       | PC ← STACK                                            | 1         | 4        |
| CPSE           | Rd, Rr             | Compare, Skip if Equal                 | if (Rd = Rr) PC ← PC + 2 or 3                         | None      | 1/2      |
| CP             | Rd, Rr             | Compare                                | Rd – Rr                                               | Z,N,V,C,H | 1        |
| CPC            | Rd, Rr             | Compare with Carry                     | Rd – Rr – C                                           | Z,N,V,C,H | 1        |
| CPI            | Rd, K              | Compare Register with Immediate        | Rd – K                                                | Z,N,V,C,H | 1        |
| SBRC           | Rr, b              | Skip if Bit in Register Cleared        | if $(Rr(b) = 0) PC \leftarrow PC + 2 \text{ or } 3$   | None      | 1/2      |
| SBRS           | Rr, b              | Skip if Bit in Register is Set         | if $(Rr(b) = 1) PC \leftarrow PC + 2 \text{ or } 3$   | None      | 1/2      |
| SBIC           | P, b               | Skip if Bit in I/O Register Cleared    | if $(P(b) = 0) PC \leftarrow PC + 2 \text{ or } 3$    | None      | 1/2      |
| SBIS           | P, b               | Skip if Bit in I/O Register is Set     | if $(R(b) = 1) PC \leftarrow PC + 2 \text{ or } 3$    | None      | 1/2      |
| BRBS           | s, k               | Branch if Status Flag Set              | if (SREG(s) = 1) then PC $\leftarrow$ PC + k + 1      | None      | 1/2      |
| BRBC           | s, k               | Branch if Status Flag Cleared          | if (SREG(s) = 0) then PC $\leftarrow$ PC + k + 1      | None      | 1/2      |
| BREQ           | k                  | Branch if Equal                        | if (Z = 1) then PC $\leftarrow$ PC + k + 1            | None      | 1/2      |
| BRNE           | k                  | Branch if Not Equal                    | if (Z = 0) then PC ← PC + k + 1                       | None      | 1/2      |
| BRCS           | k                  | Branch if Carry Set                    | if (C = 1) then PC $\leftarrow$ PC + k + 1            | None      | 1/2      |
| BRCC           | k                  | Branch if Carry Cleared                | if (C = 0) then PC $\leftarrow$ PC + k + 1            | None      | 1/2      |
| BRSH           | k                  | Branch if Same or Higher               | if (C = 0) then PC $\leftarrow$ PC + k + 1            | None      | 1/2      |
| BRLO           | k                  | Branch if Lower                        | if (C = 1) then PC $\leftarrow$ PC + k + 1            | None      | 1/2      |
| BRMI           | k                  | Branch if Minus                        | if (N = 1) then PC $\leftarrow$ PC + k + 1            | None      | 1/2      |
| BRPL           | k                  | Branch if Plus                         | if (N = 0) then PC $\leftarrow$ PC + k + 1            | None      | 1/2      |
| BRGE           | k                  | Branch if Greater or Equal, Signed     | if $(N \oplus V = 0)$ then PC $\leftarrow$ PC + k + 1 | None      | 1/2      |
| BRLT           | k                  | Branch if Less than Zero, Signed       | if $(N \oplus V = 1)$ then PC $\leftarrow$ PC + k + 1 | None      | 1/2      |
| BRHS           | k                  | Branch if Half-carry Flag Set          | if (H = 1) then PC ← PC + k + 1                       | None      | 1/2      |
| BRHC           | k                  | Branch if Half-carry Flag Cleared      | if (H = 0) then PC ← PC + k + 1                       | None      | 1/2      |
| BRTS           | k                  | Branch if T-Flag Set                   | if (T = 1) then PC ← PC + k + 1                       | None      | 1/2      |
| BRTC           | k                  | Branch if T-Flag Cleared               | if (T = 0) then PC ← PC + k + 1                       | None      | 1/2      |
| BRVS           | k                  | Branch if Overflow Flag is Set         | if (V = 1) then PC ← PC + k + 1                       | None      | 1/2      |
| BRVC           | k                  | Branch if Overflow Flag is Cleared     | if $(V = 0)$ then $PC \leftarrow PC + k + 1$          | None      | 1/2      |
| BRIE           | k                  | Branch if Interrupt Enabled            | if (I = 1) then PC $\leftarrow$ PC + k + 1            | None      | 1/2      |
| BRID           | k                  | Branch if Interrupt Disabled           | if (I = 0) then PC $\leftarrow$ PC + k + 1            | None      | 1/2      |





## **Instruction Set Summary (Continued)**

| Mnemonic                               | Operands     | Description                                                                                                                                                                                                                | Operation                                                                          | Flags                 | # Clocks                                       |
|----------------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------|------------------------------------------------|
| DATA TRANSFER I                        | NSTRUCTIONS  | -                                                                                                                                                                                                                          |                                                                                    | <u> </u>              | <u>l</u>                                       |
| MOV                                    | Rd, Rr       | Move between Registers                                                                                                                                                                                                     | Rd ← Rr                                                                            | None                  | 1                                              |
| LDI                                    | Rd, K        | Load Immediate                                                                                                                                                                                                             | Rd ← K                                                                             | None                  | 1                                              |
| LD                                     | Rd, X        | Load Indirect                                                                                                                                                                                                              | $Rd \leftarrow (X)$                                                                | None                  | 2                                              |
| LD                                     | Rd, X+       | Load Indirect and Post-Inc.                                                                                                                                                                                                | $Rd \leftarrow (X), X \leftarrow X + 1$                                            | None                  | 2                                              |
| LD                                     | Rd, -X       | Load Indirect and Pre-Dec.                                                                                                                                                                                                 | $X \leftarrow X - 1$ , $Rd \leftarrow (X)$                                         | None                  | 2                                              |
| LD                                     | Rd, Y        | Load Indirect                                                                                                                                                                                                              | $Rd \leftarrow (Y)$                                                                | None                  | 2                                              |
| LD                                     | Rd, Y+       | Load Indirect and Post-Inc.                                                                                                                                                                                                | $Rd \leftarrow (Y), Y \leftarrow Y + 1$                                            | None                  | 2                                              |
| LD                                     | Rd, -Y       | Load Indirect and Pre-Dec.                                                                                                                                                                                                 | $Y \leftarrow Y - 1$ , Rd $\leftarrow$ (Y)                                         | None                  | 2                                              |
| LDD                                    | Rd, Y+q      | Load Indirect with Displacement                                                                                                                                                                                            | $Rd \leftarrow (Y + q)$                                                            | None                  | 2                                              |
| LD                                     | Rd, Z        | Load Indirect                                                                                                                                                                                                              | $Rd \leftarrow (Z)$                                                                | None                  | 2                                              |
| LD                                     | Rd, Z+       | Load Indirect and Post-Inc.                                                                                                                                                                                                | $Rd \leftarrow (Z), Z \leftarrow Z+1$                                              | None                  | 2                                              |
| LD                                     | Rd, -Z       | Load Indirect and Pre-Dec.                                                                                                                                                                                                 | $Z \leftarrow Z - 1$ , $Rd \leftarrow (Z)$                                         | None                  | 2                                              |
| LDD                                    | Rd, Z+q      | Load Indirect with Displacement                                                                                                                                                                                            | $Rd \leftarrow (Z + q)$                                                            | None                  | 2                                              |
| LDS                                    | Rd, k        | Load Direct from SRAM                                                                                                                                                                                                      | $Rd \leftarrow (k)$                                                                | None                  | 2                                              |
| ST                                     | X, Rr        | Store Indirect                                                                                                                                                                                                             | (X) ← Rr                                                                           | None                  | 2                                              |
| ST                                     | X+, Rr       | Store Indirect and Post-Inc.                                                                                                                                                                                               | $(X) \leftarrow YY$<br>$(X) \leftarrow Rr, X \leftarrow X + 1$                     | None                  | 2                                              |
| ST                                     | -X, Rr       | Store Indirect and Pre-Dec.                                                                                                                                                                                                | $(A) \leftarrow BI, A \leftarrow A + I$<br>$X \leftarrow X - 1, (X) \leftarrow Br$ | None                  | 2                                              |
|                                        |              |                                                                                                                                                                                                                            |                                                                                    | -                     | 2                                              |
| ST                                     | Y, Rr        | Store Indirect                                                                                                                                                                                                             | (Y) ← Rr                                                                           | None                  |                                                |
| ST                                     | Y+, Rr       | Store Indirect and Pro Doc                                                                                                                                                                                                 | $(Y) \leftarrow Rr, Y \leftarrow Y + 1$                                            | None                  | 2                                              |
| ST                                     | -Y, Rr       | Store Indirect and Pre-Dec.                                                                                                                                                                                                | $Y \leftarrow Y - 1, (Y) \leftarrow Rr$                                            | None                  | 2                                              |
| STD                                    | Y+q, Rr      | Store Indirect with Displacement                                                                                                                                                                                           | (Y + q) ← Rr                                                                       | None                  | 2                                              |
| ST                                     | Z, Rr        | Store Indirect                                                                                                                                                                                                             | (Z) ← Rr                                                                           | None                  | 2                                              |
| ST                                     | Z+, Rr       | Store Indirect and Post-Inc.                                                                                                                                                                                               | $(Z) \leftarrow Rr, Z \leftarrow Z + 1$                                            | None                  | 2                                              |
| ST                                     | -Z, Rr       | Store Indirect and Pre-Dec.                                                                                                                                                                                                | $Z \leftarrow Z - 1, (Z) \leftarrow Rr$                                            | None                  | 2                                              |
| STD                                    | Z+q, Rr      | Store Indirect with Displacement                                                                                                                                                                                           | $(Z+q) \leftarrow Rr$                                                              | None                  | 2                                              |
| STS                                    | k, Rr        | Store Direct to SRAM                                                                                                                                                                                                       | (k) ← Rr                                                                           | None                  | 2                                              |
| LPM                                    |              | Load Program Memory                                                                                                                                                                                                        | R0 ← (Z)                                                                           | None                  | 3                                              |
| IN                                     | Rd, P        | In Port                                                                                                                                                                                                                    | Rd ← P                                                                             | None                  | 1                                              |
| OUT                                    | P, Rr        | Out Port                                                                                                                                                                                                                   | P ← Rr                                                                             | None                  | 1                                              |
| PUSH                                   | Rr           | Push Register on Stack                                                                                                                                                                                                     | STACK ← Rr                                                                         | None                  | 2                                              |
| POP                                    | Rd           | Pop Register from Stack                                                                                                                                                                                                    | Rd ← STACK                                                                         | None                  | 2                                              |
| BIT AND BIT-TEST                       | INSTRUCTIONS |                                                                                                                                                                                                                            |                                                                                    |                       |                                                |
| SBI                                    | P, b         | Set Bit in I/O Register                                                                                                                                                                                                    | I/O(P,b) ← 1                                                                       | None                  | 2                                              |
| CBI                                    | P, b         | Clear Bit in I/O Register                                                                                                                                                                                                  | $I/O(P,b) \leftarrow 0$                                                            | None                  | 2                                              |
| LSL                                    | Rd           | Logical Shift Left                                                                                                                                                                                                         | $Rd(n+1) \leftarrow Rd(n), Rd(0) \leftarrow 0$                                     | Z,C,N,V               | 1                                              |
| LSR                                    | Rd           | Logical Shift Right                                                                                                                                                                                                        | $Rd(n) \leftarrow Rd(n+1), Rd(7) \leftarrow 0$                                     | Z,C,N,V               | 1                                              |
| ROL                                    | Rd           | Rotate Left through Carry                                                                                                                                                                                                  | $Rd(0) \leftarrow C, Rd(n+1) \leftarrow Rd(n), C \leftarrow Rd(7)$                 | Z,C,N,V               | 1                                              |
| ROR                                    | Rd           | Rotate Right through Carry                                                                                                                                                                                                 | $Rd(7) \leftarrow C, Rd(n) \leftarrow Rd(n+1), C \leftarrow Rd(0)$                 | Z,C,N,V               | 1                                              |
| ASR                                    | Rd           | Arithmetic Shift Right                                                                                                                                                                                                     | $Rd(n) \leftarrow Rd(n+1), n = 06$                                                 | Z,C,N,V               | 1                                              |
| SWAP                                   | Rd           | Swap Nibbles                                                                                                                                                                                                               | $Rd(30) \leftarrow Rd(74), Rd(74) \leftarrow Rd(30)$                               | None                  | 1                                              |
| BSET                                   | s            | Flag Set                                                                                                                                                                                                                   | SREG(s) ← 1                                                                        | SREG(s)               | 1                                              |
| BCLR                                   | s            | Flag Clear                                                                                                                                                                                                                 | $SREG(s) \leftarrow 0$                                                             | SREG(s)               | 1                                              |
| BST                                    | Rr, b        | Bit Store from Register to T                                                                                                                                                                                               | $T \leftarrow Rr(b)$                                                               | T                     | 1                                              |
| BLD                                    | Rd, b        | Bit Load from T to Register                                                                                                                                                                                                | $Rd(b) \leftarrow T$                                                               | None                  | 1                                              |
|                                        | Tiu, b       | Set Carry                                                                                                                                                                                                                  |                                                                                    |                       | 1                                              |
| SEC<br>CLC                             |              | Clear Carry                                                                                                                                                                                                                | C ← 1                                                                              | C                     |                                                |
|                                        |              |                                                                                                                                                                                                                            | C ← 0                                                                              | N                     | 1                                              |
| SEN                                    |              | Set Negative Flag                                                                                                                                                                                                          | N ← 1                                                                              |                       | 1                                              |
| CLN                                    |              | Clear Negative Flag                                                                                                                                                                                                        | N ← 0                                                                              | N 7                   | 1                                              |
| SEZ                                    |              | Set Zero Flag                                                                                                                                                                                                              | Z ← 1                                                                              | Z                     | 1 1                                            |
| CLZ                                    |              | Clear Zero Flag                                                                                                                                                                                                            | Z ← 0                                                                              | Z                     | 1                                              |
|                                        |              | L (-lobal Interrupt Enable                                                                                                                                                                                                 | I ← 1                                                                              | 1                     | 1                                              |
| SEI                                    |              | Global Interrupt Enable                                                                                                                                                                                                    |                                                                                    |                       |                                                |
| CLI                                    |              | Global Interrupt Disable                                                                                                                                                                                                   | 1 ← 0                                                                              | 1                     | 1                                              |
| CLI<br>SES                             |              | Global Interrupt Disable Set Signed Test Flag                                                                                                                                                                              | I ← 0<br>S ← 1                                                                     | S                     | 1 1                                            |
| CLI<br>SES<br>CLS                      |              | Global Interrupt Disable Set Signed Test Flag Clear Signed Test Flag                                                                                                                                                       | I ← 0<br>S ← 1<br>S ← 0                                                            | S<br>S                | 1                                              |
| CLI<br>SES<br>CLS<br>SEV               |              | Global Interrupt Disable Set Signed Test Flag                                                                                                                                                                              | I ← 0<br>S ← 1<br>S ← 0<br>V ← 1                                                   | S<br>S<br>V           | 1<br>1<br>1                                    |
| CLI<br>SES<br>CLS                      |              | Global Interrupt Disable Set Signed Test Flag Clear Signed Test Flag                                                                                                                                                       | I ← 0<br>S ← 1<br>S ← 0                                                            | S<br>S<br>V<br>V      | 1<br>1<br>1                                    |
| CLI<br>SES<br>CLS<br>SEV               |              | Global Interrupt Disable Set Signed Test Flag Clear Signed Test Flag Set Two's Complement Overflow                                                                                                                         | I ← 0<br>S ← 1<br>S ← 0<br>V ← 1                                                   | S<br>S<br>V           | 1<br>1<br>1                                    |
| CLI<br>SES<br>CLS<br>SEV<br>CLV        |              | Global Interrupt Disable Set Signed Test Flag Clear Signed Test Flag Set Two's Complement Overflow Clear Two's Complement Overflow                                                                                         | I ← 0<br>S ← 1<br>S ← 0<br>V ← 1<br>V ← 0                                          | S<br>S<br>V<br>V      | 1<br>1<br>1<br>1<br>1                          |
| CLI<br>SES<br>CLS<br>SEV<br>CLV<br>SET |              | Global Interrupt Disable Set Signed Test Flag Clear Signed Test Flag Set Two's Complement Overflow Clear Two's Complement Overflow Set T in SREG                                                                           | I ← 0<br>S ← 1<br>S ← 0<br>V ← 1<br>V ← 0<br>T ← 1                                 | S S V V T             | 1<br>1<br>1<br>1<br>1<br>1                     |
| CLI SES CLS SEV CLV SET CLT            |              | Global Interrupt Disable Set Signed Test Flag Clear Signed Test Flag Set Two's Complement Overflow Clear Two's Complement Overflow Set T in SREG Clear T in SREG                                                           | I ← 0 S ← 1 S ← 0 V ← 1 V ← 0 T ← 1 T ← 0                                          | S S V V V T T T       | 1<br>1<br>1<br>1<br>1<br>1<br>1                |
| CLI SES CLS SEV CLV SET CLT SEH        |              | Global Interrupt Disable Set Signed Test Flag Clear Signed Test Flag Set Two's Complement Overflow Clear Two's Complement Overflow Set T in SREG Clear T in SREG Set Half-carry Flag in SREG                               | I ← 0 S ← 1 S ← 0 V ← 1 V ← 0 T ← 1 T ← 0 H ← 1                                    | S S V V V T T T H     | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1           |
| CLI SES CLS SEV CLV SET CLT SEH CLH    |              | Global Interrupt Disable Set Signed Test Flag Clear Signed Test Flag Set Two's Complement Overflow Clear Two's Complement Overflow Set T in SREG Clear T in SREG Set Half-carry Flag in SREG Clear Half-carry Flag in SREG | I ← 0 S ← 1 S ← 0 V ← 1 V ← 0 T ← 1 T ← 0 H ← 1                                    | S S V V V T T T H H H | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 |

# **Ordering Information**

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

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





## **Packaging Information**

### 20P3



### **20S**

20S, 20-lead, Plastic Gull Wing Small Outline (SOIC), 0.300" body. Dimensions in Millineters and (Inches)\* JEDEC STANDARD MS-013







\*Controlling dimension: Inches

REV. A 04/11/2001





#### **Atmel Headquarters**

Corporate Headquarters 2325 Orchard Parkway San Jose, CA 95131 TEL 1(408) 441-0311 FAX 1(408) 487-2600

#### Europe

Atmel Sarl Route des Arsenaux 41 Case Postale 80 CH-1705 Fribourg Switzerland TEL (41) 26-426-5555 FAX (41) 26-426-5500

#### Asia

Room 1219 Chinachem Golden Plaza 77 Mody Road Tsimhatsui East Kowloon Hong Kong TEL (852) 2721-9778 FAX (852) 2722-1369

#### Japan

9F, Tonetsu Shinkawa Bldg. 1-24-8 Shinkawa Chuo-ku, Tokyo 104-0033 Japan TEL (81) 3-3523-3551 FAX (81) 3-3523-7581

#### **Atmel Operations**

#### Memory

2325 Orchard Parkway San Jose, CA 95131 TEL 1(408) 441-0311 FAX 1(408) 436-4314

#### Microcontrollers

2325 Orchard Parkway San Jose, CA 95131 TEL 1(408) 441-0311 FAX 1(408) 436-4314

La Chantrerie BP 70602 44306 Nantes Cedex 3, France TEL (33) 2-40-18-18-18 FAX (33) 2-40-18-19-60

#### ASIC/ASSP/Smart Cards

Zone Industrielle 13106 Rousset Cedex, France TEL (33) 4-42-53-60-00 FAX (33) 4-42-53-60-01

1150 East Cheyenne Mtn. Blvd. Colorado Springs, CO 80906 TEL 1(719) 576-3300 FAX 1(719) 540-1759

Scottish Enterprise Technology Park Maxwell Building East Kilbride G75 0QR, Scotland TEL (44) 1355-803-000 FAX (44) 1355-242-743

#### RF/Automotive

Theresienstrasse 2 Postfach 3535 74025 Heilbronn, Germany TEL (49) 71-31-67-0 FAX (49) 71-31-67-2340

1150 East Cheyenne Mtn. Blvd. Colorado Springs, CO 80906 TEL 1(719) 576-3300 FAX 1(719) 540-1759

Biometrics/Imaging/Hi-Rel MPU/ High Speed Converters/RF Datacom Avenue de Rochepleine BP 123 38521 Saint-Egreve Cedex, France TEL (33) 4-76-58-30-00 FAX (33) 4-76-58-34-80

e-mail literature@atmel.com

Web Site http://www.atmel.com

#### © Atmel Corporation 2002.

Atmel Corporation makes no warranty for the use of its products, other than those expressly contained in the Company's standard warranty which is detailed in Atmel's Terms and Conditions located on the Company's web site. The Company assumes no responsibility for any errors which may appear in this document, reserves the right to change devices or specifications detailed herein at any time without notice, and does not make any commitment to update the information contained herein. No licenses to patents or other intellectual property of Atmel are granted by the Company in connection with the sale of Atmel products, expressly or by implication. Atmel's products are not authorized for use as critical components in life support devices or systems.

ATMEL® and AVR® are the registered trademarks of Atmel.

Other terms and product names may be the trademarks of others.

