8-Bit Microcontroller With 1K Bytes Downloadable Flash AT90S1200 Preliminary
8-Bit Microcontroller With 1K Bytes Downloadable Flash AT90S1200 Preliminary
8-Bit Microcontroller With 1K Bytes Downloadable Flash AT90S1200 Preliminary
Pin Configuration
Rev. 0838BS-B–12/97
1
Block Diagram
2 AT90S1200
AT90S1200
Description (Continued)
The architecture supports high level languages efficiently as well as extremely dense assembler code programs. The
AT90S1200 provides the following features: 1K bytes of Downloadable Flash, 64 bytes EEPROM, 15 general purpose I/O
lines, 32 general purpose working registers, internal and external interrupts, programmable Watchdog Timer with internal
oscillator, an SPI serial port for program downloading and two software selectable power saving modes. The Idle Mode
stops the CPU while allowing the registers, timer/counter, watchdog 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 Downloadable Flash
allows the program memory to be reprogrammed in-system through an SPI serial interface or by a conventional nonvolatile
memory programmer. By combining an enhanced RISC 8-bit CPU with Downloadable Flash on a monolithic chip, the Atmel
AT90S1200 is a powerful microcontroller that provides a highly flexible and cost effective solution to many embedded con-
trol applications.
The AT90S1200 AVR is supported with a full suite of program and system development tools including: 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 pullups (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 20mA and can drive LED displays directly. When pins PB0 to PB7 are used as inputs and are exter-
nally pulled low, they will source current (IIL) if the internal pullups are activated.
Port B also serves the functions of various special features of the AT90S1200 as listed on Page 25.
Port D (PD6..PD0)
Port D has seven bi-directional I/O pins with internal pullups, PD6..PD0. The Port D output buffers can sink 20 mA. As
inputs, Port D pins that are externally pulled low will source current (IIL) if the pullups are activated.
Port D also serves the functions of various special features of the AT90S1200 as listed on Page 29.
RESET
Reset input. A low on this pin for two machine cycles while the oscillator is running resets the device.
XTAL1
Input to the inverting oscillator amplifier and input to the internal clock operating circuit.
XTAL2
Output from the inverting oscillator amplifier
3
AT90S1200 Architectural Overview
The fast-access register file concept contains 32 x 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.
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 2 shows the AT90S1200 AVR Enhanced RISC microcontroller architec-
ture. The AVR uses a Harvard architecture concept - with separate memories and buses for program and data memories.
The program memory is accessed with a single level pipelining. While one instruction is being executed, the next instruc-
tion is pre-fetched from the program memory. This concept enables instructions to be executed in every clock cycle. The
program memory is in-system downloadable Flash memory.
With the relative jump and relative call instructions, the whole 512 address space is directly accessed. All AVR instructions
have a single 16-bit word format, meaning that every program memory address contains a single 16-bit instruction.
During interrupts and subroutine calls, the return address program counter (PC) is stored on the stack. The stack is a 3
level deep hardware stack dedicated for subroutines and interrupts.
The I/O memory space contains 64 addresses for CPU peripheral functions as Control Registers, Timer/Counters, A/D-
converters, and other I/O functions. The memory spaces in the AVR architecture are all linear and regular memory maps.
A flexible interrupt module has its control registers in the I/O space with an additional global interrupt enable bit in the status
register. All the different interrupts have a separate interrupt vector in the interrupt vector table at the beginning of the pro-
gram memory. The different interrupts have priority in accordance with their interrupt vector position. The lower the interrupt
vector address, the higher the priority.
4 AT90S1200
AT90S1200
$3F SREG I T H S V N Z C 10
$3E Reserved
$3D Reserved
$3C Reserved
$3B GIMSK - INT0 - - - - - - 15
$3A Reserved
$39 TIMSK - - - - - - TOIE0 - 15
$38 TIFR - - - - - - TOV0 - 16
$37 Reserved
$36 Reserved
$35 MCUCR - - SE SM - - ISC01 ISC00 17
$34 Reserved
$33 TCCR0 - - - - - CS02 CS01 CS00 19
$32 TCNT0 Timer/Counter0 (8 Bit) 20
$31 Reserved
$30 Reserved
$2F Reserved
$2E Reserved
$2D Reserved
$2C Reserved
$2B Reserved
$2A Reserved
$29 Reserved
$28 Reserved
$27 Reserved
$26 Reserved
$25 Reserved
$24 Reserved
$23 Reserved
$22 Reserved
$21 WDTCR - - - - WDE WDP2 WDP1 WDP0 21
$20 Reserved
$1F Reserved
$1E EEAR - EEPROM Address Register 22
$1D EEDR EEPROM Data Register 22
$1C EECR - - - - - - EEWE EERE 22
$1B Reserved
$1A Reserved
$19 Reserved
$18 PORTB PORTB7 PORTB6 PORTB5 PORTB4 PORTB3 PORTB2 PORTB1 PORTB0 24
$17 DDRB DDB7 DDB6 DDB5 DDB4 DDB3 DDB2 DDB1 DDB0 25
$16 PINB PINB7 PINB6 PINB5 PINB4 PINB3 PINB2 PINB1 PINB0 25
$15 Reserved
$14 Reserved
$13 Reserved
$12 PORTD - PORTD6 PORTD5 PORTD4 PORTD3 PORTD2 PORTD1 PORTD0 29
$11 DDRD - DDD6 DDD5 DDD4 DDD3 DDD2 DDD1 DDD0 29
$10 PIND - PIND6 PIND5 PIND4 PIND3 PIND2 PIND1 PIND0 29
$0F Reserved
$0E Reserved
$0D Reserved
$0C Reserved
$0B Reserved
$0A Reserved
$09 Reserved
$08 ACSR ACD - ACO ACI ACIE - ACIS1 ACIS0 23
… Reserved
$00 Reserved
5
AT90S1200 Instruction Set Summary
Mnemonics Operands Description Operation Flags #Clocks
ARITHMETIC AND LOGIC INSTRUCTIONS
ADD Rd, Rr Add two Registers Rd ← Rd + Rr Z,C,N,V,H 1
ADC Rd, Rr Add with Carry two Registers Rd ← Rd + Rr + C Z,C,N,V,H 1
SUB Rd, Rr Subtract two Registers Rd ← Rd - Rr Z,C,N,V,H 1
SUBI Rd, K Subtract Constant from Register Rd ← Rd - K Z,C,N,V,H 1
SBC Rd, Rr Subtract with Carry two Registers Rd ← Rd - Rr - C Z,C,N,V,H 1
SBCI Rd, K Subtract with Carry Constant from Reg. Rd ← Rd - K - C Z,C,N,V,H 1
AND Rd, Rr Logical AND Registers Rd ← Rd • Rr Z,N,V 1
ANDI Rd, K Logical AND Register and Constant Rd ← Rd • K Z,N,V 1
OR Rd, Rr Logical OR Registers Rd ← Rd v Rr Z,N,V 1
ORI Rd, K Logical OR Register and Constant Rd ← Rd v K Z,N,V 1
EOR Rd, Rr Exclusive OR Registers Rd ← Rd⊕Rr Z,N,V 1
COM Rd One’s Complement Rd ← $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 ← Rd v K Z,N,V 1
CBR Rd,K Clear Bit(s) in Register Rd ← Rd • (FFh - K) Z,N,V 1
INC Rd Increment Rd ← Rd + 1 Z,N,V 1
DEC Rd Decrement Rd ← Rd - 1 Z,N,V 1
TST Rd Test for Zero or Minus Rd ← Rd • Rd Z,N,V 1
CLR Rd Clear Register Rd ← Rd⊕Rd Z,N,V 1
SER Rd Set Register Rd ← $FF None 1
BRANCH INSTRUCTIONS
RJMP k Relative Jump PC ← PC + k + 1 None 2
RCALL k Relative Subroutine Call PC ← PC + k + 1 None 3
RET Subroutine Return PC ← STACK None 4
RETI Interrupt Return PC ← STACK I 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 ← PC + 2 or 3 None 1/2
SBRS Rr, b Skip if Bit in Register is Set if (Rr(b)=1) PC ← PC + 2 or 3 None 1/2
SBIC P, b Skip if Bit in I/O Register Cleared if (P(b)=0) PC ← PC + 2 or 3 None 1/2
SBIS P, b Skip if Bit in I/O Register is Set if (P(b)=1) PC ← PC + 2 or 3 None 1/2
BRBS s, k Branch if Status Flag Set if (SREG(s) = 1) then PC←PC + k + 1 None 1/2
BRBC s, k Branch if Status Flag Cleared if (SREG(s) = 0) then PC←PC + k + 1 None 1/2
BREQ k Branch if Equal if (Z = 1) then PC ← 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 ← PC + k + 1 None 1/2
BRCC k Branch if Carry Cleared if (C = 0) then PC ← PC + k + 1 None 1/2
BRSH k Branch if Same or Higher if (C = 0) then PC ← PC + k + 1 None 1/2
BRLO k Branch if Lower if (C = 1) then PC ← PC + k + 1 None 1/2
BRMI k Branch if Minus if (N = 1) then PC ← PC + k + 1 None 1/2
BRPL k Branch if Plus if (N = 0) then PC ← PC + k + 1 None 1/2
BRGE k Branch if Greater or Equal, Signed if (N ⊕ V= 0) then PC ← PC + k + 1 None 1/2
BRLT k Branch if Less Than Zero, Signed if (N ⊕ V= 1) then PC ← 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 ← PC + k + 1 None 1/2
BRIE k Branch if Interrupt Enabled if ( I = 1) then PC ← PC + k + 1 None 1/2
BRID k Branch if Interrupt Disabled if ( I = 0) then PC ← PC + k + 1 None 1/2
(continued)
AT90S1200 Instruction Set Summary (Continued)
Mnemonics Operands Description Operation Flags #Clocks
DATA TRANSFER INSTRUCTIONS
LD Rd,Z Load Register Indirect Rd ← (Z) None 2
ST Z,Rr Store Register Indirect (Z) ← Rr None 2
MOV Rd, Rr Move Between Registers Rd ← Rr None 1
LDI Rd, K Load Immediate Rd ← K None 1
6 AT90S1200
AT90S1200