SGS Thomson Microelectronics ST90E158M9G0, ST90158P9C6, ST90158M9T1, ST90158M9Q6, ST90158M9 Datasheet

...
January 2000 1/190
Rev. 3.0
ST90158 - ST90135
8/16-BIT MCU FAMILY WITH
UP TO 64K ROM/OTP/EPROM AND UP TO 2K RAM
Register File based 8/16 bit Core Architecture
with RUN, WFI, SLOW and HALT modes
+85°C and 0°C to +70°C Operating Temperature Ranges
0 - 14 MHz Operation @ 3V±10% and 0°Cto
+70°C Operating Temperature Range
Fully Programmable PLL Clock Generator, with
Frequency Multiplication and low frequency, low cost external crystal
Minimum 8-bit InstructionCycle time:83ns - (@
24 MHz internal clock frequency)
Minimum 16-bit Instruction Cycle time: 250ns -
(@ 24 MHz internal clock frequency)
Internal Memory:
– EPROM/OTP/ROM 16/24/32/48/64K bytes – ROMlessversion available – RAM512/768/1K/1.5K/2K bytes
Maximum External Memory: 64K bytes
224 general purpose registers available as
RAM, accumulators or index pointers (register file)
80-pin Plastic Quad Flat Package and 80-pin
Thin Quad Flat Package
67 fully programmable I/O bits
8 external and 1 Non-Maskable Interrupts
DMA Controller and Programmable Interrupt
Handler
Single Master Serial Peripheral Interface
Two 16-bit Timers with 8-bit Prescaler, one
usable as a Watchdog Timer (software and hardware)
Three (ST90158) or two (ST90135) 16-bit
Multifunction Timers, each with an 8 bit prescaler, 12 operating modes and DMA capabilities
8 channel 8-bitAnalog toDigital Converter, with
Automatic voltage monitoring capabilities and external reference inputs
Two (ST90158) or one (ST90135) Serial
Communication Interfaces with asynchronous, synchronous and DMA capabilities
Rich Instruction Set with 14 Addressing modes
Division-by-Zero trap generation
Versatile Development Tools, including
Assembler, Linker, C-compiler, Archiver, Source Level Debugger and Hardware Emulators with Real-Time Operating System available from Third Parties
DEVICE SUMMARY
DEVICE
Program
Memory
(Bytes)
RAM
(Bytes)
MFT SCI PACKAGE
ST90135
16K ROM 512 2 1
PQFP80
24K ROM 768 2 1 32K ROM 1K 2 1
ST90158
48K ROM 1.5K 3 2
64k ROM 2K 3 2
PQFP80/
TQFP80
ST90E158
64K
EPROM
2K 3 2 CQFP80
ST90E158LV
64K
EPROM
2K 3 2 CQFP80
ST90T158 64K OTP 2K 3 2 PQFP80
ST90T158LV 64K OTP 2K 3 2
PQFP80/ TQFP80/
ST90R158 ROMless 2K 3 2
PQFP80/
TQFP80
PQFP80
TQFP80
9
2/190
Table of Contents
190
9
1 GENERAL DESCRIPTION . . . . . . ................................................ 6
1.1 INTRODUCTION . . . . . . . . . . . . . ............................................ 6
1.1.1 ST9+ Core . . . ..................................................... 6
1.1.2 Power Saving Modes . . . .. . . . . . .. . ................................... 6
1.1.3 system Clock . . . . . .. .. . . . . .........................................6
1.1.4 I/O Ports . . . . . . . . . .. . . . ............................................ 6
1.1.5 Multifunction Timers (MFT) . . . ......................................... 7
1.1.6 Standard Timer (STIM) . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.1.7 Watchdog Timer (WDT) . . . . . . . . . .....................................7
1.1.8 Serial Peripheral Interface (SPI) . . .. . ................................... 7
1.1.9 Serial Communications Controllers (SCI) . . . . . . . . . . . . ..................... 7
1.1.10 Analog/Digital Converter (ADC) . . . . . . . . . . . .. . . . . . .. . . . . . .. . ............ 7
1.2 PIN DESCRIPTION . . .................................................... 10
1.3 I/O PORT PINS . . . . . . . . . . . . . . . . . ........................................13
2 DEVICE ARCHITECTURE . . . . . . . . . . ........................................... 18
2.1 CORE ARCHITECTURE . . . . . . .. . .. .. . . . . . ................................18
2.2 MEMORY SPACES . . . . . . . . .. . . . . ........................................ 18
2.2.1 Register File . . . . . . . .. . . . . . .. . . . . . .. . .............................. 18
2.2.2 Register Addressing . . . . ............................................20
2.3 SYSTEM REGISTERS . . . .. . . . . . . . . . . . . .. . . . .............................. 21
2.3.1 Central Interrupt Control Register .. . . . . . . . . . ........................... 21
2.3.2 Flag Register . . . . . . ............................................... 22
2.3.3 Register Pointing Techniques . ........................................23
2.3.4 Paged Registers . . . .. . . . . . . . .. .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. . . . . 26
2.3.5 Mode Register . . . . . ............................................... 26
2.3.6 Stack Pointers . . . . . . . . . .. . .. . . . . . . .................................27
2.4 MEMORY ORGANIZATION . . . . . . . . . . . . . . . ................................. 29
2.5 MEMORY MANAGEMENT UNIT . . . . . . . .. . .................................. 30
2.6 ADDRESS SPACE EXTENSION . . . . . .. . . . . . . .. . . . . . . . . . . . . . . .. . . . . . .. . . . . . . 31
2.6.1 Addressing 16-Kbyte Pages . .. . . . . . . ................................. 31
2.6.2 Addressing 64-Kbyte Segments . . . . . .................................. 32
2.7 MMU REGISTERS . ...................................................... 32
2.7.1 DPR[3:0]: Data Page Registers . . . . . . . . . . . . . . . . . . .. . . . . . .. . ........... 32
2.7.2 CSR: Code Segment Register ........................................34
2.7.3 ISR: Interrupt Segment Register . . . . .. . . . .............................. 34
2.7.4 DMASR: DMA Segment Register . . . . . . . . .............................. 34
2.8 MMU USAGE . . . . .. . . . . . .. . . . . . . . . . . . . . ................................. 36
2.8.1 Normal Program Execution . . . . . . . . .. . . . . . .. . . . . . .. . . . . ............... 36
2.8.2 Interrupts . . . . . . . . . . . . . . . . . .. . . . . . . . . .............................. 36
2.8.3 DMA . . . . . . .. . . . . . .. . . . . . .. . . . . . .. . . . . ........................... 36
3 REGISTER AND MEMORY MAP ................................................ 37
3.1 MEMORY CONFIGURATION . . . . . . . . . . . . . .................................37
3.2 EPROM PROGRAMMING . . . . . .. . . . . . . . . . .. . . . . . . . . . .. .. . . . . . . .. . . . . . . . . . . 37
3.3 MEMORY MAP . . . . . .. .. . ...............................................39
3.4 ST90158/135 REGISTER MAP . . . . . . .. . . . .................................. 40
4 INTERRUPTS . . ............................................................. 48
4.1 INTRODUCTION . . . . . . . . . . . . . ...........................................48
4.2 INTERRUPT VECTORING ................................................ 48
3/190
Table of Contents
9
4.2.1 Divide by Zero trap . . . . .. . .. . . . . . .. ................................. 48
4.2.2 Segment Paging During Interrupt Routines . ............................. 49
4.3 INTERRUPT PRIORITY LEVELS . . . . . . . . .. . . . . . .. . . . . . .. . . . . . .. . . . . . .. . . . . . 49
4.4 PRIORITY LEVEL ARBITRATION . .. ........................................49
4.4.1 Priority level 7 (Lowest) . . . . . . . . . . .. . . . . . .. . . . . . .. . . . . . .. . . . . . .. . . . . . 49
4.4.2 Maximum depth of nesting . . . ........................................ 49
4.4.3 Simultaneous Interrupts . . . . . . .. . . . . ................................. 49
4.4.4 Dynamic Priority Level Modification . . . . .. . . . . . .. . . . . . .. .. . . . . . . . . . .. . . . 50
4.5 ARBITRATION MODES . . . . . . . .. .. . . . . . . .................................. 50
4.5.1 Concurrent Mode . . .. . . . . . . . . . . . . . . . . . . . . .. . . . . . . . . .. . . . . . . .. .. . . . . 50
4.5.2 Nested Mode . . . . . . ............................................... 53
4.6 EXTERNAL INTERRUPTS . . . . . . . . .. . . . . . .. . .............................. 55
4.7 TOP LEVEL INTERRUPT . . . . . . . . .. . . . . . . .................................57
4.8 ON-CHIP PERIPHERAL INTERRUPTS . . . .. . . . . . .. . . . . . .. . . . . . .. . ........... 57
4.9 INTERRUPT RESPONSE TIME . ...........................................58
4.10INTERRUPT REGISTERS . . ...............................................59
5 ON-CHIP DIRECT MEMORY ACCESS (DMA) . . . . .................................. 63
5.1 INTRODUCTION . . . . . . . . . . . . . ...........................................63
5.2 DMA PRIORITY LEVELS . . . ...............................................63
5.3 DMA TRANSACTIONS .. . . . . . . . . . ........................................64
5.4 DMA CYCLE TIME . . . . . . . .. .. . . . . ........................................ 66
5.5 SWAP MODE . . . . . . . .. . . . ...............................................66
5.6 DMA REGISTERS . . . . . . . . . . . . ...........................................67
6 RESET AND CLOCK CONTROL UNIT (RCCU) . . . .................................68
6.1 INTRODUCTION . . . . . . . . . . . . . ...........................................68
6.2 CLOCK CONTROL UNIT . . . . . . . ...........................................68
6.2.1 Clock Control Unit Overview . . ........................................68
6.3 CLOCK MANAGEMENT . . .. .. . . . . ........................................ 69
6.3.1 PLL Clock Multiplier Programming . . . . .................................70
6.3.2 CPU Clock Prescaling . . . . . . . . . . . .. . . . . . .. . . . . . .. . . . . . .. . . . . . .. . . . . . 70
6.3.3 Peripheral Clock . . . . . . . . . . .. .. . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . .. . . . . 70
6.3.4 Low Power Modes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. ........ 71
6.3.5 Interrupt Generation . . . . . . . . . . . . . . . . . . . . . . . . . . . . .................... 71
6.4 CLOCK CONTROL REGISTERS . . . . . . .. . . . . . . .............................. 74
6.5 OSCILLATOR CHARACTERISTICS . . . . . . . . . . . .............................. 77
6.6 RESET/STOP MANAGER . . . . . . ...........................................79
6.6.1 RESET Pin Timing . . . . . . . . . . . . . . . . ................................. 80
6.7 EXTERNAL STOP MODE . . ...............................................80
7 EXTERNAL MEMORY INTERFACE (EXTMI) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
7.1 INTRODUCTION . . . . . . . . . . . . . ...........................................81
7.2 EXTERNAL MEMORYSIGNALS . . . . . . . . . . . .. . . . . ........................... 82
7.2.1 AS: Address Strobe . . . .. . . . . . . . . . . . . . . . . ........................... 82
7.2.2 DS: Data Strobe . . . . ...............................................82
7.2.3 DS2: Data Strobe 2 . . . . . . . .. . . . . . .. . . . . .. . . . . . . . .. . . . . .. . . . . . .. . . . . . 82
7.2.4 RW: Read/Write . . . . ............................................... 85
7.2.5 BREQ, BACK: Bus Request, Bus Acknowledge . . . . .. . . . . . .. . . . . . . ........ 85
7.2.6 PORT 0 . . . . . . .................................................... 86
4/190
Table of Contents
1
7.2.7 PORT 1 . . . . . . .................................................... 86
7.2.8 WAIT: External Memory Wait . . . . . . . . . . . . . . . . . . .. . . . . . . ............... 86
7.3 REGISTER DESCRIPTION . ............................................... 87
8 I/O PORTS . . . . . . . . . . . . . . . . . . . . . . . . . . ........................................ 90
8.1 INTRODUCTION . . . . . . . . . . . . . ...........................................90
8.2 SPECIFIC PORT CONFIGURATIONS .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ........ 90
8.3 PORT CONTROL REGISTERS . . . . . . . . . . .. .. . . . . ........................... 90
8.4 INPUT/OUTPUT BIT CONFIGURATION . . . . . . . . . . . . . . . . . . . . . . . . . .. . .. . . . . . .. . 91
8.5 ALTERNATE FUNCTION ARCHITECTURE . . .. . . . . . . . . . . . . . . . . . . . . ........... 95
8.5.1 Pin Declared as I/O . . ............................................... 95
8.5.2 Pin Declared as an Alternate Input . . . . . . . . . . . .. . . . . . . . . .. . . . . . . . . . . . . . . 95
8.5.3 Pin Declared as an Alternate Function Output . . .. . . . . .. . . . . . . .. . . . . . . . . . . 95
8.6 I/O STATUS AFTER WFI,HALT AND RESET . . . . . . . . . . . . . . . . . . . . . ............ 95
9 ON-CHIP PERIPHERALS . . . . . . . . . . . ...........................................96
9.1 TIMER/WATCHDOG (WDT) . . . . . .. . . . . . . .................................. 96
9.1.1 Introduction . . . . . . . .. . . . ...........................................96
9.1.2 Functional Description . . . . . . ........................................97
9.1.3 Watchdog Timer Operation . . . . . . . ....................................98
9.1.4 WDT Interrupts ................................................... 100
9.1.5 Register Description . . . . ...........................................101
9.2 MULTIFUNCTION TIMER (MFT) . . . . . . . .. . . . . . . . . . . . . . . . ................... 103
9.2.1 Introduction . . . . . . . .. . . . ..........................................103
9.2.2 Functional Description . . . . . . .......................................105
9.2.3 Input Pin Assignment . . . . . .. . . . . . . ................................. 108
9.2.4 Output Pin Assignment . . . . . .. .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. . . . 112
9.2.5 Interrupt and DMA . . . . . . . . . . .. . . . . ................................114
9.2.6 Register Description . . . . ...........................................116
9.3 STANDARD TIMER (STIM) . ..............................................127
9.3.1 Introduction . . . . . . . .. . . . ..........................................127
9.3.2 Functional Description . . . . . . .......................................128
9.3.3 Interrupt Selection . . . .............................................. 129
9.3.4 Register Mapping . . . . . . . ..........................................129
9.3.5 Register Description . . . . ...........................................130
9.4 SERIAL PERIPHERAL INTERFACE (SPI) . . . . . . . . . . . . . . . .. . . . . . .. . .......... 131
9.4.1 Introduction . . . . . . . .. . . . ..........................................131
9.4.2 Device-Specific Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. . . . . . . .. . . . . . 131
9.4.3 Functional Description . . . . . . .......................................132
9.4.4 Interrupt Structure . . . .............................................. 133
9.4.5 Working With Other Protocols . . . . ................................... 134
9.4.6 I2C-bus Interface . . . .............................................. 134
9.4.7 S-Bus Interface . . . . . .. . . . . . .. . . . . . .. . . . . . . .. .. . ................... 137
9.4.8 IM-bus Interface . . . . . . . . . . . .......................................138
9.4.9 Register Description . . . . ...........................................139
9.5 SERIAL COMMUNICATIONS INTERFACE (SCI) . . . .. . . . . . . . . . . . . . . . . . . . . . . . .. 141
9.5.1 Introduction . . . . . . . .. . . . ..........................................141
9.5.2 Functional Description . . . . . . .......................................142
9.5.3 SCI Operating Modes . . . . . .. . . . . . .. . . . . . .. . . . . . .. . . . . . .. . . . . . . .. . . . 143
9.5.4 Serial Frame Format . . . . . . . . . . . . . . . . . . . .. . . . . . . . .. . . . . .. . . . . . .. . . . . 146
5/190
Table of Contents
1
9.5.5 Clocks And Serial Transmission Rates . ................................ 149
9.5.6 SCI Initialization Procedure . . . . . . . .. . . . ............................. 149
9.5.7 Input Signals . . . . . . . . . . . . . . .......................................151
9.5.8 Output Signals . . . . . . .. . . . . . . . . . . . . .. . . . . . . . . . . . . . . .. . . . . . . ....... 151
9.5.9 Interrupts and DMA . . . . . . . . . .......................................152
9.5.10 Register Description . ..............................................155
9.6 EIGHT-CHANNEL ANALOG TO DIGITAL CONVERTER (A/D) . . . . . . . . . . . . . . . . . .. 166
9.6.1 Introduction . . . . . . . .. . . . ..........................................166
9.6.2 Functional Description . . . . . . .......................................167
9.6.3 Interrupts . . . . . . . . . . . . . . . . . .. . . . . . . . . ............................. 169
9.6.4 Register Description . . . . ...........................................170
10 ELECTRICAL CHARACTERISTICS . . . . ........................................ 174
11 GENERAL INFORMATION ................................................... 188
11.1PACKAGE MECHANICALDATA . . . . . . . . . . . . . . . . . .......................... 188
11.280-PIN PLASTIC QUADFLAT PACKAGE . . . . ................................188
11.3ORDERING INFORMATION . . . . . . . . . . . . . ................................. 189
6/190
ST90158 - GENERAL DESCRIPTION
1 GENERAL DESCRIPTION
1.1 INTRODUCTION
The ST90158 and ST90135 microcontrollers are developed and manufactured by STMicroelectron­ics using a proprietary n-well CMOS process. Their performance derives from the use of a flexi­ble 256-register programming model for ultra-fast context switching and real-time event response. The intelligent on-chip peripherals offload the ST9 core from I/O and data management processing tasks allowing critical application tasks to get the maximum use of core resources. The new-gener­ation ST9 MCU devices now also support low power consumption and low voltage operation for power-efficient and low-cost embedded systems.
1.1.1 ST9+ Core
The advanced Core consists of the Central Processing Unit(CPU), the RegisterFile, the Inter­rupt and DMA controller, and the Memory Man­agement Unit. The MMU allows addressing of up to 4 Megabytes of program and data mapped into a single linear space.
Four independent buses are controlled by the Core: a 16-bit memory bus, an 8-bit register data bus, an 8-bit register address bus and a 6-bit inter­rupt/DMA bus which connects the interrupt and DMA controllersin theon-chip peripherals with the core.
This multiple bus architecture makes the ST9 fam­ily deviceshighly efficient foraccessing onand off­chip memory and fast exchange of data with the on-chip peripherals.
The general-purpose registers canbe used as ac­cumulators, index registers, or address pointers. Adjacent registerpairs make up 16-bit registersfor addressing or 16-bit processing. Although theST9 has an 8-bit ALU, the chip handles 16-bit opera­tions, including arithmetic, loads/stores, and mem­ory/register and memory/memory exchanges.
1.1.2 Power Saving Modes
To optimize performance versus power consump­tion, a range of operating modes can be dynami­cally selected.
Run Mode. This is the full speed execution mode with CPUand peripherals running at the maximum clock speed delivered by the Phase Locked Loop (PLL) of the Clock Control Unit (CCU).
Slow Mode. Power consumption can be signifi­cantly reduced byrunning the CPU and the periph­erals at reduced clock speed using the CPU Pres­caler and CCU Clock Divider(PLL not used) or by using the CK_AF external clock.
Wait For Interrupt Mode. The Wait For Interrupt (WFI) instruction suspends program executionun­til an interrupt request is acknowledged. During WFI, the CPU clock is halted while the peripheral and interrupt controller keep running at a frequen­cy programmable via the CCU. In this mode, the power consumption of the device can be reduced by more than 95% (Low Power WFI).
Halt Mode. When executing the HALT instruction, and if the Watchdog is not enabled, the CPU and its peripherals stop operating and the status of the machine remains frozen (the clock is also stopped). A reset is necessary to exit from Halt mode.
1.1.3 system Clock
A programmable PLL Clock Generator allows standard 3 to 5MHz crystals tobe used to obtaina large range of internal frequencies up to 24 MHz.
1.1.4 I/O Ports
The I/O lines are grouped into up to nine 8-bit I/O Ports and can be configured on a bit basis to pro­vide timing,status signals, an address/databus for interfacing to external memory, timer inputs and outputs, analog inputs, external interrupts and se­rial or parallel I/O.
9
7/190
ST90158 - GENERAL DESCRIPTION
1.1.5 Multifunction Timers (MFT)
Each multifunction timer has a 16-bit Up/Down counter supported by two 16-bit Compare regis­ters and two 16-bit input capture registers. Timing resolution canbeprogrammed using an 8-bit pres­caler. Multibyte transfers between the peripheral and memory aresupported by two DMA channels.
1.1.6 Standard Timer (STIM)
The Standard Timer includes a programmable 16­bit downcounter andan associated 8-bit prescaler with Single and Continuous counting modes.
1.1.7 Watchdog Timer (WDT)
The Watchdog timer can be used to monitor sys­tem integrity. When enabled, it generates a reset after a timeout period unless the counter is re­freshed by the application software. For additional
security, watchdog function can be enabled by hardware using a specific pin.
1.1.8 Serial Peripheral Interface (SPI)
The SPI bus is used to communicate with external devices via the SPI, or I C bus communication standards. The SPI uses oneor two lines for serial data and a synchronous clock signal.
1.1.9 Serial Communications Controllers (SCI)
Each SCI provides a synchronous or asynchro­nous serial I/O port using two DMA channels. Baud rates and data formats are programmable.
1.1.10 Analog/Digital Converter (ADC)
The ADCs provide up to 8 analog inputs with on­chip sample and hold. The analog watchdog gen­erates an interrupt when the input v oltage moves out of a preset threshold.
9
8/190
ST90158 - GENERAL DESCRIPTION
Figure 1. ST90158 Block Diagram
256 bytes
Register File
RAM
up to 2 Kbytes
ST9+ CORE
8/16 bits
CPU
Interrupt
Management
MEMORY BUS
RCCU
REGISTER BUS
WATCHDOG
OSCIN
OSCOUT
RESET
INTCLK
CKAF
AS
WAIT
NMI
R/W
DS
MFT1
MFT0
T0OUTA T0OUTB
T0INA T0INB
EPROM/
ROM/OTP
up to64 Kbytes
WDIN
WDOUT
HW0SW1
All alternate functions (
Italic characters
) are mapped on Port2 through Port9
INT0-7
MFT3
T3OUTA T3OUTB
T3INA T3INB
T1OUTA T1OUTB
T1INA T1INB
ADDRESS
DATA
Port0
SDI SDO SCK
P1[7:0]
P0[7:0]
SPI
I
2
C/IM Bus
STIM
SCI0
EXTRG AIN[7:0]
TX0CKIN RX0CKIN S0IN DCD0 S0OUT CLK0OUT RTS0
STOUT
ADDRESS
Port1
Fully Prog.
I/Os
A/D
Converter
with analog
watchdog
P0[7:0] P1[7:0] P2[6:0] P4[7:0] P5[7:3], P5.1 P6[6:0] P7[7:0] P8[7:0] P9[7:4], P9[2:0]
SCI1
TX1CKIN RX1CKIN S1IN DCD1 S1OUT CLK1OUT RTS1
9
9/190
ST90158 - GENERAL DESCRIPTION
Figure 2. ST90135 Block Diagram
256 bytes
Register File
RAM
up to 1 Kbyte
ST9+ CORE
8/16 bits
CPU
Interrupt
Management
MEMORY BUS
RCCU
ADDRESS
DATA
Port0
REGISTER BUS
WATCHDOG
OSCIN
OSCOUT
RESET
INTCLK
CKAF
AS
WAIT
NMI
R/W
DS
SDI SDO SCK
P1[7:0]
P0[7:0]
MFT3
MFT1
SPI
I
2
C/IM Bus
T1OUTA T1OUTB
T1INA T1INB
STIM
SCI0
ROM
up to 32
Kbytes
EXTRG AIN[7:0]
TX0CKIN RX0CKIN S0IN DCD0 S0OUT CLK0OUT RTS0
STOUT
All alternate functions (
Italic characters
) are mapped on Port2 through Port9
INT0-7
ADDRESS
Port1
Fully Prog.
I/Os
T3OUTA T3OUTB
T3INA T3INB
WDIN
WDOUT
HW0SW1
A/D
Converter
with analog
watchdog
P0[7:0] P1[7:0] P2[6:0] P4[7:0] P5[7:3], P5.1 P6[6:0] P7[7:0] P8[7:0] P9[7:4], P9[2:0]
9
10/190
ST90158 - GENERAL DESCRIPTION
9
1.2 PIN DESCRIPTION AS: Address Strobe (output, active low, 3-state).
Address Strobe is pulsed low once at the begin­ning of each memory cycle. The rising edge of AS indicates that address, Read/Write (R/W), and Data Memory signals are valid for memory trans­fers. Underprogram control, AS canbe placed in a high-impedance statealong withPort 0, Port 1and Data Strobe (DS).
DS: Data Strobe (output, active low, 3-state). Data Strobe provides thetiming for data movement toor from Port 0 for each memory transfer. During a write cycle, data out is valid at the leading edge of DS. During a readcycle, Data In must be valid pri­or to the trailing edge of DS. When the ST90158 accesses on-chip memory, DS isheld high during the whole memory cycle. It can be placed ina high impedance state along with Port 0, Port 1 and AS.
RESET: Reset (input, active low).The ST9+ is ini­tialised by the Reset signal. With the deactivation of RESET, program execution begins from the memory location pointed to by the vector con­tained in memory locations 00h and 01h.
R/W: Read/Write (output, 3-state).Read/Write de­termines the direction of data transfer for external memory transactions. R/W is low when writing to external memory, and high for all other transac­tions. It can be placed in high impedance state along with Port 0, Port 1, ASand DS.
OSCIN, OSCOUT: Oscillator (input and output). These pins connect a parallel-resonant crystal (3
to 5 MHz), or an external source to the on-chip clock oscillator and buffer. OSCIN is the input of the oscillator inverter and internal clock generator; OSCOUT is the output of theoscillator inverter.
HW0_SW1: When connectedto VDDthrough a 1K pull-up resistor, the software watchdog option is selected. When connected to VSSthrough a 1K pull-down resistor, the hardware watchdog option is selected.
VPP: Programming voltage for EPROM/OTP de­vices. Must be connected to VSSin user mode through a 10Kohm resistor.
AVDD: Analog VDDof the Analog to Digital Con-
verter.
AVSS: Analog VSSof the Analog to Digital Con-
verter.
VDD: Main Power Supply Voltage (5V ± 10%). VSS: Digital Circuit Ground. P0[7:0], P1[7:0]: (
Input/Output,TTL or CMOS
compatible
). 16lines grouped into I/Oports provid­ing the external memory interface for addressing 64Kbytes of external memory.
P0[7:0], P1[7:0], P2[6:0], P4[7:0], P5[7:3], P5.1, P6[6:0], P7[7:0], P8[7:0], P9[7:4], P9[2:0]:
I/O Port Lines (Input/Output, TTL or CMOS compati­ble).
I/O lines grouped into I/O ports of 8 bits, bit programmable under program control as general purpose I/O or as alternate functions.
11/190
ST90158 - GENERAL DESCRIPTION
1
PIN DESCRIPTION (Cont’d) Figure 3. 80-Pin TQFP Pin-out
*EPROM or OTP devices only
ST90158/ST90135
P0.5/AD5
P0.4/AD4
P0.3/AD3
P0.2/AD2
P0.1/AD1
P0.0/AD0
P6.6
P6.5/RW
P6.4
P6.3
P6.2
P6.1
P6.0
P1.7/A15
P1.6/A14
P1.5/A13
P1.4/A12
P1.3/A11
P1.2/A10
P1.1/A9
AD6/P0.6
V
SS
AD7/P0.7
V
DD
AS
DS
V
PP
* P4.0 P4.1
INTCLK/P4.2
STOUT/P4.3
WDOUT/INT0/P4.4
INT4/P4.5
T0OUTB/INT5/P4.6
T0OUTA/P4.7
P2.0 P2.1 P2.2 P2.3 P2.4
1
20
21
40
41
60
6180
P2.5
P2.6
S1OUT/P9.0
T0OUTB/S1IN/P9.1
TX1CKIN/CLK1OUT/P9.2
S0OUT/RX1CKIN/P9.4
S0IN/P9.5
INT2/SCK/P9.6
INT6/SDO/P9.7
AIN0/RX0CKIN/WDIN/EXTRG/P7.0
AIN1/T0INB/SDI/P7.1
AIN2/CLK0OUT/TX0CKIN/P7.2
AIN3/T0INA/P7.3
AIN4/P7.4
AIN5/P7.5
AIN6/P7.6
AIN7/P7.7
AV
DD
AV
SS
NMI/T3OUTB/P8.7
P1.0/A8 RESET OSCIN V
SS
OSCOUT P5.1/SDI HW0SW1 P5.3 P5.4/T1OUTA/DCD0 P5.5/T1OUT1/RTS0 P5.6/T3OUTA/DCD1 P5.7/T3OUTB/RTS1/CKAF V
DD
P8.0/T3INA P8.1/T1INB P8.2/INT1/T1OUTA P8.3/INT3/T1OUTB P8.4/T1INA/WAIT/WDOUT P8.5/T3INB P8.6/INT7/T3OUTA
12/190
ST90158 - GENERAL DESCRIPTION
PIN DESCRIPTION (Cont’d) Figure 4. 80-Pin PQFP Pin-Out
AD4/P0.4 AD5/P0.5 AD6/P0.6
V
SS
AD7/P0.7
V
DD
AS
DS
V
PP
* P4.0 P4.1
INTCLK/P4.2
STOUT/P4.3
INT0/WDOUT/P4.4
INT4/P4.5
INT5/T0OUTB/P4.6
T0OUTA/P4.7
P2.0 P2.1 P2.2 P2.3 P2.4 P2.5 P2.6
P0.3/AD3
P0.2/AD2
P0.1/AD1
P0.0/AD0
P6.6
P6.5/RW
P6.4
P6.3
P6.2
P6.1
P6.0
P1.7/A15
P1.6/A14
P1.5/A13
P1.4/A12
P1.3/A11
P1.2/A10 P1.1/A9 P1.0/A8 RESET OSCIN V
SS
OSCOUT P5.1/SDI HW0SW1 P5.3 P5.4/T1OUTA/DCD0 P5.5/T1OUTB/RTS0 P5.6/T3OUTA/DCD1 P5.7/T3OUTB/RTS1/CK_AF V
DD
P8.0/T3INA P8.1/T1INB P8.2/T1OUTA/INT1 P8.3/T1OUTB/INT3 P8.4/T1INA/WAIT/WDOUT P8.5/T3INB P8.6/INT7/T3OUTA P8.7/NMI/T3OUTB AV
SS
S1OUT/P9.0
T0OUTB/S1IN/P9.1
TX1CKIN/CLK1OUT/P9.2
S0OUT/RX1CKIN/P9.4
S0IN/P9.5
INT2/SCK/P9.6
INT6/SDO/P9.7
AIN0/RX0CKIN/WDIN/EXTRG/P7.0
AIN1/T0INB/P7.1
AIN2/CLK0OUT/TX0CKIN/P7.2
AIN3/T0INA/P7.3
AIN4/P7.4
AIN5/P7.5
AIN6/P7.6
AIN7/P7.7
AV
DD
1
80
24
40
64
ST90158/ST90135
*EPROM or OTP devices only
9
13/190
ST90158 - GENERAL DESCRIPTION
1.3 I/O PORT PINS
All the ports of the device can be programmed as Input/Output or in Input mode, compatible with TTL or CMOS levels (except where Schmitt Trig­ger is present). Each bit can be programmed indi­vidually (Refer to the I/O ports chapter).
TTL/CMOS Input
For all those port bits where no input schmitt trig­ger is implemented, it is always possible to pro­gram the input level as TTL or CMOS compatible by programming the relevant PxC2.n control bit. Refer to the sectiontitled “Input/Output Bit Config­uration” in the I/O Ports Chapter .
Push-Pull/OD Output
The output buffer can be programmed as push­pull or open-drain: attention must be paid to the fact thatthe open-drain option correspondsonly to a disabling of P-channel MOS transistor of the buffer itself: it is still present and physically con­nected to thepin. Consequently it isnot possible to increase the output voltage on the pin over VDD+0.3 Volt, to avoid direct junctionbiasing.
Table 1. I/O Port Characteristics
Legend: WPU = Weak Pull-Up, OD = Open Drain
Input Output Weak Pull-Up Reset State
Port 0 TTL/CMOS Push-Pull/OD Yes Bidirectional WPU Port 1 TTL/CMOS Push-Pull/OD Yes Bidirectional WPU Port 2 TTL/CMOS Push-Pull/OD No Bidirectional Port 4 Schmitt trigger Push-Pull/OD Yes Bidirectional WPU Port 5 Schmitt trigger Push-Pull/OD Yes Bidirectional WPU Port 6 TTL/CMOS Push-Pull/OD No Bidirectional Port 7 Schmitt trigger Push-Pull/OD Yes Bidirectional WPU Port 8 Schmitt trigger Push-Pull/OD Yes Bidirectional WPU Port 9 Schmitt trigger Push-Pull/OD Yes Bidirectional WPU
9
14/190
ST90158 - GENERAL DESCRIPTION
I/O PORT PINS (Cont’d) How to Configure the I/Oports
To configure the I/O ports, use the information in Table 1, Table 2 andthe Port BitConfiguration Ta­ble in the I/O ports Chapter (See page 92).
Input Note = the hardware characteristics fixed for each port line in Table1.
– IfInput note = TTL/CMOS, either TTL or CMOS
input level can be selected by software.
– IfInput note = Schmitt trigger, selecting CMOS
or TTL input by software has no effect, the input will always be Schmitt Trigger.
Alternate Functions (AF) = More than one AF cannot beassigned to anI/O pin atthe sametime:
An alternate function can be selected as follows. AF Inputs: – AF isselected implicitly by enabling the corre-
sponding peripheral. Exceptionto this are A/D inputs which must beexplicitly selectedas AFby
software. AF Outputs or Bidirectional Lines: – In the case of Outputs or I/Os, AF is selected
explicitly by software.
Example 1: SCI data input
AF: S0IN, Port: P9.5, Port Style: Input Schmitt Trigger.
Write the port configuration bits: P9C2.5=1
P9C1.5=0 P9C0.5=1 Enable the SCI peripheral by software as de-
scribed in the SCI chapter.
Example 2: SCI data output
AF: S0OUT, Port: P9.4 Output push-pull(config­ured by software).
Write the port configuration bits: P9C2.4=0 P9C1.4=1 P9C0.4=1
Example 3: ADC data input
AF: AIN0, Port : P7.0, Input Note: does not apply to ADC
Write the port configuration bits: P7C2.0=1 P7C1.0=1 P7C0.0=1
Example 4: External Memory I/O
AF: AD0, Port : P0.0 Write the port configuration bits: P0C2.0=0 P0C1.0=1 P0C0.0=1
Table 2. I/O Port Description and Alternate Functions
Port
Name
General
Purpose I/O
Pin No.
Alternate Functions
TQFP
PQFP
P0.0
All ports useable for general pur­pose I/O (input, output or bidirec­tional)
75 77 AD0 I/O Address/Data bit 0 mux P0.1 76 78 AD1 I/O Address/Data bit 1 mux P0.2 77 79 AD2 I/O Address/Data bit 2 mux P0.3 78 80 AD3 I/O Address/Data bit 3 mux P0.4 79 1 AD4 I/O Address/Data bit 4 mux P0.5 80 2 AD5 I/O Address/Data bit 5 mux P0.6 1 3 AD6 I/O Address/Data bit 6 mux P0.7 3 5 AD7 I/O Address/Data bit 7 mux P1.0 60 62 A8 I/O Address bit 8 P1.1 61 63 A9 I/O Address bit 9 P1.2 62 64 A10 I/O Address bit 10
9
15/190
ST90158 - GENERAL DESCRIPTION
P1.3
All ports useable
for general pur­pose I/O (input,
output or bidirec-
tional)
63 65 A11 I/O Address bit 11 P1.4 64 66 A12 I/O Address bit 12 P1.5 65 67 A13 I/O Address bit 13 P1.6 66 68 A14 I/O Address bit 14 P1.7 67 69 A15 I/O Address bit 15 P2.0 16 18 I/O P2.1 17 19 I/O P2.2 18 20 I/O P2.3 19 21 I/O P2.4 20 22 I/O P2.5 21 23 I/O P2.6 22 24 I/O P4.0 8 10 I/O P4.1 9 11 I/O P4.2 10 12 INTCLK O Internal main Clock P4.3 11 13 STOUT O Standard Timer Output
P4.4 12 14
INT0 I External Interrupt 0 WDOUT O Watchdog Timeroutput
P4.5 13 15 INT4 I External interrupt 4
P4.6 14 16
INT5 I External Interrupt 5 T0OUTB O MF Timer 0 Output B
1)
P4.7 15 17 T0OUTA O MF Timer 0 Output A
1)
P5.1 55 57 SDI I SPI Serial Data In P5.3 53 55 I/O
P5.4 52 54
T1OUTA O MF Timer 1 output A DCD0 I SCI0 Data Carrier Detect
P5.5 51 53
RTS0 O SCI0 Request to Send T1OUTB O MF Timer 1 output B
P5.6 50 52
T3OUTA O MF Timer 3 output A DCD1 I SCI1 Data Carrier Detect
1)
P5.7 49 51
RTS1 O SCI1 Request to Send
1)
T3OUTB O MF Timer 3 output B CK_AF I External Clock Input
P6.0 68 70 I/O
Port
Name
General
Purpose I/O
Pin No.
Alternate Functions
TQFP
PQFP
9
16/190
ST90158 - GENERAL DESCRIPTION
P6.1
All ports useable
for general pur­pose I/O (input,
output or bidirec-
tional)
69 71 I/O P6.2 70 72 I/O P6.3 71 73 I/O P6.4 72 74 I/O P6.5 73 75 R/W O Read/Write P6.6 74 76 I/O
P7.0 30 32
AIN0 I A/D Analoginput 0 RX0CKIN I SCI0 Receive Clock input WDIN I T/WD input EXTRG I A/D External Trigger
P7.1 31 33
AIN1 I A/D Analoginput 1 T0INB I MF Timer 0 input B
1)
SDI I SPI Serial Data In
P7.2 32 34
AIN2 I A/D Analoginput 2 CLK0OUT O SCI0 Byte Sync Clock output TX0CKIN I SCI0 Transmit Clock input
P7.3 33 35
AIN3 I A/D Analoginput 3 T0INA I MF Timer 0 input A
1)
P7.4 34 36 AIN4 I A/D Analog input 4 P7.5 35 37 AIN5 I A/D Analog input 5 P7.6 36 38 AIN6 I A/D Analog input 6 P7.7 37 39 AIN7 I A/D Analog input 7 P8.0 47 49 T3INA I MF Timer 3input A P8.1 46 48 T1INB I MF Timer 1input B
P8.2 45 47
INT1 I External interrupt 1 T1OUTA O MF Timer 1 output A
P8.3 44 46
INT3 I External interrupt 3 T1OUTB O MF Timer 1 output B
P8.4 43 45
T1INA I MF Timer 1 input A WAIT I External Wait input WDOUT O Watchdog Timeroutput
P8.5 42 44 T3INB I MF Timer 3input B
P8.6 41 43
INT7 I External interrupt 7 T3OUTA O MF Timer 3 output A
P8.7 40 42
NMI I Non-Maskable Interrupt T3OUTB O MF Timer 3 output B
Port
Name
General
Purpose I/O
Pin No.
Alternate Functions
TQFP
PQFP
9
17/190
ST90158 - GENERAL DESCRIPTION
Note 1) Not present on ST90135
P9.0
All ports useable
for general pur­pose I/O (input,
output or bidirec-
tional)
23 25 S1OUT O SCI1 Serial Output
1)
P9.1 24 26
T0OUTB O MF Timer 0 output B
1)
S1IN I SCI1 SerialInput
1)
P9.2 25 27
CLK1OUT O SCI1 Byte Sync Clock output
1)
TX1CKIN I SCI1 Transmit Clock input
1)
P9.4 26 28
S0OUT O SCI0 Serial Output RX1CKIN O SCI1 Receive Clock input
1)
P9.5 27 29 S0IN I SCI0 Serial Input
P9.6 28 30
INT2 I External interrupt 2 SCK O SPI Serial Clock
P9.7 29 31
INT6 I External interrupt 6 SDO O SPI Serial Data Out
Port
Name
General
Purpose I/O
Pin No.
Alternate Functions
TQFP
PQFP
9
18/190
ST90158 - DEVICE ARCHITECTURE
2 DEVICE ARCHITECTURE
2.1 CORE ARCHITECTURE
The ST9+ Core or Central Processing Unit (CPU) features ahighly optimised instructionset, capable of handling bit, byte (8-bit) and word (16-bit) data, as well as BCDand Boolean formats; 14 address­ing modes are available.
Four independent buses are controlled by the Core: a 16-bit Memory bus, an 8-bit Register data bus, an 8-bit Register address bus and a 6-bit In­terrupt/DMA bus which connects the interrupt and DMA controllersin theon-chip peripherals with the Core.
This multiple bus architecture affords a high de­gree ofpipeliningand parallel operation, thus mak­ing the ST9+ family devices highly efficient, both for numerical calculation, data handling and with regard to communication with on-chip peripheral resources.
2.2 MEMORY SPACES
There are two separate memory spaces: – The Register File, which comprises 240 8-bit
registers, arranged as 15 groups (Group 0 to E), each containing sixteen 8-bit registers plus up to 64 pages of 16 registers mapped in Group F,
which hold data and control bits for the on-chip peripherals and I/Os.
– A single linear memory space accommodating
both program and data. Allof the physically sep­arate memoryareas, including the internal ROM, internal RAM and external memory are mapped in this common address space. The total ad­dressable memory space of 4 Mbytes(limited by the size of on-chip memory and the number of external address pins) is arranged as 64 seg­ments of 64 Kbytes. Each segment is further subdivided into four pages of 16 Kbytes, as illus­trated in Figure 5. A Memory Management Unit uses aset of pointer registers to address a22-bit memory field using 16-bit address-based instruc­tions.
2.2.1 Register File
The Register File consists of(see Figure6): – 224 general purpose registers (Group 0 to D,
registers R0 to R223)
– 6 system registers in the System Group (Group
E, registers R224 to R239)
– Up to 64 pages, depending on device configura-
tion, each containing up to 16registers, mapped to Group F (R240 to R255), see Figure 7.
Figure 5. Single Program and Data Memory Address Space
3FFFFFh
3F0000h 3EFFFFh
3E0000h
20FFFFh
02FFFFh 020000h
01FFFFh 010000h
00FFFFh 000000h
8 7 6
5 4 3 2 1 0
63
62
2
1
0
Address 16K Pages 64K Segments
up to 4 Mbytes
Data
Code
255 254 253 252 251
250 249 248 247
9
10
11
21FFFFh 210000h
133
134
135
33
Reserved
132
9
19/190
ST90158 - DEVICE ARCHITECTURE
MEMORY SPACES (Cont’d) Figure 6. Register Groups Figure 7. Page Pointer for Group F mapping
Figure 8. Addressing the Register File
F E D C B A
9 8 7 6 5 4 3
PAGED REGISTERS
SYSTEM REGISTERS
2 1 0
00
15
255 240
239 224
223
VA00432
UP TO
64 PAGES
GENERAL
REGISTERS
PURPOSE
224
PAGE 63
PAGE 5
PAGE 0
PAGE POINTER
R255
R240
R224
R0 VA00433
R234
REGISTERFILE
SYSTEM REGISTERS
GROUP D
GROUP B
GROUP C
(1100)
(0011)
R192
R207
255
240 239 224 223
F E
D C B A
9 8 7 6 5 4
3 2
1 0
15
VR000118
00
R195
R195
(R0C3h)
PAGED REGISTERS
9
20/190
ST90158 - DEVICE ARCHITECTURE
MEMORY SPACES (Cont’d)
2.2.2 Register Addressing
Register File registers, including Group F paged registers (but excluding Group D), may be ad­dressed explicitly by means of a decimal, hexa­decimal or binary address;thus R231, RE7h and R11100111b represent the same register (see Figure 8). Group D registers can only be ad­dressed in Working Register mode.
Note that an upper case “R” is used to denote this direct addressing mode.
Working Registers
Certain types of instruction require that registers be specified in the form “rx”, where x is in the range 0 to 15:these are known as Working Regis­ters.
Note thata lower case“r” isused to denote thisin­direct addressing mode.
Two addressing schemes are available: a single group of 16 working registers, or two separately mapped groups, each consisting of 8 working reg­isters. These groups may be mapped starting at any 8 or 16 byte boundary in the register file by means of dedicated pointer registers. This tech­nique is described in more detail in Section 2.3.3 Register Pointing Techniques, and illustrated in Figure 9 and in Figure 10.
System Registers
The 16 registers in Group E (R224 to R239) are System registersand may be addressed usingany of the register addressing modes. These registers are described in greater detail in Section 2.3 SYS­TEM REGISTERS.
Paged Registers
Up to 64 pages, each containing 16 registers, may be mapped to Group F. These are addressed us­ing any register addressing mode, in conjunction with the Page Pointer register,R234, which is one of the System registers. This register selects the page to be mapped to Group F and, once set, does not need to be changedif two or more regis­ters on the same pageare to be addressed in suc­cession.
Therefore ifthe PagePointer, R234, is setto 5, the instructions:
spp #5 ld R242, r4
will loadthe contents of working registerr4 into the third register of page5 (R242).
These paged registers holddata and controlinfor­mation relating to the on-chip peripherals, each peripheral always being associated with the same pages and registers to ensure code compatibility between ST9+ devices. The number of these reg­isters therefore depends on the peripherals which are present in the specific ST9+ family device. In other words, pages only exist if the relevant pe­ripheral is present.
Table 3. Register File Organization
Hex.
Address
Decimal
Address
Function
Register
File Group
F0-FF 240-255
Paged
Registers
Group F
E0-EF 224-239
System
Registers
Group E
D0-DF 208-223
General
Purpose
Registers
Group D
C0-CF 192-207 Group C
B0-BF 176-191 Group B A0-AF 160-175 Group A 90-9F 144-159 Group 9 80-8F 128-143 Group 8 70-7F 112-127 Group 7 60-6F 96-111 Group 6 50-5F 80-95 Group 5 40-4F 64-79 Group 4 30-3F 48-63 Group 3 20-2F 32-47 Group 2 10-1F 16-31 Group 1 00-0F 00-15 Group 0
9
21/190
ST90158 - DEVICE ARCHITECTURE
2.3 SYSTEM REGISTERS
The System registers are listed in Table 4. They are used to perform all the important system set­tings. Their purpose is described in the following pages. Refer to the chapter dealing with I/O for a description of the PORT[5:0] Data registers.
Table 4. System Registers (Group E)
2.3.1 Central Interrupt Control Register
Please referto the ”INTERRUPT”chapter for ade­tailed description of the ST9 interruptphilosophy.
CENTRAL INTERRUPT CONTROL REGISTER (CICR)
R230 - Read/Write Register Group: E (System) Reset Value: 1000 0111 (87h)
Bit 7 = GCEN:
Global Counter Enable
. This bit is the Global Counter Enable of the Multi­function Timers. The GCEN bit is ANDed with the CE bit in theTCR Register (only in devices featur­ing theMFT Multifunction Timer)in orderto enable the Timerswhen both bitsare set.This bit is set af­ter the Reset cycle.
Note: If an MFTis not included in the ST9 device, then this bit hasno effect.
Bit 6 =TLIP:
Top Level Interrupt Pending
. This bit is set by hardware when a Top Level Inter­rupt Request is recognized. This bit can also be set by software to simulate a Top Level Interrupt Request. 0: No Top Level Interruptpending 1: Top Level Interrupt pending
Bit 5 =TLI:
Top Level Interrupt bit
.
0: Top Level Interrupt isacknowledged depending
on the TLNM bit in the NICR Register.
1: Top Level Interrupt isacknowledged depending
on the IEN andTLNM bitsin theNICR Register (described in the Interrupt chapter).
Bit 4 =IEN:
Interrupt Enable .
This bit is cleared by interrupt acknowledgement, and set by interruptreturn (iret). IEN is modified implicitly byiret, ei and di instructions or by an interrupt acknowledge cycle. It can also be explic­itly written by the user, but only when nointerrupt is pending. Therefore, the user should execute a di instruction (or guarantee by other means that no interrupt request can arrive) before any write operation to the CICR register. 0: Disable all interruptsexceptTopLevel Interrupt. 1: Enable Interrupts
Bit 3 =IAM:
Interrupt Arbitration Mode
. This bit is set and clearedby software to select the arbitration mode. 0: Concurrent Mode 1: Nested Mode.
Bit 2:0 = CPL[2:0]:
Current Priority Level
. These three bits record the priority level ofthe rou­tine currently running (i.e. the Current PriorityLev­el, CPL). The highest priority level is represented by 000, and the lowest by 111. The CPL bits can be set by hardware or software and provide the reference according to which subsequent inter­rupts are either left pending or are allowedto inter­rupt the current interrupt service routine.When the current interrupt is replaced by one of a higher pri­ority, the current priority value is automatically stored until required in the NICR register.
R239 (EFh) SSPLR R238 (EEh) SSPHR R237 (EDh) USPLR R236 (ECh) USPHR R235 (EBh) MODE REGISTER R234 (EAh) PAGE POINTER REGISTER R233 (E9h) REGISTER POINTER 1 R232 (E8h) REGISTER POINTER 0 R231 (E7h) FLAG REGISTER R230 (E6h) CENTRAL INT. CNTL REG R229 (E5h) PORT5 DATA REG. R228 (E4h) PORT4 DATA REG. R227 (E3h) PORT3 DATA REG. R226 (E2h) PORT2 DATA REG. R225 (E1h) PORT1 DATA REG. R224 (E0h) PORT0 DATA REG.
70
GCE
N
TLIP TLI IEN IAM CPL2 CPL1 CPL0
9
22/190
ST90158 - DEVICE ARCHITECTURE
SYSTEM REGISTERS (Cont’d)
2.3.2 Flag Register
The Flag Register contains 8 flags which indicate the CPU status. During an interrupt, theflag regis­ter isautomatically stored in the system stack area and recalled at the end of the interrupt service rou­tine, thus returning the CPU to its original status.
This occurs for all interrupts and, when operating in nested mode, up to seven versions of the flag register may be stored.
FLAG REGISTER (FLAGR)
R231- Read/Write Register Group: E (System) Reset value: 0000 0000 (00h)
Bit 7 = C:
Carry Flag
.
The carry flag is affected by:
Addition (add, addw, adc, adcw), Subtraction (sub, subw, sbc, sbcw), Compare (cp, cpw), Shift Right Arithmetic (sra, sraw), Shift Left Arithmetic (sla, slaw), Swap Nibbles (swap), Rotate (rrc, rrcw, rlc, rlcw, ror, rol), Decimal Adjust (da), Multiply and Divide (mul, div, divws).
When set, it generally indicates a carry out of the most significant bit position of the register being used as an accumulator (bit 7 for byte operations and bit 15 for word operations).
The carry flag can be set by the Set Carry Flag (scf) instruction, cleared by the Reset Carry Flag (rcf) instruction, and complemented by the Com­plement Carry Flag (ccf) instruction.
Bit 6 = Z:
Zero Flag
. The Zero flag is affected by: Addition (add, addw, adc, adcw), Subtraction (sub, subw, sbc, sbcw), Compare (cp, cpw), Shift Right Arithmetic (sra, sraw), Shift Left Arithmetic (sla, slaw), Swap Nibbles (swap), Rotate (rrc, rrcw, rlc, rlcw, ror, rol), Decimal Adjust (da), Multiply and Divide (mul, div, divws), Logical (and, andw, or, orw, xor, xorw, cpl), Increment and Decrement (inc, incw, dec,
decw),
Test (tm, tmw, tcm, tcmw, btset). Inmostcases,theZeroflagissetwhenthecontents
of the register being used as an accumulator be­come zero, following one of the above operations.
Bit 5 =S:
Sign Flag
. The Sign flag is affected by the same instructions as the Zero flag.
The Sign flag is set when bit 7 (for a byte opera­tion) or bit 15 (for a word operation) of the register used as an accumulator is one.
Bit 4 =V:
Overflow Flag
. The Overflow flag is affected by the same instruc­tions as the Zero and Sign flags.
When set, the Overflowflag indicates that a two’s­complement number, in a result register, is in er­ror, since it has exceeded the largest (or is less than the smallest), number that can be represent­ed in two’s-complement notation.
Bit 3 =DA:
Decimal Adjust Flag
. The DA flag is used for BCDarithmetic. Since the algorithm for correcting BCD operations is differ­ent for addition and subtraction, this flag is used to specify which type of instruction was executed last, so that the subsequent Decimal Adjust (da) operation can perform its function correctly. The DA flag cannot normally be used as a test condi­tion by the programmer.
Bit 2 =H:
Half Carry Flag.
The H flag indicates a carry out of(or a borrow in­to) bit 3, as the result of adding or subtracting two 8-bit bytes, each representing two BCD digits. The H flag is used by the Decimal Adjust (da) instruc­tion to convert the binary result of a previous addi­tion orsubtraction into the correct BCDresult. Like the DA flag, this flag is not normally accessed by the user.
Bit 1 = Reserved bit (must be 0).
Bit 0 =DP:
Data/Program Memory Flag
. This bit indicates the memory area addressed. Its value is affected by the Set Data Memory (sdm) and Set Program Memory (spm) instructions. Re- fer tothe Memory Management Unit for further de­tails.
70
C Z S V DA H - DP
9
23/190
ST90158 - DEVICE ARCHITECTURE
SYSTEM REGISTERS (Cont’d)
If the bit is set, data is accessed using the Data Pointers (DPRs registers), otherwise it is pointed to by the Code Pointer (CSR register); therefore, the user initialization routine must include a Sdm instruction. Note that code is always pointed to by the Code Pointer (CSR).
Note: In the ST9+, the DP flag is only for compat­ibility with software developed for the first genera­tion of ST9 devices. With the single memory ad­dressing space, its use is now redundant. It must be kept to 1 with a Sdm instruction at the beginning of the program to ensure anormal use of the differ­ent memory pointers.
2.3.3 Register Pointing Techniques
Two registers within the System register group, are usedas pointers to theworking registers. Reg­ister Pointer0 (R232) maybe used on its ownas a single pointer to a 16-register working space, or in conjunction with Register Pointer 1 (R233), to point to two separate 8-register spaces.
For thepurpose of register pointing,the 16 register groups of the register file are subdivided into 32 8­register blocks. The values specified with the Set Register Pointer instructions refer to the blocks to be pointedto in twin 8-register mode, or tothe low­er 8-register block location in single 16-register mode.
The Set Register Pointer instructions srp, srp0 and srp1 automatically inform the CPU whether the Register File is to operate in single 16-register mode or in twin 8-register mode. The srp instruc­tion selects the single 16-register groupmode and
specifies the location of the lower 8-register block, while thesrp0 and srp1 instructions automatical­ly select the twin 8-register group mode and spec­ify the locations of each 8-register block.
There is no limitation on the order or position of these register groups, other than that they must start on an 8-register boundary in twin 8-register mode, or on a 16-register boundary in single 16­register mode.
The block number should always be an even number in single 16-register mode. The 16-regis­ter group will always start at the block whose number is the nearest even number equal to or lower than the block number specified in the srp instruction. Avoid using odd block numbers, since this can be confusing if twin mode is subsequently selected.
Thus: srp #3 will be interpreted as srp #2 and will al-
low using R16 ..R31 as r0 .. r15. In single 16-register mode, the working registers
are referred to as r0 to r15. In twin 8-register mode, registers r0 tor7 are in the block pointed to by RP0 (by means of the srp0 instruction), while registers r8 to r15 are in the block pointed to by RP1 (bymeans of the srp1 instruction).
Caution:
Group D registers can only be accessed as working registers using the Register Pointers, or bymeans of the StackPointers. Theycannot be addressed explicitly in the form “Rxxx”.
9
24/190
ST90158 - DEVICE ARCHITECTURE
SYSTEM REGISTERS (Cont’d) POINTER 0 REGISTER (RP0)
R232 - Read/Write Register Group: E (System) Reset Value: xxxx xx00 (xxh)
Bit 7:3 = RG[4:0]:
Register Group number.
These bits contain the number (in the range 0 to
31) of the register block specified in the srp0 or srp instructions. In single 16-register mode the number indicates the lower of the two 8-register blocks to which the16 working registers are to be mapped, whilein twin 8-register mode it indicates the 8-register block to which r0 to r7 are to be mapped.
Bit 2 = RPS:
Register Pointer Selector
. This bitis set bythe instructions srp0 andsrp1 to indicate that the twin register pointing mode is se­lected. The bit is reset by the srp instruction to in­dicate that the single register pointing mode is se­lected. 0: Single register pointing mode 1: Twin register pointing mode
Bit 1:0: Reserved. Forced by hardware to zero.
POINTER 1 REGISTER (RP1)
R233 - Read/Write Register Group: E (System) Reset Value: xxxx xx00(xxh)
This register is only used inthe twin register point­ing mode. When using the single register pointing mode, or when using only one of the twin register groups, the RP1 register must be considered as RESERVED and may NOT be used as a general purpose register.
Bit 7:3 = RG[4:0]:
Register Group number.
These bits contain the number (in the range 0 to 31) of the 8-register block specified inthe srp1 instruc­tion, to which r8 to r15 are to be mapped.
Bit 2 =RPS:
Register Pointer Selector
. This bit isset by thesrp0 and srp1 instructions to indicate that the twin register pointing mode is se­lected. Thebit is reset by the srp instruction to in­dicate that the single register pointing mode is se­lected. 0: Single register pointing mode 1: Twin register pointing mode
Bit 1:0: Reserved. Forced by hardware to zero.
70
RG4 RG3 RG2 RG1 RG0 RPS 0 0
70
RG4 RG3 RG2 RG1 RG0 RPS 0 0
9
25/190
ST90158 - DEVICE ARCHITECTURE
SYSTEM REGISTERS (Cont’d) Figure 9. Pointing to a single group of 16
registers
Figure 10.Pointing to two groups of 8 registers
31
30
29
28
27
26
25
9
8
7
6
5
4
3
2
1
0
F
E
D
4
3
2
1
0
BLOCK
NUMBER
REGISTER
GROUP
REGISTER
FILE
REGISTER
POINTER 0
srp #2
set by:
instruction
points to:
GROUP 1
addressed by
BLOCK 2
r15
r0
31
30
29
28
27
26
25
9
8
7
6
5
4
3
2
1
0
F
E
D
4
3
2
1
0
BLOCK
NUMBER
REGISTER
GROUP
REGISTER
FILE
REGISTER POINTER 0
srp0 #2
set by:
instructions
point to:
GROUP 1
addressed by
BLOCK 2
&
REGISTER
POINTER 1
srp1 #7
&
GROUP 3
addressed by
BLOCK 7
r7
r0
r15
r8
9
26/190
ST90158 - DEVICE ARCHITECTURE
SYSTEM REGISTERS (Cont’d)
2.3.4 Paged Registers
Up to 64 pages, each containing 16 registers, may be mapped to Group F. These paged registers hold data and control information relating to the on-chip peripherals, each peripheral always being associated with the same pages and registers to ensure code compatibility between ST9+ devices. The number of these registers dependson thepe­ripherals presentin the specific ST9 device. In oth­er words, pagesonly exist if the relevant peripher­al is present.
The paged registers are addressed using thenor­mal register addressingmodes, inconjunction with the Page Pointer register, R234, which is one of the System registers. This register selects the page to be mapped to Group F and, once set, does not need to be changedif two or more regis­ters on the same pageare to be addressed in suc­cession.
Thus the instructions:
spp #5 ld R242, r4
will load the contents of working register r4 into the third register of page 5 (R242).
Warning:
During an interrupt, the PPR register is not saved automatically in the stack. If needed, it should be saved/restored by the user within thein­terrupt routine.
PAGE POINTER REGISTER (PPR)
R234 - Read/Write Register Group: E (System) Reset value: xxxx xx00 (xxh)
Bit 7:2 = PP[5:0]:
Page Pointer
.
These bits contain the number (in the range 0 to
63) of the page specified in the spp instruction. Once the page pointer has been set, there is no need to refresh it unless a different page is re­quired.
Bit 1:0: Reserved. Forced by hardware to 0.
2.3.5 Mode Register
The Mode Register allows control of the following operating parameters:
– Selectionof internalor external Systemand User
Stack areas, – Management of the clock frequency, – Enabling of Bus request and Wait signals when
interfacing to external memory.
MODE REGISTER (MODER)
R235 - Read/Write Register Group: E (System) Reset value: 1110 0000 (E0h)
Bit 7 =SSP:
System Stack Pointer
. This bit selects an internal or external System Stack area. 0: External system stack area, in memory space. 1: Internal system stack area, in the Register File
(reset state).
Bit 6 =USP:
User Stack Pointer
. This bit selects an internal or external User Stack area. 0: External user stack area, in memory space. 1: Internaluser stack area,in the Register File (re-
set state).
Bit 5 =DIV2:
OSCIN Clock Divided by 2
. This bit controls the divide-by-2 circuit operating on OSCIN. 0: Clock divided by 1 1: Clock divided by 2
Bit 4:2 = PRS[2:0]:
CPUCLK Prescaler
. These bitsload the prescaler division factor for the internal clock (INTCLK). The prescaler factor se­lects theinternal clock frequency, which can be di­vided by a factor from 1 to 8. Refer to the Reset and Clock Control chapterfor further information.
Bit 1 =BRQEN:
Bus Request Enable
. 0: External Memory Bus Request disabled 1: External Memory Bus Request enabled on the
BREQ pin (where available).
Bit 0 =HIMP:
High Impedance Enable
. When any of Ports 0, 1, 2 or 6 depending on de­vice configuration, are programmed as Address and Data lines to interface external Memory, these lines and the Memory interface control lines (AS,
70
PP5 PP4 PP3 PP2 PP1 PP0 0 0
70
SSP USP DIV2 PRS2 PRS1 PRS0 BRQEN HIMP
9
27/190
ST90158 - DEVICE ARCHITECTURE
SYSTEM REGISTERS (Cont’d)
DS, R/W) can be forced into the High Impedance state bysetting the HIMP bit. When this bitis reset, it has no effect.
Setting the HIMPbit is recommended fornoise re­duction when only internal Memory is used.
If Port 1 and/or 2 are declared as an address AND as an I/O port (for example: P10... P14 = Address, and P15... P17 = I/O), the HIMP bit has no effect on the I/O lines.
2.3.6 Stack Pointers
Two separate, double-register stack pointers are available: the System Stack Pointer and the User Stack Pointer, both of which can address registers or memory.
The stack pointers point to the “bottom” of the stacks which are filled using the push commands and emptied using the pop commands. The stack pointer is automatically pre-decremented when data is “pushed” in and post-incremented when data is “popped” out.
The push and pop commands usedto manage the System Stack may be addressed to the User Stack by adding the suffix “u”. To use a stackin­struction for a word, the suffix “w” is added. These suffixes may be combined.
When bytes (or words) are “popped” out from a stack, the contents of the stack locations are un­changed until fresh data is loaded. Thus, when data is “popped” from a stack area, the stack con­tents remain unchanged.
Note: Instructions such as: pushuw RR236 or pushw RR238, as well as the corresponding pop instructions (where R236 & R237, and R238
& R239 are themselves theuser and systemstack pointers respectively), mustnot be used, since the pointer values are themselves automatically changed by the push or pop instruction, thus cor­rupting their value.
System Stack
The System Stack is used for the temporary stor­age of system and/or control data, such as the Flag register and the Program counter.
The following automatically push data onto the System Stack:
Interrupts When entering an interrupt, the PC and the Flag
Register are pushed onto the System Stack. If the ENCSR bit in the EMR2 register is set, then the
Code Segment Register is also pushed onto the System Stack.
Subroutine Calls When a call instruction is executed, only the PC
is pushed onto stack, whereas when a calls in­struction (call segment) is executed, both the PC and the Code Segment Register are pushed onto the System Stack.
Link Instruction The link or linku instructions create a C lan-
guage stack frame of user-defined length in the System or User Stack.
All of the above conditions are associated with their counterparts, such as return instructions, which pop the stored data items off the stack.
User Stack
The User Stack provides a totally user-controlled stacking area.
The User Stack Pointer consists of two registers, R236 and R237, whichare both used for address­ing a stack in memory. When stacking in the Reg­ister File, the User Stack Pointer High Register, R236, becomes redundant but must be consid­ered as reserved.
Stack Pointers
Both System and User stacks are pointed to by double-byte stack pointers. Stacks may be set up in RAM or in the Register File. Only the lower byte will be required if the stack is in the Register File. The upper byte must then be considered as re­served and mustnot be used asa general purpose register.
The stack pointer registers are located in the Sys­tem Group ofthe Register File, thisis illustratedin Table 4.
Stack location
Care is necessary whenmanaging stacks as there is no limit to stack sizes apart from the bottom of any address space in which the stack is placed. Consequently programmers are advised to use a stack pointer value as high as possible, particular­ly when using the RegisterFile as astacking area.
Group D is a good location for a stack in the Reg­ister File,since it is the highest availablearea. The stacks may be located anywhere in the first 14 groups of the Register File (internal stacks) or in RAM (external stacks).
Note. Stacks must not be located in the Paged Register Group or in theSystem Register Group.
9
28/190
ST90158 - DEVICE ARCHITECTURE
SYSTEM REGISTERS (Cont’d) USER STACK POINTER HIGH REGISTER
(USPHR)
R236 - Read/Write Register Group: E (System) Reset value: undefined
USER STACK POINTER LOW REGISTER (USPLR)
R237 - Read/Write Register Group: E (System) Reset value: undefined
Figure 11. Internal Stack Mode
SYSTEM STACK POINTER HIGH REGISTER (SSPHR)
R238 - Read/Write Register Group: E (System) Reset value: undefined
SYSTEM STACK POINTER LOW REGISTER (SSPLR)
R239 - Read/Write Register Group: E (System) Reset value: undefined
Figure 12. External Stack Mode
70
USP15USP14USP13USP12USP11USP1
0
USP9 USP8
70
USP7 USP6 USP5 USP4 USP3 USP2 USP1 USP0
F
E
D
4
3
2
1
0
REGISTER
FILE
STACKPOINTER (LOW)
points to:
STACK
70
SSP15SSP14SSP13SSP12SSP11SSP1
0
SSP9 SSP8
70
SSP7 SSP6 SSP5 SSP4 SSP3 SSP2 SSP1 SSP0
F
E
D
4
3
2
1
0
REGISTER
FILE
STACK POINTER (LOW)
point to:
STACK
MEMORY
STACKPOINTER (HIGH)
&
9
29/190
ST90158 - DEVICE ARCHITECTURE
2.4 MEMORY ORGANIZATION
Code and data are accessed within thesame line­ar address space. All of the physically separate memory areas, including the internal ROM, inter­nal RAM and external memory are mapped in a common address space.
The ST9+ provides a total addressable memory space of 4 Mbytes. This address space is ar­ranged as 64 segments of 64 Kbytes; each seg­ment isagain subdividedinto four 16Kbyte pages.
The mapping of the various memory areas (inter­nal RAM or ROM, external memory) differs from device to device. Each 64-Kbyte physical memory segment is mapped either internally or externally; if the memory is internal and smaller than 64 Kbytes, the remaining locations in the 64-Kbyte segment are not used (reserved).
Refer to the Register and Memory Map Chapter for more details on the memory map.
9
30/190
ST90158 - DEVICE ARCHITECTURE
2.5 MEMORY MANAGEMENT UNIT
The CPU Core includes a Memory Management Unit (MMU) which must be programmed to per­form memory accesses (even if external memory is not used).
The MMU is controlled by 7 registers and 2 bits (ENCSR and DPRREM) present in EMR2, which may be written and read by the user program. These registers are mapped within group F, Page 21 of the Register File. The 7 registers may be
sub-divided into 2main groups: a first group of four 8-bit registers (DPR[3:0]), and a second group of three 6-bitregisters (CSR,ISR, and DMASR). The first group is used to extend the address during Data Memory access (DPR[3:0]). The second is used to manage Program and Data Memory ac­cesses during Code execution (CSR), Interrupts Service Routines (ISR or CSR), and DMA trans­fers (DMASR or ISR).
Figure 13. Page 21 Registers
DMASR ISR
EMR2 EMR1 CSR DPR3 DPR2 DPR1 DPR0
R255 R254 R253 R252 R251 R250 R249 R248 R247 R246 R245 R244 R243 R242 R241 R240
FFh FEh FDh FCh FBh FAh F9h F8h F7h F6h F5h F4h F3h F2h F1h F0h
MMU
EM
Page 21
MMU
MMU
Bit DPRREM=0
SSPLR SSPHR USPLR USPHR
MODER
PPR
RP1 RP0
FLAGR
CICR P5DR P4DR P3DR P2DR P1DR P0DR
DMASR
ISR
EMR2 EMR1
CSR DPR3 DPR2
1
DPR0
Bit DPRREM=1
SSPLR SSPHR USPLR USPHR
MODER
PPR RP1 RP0
FLAGR
CICR P5DR P4DR
P3DR P2DR P1DR P0DR
DMASR
ISR
EMR2 EMR1
CSR DPR3 DPR2 DPR1 DPR0
Relocation of P[3:0] and DPR[3:0] Registers
(default setting)
9
+ 160 hidden pages