P6.0 - P6.71 - 8I/O 8-bit bidirectional I/O port, bit-wise programmable for input or output viadirection bit.
Programming an I/O pin as input forces the corresponding output driver to high
impedance state. Port 6 outputs can be configured as push-pull or open drain
drivers. The following Port 6 pins have alternate functions:
39IP5.10T6EUDGPT2 TimerT6 External Up / Down Control Input
40IP5.11T5EUDGPT2 TimerT5 External Up / Down Control Input
41IP5.12T6INGPT2 Timer T6 Count Input
42IP5.13T5INGPT2 Timer T5 Count Input
43IP5.14T4EUDGPT1 TimerT4 External Up / Down Control Input
44IP5.15T2EUDGPT1 TimerT2 External Up / Down Control Input
Programming an I/O pin as input forces the corresponding output driver to high
impedance state. Port 8 outputs can be configured as push-pull or open drain
drivers. The input threshold of Port 8 is selectable (TTL or special).
The following Port 8 pins have alternate functions:
Programming an I/O pin as input forces the corresponding output driver to high
impedance state. Port 7 outputs can be configured as push-pull or open drain
drivers. The input threshold of Port 7 is selectable (TTL or special).
The following Port 7 pins have alternate functions:
II16-bit input-only port with Schmitt-Trigger characteristics. The pins of Port 5 can be
the analog input channels (up to 16) for the A/D converter, where P5.x equals ANx
(Analog input channel x), or they are timer inputs:
I/O 16-bit bidirectional I/O port, bit-wise programmable for input or output via direction
bit. Programming an I/O pin as input forces the corresponding output driver to high
impedance state. Port 2 outputs can be configured as push-pull or open drain
drivers. The input threshold of Port 2 is selectable (TTL or special).
The following Port 2 pins have alternate functions:
15-bit (P3.14 is missing) bidirectional I/O port, bit-wise programmable for input or
I/O
output via direction bit. Programming an I/O pin as input forces the corresponding
I/O
output driver to high impedance state. Port 3 outputs can be configured as push-pull
or open drain drivers. The input threshold of Port 3 is selectable (TTL or special).
The following Port 3 pins have alternate functions:
WRHExternal Memory High Byte Write Strobe
7/76
ST10F168
Table 1 : Pin Description (continued)
SymbolPinTypeFunction
P4.0 - P4.785-92I/O 8-bit bidirectional I/O port, bit-wise programmable for input or output via direction bit.
Programming an I/O pin as input forces the corresponding output driver to high
impedance state. For external bus configuration, Port 4 can be used to output the
segment address lines:
85-89OP4.0-P4.4 A16-A20Segment Address Line
90OP4.5A21Segment Address Line
ICAN_RxDCAN Receiver Data Input
91OP4.6A22Segment Address Line
OCAN_TxDCAN Transmitter Data Output
92OP4.7A23Most Significant Segment Addrress Line
RD95OExternal Memory Read Strobe. RD is activated for every external instruction or data
WR/WRL96OExternal Memory Write Strobe. In WR-mode this pin is activated for every external
READY/
READY
ALE98OAddress Latch Enable Output. In case of use of external addressing or of multi-
EA99IExternal Access Enable pin. A low level at this pin during and after Reset forces the
P0L.0 - P0L.7
P0H.0
P0H.1 - P0H.7
97IReady Input. The active level is programmable. When the Ready function is
100 - 107,
108,
111 - 117
read access.
data write access. In WRL mode this pin is activated for low Byte data write
accesses on a 16-bit bus, and for every data write access on an 8-bit bus. See
WRCFG in the SYSCON register for mode selection.
enabled, the selected inactive level at this pin, during an external memory access,
will force the insertion of wait state cycles until the pin returns to the selected active
level.
plexed mode, this signal is the latch command of the address lines.
ST10F168 to start the program in internal memory space. A high level forces the
ST10F168 to start in the external memory space.
I/O Two 8-bit bidirectional I/O ports P0L and P0H, bit-wise programmable for input or
output via direction bit. Programming an I/O pin as input forces the corresponding
output driver to high impedance state.
In case of an external bus configuration, Port0 serves as the address (A) and as the
address / data (AD)bus in multiplexed bus modes and as the data (D) bus in demultiplexed bus modes.
I/O Two 8-bit bidirectional I/O ports P1L and P1H, bit-wise programmable for input or
output via direction bit. Programming an I/O pin as input forces the corresponding
output driver to high impedance state. Port1 is used as the 16-bit address bus (A) in
demultiplexed bus modes and also after switching from a demultiplexed bus mode
to a multiplexed bus mode.
The following Port1 pins have alternate functions:
132IP1H.4CC24IOCAPCOM2: CC24 Capture Input
133IP1H.5CC25IOCAPCOM2: CC25 Capture Input
134IP1H.6CC26IOCAPCOM2: CC26 Capture Input
135IP1H.7CC27IOCAPCOM2: CC27 Capture Input
It is used also as the timing pin for the return from interruptible powerdown mode.
V
DD
17,46,
56,72,
82,93,
109, 126,
Digital Supply Voltage:
= + 5V during normal operation and idle mode.
> 2.5V during power down mode.
136, 144
V
SS
18,45,
55,71,
83,94,
Digital Ground.
110, 127,
139, 143
9/76
ST10F168
3 - FUNCTIONAL DESCRIPTION
The architecture of the ST10F168 combines
advantages of both RISC and CISC processors
and an advanced peripheral subsystem.
Figure 3 : Block Diagram
256KByte
Flash
memory
32
The block diagram gives an overview of the
different on-chip components and the high
bandwidth internal bus structure of the ST10F168.
16
CPU-Core
16
Internal
RAM
CAN_RxD P4.5
CAN_TxDP4.6
6K Byte
XRAM
CAN
16
16
8
Port0Port1Port4
Port 6
8
Controller
ExternalBus
16
10-BitADC
Port 5
16
16
Interrupt Controller
GPT1
GPT2
BRG
Port 3
PEC
16
ASCusart
1588
SSC
BRG
PWM
CAPCOM2
Port7
Watchdog
OSC.
+PLL
CAPCOM1
Port 8
Port2
XTAL1
XTAL2
16
10/76
4 - MEMORY ORGANIZATION
The memory space of the ST10F168 is configured
in a Von Neumann architecture. Code memory,
data memory, registers and I/O ports are organized within the same linear address space of
16M Byte. The entire memory space can be
accessed bytewise or wordwise. Particular portions of the on-chip memory have additionally
been made directly bit addressable.
FLASH: 256K Byte of on-chip Flash memory. See
Flash Memory
on page13
IRAM:2K Byteofon-chip internal RAM
(dual-port) is provided as a storage for data, system stack, general purpose register banks and
code. A register bank is 16 wordwide (R0 to R15)
and / or bytewide (RL0, RH0, …, RL7, RH7) general purpose registers.
XRAM: 6K Byte of on-chip extension RAM (single
port XRAM) is provided asa storage for data, user
stack and code. The XRAM is connected to the
internal XBUS and is accessed like an external
memory in16-bit demultiplexed bus-mode without
wait state or read / write delay (80ns access at
25MHz CPU clock). Byte and Word access are
allowed.
The XRAMaddress range is 00’D000h 00’E7FFh if the XRAM is enabled (XPEN bit 2 of
SYSCON register). As the XRAM appears like
external memory, it cannot be used for the
ST10F168’s system stack or register banks. The
XRAM is not provided for single bit storage and
ST10F168
therefore is not bit addressable. If bit XPEN is
cleared, then any access in the address range
00’D000h - 00’E7FFh will be directed to external
memory interface, using the BUSCONx register
corresponding to address matching ADDRSELx
register.
SFR/ESFR: 1024 Byte (2 x 512 Byte) of address
space is reserved for the Special Function Register areas. SFRs are wordwide registers which are
used for controlling and monitoring functions of
the different on-chip units.
CAN: Address range 00’EF00h - 00’EFFFh is
reserved for the CAN Module access. The CAN is
enabled by setting XPEN bit 2 of the SYSCON
register. Accesses to the CANModule use demultiplexed addresses and a 16-bit data bus (Byte
accesses are possible). Two wait states give an
access time of 160ns at 25MHz CPU clock. No
tristate wait state is used.
Note If the CAN module is used, Port 4 can not
be programmed to output all 8 segment
address lines. Therefore, only 4 segment
address lines can be used, reducing the
external memory space to 5M Byte (1M
Byte per CS line)
To meet the needs of designs where more memory is requiredthan is provided on chip, up to 16M
Byte of external RAM and / or ROM can be connected to the microcontroller.
RAM, SFR and X-pheripherals are
mapped into the address space.
SYSCON.XPEN=1enables CAN
and XRAM (before EINIT)
0x0’FFFF
SFR Area
0x0’FE00
0x0’FDFF
IRAM : 2K Byte
0x0’F600
0x0’EFFF
CAN Module
0x0’EF00
0x020x0’8000
0x0’7FFF
0x0’40000x01
0x0’3FFF
0x00
Data
Page
Number
0x0’0000
Absolut
Memory
Address
Bank 1L : 16K Byte
Bank 0 : 16K Byte
0x0’E7FF
XRAM : 6K Byte
0x0’D000
* Bank 0 and Bank 1 L may be remapped from segment 0
to segment 1 by setting SYSCON.ROMS1 (before EINIT)
12/76
5 - FLASH MEMORY
The ST10F168 provides 256K Byte of an
electrically erasable and reprogrammable Flash
Memory on-chip.
The Flash Memory can be used both forcode and
data storage. It is organized into four 32-bit wide
blocks allowing even double Word instructions to
be fetched in one machine cycle. The four blocks
of size16K, 48K,96K and 96KByte can be erased
and reprogrammed individually (see Table 2 and
Table 3).
The Flash Memory can be programmed in a programming board or in the target system which
provides high system flexibility. The algorithms to
program or erase the flash memory are embedded in the Flash Memory itself (ST Embedded
Algorithm Kernel, or STEAKTM).
To start a program / erase operation, the user’s
software has just to load GPRs with the address
and data to be programmed, or sector to be
erased. STEAK uses embedded routines, which
ST10F168
check the validity of the programmed parameters,
decode and then execute the programming or
erase command. During operation, the STEAK
routines carry out checks and retries to verify
proper cell programming or erasing. When an
error occurs, STEAK returns an error-code which
identifies the cause of the error.
A Flash Memory protection option prevents the
read-back of the Flash Memory contents from
external memory, or from on-chip RAM. Code
operation from within the Flash continues as normal.
The first bank (16K Byte) and part of the second
bank (16K Byte out of 48K Byte) of the on-chip
Flash Memory of the ST10F168 can be mapped
to either segment 0 (addresses 00000h to
07FFFh) or to segment 1 (addresses 10000h to
17FFFh) during the initialization phase. External
memory can be used for additional system
flexibility.
VDD=5V±10%, VPP=12V ± 5%, VSS=0V,f
= 25MHz, for Q6 version : TA=-40, +85°C and for Q2
CPU
version TA = -40, +125°C.
Table 2 : Flash Memory Characteristics
SymbolParameterTest ConditionsMin.Typ.Max.Unit
CPU Frequency during
CPU
erasing / programming operation
= 25MHz
Erasing /Programming Cycles
Single Word Programming Time
Double Word Programming Time
Sector Erasing Time
Data Retention TimeDefectivity below 1ppm / year
RET
1. Typical value for a non cycled flash. Maximum value is a software limit put inside STEAK. Can be changed after flash
characterization by STMicroelectronics.
010000h to 013FFFh
014000h to 01FFFFh
020000h to 03FFFFh
038000h to 04FFFFh
16K
48K
96K
96K
µs
µs
s
13/76
ST10F168
5.1 - Programming / Erasing with ST
Embedded Algorithm Kernel
There are three stages to run STEAK :
– To load the registers R0 to R4 with the STEAK
command, the address and the data to be programed, or sector to be erased. Table 4 gives
the STEAK parameters for each type of Flash
programming / erasing operation. Table 5 defines the codes used in Table 4.
– To initiatethe Unlock Sequence.The Unlock Se-
quence is composed of two consecutive writes
to an even address in the Flash active address
space - the first write has direct addressing
mode (MOV mem, Rwn) - the second write has
– To read the return values in R0. When the em-
bedded programming / erasing algorithm returns to trigger point, return values are given in
R0. Table 6 gives the error-code definitions,
Table 7 gives the return values in each register
for each type of Flash programming / erasing
command.
Note The Flash Embedded STEAK Algorithms
require at least 50 words on the Internal
System Stack. STEAK verifies that there is
enough free space on the System Stack,
before performing a programming or erasing operation.The MDH, MDL and MDC
register content are modified.
indirect addressing mode (MOV [Rwm], Rwn).
Rwn can be any unused Word-GPR (R6to R15)
loaded with a value resulting in the same even
address as “mem”.
Code examples for programming and erasing the
Flash Memory using STEAK are given in
Section 5.2.
Table 4 : STEAK parameters
CommandR0R1R2R3R4
Single Word programming55AshAddOffWnu2TCL
Double Word programmingDD4shAddOffDWLDWH2TCL
Multiple (block) programmingAA5shBegAddOffEndAddOffSourceAddr2TCL
Sector ErasingEEEEh5555hBnkBnk2TCL
Read Status7777hnununu2TCL
Table 5 : Programming / erasing code definition
sSegment of the Target Flash Memory cell,
AddOffSegment Offset of the Target Flash Memory cell. Must be even value (Word-aligned address).
WData (Word) to be written in Flash.
DWL,DWH Data (double Word, DHL = low Word, DWH = high Word) to be written in Flash.
BegAddOff
EndAddOff
SourceAdd
BnkNumber of the Bank to be erased. For security, R2 and R3 must hold the same value.
2TCLCPU clock period innano-seconds (eg. R4 = 50d means CPU frequency is 20MHz).
Segment Offset of the FIRST Target Flash Memory Word to be written in a Multiple programming
command. Must be even value (Word-aligned address).
Segment Offset of the LAST Target Flash Memory Word to be written in a Multiple programming
command.
Must be even value (Word-aligned address). The value D = (EndAddOff - BegAddOff) must be: 0 <= D <
16384 (ie. up to one page (16K Byte) can be written in the flash with one multi-Word programming
command).
Start address for the block to be programmed.
This address is using implicitly the data paging mechanism of the CPU. SourceAdd value must respect
the following rules :
- SourceAdd + (EndAddOff - BegAddOff) < 16384.
- Page 0 and 1can NOT be used for source data if bit ROMS1 = ‘1’ (in SYSCON register).
Note that source data can be located in Flash (In pages 0, 1, 6 to 19 if bit ROMS1 = ‘0’, or in pages 4 to19
00hOperation was successful
01hFlash Protection is active
02hVpp voltage not present
03hProgramming operation failed
04hAddress value (R1) incorrect: not in Flash address area or odd
05hCPU period out of range (must be between 30 ns to 500 ns)
06hNot enough free space on system stack for proper operation
07hIncorrect bank number (R2,R3) specified
08hErase operation failed (phase 1)
09hBad source address for Multiple Word programming command
0AhBad number of words to be copied in Multiple Word programming command: one destination will be
out of flash.
0BhPLL Unlocked or Oscillator watchdog overflow occured during programming or erasing the flash.
0ChErase operation failed (phase 2)
FFhUnknown or bad command
ST10F168
Table 7 : Return values for each programming / erase command
Programming
Command
Single or
double Word
programming
Block
programming
ErasingError
After status
read
Note The Flash Embedded STEAK Algorithms
require at least 50 words on the Internal
System Stack for proper operation. The
program itself verifies that there is enough
free space on the System Stack before
performing a programming or erasing
operation, by computing the Word number
between Stack Pointer (SP) and Stack
Overflow register (STKOV ).
The MDH, MDL and MDC register content
are modified.
Registers R0 to R4 are used as Input Data
for STEAK, and are modified as explained
R0R1R2R3R4-R15
Error
code
Error
The last segment offset address of the
code
last written Word in Flash (failing Flash
address if R0 is not equal to zero)
code
Error
Flash embedded rev
code
MSByte = major release
LSByte = minor revision
UnchangedData in Flash for
location Segment +
SegmentOffset
(R0.[3:0] with R1)
UndefinedUnchanged
UndefinedUnchanged
Circuit identifiers :
R2 = #0787h
R3 = #0101h for this device
above (Return Values).
Registers R5 to R15 are used internally by
STEAK, but preserved on entry and
restore on exit of STEAK.
IT IS VERY IMPORTANT TO TAKE INTO
ACCOUNT THE FACT THAT STEAK
USES UP TO 50 WORDS ON THE SYSTEMSTACK.TOPREVENTANY
ABNORMAL SITUATION, IT IS VERY
IMPORTANTTOINITIALIZECORRECTLY THE STACKSIZE TO AT LEAST
64 WORDS, AND TO CORRECTLY INITIALIZE REGISTER STKOV.
Data in Flash for
location Segment +
Segment Offset + 2
(R0[3:0] with R1+2)
Unchanged
Unchanged
15/76
ST10F168
5.2 - Programming Examples
Programming a double Word
; code shown below assumes that Flash is mapped in segment 1
; ie. bit ROMS1 = ‘1’ in SYSCON register
; Flash must be enabled, ie. bit ROMEN = ‘1’ in SYSCON.
MOVR0, #0DD40h; DD4xh : Double Word programming command
ORR0, #01h; Selects segment 1 in flash memory
MOVR1, #00224h; Address to be programmed is 01’0224h
MOVR2, #03456h; Data to be programmed at 01’0224h
MOVR3, #04567h; Data to be programmed at 01’0226h
MOVR4, #050d; 50ns is 20MHz CPU clock frequency
MOVR7, #08000h; R7 used for Flash trigger sequence
#define FCR 08000h
; Flash Unlock Sequence consists in two consecutive writes, with the direct
addressing mode and then the indirect addressing mode. FCR must represent an
even address in the active address space of the Flash memory, and Rwn can be
any unused Word GPR (R6 to R15)loaded with a value resulting in the same even
address than FCR
EXTS#1, #2; Flash can be mapped in segment 0 or 1
MOVFCR, R7; first part
MOV[R7], R7; second part
NOP; WARNING: place 2 NOP operations after
NOP; the Unlock sequence to avoid all possible
; pipeline conflicts in STEAK programs
Note For easier coding, the standard data paging addressing scheme is overriden for the two MOV
instructions of the Flash Trigger Sequence (EXTS instruction). However this coding also locks
both standard and PEC interrupts and class A hardware traps. This override can be replaced by
an ATOMIC instruction if thestandard DPP addressing scheme must be preserved.
16/76
ST10F168
Programming a block of data
The following code is provided as an example to program ablock of data. Flash to be programmed is from
address 01’9000h to 01’9FFEh (included). Source data (data to be copied into flash)is located in external
RAM from address 05’1000h (to 05’1FFEh, implicitly) :
; code shown below assumes that flash is mapped in segment 1
; ie. bit ROMS1 = ‘1’ in SYSCON register
; Flash must be enabled, ie. bit ROMEN = ‘1’ in SYSCON.
MOVR0, #0AA50h; AA5xh : Multi Word programming command
ORR0, #01h; Selects segment 1 in Flash memory
MOVR1, #09000h; First Flash Segment Offset Address
MOVR2, #09FFEh; Last Flash Segment Offset Address
MOVR3, #09000h; Source data address: use DPP2 as
; data page pointer
SCXTDPP2,#20d; Source is in page 20 (first page of
; segment 5): save previous DPP2 value
; and load it with source page number
MOVR4, #050d; 50ns is 20MHz CPU clock frequency
MOVR7, #08000h; R7 used for Flash trigger sequence
#define FCR 08000h
EXTS#1, #2; Flash can be mapped in segment 0 or 1
MOVFCR, R7; first part
MOV[R7], R7; second part
NOP; WARNING: place 2 NOP operations after
NOP; the Unlock sequence to avoid all possible
; pipeline conflicts in STEAK programs
POPDPP2; restore DPP2
17/76
ST10F168
5.3 - Flash Memory Configuration
Thedefaultmemoryconfigurationofthe
ST10F168 Memory is determined by the state of
the EA pin at reset. This value is stored in the
Internal ROM Enable bit : ROMEN of the
SYSCON Register.
When ROMEN = 0, the internal FLASH is disabled
and external ROM is used for startup control.
Flash memory can be enabled later by setting the
ROMEN bit of SYSCON to 1. Ensure that the
code which performs this setting is NOT running
from external ROM in a segment that will be
replaced by FLASH memory, otherwise unexpected behaviour may occur.
For example, if the external ROM code is located
in the first 32K Byte of segment 0, the first
32K Byte of the FLASH must then be enabled in
segment 1. This is done by setting the ROMS1 bit
of SYSCON to 0, before or simultaneously with
setting the ROMEN bit. This must be done in the
externally supplied program, before the execution
of the EINIT instruction. If program execution
starts from external memory, but the Flash memory mapped in segment 0 is accessed later, then
the code that sets the ROMEN bit must be executed either in segment 0 but above address
00’8000h, or from the internal RAM.
Bit ROMS1 only affects the mapping of the first
32K Byte of the Flash memory. All other parts of
theFlash memory(addresses01’8000h 04’FFFFh) remain unaffected.
Note: TheSGTDIS Segmentation Disable / Enable
must also be set to 0 to enable the use of the full
256K Byte of on-chip memory in addition to the
external boot memory. The correct procedure for
changing the segmentation registers must be
observed to prevent an unwanted trap condition :
– Instructions that configure the internal memory
must onlybe executed from external memoryor
from the internal RAM.
– AnAbsoluteInter-SegmentJump(JMPS)
instructionmust beexecuted after Flash enabling,
before the next instruction, even if the next
instruction is locatedin the consecutive address.
– Whenever the internalmemory is disabled, ena-
bled or remapped, the DPPs must be explicitly
(re)loaded to enable correct data accesses to
the internal memory and / or external memory.
5.4 - Flash Protection
If Flash Protection is active, data operands in the
on-chip Flash Memory area can only be read by a
program executed from the Flash Memory itself.
Program branches from or into the on-chip Flash
memory are possible in the Flash protection mode.
Erasing and programming of the Flash memory is
not possible as long as protection is active.
Flash protection is controlled by the Protection
UPROM Programming Bit (UPROG). UPROG is a
’hidden’ one-time programmable bit only accessible in a special mode which can be entered via a
Flash EPROM programming board for example. If
UPROG is set to ”1”, Flash protection is active
after reset. By default Flash Protection is disabled
(UPROG=0).
When flash protection is active (the default after
reset if UPROG bit is set), then any read accessin
the flash by a code executed from external or
internal RAM (IRAM or XRAM) will return the
value 0B88Bh. Any call of STEAK will return the
error code ‘01’ (Protected flash).
Normally Flash protection should never be deactivated, once activated. If this has to be done, for
example because the Flash memory has to be
reprogrammed with updated program / variables,
a zero value has to be written at any even address
in the active address space of the Flash memory.
This write can be done only by an instruction executed from the internal Flash Memory itself.
For example:
MOV FLASH,ZEROS ; Deactivate Flash
Protection.
; Flash is any even address in Flash
memory space. This instruction MUST
be executed from Flash memory itself.
After this instruction, the flash is temporarily
de-protected, thus any read access of the flash
from code executed from external memory or
internal RAMs will be correctly executed, and calls
of STEAK can be correctly performed (programming, erasing or status reading).
Notes 1. That all STEAK commands re-activate
the flash protection if bit UPROG is set
when completed.
2. Currently the only way to program the
UPROG one-time programmable bit is by
using an external ST10F167 / ST10F168
EPB kit.
5.5 - Bootstrap Leader Mode
Pin P0L.4 (BSL) activates the on-chip bootstrap
loader, when low during hardware reset. The
bootstrap loader allows moving the start code into
the internal RAM of the ST10F168 via the serial
interface ASC0. The ST10F168 will remain in
bootstrap loader mode until a hardware reset with
P0L.4 high or a software reset. The bootstraps
loader acknowledge byte is D5h.
18/76
6 - CENTRAL PROCESSING UNIT (CPU)
The CPU includes a4-stage instruction pipeline, a
16-bit arithmetic and logic unit (ALU) and dedicated SFRs. Additional hardware has been added
for a separate multiply and divide unit, a bit-mask
generator and a barrel shifter.
Most of the ST10F168’s instructions can be executed in one instruction cycle which requires 80ns
at 25MHz CPU clock. For example, shift and
rotate instructions are processed in one instruction cycle independent of the number of bit to be
shifted. Multiple-cycle instructionshave been optimized: branches are carried out in 2 cycles, 16 x
16-bit multiplication in 5 cycles and a 32/16 bit
division in 10 cycles.The jump cache reduces the
execution timeof repeatedly performed jumps in a
loop, from 2 cycles to 1 cycle.
Figure 5 : CPU Block Diagram
ST10F168
The CPU uses a bank of 16 word registers to run
the current context. This bank of General Purpose
Registers (GPR) is physically stored within the
on-chip RAM area. A Context Pointer (CP) register determines the base address of the active register bank to be accessed by the CPU. The
number of register banks is only restricted by the
available internal RAM space. Foreasy parameter
passing, one register bank may overlap others.
A system stack of up to 2048 Byte stores temporary data. The system stack is allocated in the
on-chip RAM area, and it is accessed by the CPU
via the stack pointer (SP) register. Two separate
SFRs, STKOV and STKUN, are implicitly compared against the stack pointer value on each
stack access, for the detection of a stack overflow
or underflow.
256K Byte
Flash
memory
32
SP
STKOV
STKUN
Exec. Unit
Instr. Ptr
Instr. Reg
4-Stage
Pipeline
PSW
SYSCON
BUSCON 0
BUSCON 1
BUSCON 2
BUSCON 3
BUSCON 4
Data Pg. Ptrs
CPU
MDH
MLD
Mul./Div.-HW
Bit-Mask Gen.
ALU
16-Bit
Barrel-Shift
CP
ADDRSEL 1
ADDRSEL 2
ADDRSEL 3
ADDRSEL 4
Code Seg. Ptr.
R15
General
Purpose
Registers
R0
16
16
Internal
RAM
2K Byte
Bank
n
Bank
i
Bank
0
19/76
ST10F168
6.1 - Instruction Set Summary
The Table8 liststhe instructions of the ST10F168.
The various addressing modes, instruction operation, parameters for conditional execution of
Table 8 : Instruction set summary
MnemonicDescriptionBytes
ADD(B)Add Word (Byte) operands2 / 4
ADDC(B)Add Word (Byte) operands with Carry2 / 4
SUB(B)Subtract Word (Byte) operands2 / 4
SUBC(B)Subtract Word (Byte) operands with Carry2 / 4
MUL(U)(Un)Signed multiply direct GPRby direct GPR (16 x 16-bit)2
DIV(U)(Un)Signed divide register MDL by direct GPR (16 / 16-bit)2
DIVL(U)(Un)Signed long divide register MD by direct GPR (32 / 16-bit)2
CPL(B)Complement direct Word (Byte) GPR2
NEG(B)Negate direct Word (Byte) GPR2
AND(B)Bitwise AND, (Word / Byte operands)2 / 4
OR(B)Bitwise OR, (Word / Byte operands)2 / 4
XOR(B)Bitwise XOR, (Word / Byte operands)2 / 4
BCLRClear direct bit2
BSETSet direct bit2
BMOV(N)Move (negated) direct bit to direct bit4
BAND, BOR, BXORAND / OR / XOR direct bit with direct bit4
BCMPCompare direct bit to direct bit4
BFLDH/LBitwise modify masked high / low Byte of bit-addressable direct Word memory with
immediate data
CMP(B)Compare Word (Byte) operands2 / 4
CMPD1/2Compare Word data to GPR and decrement GPR by 1/22 / 4
CMPI1/2Compare Word data to GPR and increment GPR by 1/22 / 4
PRIORDetermine number of shift cycles to normalize direct Word GPR and store result in
direct Word GPR
SHL/SHRShift left / right direct Word GPR2
ROL/RORRotate left / right direct Word GPR2
ASHRArithmetic (sign bit) shift right direct Word GPR2
MOV(B)Move Word (Byte) data2 / 4
MOVBSMove Byte operand to Word operand with sign extension2 / 4
MOVBZMove Byte operand to Word operand. with zero extension2 / 4
JMPSJump absolute to a code segment4
J(N)BJump relative if direct bit is (not) set4
JBCJump relative and clear bit if direct bit is set4
instructions, opcodes and a detailed description of
each instructioncan be found in the“ST10 Family
Programming Manual”.
4
2
20/76
ST10F168
Table 8 : Instruction set summary
MnemonicDescriptionBytes
JNBSJump relative and set bit if direct bit is not set4
CALLA, CALLI, CALLR Call absolute / indirect / relative subroutine if condition is met4
CALLSCall absolute subroutine in any code segment4
PCALLPush direct Word register onto system stack and call absolute subroutine4
TRAPCall interrupt service routine via immediate trap number2
PUSH, POPPush / pop direct Word register onto / from system stack2
SCXT
RETReturn from intra-segment subroutine2
RETSReturn from inter-segment subroutine2
RETPReturn from intra-segment subroutine and pop direct Word register from system
RETIReturn from interrupt service subroutine2
SRSTSoftware Reset4
IDLEEnter Idle Mode4
PWRDNEnter Power Down Mode (supposes NMI-pin being low)4
Push direct Word register onto system stack and update register with Word operand4
stack
Signify End-of-Initialization on
RSTOUT-pin
2
4
21/76
ST10F168
7 - EXTERNAL BUS CONTROLLER
All external memory accesses are performed by
the on-chip external bus controller. The EBC can
be programmed to single chip mode when no
external memory is required, or to one of four different external memory access modes :
In demultiplexed busmodes addresses areoutput
on Port1 and data are input / output on Port0 or
P0L, respectively. In the multiplexed bus modes
both addresses and data use Port0 for input/ output.
Timing characteristics of the external bus interface (memory cycle time, memory tri-state time,
length of ALE and read / write delay) areprogrammable giving the choice of a wide range of memories and external peripherals.Up to 4 independent
address windows may be defined (using register
pairs ADDRSELx / BUSCONx) to access different
resources and bus characteristics. These address
windowsarearranged hierarchicallywhere
BUSCON4 overrides BUSCON3 and BUSCON2
overrides BUSCON1. All accesses to locations
not covered by these 4 address windows are controlled by BUSCON0. Up to 5 external CS signals
(4 windows plus default) can be generated in
order to save external glue logic. Access to very
slow memories is supported by a ‘Ready’ function.
A HOLD/HLDA protocol is available for bus arbitration which shares external resources with other
bus masters. The bus arbitration is enabled by
setting bit HLDEN in register SYSCON. After setting HLDEN once, pins P6.7...P6.5 (BREQ,
HLDA, HOLD) are automatically controlled by the
EBC. In master mode (default after reset) the
HLDA pin is an output. By setting bit DP6.7 to’1’
the slave mode is selected where pin HLDA is
switched to input. This directly connects the slave
controller to another master controller without
glue logic.
For applications which require less external
memory space, the address space can be
restricted to 1M Byte, 256K Byte or to 64K Byte.
Port4 outputs all 8 address lines if an address
space of 16M Byte is used, otherwise four, two or
no address lines.
Chip select timingcan be programmed. By default
(after reset), the CSx lines change half a CPU
clock cycle after the rising edge of ALE. With the
CSCFG bit set in the SYSCON register the CSx
lines can change with the rising edge of ALE.
The active level of the READY pin can be set by
bit RDYPOLx in the BUSCONx registers. When
the READY function is enabled for a specific
address window, each bus cycle within the window must be terminated with the active level
defined by bit RDYPOLx in the associated BUSCONx register.
22/76
8 - INTERRUPT SYSTEM
The interrupt response time for internal program
execution is from 200ns to 480ns at 25MHz CPU
clock.
The ST10F168 architecture supports several
mechanisms for fast and flexible response to service requests that can be generated from various
sources (internal or external) to the microcontroller. Any of these interrupt requests can be serviced by the Interrupt Controller or by the
Peripheral Event Controller (PEC).
In contrast to a standard interrupt service where
the current program execution is suspended and
a branch to theinterrupt vector table is performed,
just one cycle is ‘stolen’ from the current CPU
activity to perform a PEC service. A PEC service
implies a single Byte or Word data transfer
between any two memory locations with an
additional increment of either the PEC source or
the destination pointer. An individual PEC transfer
counter is implicitly decremented for each PEC
service except when performing in the continuous
transfer mode. When this counter reaches zero, a
standardinterruptisperformedtothe
corresponding source related vector location.
PEC services are very well suited to perform the
transmission or the reception of blocks of data.
ST10F168
The ST10F168 has 8 PEC channels, each of
them offers such fast interrupt-driven data transfer
capabilities.
A interrupt control register which contains an
interrupt request flag, an interrupt enable flag and
an interrupt priority bitfield is dedicated to each
existing interrupt source. Thanks to its related
register, each source can be programmed to one
of sixteen interrupt priority levels. Once starting to
be processed by the CPU, an interrupt service
can only be interrupted by a higher prioritized
service request. For the standard interrupt
processing, each of the possible interrupt sources
has a dedicated vector location.
Fast external interrupt inputs are provided to service external interrupts with high precision
requirements. These fast interrupt inputs feature
programmable edge detection (rising edge, falling
edge or both edges). Software interrupts are supported by means of the ‘TRAP’ instruction in combination with an individual trap (interrupt) number.
Table 9 shows all the available ST10F168 interrupt sourcesand thecorresponding hardware-relatedinterrupt flags,vectors, vector
locations and trap (interrupt) numbers: