



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

| Detuns                     |                                                                         |
|----------------------------|-------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                |
| Core Processor             | AVR                                                                     |
| Core Size                  | 8-Bit                                                                   |
| Speed                      | 8MHz                                                                    |
| Connectivity               | SPI, UART/USART                                                         |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                   |
| Number of I/O              | 32                                                                      |
| Program Memory Size        | 8KB (4K x 16)                                                           |
| Program Memory Type        | FLASH                                                                   |
| EEPROM Size                | 512 x 8                                                                 |
| RAM Size                   | 512 x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 6V                                                                 |
| Data Converters            | -                                                                       |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | -40°C ~ 85°C                                                            |
| Mounting Type              | Surface Mount                                                           |
| Package / Case             | 44-LCC (J-Lead)                                                         |
| Supplier Device Package    | 44-PLCC (16.6x16.6)                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/at90s8515-8ji |
|                            |                                                                         |

Email: info@E-XFL.COM

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



## **Pin Configurations**

PDIP

PLCC







### Architectural Overview

The fast-access register file concept contains  $32 \times 8$ -bit general-purpose working registers with a single clock cycle access time. This means that during one single clock cycle, one ALU (Arithmetic Logic Unit) operation is executed. Two operands are output from the register file, the operation is executed and the result is stored back in the register file – in one clock cycle.

Six of the 32 registers can be used as three 16-bit indirect address register pointers for Data Space addressing, enabling efficient address calculations. One of the three address pointers is also used as the address pointer for the constant table look-up function. These added function registers are the 16-bit X-, Y-, and Z-register.

The ALU supports arithmetic and logic functions between registers or between a constant and a register. Single register operations are also executed in the ALU. Figure 4 shows the AT90S8515 AVR RISC microcontroller architecture.

In addition to the register operation, the conventional memory addressing modes can be used on the register file as well. This is enabled by the fact that the register file is assigned the 32 lowermost Data Space addresses (\$00 - \$1F), allowing them to be accessed as though they were ordinary memory locations.

The I/O memory space contains 64 addresses for CPU peripheral functions such as Control Registers, Timer/Counters, A/D converters and other I/O functions. The I/O memory can be accessed directly or as the Data Space locations following those of the register file, \$20 - \$5F.

The AVR uses a Harvard architecture concept – with separate memories and buses for program and data. The program memory is executed with a two-stage pipeline. While one instruction is being executed, the next instruction is pre-fetched from the program memory. This concept enables instructions to be executed in every clock cycle. The program memory is In-System Programmable Flash memory.

With the relative jump and call instructions, the whole 4K address space is directly accessed. Most AVR instructions have a single 16-bit word format. Every program memory address contains a 16- or 32-bit instruction.

During interrupts and subroutine calls, the return address Program Counter (PC) is stored on the stack. The stack is effectively allocated in the general data SRAM and consequently, the stack size is only limited by the total SRAM size and the usage of the SRAM. All user programs must initialize the SP in the reset routine (before subroutines or interrupts are executed). The 16-bit Stack Pointer (SP) is read/write-accessible in the I/O space.

The 512-byte data SRAM can be easily accessed through the five different addressing modes supported in the AVR architecture.

The memory spaces in the AVR architecture are all linear and regular memory maps.





### General-purpose Register File

Figure 6 shows the structure of the 32 general-purpose working registers in the CPU.

#### Figure 6. AVR CPU General-purpose Working Registers



X-register low byte X-register high byte Y-register low byte Y-register high byte Z-register low byte Z-register high byte

All the register operating instructions in the instruction set have direct and single-cycle access to all registers. The only exception are the five constant arithmetic and logic instructions SBCI, SUBI, CPI, ANDI and ORI between a constant and a register and the LDI instruction for load immediate constant data. These instructions apply to the second half of the registers in the register file (R16..R31). The general SBC, SUB, CP, AND and OR and all other operations between two registers or on a single register apply to the entire register file.

As shown in Figure 6, each register is also assigned a data memory address, mapping them directly into the first 32 locations of the user Data Space. Although not being physically implemented as SRAM locations, this memory organization provides great flexibility in access of the registers, as the X-, Y- and Z-registers can be set to index any register in the file.

The registers R26..R31 have some added functions to their general-purpose usage. These registers are address pointers for indirect addressing of the Data Space. The three indirect address registers X, Y, and Z are defined as:



Figure 7. X-, Y-, and Z-registers

AT90S8515

X-register, Y-register and

**Z-register** 

10

# AT90S8515

d

31

|                                        | two additional clock cycles is used per byte. This has the following effect: Data transfer instructions take two extra clock cycles, whereas interrupt, subroutine calls and returns will need four clock cycles more than specified in the instruction set manual.                                                                                                                                                                    |
|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                        | The five different addressing modes for the data memory cover: Direct, Indirect with Displacement, Indirect, Indirect with Pre-decrement and Indirect with Post-increment. In the register file, registers R26 to R31 feature the indirect addressing pointer registers.                                                                                                                                                               |
|                                        | The direct addressing reaches the entire data space.                                                                                                                                                                                                                                                                                                                                                                                   |
|                                        | The Indirect with Displacement mode features 63 address locations reached from the base address given by the Y- or Z-register.                                                                                                                                                                                                                                                                                                         |
|                                        | When using register indirect addressing modes with automatic pre-decrement and post-<br>increment, the address registers X, Y and Z are decremented and incremented.                                                                                                                                                                                                                                                                   |
|                                        | The 32 general-purpose working registers, 64 I/O registers, the 512 bytes of internal data SRAM, and the 64K bytes of optional external data SRAM in the AT90S8515 are all accessible through all these addressing modes.                                                                                                                                                                                                              |
|                                        | See the next section for a detailed description of the different addressing modes.                                                                                                                                                                                                                                                                                                                                                     |
| Program and Data<br>Addressing Modes   | The AT90S8515 AVR RISC microcontroller supports powerful and efficient addressing modes for access to the program memory (Flash) and data memory (SRAM, Register file and I/O memory). This section describes the different addressing modes supported by the AVR architecture. 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<br>Register RD | Figure 9. Direct Single Register Addressing                                                                                                                                                                                                                                                                                                                                                                                            |
|                                        | 15 4 0<br>OP d                                                                                                                                                                                                                                                                                                                                                                                                                         |

The operand is contained in register d (Rd).





The user can select the start-up time according to typical oscillator start-up. The number of WDT oscillator cycles used for each time-out is shown in Table 4. The frequency of the Watchdog Oscillator is voltage-dependent as shown in "Typical Characteristics" on page 95.

| Table 4. | Number of Watchdog Oscillator Cycles |  |
|----------|--------------------------------------|--|
|----------|--------------------------------------|--|

| FSTRT        | Time-out at V <sub>CC</sub> = 5V | Number of WDT Cycles |  |  |
|--------------|----------------------------------|----------------------|--|--|
| Programmed   | 0.28 ms                          | 256                  |  |  |
| Unprogrammed | 16.0 ms                          | 16K                  |  |  |

#### **Power-on Reset**

A Power-on Reset (POR) circuit ensures that the device is reset from power-on. As shown in Figure 23, an internal timer clocked from the Watchdog Timer oscillator prevents the MCU from starting until after a certain period after  $V_{CC}$  has reached the Power-on Threshold Voltage ( $V_{POT}$ ), regardless of the  $V_{CC}$  rise time (see Figure 24). The FSTRT Fuse bit in the Flash can be programmed to give a shorter start-up time if a certamic resonator or any other fast-start oscillator is used to clock the MCU.

If the built-in start-up delay is sufficient,  $\overline{\text{RESET}}$  can be connected to V<sub>CC</sub> directly or via an external pull-up resistor. By holding the pin low for a period after V<sub>CC</sub> has been applied, the Power-on Reset period can be extended. Refer to Figure 25 for a timing example of this.





#### Figure 25. MCU Start-up, RESET Controlled Externally





interrupt. Some of the interrupt flags can also be cleared by writing a logical "1" to the flag bit position(s) to be cleared.

If an interrupt condition occurs when the corresponding interrupt enable bit is cleared (zero), the interrupt flag will be set and remembered until the interrupt is enabled or the flag is cleared by software.

If one or more interrupt conditions occur when the global interrupt enable bit is cleared (zero), the corresponding interrupt flag(s) will be set and remembered until the global interrupt enable bit is set (one) and will be executed by order of priority.

Note that external level interrupt does not have a flag and will only be remembered for as long as the interrupt condition is active.

#### General Interrupt Mask Register – GIMSK



#### Bit 7 – INT1: External Interrupt Request 1 Enable

When the INT1 bit is set (one) and the I-bit in the Status Register (SREG) is set (one), the external pin interrupt is enabled. The Interrupt Sense Control1 bits 1/0 (ISC11 and ISC10) in the MCU general Control Register (MCUCR) define whether the external interrupt is activated on rising or falling edge of the INT1 pin or is level-sensed. Activity on the pin will cause an interrupt request even if INT1 is configured as an output. The corresponding interrupt of External Interrupt Request 1 is executed from program memory address \$002. See also "External Interrupts".

#### • Bit 6 – INT0: External Interrupt Request 0 Enable

When the INT0 bit is set (one) and the I-bit in the Status Register (SREG) is set (one), the external pin interrupt is enabled. The Interrupt Sense Control0 bits 1/0 (ISC01 and ISC00) in the MCU general Control Register (MCUCR) define whether the external interrupt is activated on rising or falling edge of the INT0 pin or is level-sensed. Activity on the pin will cause an interrupt request even if INT0 is configured as an output. The corresponding interrupt of External Interrupt Request 0 is executed from program memory address \$001. See also "External Interrupts".

#### • Bits 5..0 - Res: Reserved Bits

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

#### General Interrupt Flag Register – GIFR



#### • Bit 7 – INTF1: External Interrupt Flag1

When an edge on the INT1 pin triggers an interrupt request, the corresponding interrupt flag, INTF1 becomes set (one). If the I-bit in SREG and the corresponding interrupt enable bit, INT1 in GIMSK is set (one), the MCU will jump to the interrupt vector. The flag is cleared when the interrupt routine is executed. Alternatively, the flag can be cleared by writing a logical "1" to it. This flag is always cleared when INT1 is configured as level interrupt.



#### • 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 programmer's 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 section "Sleep Modes".

#### • Bits 3, 2 – ISC11, ISC10: Interrupt Sense Control 1, Bit 1 and Bit 0

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

Table 5. Interrupt 1 Sense Control

| ISC11 | ISC10 | Description                                              |  |  |  |  |
|-------|-------|----------------------------------------------------------|--|--|--|--|
| 0     | 0     | he low level of INT1 generates an interrupt request.     |  |  |  |  |
| 0     | 1     | Reserved                                                 |  |  |  |  |
| 1     | 0     | The falling edge of INT1 generates an interrupt request. |  |  |  |  |
| 1     | 1     | The rising edge of INT1 generates an interrupt request.  |  |  |  |  |

#### • 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 are set. The level and edges on the external INT0 pin that activate the interrupt are defined in Table 6.

Table 6. Interrupt 0 Sense Control

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

The value on the INTn 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.

# <u>AÎMEL</u>

The Stop condition provides a Timer Enable/Disable function. The CK down divided modes are scaled directly from the CK oscillator clock. If the external pin modes are used for Timer/Counter0, transitions on PB0/(T0) will clock the counter even if the pin is configured as an output. This feature can give the user software control of the counting.

#### Timer Counter0 – TCNT0



The Timer/Counter0 is realized as an up-counter with read and write access. If the Timer/Counter0 is written and a clock source is present, the Timer/Counter0 continues counting in the clock cycle following the write operation.

#### 16-bit Timer/Counter1

Figure 30 shows the block diagram for Timer/Counter1.

#### Figure 30. Timer/Counter1 Block Diagram



The 16-bit Timer/Counter1 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/Counter1 Control Registers (TCCR1A and TCCR1B). The different status flags (overflow, compare match and capture event) are found in the Timer/Counter Interrupt Flag Register (TIFR). Control signals are found in the Timer/Counter1 Control Registers (TCCR1A and TCCR1B). The interrupt enable/disable settings for Timer/Counter1 are found in the Timer/Counter Interrupt Mask Register (TIMSK).

When Timer/Counter1 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 16-bit Timer/Counter1 features both a high-resolution and a high-accuracy usage with the lower prescaling opportunities. Similarly, the high prescaling opportunities make the Timer/Counter1 useful for lower speed functions or exact timing functions with infrequent actions.

The Timer/Counter1 supports two Output Compare functions using the Output Compare Register 1 A and B (OCR1A and OCR1B) as the data sources to be compared to the Timer/Counter1 contents. The Output Compare functions include optional clearing of the counter on compareA match and actions on the Output Compare pins on both compare matches.

Timer/Counter1 can also be used as an 8-, 9- or 10-bit Pulse Width Modulator. In this mode, the counter and the OCR1A/OCR1B registers serve as a dual, glitch-free, standalone PWM with centered pulses. Refer to page 47 for a detailed description of this function.

The Input Capture function of Timer/Counter1 provides a capture of the Timer/Counter1 contents to the Input Capture Register (ICR1), triggered by an external event on the input capture pin (ICP). The actual capture event settings are defined by the Timer/Counter1 Control Register (TCCR1B). In addition, the Analog Comparator can be set to trigger the Input Capture. Refer to "Analog Comparator" on page 59 for details on this. The ICP pin logic is shown in Figure 31.





ACIC: COMPARATOR IC ENABLE ACO: COMPARATOR OUTPUT

If the Noise Canceler function is enabled, the actual trigger condition for the capture event is monitored over four samples and all four must be equal to activate the capture flag.



## **Analog Comparator**

The Analog Comparator compares the input values on the positive input PB2 (AIN0) and negative input PB3 (AIN1). When the voltage on the positive input PB2 (AIN0) is higher than the voltage on the negative input PB3 (AIN1), the Analog Comparator Output (ACO) is set (one). The comparator's output can be set to trigger the Timer/Counter1 Input Capture function. In addition, the comparator can trigger a separate interrupt, exclusive to the Analog Comparator. The user can select interrupt triggering on comparator output rise, fall or toggle. A block diagram of the comparator and its surrounding logic is shown in Figure 41.





#### Analog Comparator Control and Status Register – ACSR

| Bit           | 7   | 6 | 5   | 4   | 3    | 2    | 1     | 0     | _    |
|---------------|-----|---|-----|-----|------|------|-------|-------|------|
| \$08 (\$28)   | ACD | - | ACO | ACI | ACIE | ACIC | ACIS1 | ACIS0 | ACSR |
| Read/Write    | R/W | R | R   | R/W | R/W  | R/W  | R/W   | R/W   | •    |
| Initial Value | 0   | 0 | N/A | 0   | 0    | 0    | 0     | 0     |      |

#### • Bit 7 – ACD: Analog Comparator Disable

When this bit is set (one), the power to the Analog Comparator is switched off. This bit can be set at any time to turn off the Analog Comparator. This will reduce power consumption in active and idle mode. When changing the ACD bit, the Analog Comparator interrupt must be disabled by clearing the ACIE bit in ACSR. Otherwise an interrupt can occur when the bit is changed.

• Bit 6 - Res: Reserved Bit

This bit is a reserved bit in the AT90S8515 and will always read as zero.

Bit 5 – ACO: Analog Comparator Output

ACO is directly connected to the comparator output.

• Bit 4 – ACI: Analog Comparator Interrupt Flag

This bit is set (one) when a comparator output event triggers the interrupt mode defined by ACI1 and ACI0. The Analog Comparator Interrupt routine is executed if the ACIE bit is set (one) and the I-bit in SREG is set (one). ACI is cleared by hardware when executing the corresponding interrupt handling vector. Alternatively, ACI is cleared by writing a logical "1" to the flag. Observe however, that if another bit in this register is modified



Default, the external SRAM access, is a 3-cycle scheme as depicted in Figure 43. When one extra wait state is needed in the access cycle, set the SRW bit (one) in the MCUCR register. The resulting access scheme is shown in Figure 44. In both cases, note that PORTA is data bus in one cycle only. As soon as the data access finishes, PORTA becomes a low-order address bus again.

For details of the timing for the SRAM interface, please refer to Figure 68, Table 37, Table 38, Table 39 and Table 40, beginning on page 92. Refer to "Architectural Overview" on page 7 for a description of the memory map, including address space for SRAM.



Figure 42. External SRAM Connected to the AVR

Figure 43. External Data SRAM Memory Cycles without Wait State











#### Table 32. Serial Programming Instruction Set

|                      | Instruction Format |                    |                   |           |                                                                                                    |
|----------------------|--------------------|--------------------|-------------------|-----------|----------------------------------------------------------------------------------------------------|
| Instruction          | Byte 1             | Byte 2             | Byte 3            | Byte4     | Operation                                                                                          |
| Programming Enable   | 1010 1100          | 0101 0011          | xxxx xxxx         | XXXX XXXX | Enable serial programming while RESET is low.                                                      |
| Chip Erase           | 1010 1100          | 100x xxxx          | xxxx xxxx         | xxxx xxxx | Chip Erase Flash and EEPROM memory arrays.                                                         |
| Read Program Memory  | 0010 <b>H</b> 000  | xxxx <b>aaaa</b>   | bbbb bbbb         | 0000 0000 | Read <b>H</b> (high or low) data <b>o</b> from program memory at word address <b>a:b</b> .         |
| Write Program Memory | 0100 <b>H</b> 000  | xxxx <b>aaaa</b>   | bbbb bbbb         | 1111 1111 | Write <b>H</b> (high or low) data <b>i</b> to program memory at word address <b>a</b> : <b>b</b> . |
| Read EEPROM Memory   | 1010 0000          | xxxx xxx <b>a</b>  | bbbb bbbb         | 0000 0000 | Read data o from EEPROM memory at address a:b.                                                     |
| Write EEPROM Memory  | 1100 0000          | XXXX XXX <b>a</b>  | bbbb bbbb         | 1111 1111 | Write data i to EEPROM memory at address a:b.                                                      |
| Write Lock Bits      | 1010 1100          | 111x x <b>21</b> x | xxxx xxxx         | xxxx xxxx | Write Lock bits. Set bits <b>1,2</b> = "0" to program Lock bits.                                   |
| Read Signature Bytes | 0011 0000          | xxxx xxxx          | xxxx xx <b>bb</b> | 0000 0000 | Read signature byte <b>o</b> at address <b>b</b> . <sup>(1)</sup>                                  |

**a** = address high bits

**b** = address low bits

 $\mathbf{H} = 0 - \text{Low byte}, 1 - \text{High Byte}$ 

- $\mathbf{o} = data out$
- i = data in
- x = don't care
- 1 = Lock bit 1
- **2** = Lock bit 2

# Serial Programming Characteristics





**Table 33.** Serial Programming Characteristics,  $T_A = -40^{\circ}C$  to  $85^{\circ}C$ ,  $V_{CC} = 2.7V - 6.0V$  (unless otherwise noted)

| Symbol              | Parameter                                      | Min                   | Тур  | Max  | Units |
|---------------------|------------------------------------------------|-----------------------|------|------|-------|
| 1/t <sub>CLCL</sub> | Oscillator Frequency ( $V_{CC} = 2.7 - 4.0V$ ) | 0                     |      | 4.0  | MHz   |
| t <sub>CLCL</sub>   | Oscillator Period ( $V_{CC} = 2.7 - 4.0V$ )    | 250.0                 |      |      | ns    |
| 1/t <sub>CLCL</sub> | Oscillator Frequency ( $V_{CC} = 4.0 - 6.0V$ ) | 0                     |      | 8.0  | MHz   |
| t <sub>CLCL</sub>   | Oscillator Period ( $V_{CC} = 4.0 - 6.0V$ )    | 125.0                 |      |      | ns    |
| t <sub>SHSL</sub>   | SCK Pulse Width High                           | 2.0 t <sub>CLCL</sub> |      |      | ns    |
| t <sub>SLSH</sub>   | SCK Pulse Width Low                            | 2.0 t <sub>CLCL</sub> |      |      | ns    |
| t <sub>ovsh</sub>   | MOSI Setup to SCK High                         | t <sub>CLCL</sub>     |      |      | ns    |
| t <sub>SHOX</sub>   | MOSI Hold after SCK High                       | 2.0 t <sub>CLCL</sub> |      |      | ns    |
| t <sub>SLIV</sub>   | SCK Low to MISO Valid                          | 10.0                  | 16.0 | 32.0 | ns    |

Table 34. Minimum Wait Delay after the Chip Erase Instruction

| Symbol                | 3.2V  | 3.6V  | 4.0V  | 5.0V |
|-----------------------|-------|-------|-------|------|
| t <sub>WD_ERASE</sub> | 18 ms | 14 ms | 12 ms | 8 ms |

Table 35. Minimum Wait Delay after Writing a Flash or EEPROM Location

| Symbol               | 3.2V | 3.6V | 4.0V | 5.0V |
|----------------------|------|------|------|------|
| t <sub>WD_PROG</sub> | 9 ms | 7 ms | 6 ms | 4 ms |



Analog Comparator offset voltage is measured as absolute offset.



Figure 76. Analog Comparator Offset Voltage vs. Common Mode Voltage

















WATCHDOG OSCILLATOR FREQUENCY vs. V<sub>cc</sub>













Figure 86. I/O Pin Input Hysteresis vs. V<sub>CC</sub>









## **Instruction Set Summary**

| Mnemonic     | Operands        | Description                            | Operation                                             | Flags     | # Clocks   |
|--------------|-----------------|----------------------------------------|-------------------------------------------------------|-----------|------------|
| ARITHMETIC A | ND LOGIC INSTRU | ICTIONS                                |                                                       | •         | _ <b>-</b> |
| 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:RdI ← Rdh:RdI + 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          |
| 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          |
| SBIW         | Rdl, K          | Subtract Immediate from Word           | Rdh:RdI ← Rdh:RdI - K                                 | Z,C,N,V,S | 2          |
| 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 ullet K$                            | Z,N,V     | 1          |
| OR           | Rd, Rr          | Logical OR Registers                   | $Rd \leftarrow Rd \lor Rr$                            | Z,N,V     | 1          |
| ORI          | Rd, K           | Logical OR Register and Constant       | $Rd \leftarrow Rd \lor 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 \lor 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 \leftarrow 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 \leftarrow FF$                                    | None      | 1          |
| BRANCH INSTR |                 |                                        |                                                       |           |            |
| RJMP         | k               | Relative Jump                          | $PC \leftarrow PC + k + 1$                            | None      | 2          |
| IJMP         |                 | Indirect Jump to (Z)                   | $PC \leftarrow Z$                                     | None      | 2          |
| RCALL        | k               | Relative Subroutine Call               | $PC \leftarrow PC + k + 1$                            | None      | 3          |
| ICALL        |                 | Indirect Call to (Z)                   | $PC \leftarrow Z$                                     | None      | 3          |
| RET          |                 | Subroutine Return                      | $PC \leftarrow STACK$                                 | None      | 4          |
| RETI         |                 | Interrupt Return                       | PC ← STACK                                            | 1         | 4          |
| CPSE         | Rd, Rr          | Compare, Skip if Equal                 | if (Rd = Rr) PC $\leftarrow$ PC + 2 or 3              | None      | 1/2/3      |
| 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 or 3            | None      | 1/2/3      |
| SBRS         | Rr, b           | Skip if Bit in Register is Set         | if $(Rr(b) = 1) PC \leftarrow PC + 2 \text{ or } 3$   | None      | 1/2/3      |
| 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/3      |
| SBIS         | P, b            | Skip if Bit in I/O Register is Set     | if (P(b) = 1) PC $\leftarrow$ PC + 2 or 3             | None      | 1/2/3      |
| 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 $\leftarrow$ 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 $\leftarrow$ PC + k + 1            | None      | 1/2        |
| BRHC         | k               | Branch if Half-carry Flag Cleared      | if (H = 0) then PC $\leftarrow$ PC + k + 1            | None      | 1/2        |
| BRTS         | k               | Branch if T-flag Set                   | if (T = 1) then PC $\leftarrow$ PC + k + 1            | None      | 1/2        |
| BRTC         | k               | Branch if T-flag Cleared               | if (T = 0) then PC $\leftarrow$ PC + k + 1            | None      | 1/2        |
| BRVS         | k               | Branch if Overflow Flag is Set         | if $(V = 1)$ then PC $\leftarrow$ 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        |



## AT90S8515 Ordering Information

| Speed (MHz) | Power Supply | Ordering Code | Package | Operation Range |
|-------------|--------------|---------------|---------|-----------------|
| 4           | 2.7V - 6.0V  | AT90S8515-4AC | 44A     | Commercial      |
|             |              | AT90S8515-4JC | 44J     | (0°C to 70°C)   |
|             |              | AT90S8515-4PC | 40P6    |                 |
|             |              | AT90S8515-4AI | 44A     | Industrial      |
|             |              | AT90S8515-4JI | 44J     | (-40°C to 85°C) |
|             |              | AT90S8515-4PI | 40P6    |                 |
| 8           | 4.0V - 6.0V  | AT90S8515-8AC | 44A     | Commercial      |
|             |              | AT90S8515-8JC | 44J     | (0°C to 70°C)   |
|             |              | AT90S8515-8PC | 40P6    |                 |
|             |              | AT90S8515-8AI | 44A     | Industrial      |
|             |              | AT90S8515-8JI | 44J     | (-40°C to 85°C) |
|             |              | AT90S8515-8PI | 40P6    |                 |

Note: Order AT90S8515A-XXX for devices with the FSTRT Fuse programmed.

| Package Type |                                                                   |  |  |  |
|--------------|-------------------------------------------------------------------|--|--|--|
| 44 <b>A</b>  | 44-lead, Thin (1.0 mm) Plastic Gull Wing Quad Flat Package (TQFP) |  |  |  |
| 44J          | 44-lead, Plastic J-leaded Chip Carrier (PLCC)                     |  |  |  |
| 40P6         | 40-lead, 0.600" Wide, Plastic Dual Inline Package (PDIP)          |  |  |  |

# 108 AT90S8515



#### **Atmel Headquarters**

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

#### Europe

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

#### Asia

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

#### Japan

Atmel Japan K.K. 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 Product Operations**

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

#### Atmel Grenoble

Avenue de Rochepleine BP 123 38521 Saint-Egreve Cedex, France TEL (33) 4-7658-3000 FAX (33) 4-7658-3480

#### Atmel Heilbronn

Theresienstrasse 2 POB 3535 D-74025 Heilbronn, Germany TEL (49) 71 31 67 25 94 FAX (49) 71 31 67 24 23

#### Atmel Nantes

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

#### Atmel Rousset

Zone Industrielle 13106 Rousset Cedex, France TEL (33) 4-4253-6000 FAX (33) 4-4253-6001

#### Atmel Smart Card ICs

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

> *e-mail* literature@atmel.com

> Web Site http://www.atmel.com

BBS 1-(408) 436-4309

#### © Atmel Corporation 2001.

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.

