**ST8002** # 2K ROM HCMOS MICROCONTROLLER # **ADVANCED DATA** # **HARDWARE** - HCMOS TECHNOLOGY. - 8 BIT CORE & ARCHITECTURE. - POWER SAVING WAIT, HALT AND RAM RETENTION MODES. - 2112 BYTES OF USER ROM. - 128 BYTES OF RAM. - 20 BI-DIRECTIONNAL I/O LINES. - 16 BIT FREE RUNNING COUNTER TIMER FEATURING ONE INPUT CAPTURE SYSTEM AND ONE OUTPUT COMPARE SYSTEM. - TIMER INTERRUPTS. - 1 DEDICATED EXTERNAL INTERRUPT. - MASTER RESET AND POWER ON RESET. - SINGLE 3 TO 6 VOLTS SUPPLY (±10%). - 2 VOLTS RAM RETENTION MODE - USER MASK OPTIONS: Input Pull-down on port A and port C. - -RC or XTAL / CERAMIC oscillator option - -Interrupt trigger : edge or level & edge - -Internal clock for TIMER. - 28 PIN DUAL-IN-LINE PACKAGE - 28 PIN SMALL OUTLINE (SO) PACKAGE. #### SOFTWARE - 8 BIT DATA MANIPULATION. - 74 BASIC INSTRUCTIONS. - 8 BY 8 UNSIGNED MULTIPLY INSTRUCTION. - 7 MAIN ADDRESSING MODES (IMMEDIAT / DIRECT/ EXTENDED / RELATIVE / INDEXED / INDIRECT / BIT). - DEVELOPMENT SUPPORT ON REAL TIME EMULATOR AND PC/DOS SOFTWARE (CROSS ASSEMBLER, DEBUGGER). # N-DIP-28 S-SOIC-28 (Plastic Package) (Surface Mount) # **PIN CONNECTIONS** # DESCRIPTION The ST8002 is a complete HCMOS microcontroller unit (MCU); The device includes an on-chip oscillator, CPU, ROM, RAM, I/O and one TIMER. The fully static design allows frequency operations down to DC, reducing power consumption when needed. March 1990 # PART 1. BLOCK DIAGRAM # PART 2. ST8002 PIN ASSIGNMENT Refer to Top View Figures of 40 pin Dual In Line and 44 lead PLCC packages. # 1.2 PIN DESCRIPTION # RESET The ST8002 can be initialized by the RESET input signal, active low. This event is considered as the first priority interrupt for the core. Refer to Part 5 (ST8002 INTERRUPT STRUCTURE) for more detailed information. # INT INT is the external, software maskable interrupt. It can be activated in two different ways (negative edge or negative edge & level sensitive) depending of the User Mask Option. Refer to part 5 (ST8002 INTERRUPT STRUCTURE) for more detailed information. #### PA0-PA7 / PB5-PB7 / PC0-PC7 Standard bi-directionnal I/O lines. Port A, Port B and Port C are each made of 8 lines. Refer to Part 8 (I/O PORTS) for detailed information. # PD<sub>5</sub> One bi-directionnal I/O line of Port D. #### PD7 Input only line of port D. PD7 and ICAP signals share the same pin (pin 25). #### **OCMP** This Output Compare signal is provided by the Timer System Output Compare Logic. Refer to Part 9 (16 BIT TIMER) for detailed information. #### ICAP This Input Capture signal is used by the Timer system for signals / Events mesurement purposes. Refer to Part 9 ( 16 BIT TIMER) for detailed information. # OSCIN, OSCOUT Oscillator input and output pins. These pins must be connected to a parallel resonant crystal or ceramic. An external clock source can also be inputed thru OSCIN. Refer to part 6 (CLOCK) for additionnal information about oscillator characteristics. # $V_{DD}$ Single power supply voltage 3 to 6 volts. Vss Ground # PART 3 . CENTRAL PROCESSING UNIT # 3.1 INTRODUCTION This CPU is an 8 bit microprocessor whose instruction set is defined in PART 4. The fully static design allows operation at frequencies down to DC, further reducing its low-power consumption. # 3.1.1 HARDWARE FEATURES - HCMOS Technology - 8 bit architecture - Up to 16 bit address bus - Six internal registers : - Accumulator (8 bits) - 2 Index Registers (8 bits) - Program counter (up to 16 bits) - Stack Pointer (up to 8 bits) - Code Condition Register - Power saving HALT, WAIT and data retention modes - Fully static operation #### 3.1.2 SOFTWARE FEATURES - 74 basic instructions - 8X8 unsigned multiply instruction - 17 addressing modes - True bit manipulation. - Two power save standby modes (WAIT, HALT). - Refer to PART 4. (ST8 instruction set) for a complete description of the instruction set. # 3.2 CPU REGISTERS The CPU contains six registers, as shown in the programming model of Figure 3.1. Following an interrupt, the registers are stacked in the order shown in Figure 3.2. The Y index register is never stacked. # 3.2.1 ACCUMULATOR (A) The accumulator is an 8 bit general purpose register used to hold operands and results of the arithmetic calculations and to perform data manipulations. Figure 3.1 . Programming Model # Figure 3.3 : MEMORY MAP | \$0000 | 1/0 | 0000 | | Port | 0000 | | Port A Data Register | \$0 | |--------|----------|------|---|-----------------|------|---|---------------------------------|-----| | | 32 Bytes | | | 8 Bytes | | | Port B Data Register | \$0 | | | 0227.00 | | | | | | Port C Data Register | \$0 | | \$001F | | 0031 | | Unused | | | Port D Fixed Input Register | \$0 | | \$0020 | User | 0032 | \ | 10 Bytes | | | Port A Data Direction Reigster | \$0 | | | ROM | | \ | L | | | Port B Data Direction Register | \$0 | | | 48 Bytes | | \ | Timer | | | Port C Data Direction Register | \$0 | | \$004F | | 0079 | \ | 10 Bytes | | | Port D Data Direction Register | \$0 | | \$0050 | Unused | 0800 | \ | <u> </u> | _ | | Unused | \$0 | | \$007F | 48 Bytes | 127 | | i<br> | | | Unused | \$0 | | \$0080 | | 128 | \ | Unused<br>Bytes | | | Unused | \$0 | | | 128 | | \ | Dytes | | | Unused | \$0 | | 600BF | Bytes | 0191 | \ | | 0031 | | Unused | \$0 | | \$00C0 | Stack | 0192 | | | | | Unused | \$0 | | \$00FF | 64 Bytes | 0255 | | | 1 | | Unused | \$0 | | \$0100 | User | 0256 | | | 1 | | Unused | \$0 | | | ROM | | | | , | 1 | Unused | \$1 | | | 2048 | | | | | | Unused | \$1 | | | Bytes | | | | | | Timer Control Register | \$1 | | | | | | | | 1 | Timer Status Register | \$1 | | | | | | | | Ì | Input Capture High Register | \$1 | | \$08FF | | 2303 | | | | 1 | Input Capture Low Register | \$1 | | \$0900 | Unused | 2304 | | | | ļ | Output Compare High Register | \$1 | | | 5876By | | | | | į | Output Compare Low Register | \$1 | | | tes | | | | | 1 | Counter High Register | \$1 | | | | | | | | 1 | Counter Low Register | \$ | | | ] | | | | | | Alternate Counter High Register | \$1 | | 1FEF | | 8175 | | | | 1 | Alternate Counter Low Register | \$1 | | \$1FF0 | User | 8176 | | | | 1 | Unused | \$ | | | Vectors | | | | | 1 | Unused | \$ | | | 16 Bytes | | | | | 1 | Unused | \$1 | | \$1FFF | 1 1 | 8191 | | | | į | Unused | \$1 | Figure 3.2: Stacking Order # 3.2.2 INDEX REGISTER (X AND Y) These 8-bit registers are used to create an effective address. They are also used for data manipulations with the read-modify-write type of instructions as well as a temporary storage register when not performing addressing operations. To indicate if an instruction refers to the Y index register and not to the X one, a precede instruction (PRE) is generated by the cross assembler. The Y index register is not pushed onto stack when an interrupt occurs. # 3.2.3 PROGRAM COUNTER The program counter is a register of 16 bits max containing the address of the next instruction to be executed by the processor. # 3.2.4 STACK POINTER (SP) The stack pointer is a register of 8 bits max containing the address of the next free location on the pushdown/pop-up stack. # NOTE The stack pointer can be placed either on page 0 (\$0000 to \$00ff) or on page N (\$0N00 to \$ONFF). Refer to 3.3 (Memory map) for stack position and depth inside the ram area. The stack area of RAM is used to store the return address on subroutine calls and the machine state during interrupts. During external reset and during a reset stack pointer (RSP) instruction, the stack pointer is set to its upper limit. Nested interrupt and/or subroutines may use up to 256 (decimal) locations, in the case of an 8 bit stack. When the maximum number of location is exceeded, the stack pointer wraps around and points to its upper limit and loses the previously stored information. A subroutine call occupies two RAM bytes on the stack, while an interrupt uses five RAM bytes. # 3.2.5 CONDITION CODE REGISTER (CC) The condition code register is a 5-bit register which indicates the results of the instruction just executed as well as the state of the processor. These bits can be individually tested by a program and specified action taken as a result of their state. The following paragraphs describe each bit. # Half carry bit (H) The H bit is set to 1 when a carry occurs between bits 3 and 4 of the ALU during an ADD or ACC instruction. The H bit is used in binary coded decimal subroutines. # Interrupt mask bit (I) When the I bit is set, all interrupts are disabled. Clearing this bit enables the interrupts. If an external interrupt occurs while the I bit is set, the interrupts are latched and is processed after the I bit are next cleared; therefore, no interrupts are lost. # Negative (N) When set, this bit indicates that the result of the last arithmetic, logical, or data manipulation is negative (bit 7 in the result is a logic one). # Zero (Z) When set, this bit indicates that the result of the last arithmetic, logical or data manipulation is zero. # Carry/borrow (C) Indicates that a carry or borrow out of the arithmetic logic unit (ALU) occurred during the last arithmetic operation. This bit is also affected during bit test, branch instructions, shifts and rotates. # 3.3 MEMORY MAP As shown in Figure 3.3, the MCU is capable of addressing 8192 bytes of memory and I/O registers with its program counter. ST8002 MCU has implemented 2258 bytes of these locations. The first 256 bytes of memory (page zero) include: 18 bytes of I/O features such as data ports, port DDRs, timer registers. 48 bytes of user ROM, and 128 bytes of RAM. The next 2048 bytes complete the user ROM. The highest address bytes contain the user defined reset and the interrupt vectors. The 128 bytes of user RAM include up to 64 bytes for the stack. Since most programs use only a small part of the allocated stack locations for interrupts and/or subroutine stacking purposes, the unused bytes are usable for program data storage. #### **PART 4. INSTRUCTION SET** # 4.1 INSTRUCTION SET Note: This chapter is an overview of the ST8 family instruction set. Refer to SGS-THOMSON appropriate documentation (ST8 macro assembler user's guide / ST8 programming manual) for detailed information. # THE ST8 INSTRUCTION SET IS AN 8 BIT DATA BASED INSTRUCTION SET THAT CAN BE DIVIDED INTO FIVE MAJOR GROUPS: # GROUP 1 = REGISTER / MEMORY AND ABSOLUTE JUMP GROUP In this group of instructions, the operands can be the accumulator, the X index register, the Y index register or any "effective memory address" obtained by the different addressing modes. Examples: - LD <ea>, a - means that the memory byte located at address <ea> is loaded with the 8 bit content of the accumulator a. # GROUP 2 = READ - MODIFY - WRITE GROUP These instructions can read a register or a memory location, modify its content and write the new value back. Example: - RRC <ea> - means that the content of the memory byte located at address <ea> is rotated right through the carry bit, result written in memory <ea> and carry bit. # GROUP 3 = BIT MANIPULATION # AND TEST GROUP Test instructions can test any bit of the first 256 memory locations and jump conditional within an 8 bit pc-relative displacement. Example: - BTJT <ea>, #b, ee - corresponds to the relative jump (displacement = ee) if bit number #b of memory location <ea> is set. (Bit test and jump if true). Bit manipulation instructions can set or reset any bit within the first 256 memory locations, except for ROM (\$20-\$4F) and registers located at addresses \$03, \$0B, \$10, \$13, \$14 and \$15. Example: - BSET <ea>, #b - sets the bit #b of memory location <ea>. # GROUP 4 = PC-RELATIVE JUMP GROUP These instructions execute a pc-relative jump (8bit displacement) depending on the state of flag bits inside the condition code register (H, I, N, Z, C flags). Example: - JRC ee - jump relative if carry, displacement = ee #### GROUP 5 = MISCELLANEOUS GROUP. These instructions are mainly control instructions on registers, stack, interrupts, subroutines and power down modes. The multiply instruction is also included in this group. It performs an 8 by 8 bit unsigned multiplication between index register and accumulator, result given on 16 bits (on acc. and index registers. # 4.2 ADDRESSING MODES: The CPU uses 17 different addressing modes to provide the programmer with an opportunity to optimize the code to all situations. The various indexed addressing mode make it possible to locate data labels, code conversion tables and scaling tables anywhere in the memory space. Short indexed accesses are single byte instructions, while the longest instructions (three bytes) allow access of tables throughout memory. Short absolute (direct) and long absolute (extended) addressings are also included. Extended addressing permits jump instructions to reach all memory. Tables in 4.3 show the addressing modes for each instructions. The term "effective address" (EA) is used in describing the various addressing modes, and is defined as the address to or from which the argument for an instruction is fetched or stored\*. The 17 addressing modes of the processor are described below. Parentheses are used to indicate "content of" the memory location or register referred to e.g. (PC) indicates the content of the location pointed to by the PC. \*LSBEA is used to represent the least significant byte of EA and MSBEA the most significant one. ### USING A PRE-BYTE In order to extend the number of op-codes available for an eight bit CPU (256 op-codes), three "pre-byte" op-codes have been introduced. These pre-byte have to be seen as "pre-instructions" that modify the meaning of the following instruction. The whole instruction become: - n-1 End of previous instruction - \_ n Pre-byte - n Op-code - \_ n ... (operand if needed) - \_ n+1 Pre-byte or Op-code of next instruction. These pre-bytes introduce two possibilities: - Use of Y as the index register instead of the X (pre-byte Y Direct = PDY = \$90) - Use of Indirect addressing mode. Each time the indirect memory addressing mode is selected, a pre-byte must precede the instruction OP-code (\$91 or \$92). Refer to 4.3 (OP-code tables) for detailed examples. Indirect indexed addressing can be also defined with X as index (PIX = \$92) or with Y as index (PIY = \$91) # 4.2.1. INHERENT In inherent instructions, all the information needed to execute the instruction is contained in the Opcode. Operations specifying only the index register or accumulator, and no other arguments, are included in this mode. # 4.2.2 . IMMEDIATE In immediate addressing the operand is stored in the byte immediately following the Op-code. #### 4.2.3 . DIRECT In the direct addressing mode, the effective address of the argument is contained in a single byte following the Op-code byte. Direct addressing allows the user to directly address the lowest 256 bytes in memory with a single two byte instruction. #### 4.2.4 .EXTENDED In the extended addressing mode, the effective address of the argument is contained in the two bytes following the op-code. Instructions with extended addressing modes are capable of referencing arguments anywhere in memory. # 4.2.5 . INDEXED, NO OFFSET In the indexed, no offset addressing mode, the effective address of the argument is contained in one of the 8-bit index register (X or Y). To access Y, the preceding instruction PRE is used prior to the instruction using the indexed, no offset addressing mode. Thus, this addressing mode can access the first 256 memory locations. These instructions are only one byte long. This mode is used to move a pointer through a table or addressing of a frequently referenced RAM or I/O location. #### 4.2.6 . INDEXED, 8BIT OFFSET The EA is obtained by adding the contents of the second instruction byte to the appropriate index register. This mode allows addressing of 256 locations of the 511 lowest memory locations: #### 4.2.7. INDEXED, 16 BIT OFFSET The EA is obtained by adding the 16-bits unsigned value composed by the second (MSB) and the third (LSB) instruction bytes to the appropriate index register. This mode allows addressing of 256 locations anywhere in the memory map. # 4.2.8 .RELATIVE The relative addressing mode is used for branch instruction (e.g. Branch on bit, Branch on condition, Branch subroutine). The branch address (new value of PC) is calculated by adding to the content of the PC, one 8 bit signed value (displacement). This means that the variation of PC value is in the range -126 to +129: # 4.2.9 . BIT SET/ CLEAR Bit Set / Clear mode is used to modify one single bit of a memory location in page zero. This is achieve by a read modify write mode. The position of the bit is given on 3 bits included in the op-code and the memory location is given by the second byte (direct addressing mode) . #### 4.2.10 . BIT TEST AND BRANCH Bit test and branch mode gives a relative branch according to the value of a single bit of a memory location in page zero (like Bit Set / Clear mode). Three bytes are needed to specify this kind of instruction: - Op-code which contains the position of the tested bit in the Memory location concerned - Memory location to be located EA1. - Displacement (8 bit signed value), if test true, the displacement is added to the content of the PC. # 4.2.11 . SHORT INDIRECT For this mode the effective address is obtained in two steps: The second byte of the instruction is used as a page zero address. The content of memory location pointed by this address is the effective address: - LSBEA = ((PC + 1)); PC <---PC + 2 - MSBEA = 00 This mode could be called the "indirect direct" mode because the second step is the same as the one of direct mode. #### 4.2.12 LONG INDIRECT In the long indirect mode the second byte of the instruction is used as a zero page pointer. The most significant byte of the EA is the content of this location. The least significant byte is found in the content of the following zero page location (increment the pointer): - MSBEA = ( (PC + 1) ) ; PC <---PC + 2 - LSBEA = ((PC + 1) + 1) This mode could be call "indirect extended" mode because, after picking the EA, it is similar to the previous extended mode. Three bytes including the pre-byte are needed to describe this mode. # 4.2.13 . SHORT INDIRECT INDEXED For this mode the effective address is obtained in three steps. The second byte of the instruction is used as a page zero address. The content of the memory location pointed by this address is added to the value of the index register. The result is the EA. - \_ MSBEA = Carry - Index = X or Y according to the pre-byte (PIX or PIY) # 4.2.14 . LONG INDIRECT INDEXED In long indirect indexed mode the second byte of the instruction is used as a zero page pointer. A 16 bit word is read using this pointer (Most significant byte is byte pointed, Least significant byte is found in the content of the following location). The effective address is done by adding the index register value to these two bytes: - LSBEA = ((PC + 1) + 1) + Index - Index = X or Y according to the pre-byte (PIX or PIY) #### 4.2.15 . INDIRECT RELATIVE The indirect relative addressing mode is working as the relative mode but the displacement is not the content of the second byte of the instruction. This content is used as a zero page address where the displacement is located. - LSBEA = LSBPC + 2 + ( (PC + 1) ) ; PC <---EA, if branch taken</p> - \_ MSBEA = MSBPC + CARRY - \_ Otherwise, EA = PC <---PC + 2 # 4.2.16 . INDIRECT BIT SET / CLEAR Indirect Bit Set / Clear mode is working like Bit Set / Clear mode except that the modified byte address is not the content of the second byte of the instruction. This content is used as a zero page address where the concerned byte is located. # 4.2.17, INDIRECT BIT TEST AND BRANCH Indirect Bit test and branch mode works as previous Test and branch mode but the tested byte is addressed as the modify byte in previous Indirect Bit Set / Clear. # 4.3. MNEMONICS - OPCODES - CYCLES TABLES The information given in this chapter is an overview of instruction possibilities. Refer to the "STB programming manual" document for complete information. Each instruction of the five groups discussed in 4.1 is described in the next table. In these tables the following symbols mean | | | а | Accumulator a | |-----------------|-------------------------------|------------|-----------------------------------| | | | iX, X or Y | Index register (pre-byte 90 if Y) | | EFFECTIVE A | DDRESS SOURCE CODING | S | Stack pointer | | #nn | Immediate | CC | Condition Codes register | | ad8 | Direct | nn | 8 bit immediate value | | ad16 | Extended | a 8 | 8 bit address | | (iX) | Indexed, no offset | a 16 | 16 bit address | | (d8,iX) | Indexed, 8 bit offset | d8 | 8 bit signed offset | | (d16,iX) | Indexed, 16 bit offset | ee | 8 bit PC-relative displacement | | (ad8) or (ad16) | Memory indirect, no index | ad | Source coding of address | | ((ad8) , iX) | Memory indirect, post indexed | b | 3 bit , bit number | | or ((ad16), iX) | Wernery memost, post macked | < ea> | Effective address | # **EXAMPLE** | FUNCTION | SOURCE CODING | ADDRESSING MODES<br>Immediate | |--------------------|---------------|-------------------------------| | Load a with memory | LD a,< ea > | <sub>2</sub> A6 <sup>2</sup> | # Bytes OP-Code # Cycles # GROUP 1: REGISTER / MEMORY AND ABSOLUTE JUMP GROUP | | | | | ADDRESSI | NG MODE | | | |----------------------------|---------------|------------------------------|------------------------------|-------------------|------------------------------|------------------------------|------------------------------| | FUNCTION | SOURCE CODING | Immediate | Direct | Extended | Index 0 | Index 8 | Index 16 | | Load A with memory | LD a,< ea> | 2 A6 <sup>2</sup> | <sub>2</sub> B6 <sup>3</sup> | 3 C6 <sup>4</sup> | 1 F6 <sup>3</sup> | <sub>2</sub> E6 <sup>4</sup> | <sub>3</sub> D6 <sup>5</sup> | | Load iX with memory | LD iX,< ea> | 2 AE 2 | <sub>2</sub> BE <sup>3</sup> | 3 CE 4 | <sub>1</sub> FE <sup>3</sup> | 2 EE <sup>4</sup> | 3 DE 5 | | Load memory with A | LD < ea>,a | | <sub>2</sub> B7 <sup>4</sup> | 3 C7 <sup>5</sup> | 1 F7 <sup>4</sup> | <sub>2</sub> E7 <sup>5</sup> | 3 D7 <sup>6</sup> | | Load memory with iX | LD < ea>,iX | | <sub>2</sub> BF <sup>4</sup> | 3 CF <sup>5</sup> | 1 FF <sup>4</sup> | 2 EF <sup>5</sup> | 3 DF <sup>6</sup> | | Add memory to A | ADD a,< ea> | 2 AB <sup>2</sup> | 2 BB <sup>3</sup> | 3 CB <sup>4</sup> | 1 FB <sup>3</sup> | 2 EB <sup>4</sup> | 3 DB <sup>5</sup> | | Add memory and carry to A | ADC a,< ea> | 2 A9 <sup>2</sup> | <sub>2</sub> B9 <sup>3</sup> | 3 C9 <sup>4</sup> | 1 F9 <sup>3</sup> | <sub>2</sub> E9 <sup>4</sup> | <sub>3</sub> D9 <sup>5</sup> | | Subtract memory to A | SUB a,< ea> | 2 A0 <sup>2</sup> | <sub>2</sub> B0 <sup>3</sup> | 3 CO 4 | 1 F0 <sup>3</sup> | <sub>2</sub> E0 <sup>4</sup> | <sub>3</sub> D0 <sup>5</sup> | | Subtract memory with carry | SBC a,< ea> | 2 A2 <sup>2</sup> | <sub>2</sub> B2 <sup>3</sup> | 3 C2 <sup>4</sup> | 1 F2 <sup>3</sup> | <sub>2</sub> E2 <sup>4</sup> | <sub>3</sub> D2 <sup>5</sup> | | And memory to A | AND a,< ea> | 2 A4 <sup>2</sup> | <sub>2</sub> B4 <sup>3</sup> | 3 C4 <sup>4</sup> | 1 F4 <sup>3</sup> | <sub>2</sub> E4 <sup>4</sup> | <sub>3</sub> D4 <sup>5</sup> | | Or memory with A | OR a,< ea> | 2 AA <sup>2</sup> | <sub>2</sub> BA <sup>3</sup> | 3 CA 4 | 1 FA <sup>3</sup> | 2 EA 4 | 3 DA <sup>5</sup> | | Exclusive OR | XOR a,< ea> | <sub>2</sub> A8 <sup>2</sup> | <sub>2</sub> B8 <sup>3</sup> | 3 C8 <sup>4</sup> | 1 F8 <sup>3</sup> | 2 E8 <sup>4</sup> | 3 D8 <sup>5</sup> | | Arithmetic Compare A | CP a,< ea> | 2 A1 <sup>2</sup> | <sub>2</sub> B1 <sup>3</sup> | 3 C1 <sup>4</sup> | 1 F1 <sup>3</sup> | <sub>2</sub> E1 <sup>4</sup> | <sub>3</sub> D1 <sup>5</sup> | | Arithmetic Compare iX | CP iX,< ea> | 2 A3 <sup>2</sup> | <sub>2</sub> B3 <sup>3</sup> | 3 C3 <sup>4</sup> | 1 F3 <sup>3</sup> | <sub>2</sub> E3 <sup>4</sup> | 3 D3 <sup>5</sup> | | Bit compare A and memory | BCP a,< ea> | <sub>2</sub> A5 <sup>2</sup> | <sub>2</sub> B5 <sup>3</sup> | 3 C5 <sup>4</sup> | 1 F5 <sup>3</sup> | <sub>2</sub> E5 <sup>4</sup> | <sub>3</sub> D5 <sup>5</sup> | | Absolute Jump | JP < ea> | | <sub>2</sub> BC <sup>2</sup> | 3 CC <sup>3</sup> | 1 FC <sup>2</sup> | 2 EC <sup>3</sup> | 3 DC 4 | | Call subroutine | CALL < ea> | | 2 BD 5 | 3 CD 6 | 1 FD <sup>5</sup> | <sub>2</sub> ED <sup>6</sup> | 3 DD <sup>7</sup> | GROUP 2 : READ - MODIFY - WRITE GROUP | FUNCTION | ADDRESSING | | | ADD | ADDRESSING MODES | odes | | | |---------------------------|------------|-------------------|--------------------------------|-------------------|---------------------|--------------------------------|---------------------|---------------------| | | CODING | 미마 | Ē× | Direct | Memory | INDEX<br>0 | hdex<br>+d8 | Index<br>+[ad8] | | Increment | INC < ea> | 1 4C 3 | 1 503 | 2 3C 2 | 3 923C 7 | , 7C <sup>5</sup> | 2 6C <sup>6</sup> | 3 926C <sup>8</sup> | | (Y index) | | | 2 905C <sup>4</sup> | | | 2 907C <sup>6</sup> | 3 906C <sup>7</sup> | 3 916C <sup>8</sup> | | Decrement | DEC < ea> | 1 4A 3 | 1 5A <sup>3</sup> | 2 3A <sup>5</sup> | 3 923A 7 | 1 7A 5 | 2 6A <sup>6</sup> | 3 926A <sup>8</sup> | | (Y index) | | | <sup>2</sup> 905A <sup>4</sup> | | | 2 907A <sup>6</sup> | 3 906A 7 | 3 916A <sup>8</sup> | | Clear | CLR < ea> | 1 4F 3 | <sub>1</sub> 5F <sup>3</sup> | 2 3F <sup>5</sup> | 3 923F <sup>7</sup> | 1 7F 5 | 2 6F <sup>6</sup> | 3 926F <sup>8</sup> | | (Y index) | | | <sub>2</sub> 905F <sup>4</sup> | | | 2 907F <sup>6</sup> | 3 906F <sup>7</sup> | 3 916F <sup>8</sup> | | One's Complement | CPL < ea> | 1 43 3 | 1 53 3 | 2 33 5 | 3 9233 7 | 1 73 5 | 2 63 <sup>6</sup> | 3 9263 8 | | (Y index) | | | 2 9053 4 | | | 2 9073 <sup>6</sup> | 3 9063 7 | 3 9163 8 | | Negate (2's complement) | NEG < ea> | 1 40 3 | 1 50 3 | 2 30 <sup>5</sup> | 3 9230 7 | 1 70 5 | 2 60 <sup>6</sup> | 3 9260 <sup>8</sup> | | (Y index) | | | 2 9050 4 | | | 2 9070 <sup>6</sup> | 3 9060 7 | 3 9160 <sup>8</sup> | | Rotate Left thru Carry | RLC < ea> | 1 49 3 | 1 593 | 2 39 5 | 3 9239 7 | 1 79 5 | 2 69 <sup>6</sup> | 3 9269 <sup>8</sup> | | (Y index) | | | 2 9059 4 | | | <sub>2</sub> 9079 <sup>6</sup> | 3 9069 7 | 3 9169 8 | | Rotate Right thru Carry | RRC < ea> | 1 46 3 | 1 563 | 2 36 <sup>5</sup> | 3 9236 7 | 1 76 5 | 2 66 <sup>6</sup> | 3 9266 <sup>8</sup> | | (Y index) | | | 2 9056 <sup>4</sup> | | Í | <sub>2</sub> 9076 <sup>6</sup> | 3 9066 7 | 3 9166 <sup>8</sup> | | Shift Left Logical | SLL < ea> | 1 48 3 | 1.583 | 2 38 5 | 3 9238 7 | 1 78 5 | 2 68 | 3 9268 | | (Y index) | | | 2 9058 4 | | | 2 9078 <sup>6</sup> | 3 9068 7 | 3 9168 <sup>8</sup> | | Shift Right Logical | SRL < ea> | 1 44 3 | 1 54 3 | 2 34 5 | 3 9234 7 | 1 74 5 | 2 64 6 | 3 9264 <sup>8</sup> | | (Y index) | | | 2 9054 4 | | | 2 9074 <sup>6</sup> | 3 9064 7 | 3 9164 | | Shift Left Arithmetic | SLA < ea> | 1 48 3 | , 58 <sup>3</sup> | 2 38 <sup>5</sup> | 3 9238 7 | 1 78 5 | 2 68 <sup>6</sup> | 3 9268 | | (Y index) | | | 2 9058 4 | | | 2 9078 6 | 3 9068 7 | 3 9168 <sup>8</sup> | | Shift Right Arithmetic | SRA < ea> | 1 47 3 | 1 57 3 | 2 37 5 | 3 9237 7 | 1 77 5 | 2 67 6 | 3 9267 8 | | (Y index) | | | 2 9057 4 | i | | 2 9077 6 | 3 9067 | 3 9167 8 | | Test for Negative or Zero | TNZ < ea> | 1 4D <sup>3</sup> | 1 5D <sup>3</sup> | 2 3D <sup>4</sup> | 3 923D <sup>6</sup> | 1 7D 4 | 2 6D <sup>5</sup> | 3 926D <sup>7</sup> | | (Y index) | | | 2 905D <sup>4</sup> | | | 2 907D <sup>5</sup> | 3 906D <sup>6</sup> | 3 916D <sup>7</sup> | | Swap Nibbles | SWAP < ea> | 1 4E 3 | 1 5E <sup>3</sup> | 2 3E 5 | 3 923E <sup>7</sup> | 1 7E <sup>5</sup> | 2 6E <sup>6</sup> | 3 926E <sup>8</sup> | | (Y index) | Τ | | 2 905E <sup>4</sup> | | | 2 907E <sup>6</sup> | 3 906E 7 | 3 916E <sup>8</sup> | SGS-THOMSON MICROELECTROMICS **GROUP 3: BIT MANIPULATION AND TEST GROUP** | | | ADDRESSING MODES | | | |----------------------------|------------------------|------------------------------------|--------------------------------------|--| | FUNCTION | SOURCE CODING | Direct | Memory Indirect | | | _ | | ad8 | [ad8] | | | Bit Set | BSET < ea > , # b | 2 (10+2*b) <sup>5</sup> | <sub>3</sub> 92(10+2*b) <sup>7</sup> | | | Bit Reset | BRES < ea > , # b | 2 (11+2*b) <sup>5</sup> | <sub>3</sub> 92(10+2*b) <sup>7</sup> | | | Bit Test and Jump if True | BTJT < ea > , # b , ee | 3 (00+2*b) <sup>5</sup> | 4 92(00+2*b) <sup>7</sup> | | | Bit Test and Jump if False | BTJF < ea > , # b , ee | <sub>3</sub> (01+2*b) <sup>5</sup> | 4 92(01+2*b) <sup>7</sup> | | **GROUP 4: PC-RELATIVE JUMP GROUP** | | | | ADDR | ESSING MODES | | |-----------------------------------------------|----------|-------|------------------------------|--------------------------------|--| | FUNCTION | SOURCE C | ODING | Direct | Memory Indirect | | | | | | ad | +[ad8] [ad8] | | | Jump Relative True | JRT | ee | 2 <b>20</b> <sup>3</sup> | <sub>3</sub> 9220 <sup>5</sup> | | | (Jump Relative always) | JRA | ee | 2 20 <sup>3</sup> | <sub>3</sub> 9220 <sup>5</sup> | | | Jump Relative False | JRF | ee | 2 21 <sup>3</sup> | <sub>3</sub> 9221 <sup>5</sup> | | | Jump Relative if Unsigned Greater than | JRUGT | ee | 2 22 3 | <sub>3</sub> 9222 <sup>5</sup> | | | Jump Relative if Unsigned Lower or<br>Equal | JRULE | ee | 2 23 <sup>3</sup> | <sub>3</sub> 9223 <sup>5</sup> | | | Jump Relative if No Carry | JRNC | ee | 2 24 3 | <sub>3</sub> 9224 <sup>5</sup> | | | Jump Relative if Unsigned Greater or<br>Equal | JRUGE | ee | 2 24 <sup>3</sup> | <sub>3</sub> 9224 <sup>5</sup> | | | Jump Relative if Carry | JRC | ee | <sub>2</sub> 25 <sup>3</sup> | <sub>3</sub> 9225 <sup>5</sup> | | | Jump Relative if Unsigned Lower than | JRULT | ee | 2 25 <sup>3</sup> | <sub>3</sub> 9225 <sup>5</sup> | | | Jump Relative if Not Equal | JRNE | ee | <sub>2</sub> 26 <sup>3</sup> | <sub>3</sub> 9226 <sup>5</sup> | | | Jump Relative if Equal | JREQ | ee | 2 27 <sup>3</sup> | <sub>3</sub> 9227 <sup>5</sup> | | | Jump Relative if Half Carry | JRH | ee | 2 28 <sup>3</sup> | <sub>3</sub> 9228 <sup>5</sup> | | | Jump Relative if Not Half Carry | JRNH | ee | 2 29 <sup>3</sup> | <sub>3</sub> 9229 <sup>5</sup> | | | Jump Relative if Plus | JRPL | ee | 2 2A <sup>3</sup> | <sub>3</sub> 922A <sup>5</sup> | | | Jump Relative if Minus | JRMI | ee | 2 2B <sup>3</sup> | <sub>3</sub> 922B <sup>5</sup> | | | Jump Relative if Not Interrupt Mask | JRNM | ee | 2 2C <sup>3</sup> | <sub>3</sub> 922C <sup>5</sup> | | | Jump Relative if Interrupt Mask | JRM | ee | 2 2D <sup>3</sup> | <sub>3</sub> 922D <sup>5</sup> | | | Jump Relative if Interrupt Line Low | JRIL | ee | <sub>2</sub> 2E <sup>3</sup> | <sub>3</sub> 922E <sup>5</sup> | | | Jump Relative if Interrupt Line High | JRIH | ee | <sub>2</sub> 2F <sup>3</sup> | 3 <b>922</b> F <sup>5</sup> | | | Call Subroutine Relative | CALLR | ee | 2 AD <sup>6</sup> | <sub>3</sub> 92AD <sup>8</sup> | | # **GROUP 5: MISCELLANEOUS GROUP** | FUNCTION | SOURCE | CODING | NO INDEX OR X | Y INDEX | |-------------------------------------|--------|--------|--------------------|--------------------------------| | Multiply (iX, A = iX * A) | MUL | iX , a | 1 42 11 | 2 9042 12 | | Load iX with acc. a content | LD | iX , a | 1 97 2 | 2 9097 <sup>3</sup> | | Load acc. a with iX content | LD | a , iX | 1 9F <sup>2</sup> | <sub>2</sub> 909F <sup>3</sup> | | Load Stack p. with acc. a content | LD | S,a | 1 95 2 | | | Load acc. a with Stack p. content | LD | a,S | 1 9E <sup>2</sup> | | | Load Stack p. with iX content | LD | S, iX | 1 94 2 | 2 9094 <sup>3</sup> | | Load iX with Stack p. content | LD | iX , S | 1 96 <sup>2</sup> | <sub>2</sub> 9096 <sup>3</sup> | | Load X reg. with Y reg. content | LD | X , Y | 1 93 2 | | | Load Y reg. with X reg. content | LD | Y,X | | 2 9093 <sup>3</sup> | | Push acc. a onto the Stack | PUSH | Α | 1 88 3 | | | Pop acc. a from the Stack | POP | Α | 1 84 4 | | | Push iX onto the stack | PUSH | iX | 1 89 3 | 2 9089 4 | | Pop iX from the Stack | POP | iX | 1 85 4 | 2 9085 5 | | Push Condition Codes onto the Stack | PUSH | СС | 1 8A <sup>3</sup> | | | Pop Condition Codes from the Stack | POP | cc | 1 86 4 | | | Reset Carry Flag | RCF | | 1 98 2 | | | Set Carry Flag | SCF | | 1 99 2 | ** | | Reset Interrupt Mask | RIM | | ↑ 9A <sup>2</sup> | | | Set Interrupt Mask | SIM | | 1 9B <sup>2</sup> | | | Reset Stack Pointer | RSP | | 1 9C <sup>2</sup> | | | No Operation | NOP | | 1 9D <sup>2</sup> | | | Interrupt Routine Return | IRET | | 1 80 <sup>9</sup> | | | Subroutine Return | RET | | 1 81 <sup>6</sup> | | | Software Trap | TRAP | | 1 83 <sup>10</sup> | | | Halt | HALT | | 1 8E <sup>2</sup> | | | Wait For Interrupt | WFI | | 1 8F <sup>2</sup> | | # **PART 5. RESET AND INTERRUPTS** #### 5.1 RESETS The ST8002 has two reset modes: an active low external reset pin (RESET) and a power-on reset function (POR). Refer to Figure 5.1 for timing sequence diagram. # 5.1.1 RESET PIN The Reset input pin is used to reset the MCU to provide an orderly software startup procedure. When using the external reset mode, the RESET pin must stay low for a minimum of one and one half $t_{cyc}$ . The RESET pin contains an internal Schmitt Trigger as part of its input to improve noise immunity # 5.1.2 POWER-ON RESET The power-On reset occurs when a positive transition is detected on $V_{DD}.$ The power-on reset is strictly used for power up conditions and should not be used to detect any drops in the power supply voltage. There is no provision for a power-down reset. The power-on circuity provides for a 4096 $t_{\rm cyc}$ delay from the time that the oscillator becomes active. If the external RESET pin is low at the end of the 4096 $t_{\rm cyc}$ time out, the processor remains in the reset condition until RESET goes high. The user must ensure that $V_{\rm DD}$ has risen to a point where the MCU can operate properly prior to the time the 4096 POR reset cycles have elapsed. If there is doubt, the external RESET pin should remain low until $V_{\rm DD}$ has risen to the minimum operating voltage specified. Table 5.2 shows the actions of the two resets on internal circuits, but not necessarily the order of occurence (X indicates that the condition occurs for the particular reset). # **5.2 INTERRUPTS** Systems often require normal processing to be interrupted in order to handle external events. The ST8002 may be interrupted by different methods: either one maskable hardware interrupts (INT or TIMER) or a non-maskable software interrupt (TRAP). Timer interrupt has several flags which will cause the interrupt. Generally, interrupt flags are located in read-only status registers, whereas their equivalent enable bits are located in associated control registers. The interrupt flags and enable bits are never contained in the same register. If the enable bit is a logic zero it blocks the interrupt from occuring but does not in- hibit the flag from being set. Reset clears all enable bits to disable interrupts during the reset procedure. The general sequence for clearing an interrupt is a software sequence of first accessing the status register while the interrupt flag is set, followed by a read or write of an associated register. When any of these interrupts occur, and if the enable bit is a logic one, normal processing is suspended at the end of the current instruction execution. Interrupts cause the processor registers to be saved on the stack and the interrupt mask (I bit) is set to prevent additional interrupts. The appropriate interrupt vector then points to the starting address of the interrupt service routine (refer to figure 5.3 for vector location). Upon completion of the interrupt service routine, the IRET instruction (which is normally a part of the service routine) causes the register contents to be recovered from the stack followed by a return to normal processing. The stack order is shown in Figure 3.2 (Part 3). The interrupt timing diagram is shown on Figure 5.7. The interrupt latency may be calculated as: 11 cycles plus the time to complete the current running instruction. # 5.2.1 HARDWARE CONTROLLED INTERRUPT SEQUENCE The three functions, RESET, HALT and WFI, are not in the strictest sense interrupts; however, they are acted upon in a similar manner. Flowcharts for hardware interrupts are shown in Figure 5.4 and for HALT and WFI are provided in Figure 5.5 - (a) A low input on the RESET input pin causes the program to vector to its starting address which is specified by the contents of memory locations \$1FFE and \$1FFF. The I bit in the condition code register is also set. Much of the MCU is configured to a known state during this type of reset as previouly described in paragraph 5.1. - (b) The HALT instruction causes the oscillator to be turned off and the processor to "sleep" until an external interrupt (INT) or reset occurs. - (c) The WFI instruction causes all processor clocks to stop, but leaves the Timer clocks running. This "rest" state of the processor can be cleared by reset, external interrupt (INT) or Timer Interrupt. Figure 5.1 . Power-on Reset And RESET Table 5.2 . Reset Action On Internal Circuit | Condition | RESET<br>Pin | Power-On<br>Reset | |-------------------------------------------------------------------------------------------|--------------|-------------------| | Timer Prescaler reset to Zero State. | х | × | | Timer Counter Configured to \$FFFC. | Х | x | | Timer Output Compare (OCMP) Bit Reset to Zero. | X | x | | All Timer Interrupt Enable Bits Cleared (ICIE,OCIE and TOIE) to disable timer interrupts. | x | x | | The OVL timer bit is cleared by reset. | X | x | | All data direction registers cleared to zero (input). | X | x | | Configure stack pointer to \$00FF. | х | x | | Force internal address bus to restart vector (\$1FFE-\$1FFF). | х | × | | Set I bit in condition code register to a logic one. | х | x | | Clear halt latch. | X* | x | | Clear External Interrupt latch. | x | x | | Clear WAIT latch. | × | × | <sup>\*</sup> Indicates that TIMEOUT still occurs # 5.2.2 . SOFTWARE INTERRUPT (TRAP) The software TRAP is an executable instruction. The action of the instruction is similar to the hardware interrupt. TRAP is executed regardless of the state of the interruptmask (I bit) in the condition code register. The interrupt service routine address is specified by the contents of memory location \$1FFC and \$1FFD. #### 5.2.3 . EXTERNAL INTERRUPT If the mask (I bit) of the condition code register has been cleared and the external interrupt pin (INT) has gone low, then the external interrupt is recognized. When the interrupt is recognized, the current state of the CPU is pushed into the stack and the I bit is set, which masks further interrupts until the present one is serviced. The interrupt service routine address is specified by the contents of memory location \$1FFA and \$1FFB. A level-sensitive and negative edge-sensitive trigger, or a negative edge-sensitive only trigger are available as a mask option. Figures 5.6 and 5.7 show both a functional and mode timing diagram for the interrupt line. The first method shows single pulses on the interrupt line spaced far enough apart to be serviced. The minhum time between pulses is a function of the number of cycles required to execute the interrupt service routine plus 21 cycles. Once a pulse occurs, the next pulse should not occur until the MCU software has exited the routine (an IRET instruction occurs). <sup>\*</sup> Indicates that Timeout still occurs. Table 5.3. Vector Addresses for Interrupts and Reset | Register | Flag Name | Interrupts | CPU Interupts | Vector Address | |--------------|-----------|--------------------|---------------|----------------| | N/A | N/A | Reset | RESET | \$1FFE-\$1FFF | | N/A | N/A | Software | TRAP | \$1FFC-\$1FFD | | N/A | N/A | External Interrupt | INT | \$1FFA-\$1FFB | | Timer Status | ICF | Input Capture | TIMER | \$1FF8-\$1FF9 | | | OCF | Output Compare | " | | | İ | TOF | Timer Overflow | ** | | Figure 5.6 shows several interrupt lines "wire-ORed" to form the interrupts at the processor. Thus, if after servicing one interrupt the interrupt line remains low, then the next interrupt is recognized. The internal interrupt latch is cleared in the first part of the service routine; Therefore, one, and only one, external interrupt pulse could be latched during TILIL and serviced as soon as the I bit is cleared. # 5.2.4 . TIMER INTERRUPT There are three different timer interrupt flags that will cause a timer interrupt whenever they are set and enabled. These three interrupt flags are found in the three most significant bits of the timer status register (TSR, location \$13) and all three will vector to the same interrupt service routine (\$1FF8-\$1FF9). All interrupt flags have corresponding enable bits (ICIE, OCIE and TOIE) in the timer control register (TCR, location \$12). Reset clears all enable bits, thus preventing an interrupt from occuring during the reset time period. The actual processor interrupt is generated only if the I bit in the condition code register is also cleared. When the interrupt is recognized the current machine state is pushed into the stack and I bit is set. This masks further interrupts until the present one is serviced. The interrupt service routine address is specified by the contents of memory location \$1FF8 and \$1FF9. The general sequence for clearing an interrupt is a software sequence of accessing the status register while the flag is set, followed by a read or write of an associated register. Refer to Part 9 "PROGRAMMABLE TIMER" for additional information about the timer circuitry. #### 5.3 . LOW POWER MODES #### 5.3.1 . HALT INSTRUCTION The HALT instruction places the ST8002 in its lowest power consumption mode. In the HALT mode the internal oscillator is turned off, causing all inter- nal processing to be halted; During the HALT mode the I bit in the condition code register is cleared to enable external interrupts. All other registers and memory remain unaltere and all input/output line remains unchanged. Th continues until an external interrupt (INT) or reset sent. Then, the internal I oscillator is turned on. The external interrupt or reset causes the program counter to vector to memory location \$1FFA and \$1FFB or \$1FFE and \$1FFF which respective contain the starting address of the interrupt or the reset service routine. # 5.3.2. WFI INSTRUCTION The WFI instruction places the ST8002 in a lo power consumption mode, but the WFI mode consumes somewhat more power than the HALT mode in the WFI mode, the internal clock remains activated all CPU processing is stopped; however, the programmable timer, serial peripheral interface and serial communications interface systems remain active. During the WFI mode, the I bit in the condition code register is cleared to enable all interrupts. All other registers and memory remain uncertainty and all parallel input/output lines remain unchanged. This continues until any interrupt or reset is sense At this time the program counter branches to the memory location (\$1FF8 through \$1FFF) which contains the starting address of the interrupt or reservice routine. # 5.4 . DATA RETENTION MODE The contents of RAM and CPU registers are retained at supply voltage as low as 2.0 Vdc. This referred as the data retention mode, where the RAM data is held, but the device is not guarantee to operate. Figure 5.4. Hardware interrupt Flowchart Figure 5.5 . HALT/WFI Flowchart Figure 5.6. External Interrupt Function Diagram Figure 5.7 .External Interrupt Mode Diagram # Figure 5.8. Interrupt Timing Diagram # PART 6. CLOCK SYSTEM, WFI AND HALT MODES # 6.1 . ON CHIP CLOCK SYSTEM - CHARACTERISTICS. The ST8002 can be configured by mask option to accept either a Crystal/Ceramic resonator input or an RC network to control the internal oscillator. The internal clock (Fop) is derived by a divide-by-two of the internal oscillator frequency (fosc). # 6.1.1 . CRYSTAL The circuit shown in Figure 6.1 (b) is recommended when using a crystal. The internal oscillator is designed to interface with an AT-cut parallel resonant quartz crystal resonator in the frequency range specified for fosc. Use of an external CMOS oscillator is recommended when crystals outside the specified ranges are to be used. The crystal and components should be mounted as close as possible to the input pins to minimize output distortion and startup stabilization time. Refer to paragraph 12 for VDD and maximum frequency specifications. **CCrystal** | | 2 MHZ | 4 MHZ | 8MHz | Units | |-------------------|-------|-------|-------|-------| | R <sub>SMAX</sub> | 400 | 75 | 60 | Ω | | C <sub>0</sub> | 5 | 7 | 10 | рF | | C <sub>1</sub> | 8. | 12 | 15 | nF | | Coscin | 15-40 | 15-30 | 15-25 | рF | | Соѕсоит | 15-30 | 15-25 | 15-20 | рF | | R₽ | 10 | 10 | 10 | MΩ | | Q | 30 | 40 | 60 | к | #### **Ceramic Resonator** | | 2-8 MHZ | Units | |----------------|---------|-------| | Rs (Typicall) | 10 | Ω | | C <sub>0</sub> | 40 | pF | | C <sub>1</sub> | 4.3 | рF | | Coscin | 30 | pF | | Соѕсоит | 30 | pF | | R <sub>P</sub> | 1-10 | MΩ | | Q | 1250 | - | (a) Crystal / Ceramic Resonator Parameters Figure 6.1 . Oscillator Connections # 6.1.2 . CERAMIC RESONATOR A ceramic may be used in place of the crystal in costsensitive applications. The circuit in Figure 6.1 (b) is recommended when using a ceramic resonator. Figure 6.1 (a) lists the recommended capacitance and feedback resistance values. The manufacturer of the particular ceramic resonator being considered should be consulted for specific information. #### 6.1.3 . RC If the RC oscillator is selected, then a resistor is connected to the oscillator pins as shown in Figure 6.1 (d). The relation between R and fosc is shown in Figure 6.1 ure 6.6. #### 6.1.4 . EXTERNAL CLOCK An external clock should be applied to the OSCIN input with the OSCOUT pin not connected, as shown in Figure 6.1(e). An external clock may be used with either the RC or crystal oscillator option. The toxov ot t<sub>ILCH</sub> specifications do not apply when using an external clock input. The equivalent specification of the external clock source should be used instead of toxov or t<sub>ILCH</sub>. Figure 6.6 . Typical Frequency vs Resistance For RC Oscillator Option (VDD = 5.0V) # 6.2 . LOW POWER MODES # 6.2.1 . HALT INSTRUCTION The HALT instruction places the CPU in its lowest power consumption mode. In the HALT mode the internal oscillator is turned off, causing all internal processing to be halted. Refer to Figure 6.3. During the HALT mode, the I bit of the condition code register is cleared to enable external interrupts. All other registers remain unaltered. This continues until an external interrupt or RESET is sensed while the oscillator is turned on, but the CPU remains inactive. When the oscillator has correctly restarted, the first code operation is fetched at starting address of the interrupt or reset service routine. # 6.2.2. WFI INSTRUCTION The WFI instruction places the CPU in a low power consumption mode, but the WFI mode consumes somewhat more power than the HALT mode. In the WFI mode, the internal clock remains active, and all CPU processing is stopped. However, the peripherals remain active. Refer to Figure 6.3. During the WFI mode, the I bit of the condition code register is cleared to enable any interrupt. All other registers remain unaltered. This continues until any interrupt or reset is sensed. At the time the program couter vectors to the memory location which contains the starting address of the interrupt or reset service routing. # 6.2.3 . DATA RETENTION MODE The contents of the CPU registers are retained at supply voltages as low as $2.0 V_{DC}$ . This is referred to as the data retention mode, where the data RAM is held, but the device is not guaranteed to operate. Figure 6.3. HALT/WAIT Flowchart | The ST8002 I memory). | has no | t been | designed | to : | support | any | microprocessor | mode | (addressing | external | program | |-----------------------|--------|--------|----------|------|--------------|-------|----------------|------|-------------|----------|---------| | memory). | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 4 | SGS | -THOMSON _ | | | | | | | | | | | — ) <b>a</b> | <br>د | Ś | | | | | PART 7 . ST8002 MICROPROCESSOR MODE # PART 8 . INPUT OUTPUT PORTS PROGRAMMING # 8.1 . INPUT/OUTPUT PORTS PROGRAMMING # 8.1.1 PARALLEL PORTS Ports A, B and C may be programmed as input or output under software control. The direction of the pins is determined by the state of the corresponding bit in the port data direction register (DDR). Each 8-bit port having an associated DDR bit is set to a logic one. A pin is configured as an input if its corresponding DDR bit is cleared to a logic zero. At power-on or reset, all DDRs are cleared, which configures all port A, B and C pins as inputs. The data direction registers are capable of being written to or read by the processor. Refer to Figure 8.1 and table 8.2 During the programming output state, a read of the data register actually reads the value of the output data latch and not the I/O pin. # 8.1.2 PA0 - PA7 These eight I/O lines compose the port A. The state of any pin is software programmable and all port A lines are configured as input during power-on or reset. #### 8.1.3 PB5 - PB7 These 3 lines compose the port B. The state of any pin is software programmable and all port B lines are configured as input during power-on or reset. All unused bits read as zeroes. ## 8.1.4 PC0 - PC7 These eight lines compose the port C. The state of any pin is software programmable and all port C lines are configured as input during power-on or reset. # 8.1.5 PORT D5, D7 Port D is a 2 lines port. PD5 is a bidirectionnal standard I/O pin. Input or output function is defined by bit 5 of port D Data Direction Register (\$07). PD7 is an input only line, shared with ICAP Timer input signal. Bit 4 of port D is always read as one; the other bits always read as zeroes. On port D DDR register (\$07), all unused bits read as zeroes. It is recommended that all unused inputs and I/O port be tied to an appropriate logic level (e.g., either V<sub>DD</sub> or V<sub>SS</sub>). # I/O PIN FUNCTIONS | R/ <b>W</b> * | DDR | I/O pin functions | | | | | |------------------------------------------------------------------------------|-----|--------------------------------------------------------------------|--|--|--|--| | 0 0 The I/O pin is in input mode. Data is written into the output data latch | | | | | | | | 0 | 1 | Data is written into the output data latch and output the I/O pin. | | | | | | 1 | 0 | The state of the I/O pin is read. | | | | | | 1 | 1 | The I/O pin is in an output mode. The output data latch is read. | | | | | \* R/W is an internal signal. Figure 8.1 . Parallel Port I/O Circuitry #### PART 9 . 16 BIT TIMER ### 9.1 . INTRODUCTION # 9.1.1 . GENERAL The 16-bit programmable timer can be used for many purposes including pulse length measurement of one input signal and generating one output signal waveform. Pulse lengths for both input and output signals can vary from several microseconds to many seconds. The timer is preceded by a manufacturing mask option programmable prescale - Mask option 1: The prescaler divides by 8 the internal processor clock - Mask option 2: The prescaler divides by 4 the internal processor clock - Mask option 3: The prescaler divides by 2 the internal processor clock. Depending of the mask option, the timer is also capable of generating periodic interrupts or indicating passage of an arbitrary multiple of 2,4 or 8 numbers of MCU cycles. Because the timer has a 16-bit architecture, each specific functional segment (capability) is represented by two registers. These registers contain the "high byte" and "low byte" of that function. However an access of the "high byte" inhibits that specific Timer capability until the "low byte" is also accessed. The programmable Timer capabilities are provided by using the following 10 addressable 8-bit registers: - Timer Control Register (TCR); - Timer Status Register (TSR); - Input Capture High Register (ICHR); - Input Capture Low Register (ICLR); - Output Compare High Register (OCHR); - Output Compare Low Register (OCLR); - Counter High Register (CHR); - Counter Low Register (CLR); - Alternate Counter High Register (ACHR); - Alternate Counter Low Register (ACLR); # 9.2. CONNECTIONS 9.2.1 . CONNECTIONS TO EXTERNAL DEVICES There are 2 connections to external devices - Input Capture Pins (ICAP) - Output Compare Pins (OCMP). 9.2.2 . CONNECTIONS TO INTERNAL MCU BUS - PHI2: Internal Processor Clock - CS: Chip Select - R/W: Read / Write - POR: Power On Reset - INT : Timer Interrupt. - DATA BUS - \_ ADDRESS BUS Figure 9.1 . Programmable Timer Block Diagram # 9.3 . HARDWARE FUNCTIONAL DESCRIPTION # 9.3.1. TIMER STATE TIMING DIAGRAM FOR RESET # Mask option 1: Internal Processor clock divided by 8 Note: Counter Register and Timer Control Register are the only registers affected by power-on or external reset. Mask Option 2 : Internal Processor Clock Divided by 4 Note: Counter Register and Timer Control Register are the only registers affected by power-on or external reset. # 9.3.1 . (Continued) # Mask Option 3: Internel Processor Clock Divided by 2 Note: Counter Register and Timer Control Register are the only registers affected by power-on or external reset. # 9.3.2. TIMER STATE TIMING DIAGRAM FOR TIMER OVERFLOW # Mask option 1: Internal Processor clock divided by 8 Note: The TOF-BIT is set by a transition of the free running counter from \$FFFF to \$0000. It is cleared by a processor access of the Timer Status Register (with TOF set) followed by an access (read or write) to the low byte of the Counter Low Register (CLR). # 9.3.2 . (Continued) # Mask Option 2: Internal Processor Clock Divided by 4 Note: The TOF-BIT is set by a transition of the free running counter from \$FFFF to \$0000. It is cleared by a processor access of the Timer Status Register (with TOF set) followed by an access (read or write) to the low byte of the Counter Low Register (CLR). # Mask Option 3: Internel Processor Clock Divided by 2 Note: The TOF-BIT is set by a transition of the free running counter from \$FFFF to \$0000. It is cleared by a processor access of the Timer Status Register (with TOF set) followed by an access (read or write) to the low byte of the Counter Low Register (CLR). # 9.3.3. TIMER STATE TIMING DIAGRAM FOR OUTPUT COMPARE # Mask option 1: Internal Processor clock divided by 8 The CPU write to the compare registers may take place at any time but a compare only occurs at timer state T01. Thus a 8-cycles difference may exist between the write to the compare register and the actual compare. Note 2 :Internal compare takes place during timer state T01. Note 3 :OCF is set at timer state T11 which follows the comparison match (\$FFFC in this example). # Mask Option 2: Internal Processor Clock Divided by 4 Note 1 The CPU write to the compare registers may take place at any time but a compare only occurs at timer state T01. Thus a 4-cycles difference may exist between the write to the compare register and the actual compare. Note 2 :Internal compare takes place during timer state T01. Note 3 :OCF is set at timer state T11 which follows the comparison match (\$FFFD in this example). # 9.3.3 . (Continued) # Mask Option 3: Internal Processor Clock Divided by 2 Note 1 The CPU write to the compare registers may take place at any time but a compare only occurs at timer state T11. Thus a 2-cycles difference may exist between the write to the compare register and the actual compare. Note 2 :Internal compare takes place during timer state T11. Note 3 :OCF is set at timer state T11 which follows the comparison match (\$FFFF in this example). # 9.3.4. TIMER STATE TIMING DIAGRAM FOR INPUT CAPTURE # Mask option 1: Internal Processor clock divided by 8 Note: If the input edge occurs in the shaded area from one timer state T10 to the other timer state T10, the input capture flag is set during the next T11 state. # 9.3.4 . (Continued) # Mask Option 2: Internal Processor Clock Divided by 4 Note: If the input edge occurs in the shaded area from one timer state T10 to the other timer state T10, the input capture flag is set during the next T11 state. # Mask Option 3: Internel Processor Clock Divided by 2 Note: If the input edge occurs in the shaded area from one timer state T10 to the other timer state T10, the input capture flag is set during the next T11 state. # 9.4 SOFTWARE FUNCTIONAL DESCRIPTION #### 9.4.1 . COUNTER The key element of the programmble Timer is a 16-bit free running counter or counter register, preceded by a fixed prescaler which divides the internal processor clock by two, four or height according to the manufacturing mask option. The prescaler gives a Timer resolution of 0.5 microsecond for option 3, 1 microsecond for option 2 and 2 microsecond for option 1, with a 4 MHz processor clock. The counter is clocked to increasing values during the low portion of the internal processor clock. Software can read the counter at any time without affecting its value. The double byte free running counter can be read from two locations called "Counter Register" or "Alternate Counter Register". A read sequence containing only a read of the least significant byte of the free running counter will receive the count value at the time of the read. If a read of the free running counter or counter alternate register first addresses the most significant byte it causes the least significant byte to be transferred into a buffer. This buffer value remains unchanged after the most significant byte is "read" even if the user reads the most significant byte several times. This buffer is accessed when reading the free running counter or counter alternate register least significant byte (CLR or ACLR), and thus completes the read sequence of the total counter value. Note that in reading either the free running counter or counter alternate register, if the most significant byte is read, the least significant byte must also be read in order to complete the sequence. The free running counter is configured to \$FFFC during external reset and is always a read-only register. During a power-on reset (POR), the counter is also configured to \$FFFC and begins running the oscillator startup delay. Because the 16 bit free running counter is preceded by a mask option programmable divide by 2, 4 or 8 prescaler, the value in the free running counter repeats respectively every 131072, 262144, or 524288 internal processor clock. When the counter rolls over from \$FFFF to \$0000, the Timer Overflow flag (TOF) bit is set (bit-5 of TSR). Timer interrupt is then enabled by setting the TOIE bit (bit 5 of TCR). # 9.4.2. INPUT CAPTURE Input Capture High Register: | | , <del>-</del> | | | | | | | |------|----------------|-------|-------|-------|-------|-------|-------| | | | | | | | | | | CTH7 | CTHE | CTHE | CTU | CTU2 | CTU2 | CTU1 | CTUA | | CITI | CITIO | 01113 | C1114 | CITIS | CITIZ | Cirii | CITIO | | 1 | | | | | | 1 | | # Input Capture Low register: | CTL7 Ç1 | TL6 CTL5 | CTL4 | CTL3 | CTL2 | CTL1 | CTL0 | |---------|----------|------|------|------|------|------| |---------|----------|------|------|------|------|------| The Input Capture Register (ICR) is a 16-bit register, which is made up of two 8-bit register: the most significant byte register (ICHR) and the least significant byte register (ICLR). These registers are read only and are used to latch the value of the free running counterafter a defined transition is sensed by the input capture edge detector at pin ICAP. When an input capture occurs, the corresponding flag ICF (bit-7) in Timer Status Register (TSR) is set. The level transition of the input capture pin ICAP which trigggers the counter transfer for ICR is defined by the corresponding input edge bit IEDG (bit-1) of the Timer Control Register (TCR). - \_ IEDG1 = 0 = Negative Edge Sensitive - \_ IEDG1 = 1 = Positive Edge Sensitive. Hardware circuitry has to provide protection from generating a wrong input capture when changing the edge sensitivity option of ICAP pin (IEDG-bit). The Input Capture Register is undetermined at power-on and is not affected by an external reset. An interrupt can also accompany an input capture provided the corresponding interrupt enable bit, ICIE (bit-7 of Timer Control Register) is set. The result obtained by an input capture will be one more than the value of the free running counter on the rising edge of the internal processor clock preceding the external transition (refer to 9. 3.4). This delay is required for internal synchronisation. The free running counter is transferred to the input capture Register on each proper signal transition regardless of whether the Input Capture Flag ICF (bit-7 of Timer Status Register) is set or clear. The Input Capture Register always contains the free running counter value which corresponds to the most recent input capture. After a read of the most significant byte of the Input Capture Register (ICHR), counter transfer of input capture is inhibited until the least significant byte of input capture Register (ICLR) is also read. This characteristic forces the minimum pulse period attainabe to be determined by the time used in the capture software routine and its interaction with the main program. A read of the least significant byte of the input Capture Register (ICLR) does not inhibit the free running transfer. Again, minimum pulse periods are the ones which allow software to read the least significant byte and perform needed operations. There is no conflict between the read of the Input Capture Register and the running counter transfer since they occur on opposite edges of the internal processor clock ## 9.4.3. OUTPUT COMPARE REGISTERS Output Compare Registers can be used for several purposes such as controlling an output waveform or indicating when a period of time has elapsed. The Output Compare Registers are unique because all bits are readable and writable and are not affected by the Timer hardware. Power-on or external reset does not affect the contents of these registers, and if the compare functions are not utilised, the two bytes of the Output Compare Registers can be used as storage locations. Output Compare High Register: | CMH7 | СМН6 | СМН5 | CMH4 | СМНЗ | CMH2 | CMH1 | СМНО | |------|------|------|------|------|------|------|------| | | L | | | | | | | ### Output Compare Low Register 1: | CML7 | CML6 | CML5 | CML4 | CML3 | CML2 | CML1 | CML0 | |------|------|------|------|------|------|------|------| |------|------|------|------|------|------|------|------| The Output Compare Register (OCR) is a 16-bit register, which is made up of two 8-bit registers: The most significant byte register (OCHR) and the least significant byte register (OCLR. The contents of the Output Compare Register are compared with the contents of the free running counter once during every 2,4 or 8 internal processor clock periods according to the timer clock source mask option 1 (Fop /2), 2 (Fop /4) or 3 (Fop /8). If match is found, the Output Compare Flag OCF (bit-6 of Timer Status Register) is set and the corresponding output level OLVL1-bit (bit 0 of the Timer Control Register) is co- pied to an output level latch connected to the OCMP pin. The value in the output compares register and the output level bit register. It could be changed after each successful comparison in order to control an output waveform or establish a new elapsed timeout. An interrupt can also accompany a successful output compare provided the corresponding interrupt enable bit OCIE (bit-6 of the Timer Control Register), is set. After a processor write cycle to the Output Compare Register containing the most significant byte, the output compare function is inhibited until the least significant byte is also written. The user must write both bytes (locations) if the most significant byte is writen first. A write made to only the least significant byte will not inhibit the compare function. The minimum time required to update the Output Compare Register is a function of the software program rather than the internal hardware. The output level bit (OLVL) is copied to the corresponding output level latch and hence, to the OCMPpin regardless of whether the Output Compare Flag (OCF) is set or not. ## 9.4.4 . TIMER CONTROL REGISTER The Timer Control Register (TRC) is an 8 bit read/write register. Three of these bits in this control register are the interrupts associated with the three flag bits found in the Timer status register (see section 9.4.5). One bit controls which edge is significant edge detector for the input capture (negative or positive). One bit controls the next values to be copied to the output level latches in response to successful output compares. Timer Control Register: | ICIE | OCIE | TOIE | 0 | 0 | 0 | IEDG | OLVL | |------|------|------|---|---|---|------|------| | | | 1 | 1 | | 1 | : | t . | ## Bit-7: ICIE If ,the Input Capture Interrupt Enable (ICIE) is set, a Timer interrupt is enabled whenever the ICF status flag (in the Timer Status Register) is set. If the ICIE-bit is clear, the interrupt is inhibited. The ICIE-bit is cleared by power-on or external reset. ### Bit-6: OCIE If the Output Compare Interrupt Enable (OCIE) is set, a Timer interrupt is enabled whenever the OCF status flag (in the Timer Status Register) is set. If the OCIE-bit is clear, the interrupt is inhibited. The OCIE-bit is cleared by power-on or external reset. ### Bit-5: TOIE If the Timer Overflow Interrupt Enable (TOIE) is set, a Timer interrupt is enable whenever the TOF status flag (in the Timer Status Register) is set. If the TOIE-bit is clear, the interrupt is inhibited. The TOIE-bit is cleared by power-on or external reset. #### Bit-1: IEDG The value of the IEDG-bit (Input Edge ) determines which level transition on pin ICAP will trigger a free running counter transfer to the Input Capture Register. The IEDG-bit is undetermined at power-on or external reset. - LIEDG = 0 = Negative Edge - \_ IEDG = 1 = Positive Edge #### Bit-0: OLVL The value of OLVL-bit (output Level) is copied into the output level latch by the next successful output compare and will appear at pin OCMP. The OLVL-bit and the output level latch are cleared by power-on or external reset. - OLVL = 0 = Low Output - OLVL = 1 = High Output. #### 9.4.5. TIMER STATUS REGISTER The Timer Status Register (TSR) is an 8-bit register of which the three most significant bits contain readonly status information. These five bits indicates the following. - a) A proper transition has been taken at pin ICAP with an accompanying transfer of the free running counter content to the corresponding Input Capture Register. - b) A match has been found between the free running counter and the Output compare Register OCR. - c) A free running counter transition from \$FFFF to \$0000 has been sensed (Timer Overflow). The timer Status Register is illustrated below and followed by a definition of each bit. Timer Status Register: | ICF OCF TOF 0 0 0 0 0 | |-----------------------| |-----------------------| #### Bit-7: ICF1 The Input Capture Flag (ICF) is set when a proper edge has been sensed by the input capture edge detector at pin ICAP. The edge is selected by the IEDG-bit in the Timer Control Register. It is cleared by a processor access of the Timer Status Register (with ICF set) followed by accessing (read or write) the low byte of the Input Capture Register (ICLR). The Input Capture Flag is undetermined at poweron, and is not affected by an external reset. ## Bit-6: OCF The Output Compare Flag (OCF) is set when the content of the free running counter matches the content of the Output Compare Register. It is cleared by a processor access of the Timer Status Register (with OCF set) followed by accessing (read or write) the low byte of the Output Compare Register (OCLR). The Output Compare Flag is undetermined at power-on, and is not affected by an external reset. ## Bit-5: TOF The Timer Overflow Flag (TOF) is set by a transition of the free running counter from \$FFFF to \$0000. It is cleared by a processor access of the Timer Status Register (with TOF set) followed by accessing (read or write) the low byte of the counter low register (CLR). The Timer Overflow Flag is undetermined at poweron, and is not affected by an external reset. Note: An access to the Alternate Counter Register (ACLR or ACHR) does not affect the TOF-bit. Accessing the Timer Status Register satisfies the first condition required to clear any status bits which happen to be set during the access. The remaining step is to access the register which is associated with the status bit. Typically, this presents no problem for the input capture and output compare function. A problem may occur when using the timer overflow function and reading the free running counter at random times to measure on elapsed time. Without incorporating the proper precautions into software, the Timer Overflow Flag (TOG-bit) could unintentionally be cleared if: a) The Timer Status Register is accessed when TOF is set. b) The least significant byte of the free running counter (CLR) is read but not for the purpose of servicing the flag. ## 9.4.6. TIMER INTERRUPTS There are three different Timer Interrupt Flags (ICF, OCF, TOF) that will cause a Timer interrupt whenever they are set and enable. These three interrupt flags are found in the most significant bits of the Timer Status Register (TSR). There are three corresponding enable bits: ICIE for ICF, OCIE for OCF and TOIE for TOF. These enable bits are located in the Timer Control Regster (TCR). Power-on and external reset clears all enable bits, thus preventing an interrupt from occuring during the reset time period. The general sequence for clearing an interrupt is a software sequence of accessing by a read or write of the low byte associated register. # 9.4.7 . POWER-ON AND EXTERNAL RESET INFLUENCE The timer Control Regsister and the free running counter are the only sections of the timer affected by a power-on or an external reset. #### 9.4.7.1 . Output Compare Functions The OCMP output latch is forced low during reset and stays low until valid compares change them to a high level. Because the Output Compare Flags(OCF) and Output Compare Registers are undeterminate at power-on, and are not affected by an external reset, care must be exercise when initializing the output compare functions with software. The following procedure is recommended. a) Write the "high" byte at the output compare register to inhibit further compares until the low byte is written. - b) Read the Timer Status Register to arm the OCF, bit if it is already set. - c) Write the Output Compare Register "low" byte to enable the output compare function with the flag clear. The purpose of this procedure is to prevent the OCF, bit from being set between the time it is read and the write to the corresponding Output Compare Register ### 9.4.8 WFI AND HALT During the WFI mode the TIMER continues to operate normally and may generate an interrupt to trigger the CPU out of the WFI state. During the HALT mode the TIMER holds its current state retaining all data, and resumes operations from this point when an external interrupt is received. If an external reset is received the TIMER value will be set at \$FFFC. A power-on detect has the same effect. Another feature of the programmable timer is that in the HALT mode, if a least one valid input capture edge occurs at the ICAP pin, the corresponding input capture detect circuitry is armed. This action does not set any timer flags nor "wake-up" the MCU. But, when the MCU does wake up, there is an active input capture flag (and data) from the first valid edge that occured during the HALT mode. If the HALT mode is exited by an external reset then no such input capture flag or data action takes place even if there was a valid input capture edge (at the ICAP pin) during the MCU HALT mode. ### PART 10. ST8002 ELECTRICAL SPECIFICATIONS ### 10.1. MAXIMUM RATINGS The ST8002 device contains circuitry to protect the inputs againts damage due to high static voltage or electric field. Never the less it is advised to take normal precautions and avoid to apply to this high impedance voltage circuit, any voltage higher than the maximum rated voltages. It is recommended for proper operation that $V_{\text{IN}}$ and $V_{\text{OUT}}$ be constrained to the range : ## - $V_{SS} \le V_{IN}$ or $V_{OUT} \le V_{DD}$ To enhance reliability of operation, it is recommended to connect unused inputs to an appropriate logic voltage level such as $V_{SS}$ or $V_{DD}$ . All the voltage in the following tables are referenced to $\ensuremath{\text{V}_{\text{SS}}}$ TABLE 10.1. MAXIMUM RATINGS (Voltage Referenced to Vss) | Symbol | Ratings | Value | Unit | |------------------|---------------------------------------------------------------------|----------------------------------|------| | V <sub>DD</sub> | Supply Voltage | -0.3 to +7.0 | V | | VIN | Input Voltage | $V_{SS}$ -0.3 to $V_{DD}$ + 0.3 | V | | 1 | Current Drain Per Pin Excluding V <sub>DD</sub> and V <sub>SS</sub> | 25 | mA | | TA | Operating Temperature Range | T <sub>L</sub> to T <sub>H</sub> | °C | | | ST8108B1 (Standard) | 0 to +70 | °C | | | ST8108B6 (Extended) | -40 to +85 | °C | | | ST8108B3 (Automotive) | -40 to +125 | °C | | T <sub>STG</sub> | Storage Temperature Range | -65 to +150 | °C | # **TABLE 10.2. THERMAL CHARACTERISTICS** | Symbol | Characteristics | Value | Unit | |--------|------------------------------------|-------|------| | θJA | Thermal Resistance | | °C/W | | | Ceramic | 50 | | | | Plastic | 60 | | | | Plastic leaded Chip Carrier (PLCC) | 70 | | # Figure 10.1. Equivalent Test Load $V_{DD} = 4.5V$ | Pins | R1 | R2 | С | |---------|--------|--------|------| | PA0-PA7 | 3.26kΩ | 2.38kΩ | 50pF | | PB5-PB7 | | | | | PC0-PC7 | | | | $V_{DD}=3.0V$ | Pins | R1 | R2 | С | |---------|---------|--------|------| | PA0-PA7 | 10.91kΩ | 6.32kΩ | 50pF | | PB5-PB7 | | | | | PC0-PC7 | | | | ## 10.2. POWER CONSIDERATIONS T<sub>J</sub>, the average chip-junction temperature in Celsius can be calculated from the following equation: $$T_{J} = T_{A} + (P_{D} \cdot \theta J_{A}) \tag{1}$$ # Where: - TA is the Ambient Temperature in °C, - θJa ithe Package Thermal Resistance, Junction-to-Ambient in °C/W. - PD the sum of PINT and PI/O. - PINT equals I<sub>CC</sub> time V<sub>CC</sub>, Watts-Chip Internal Power - P<sub>I/O</sub> the Power Dissipation on Input and Output Pins, User Determined. For most applications $P_{\text{I/O}} < P_{\text{INT}}$ and can be neglected . PPORT may be significant if the device is configured to drive Darlington bases or sink LED Loads. An approximate relationship between $P_D$ and $T_J$ (if $P_{I/O}$ is neglected) is: $$P_D = K \div (T_J + 273^{\circ}C)$$ (2) Therefore: $$K = P_{D} \cdot (T_A + 273^{\circ}C) + \theta J_A \cdot P_D^2$$ (3 Where K is constant pertaining to the particular part, K can be determined from equation (3) by measuring $P_D$ (at equilibrium) for a kwon $T_A$ . Using this value of K, the values of $P_D$ and $T_J$ can be obtained by solving equations (1) and (2) iteratively for any value of $T_A$ #### Table 10.4. DC ELECTRICAL CHARACTERISTICS $(V_{DD} = 5.0 \text{ V}_{dc} \pm 10\%, V_{SS} = 0 \text{ V}_{dc}, T_A = T_L \text{ to } T_H \text{ unless otherwise noted})$ | Symbol | Characteristics | Min. | Тур. | Max. | Unit | |-----------------|--------------------------------------------------------------|----------------------|----------|---------------------|----------| | Vol | Output Voltage, Load ≤ 10.0 μA | | | 0.1 | ٧ | | $V_{OH}$ | | V <sub>DD</sub> -0.1 | | | ٧ | | | Output High Voltage | | | | | | $V_{OH}$ | (I LOAD = 0.8 mA) PA0-PA7,PB5-PB7,PC0-PC7,OCMP_(See Fig.9.2) | V <sub>DD</sub> -0.8 | | | V | | V <sub>OH</sub> | (I LOAD = 1.6 mA)PD1-PD4 (See Fig. 9.3) | V <sub>DD</sub> -0.8 | | | V | | Vol | Output Low Voltage (See Fig. 9.4) | | | | V | | | (I LOAD = 1.6 mA) PA0-PA7,PB5-PB7,PC0-PC7,OCMP | | | 0.4 | | | $V_{IH}$ | Input High Voltage | | | | | | | PA0-PA7,PB5-PB7,PC0-PC7,PD5,PD7,ICAP,IRQ,RESET,OSC1 | 0.7xV <sub>DD</sub> | | V <sub>DD</sub> | V | | $V_{IL}$ | Input Low Voltage | | | | | | | PA0-PA7,PB5-PB7,PC0-PC7,PD5,PD7,ICAP,IRQ,RESET,OSC1 | Vss | | 0.2xV <sub>DD</sub> | V | | V <sub>RM</sub> | Data Retention Mode (0 to 70°C) | 2 | | | ٧ | | | Supply Current (See Notes) | | | | | | I <sub>DD</sub> | Run (Fosc = 4.2 MHz)<br>(Fosc = 8 MHz) | | 3.5<br>6 | 7.0<br>12.0 | mA<br>mA | | 1 <sub>DD</sub> | Wait (Fosc = 4.2 MHz)<br>(Fosc = 8 MHz) | | 1.6<br>3 | 4.0<br>8.0 | mA<br>mA | | | Stop | | | | <br> | | $I_{DD}$ | -40 to 85°C | | 1 | 10 | μΑ | | I <sub>DD</sub> | -40 to 125°C | | 1 | 10 | μА | | I₁∟ | I/O Ports Hi-Z Leakage Current | | | | μА | | | PA0-PA7,PB5-PB7,PC0-PC7,PD5-PD7 | | | ± 10 | | | lin | Input Current : RESET, IRQ, ICAP, OSC1, PD0, PD5, PD7 | | | ±1 | μΑ | | Cout | Capacitance : Ports (as Input or Output) | | | 12 | рF | | CIN | RESET, IRQ, ICAP, OSC1, PD5, PD7 | | | 8 | рF | #### Notes: 4 - 1 All values show reflect average measurements - 2 Typical values at midpiont of voltage range, 25°C only - 3 Wait IDD : timer system active. - Run (Operating) $I_{DD}$ , wait $I_{DD}$ : measured using external square wave clock source (f $_{OSC}$ = 4.2 MHz) all inputs 0.2V from rail, no DC loads, less than 50 pF on all outputs, $C_L$ = 20 pF on OSCOUT. - 5 Wait, stop $I_{DD}$ : all ports configured as inputs, $V_{IL}=0.2V$ , $V_{IH}=$ $V_{DD}$ -0.2V Stop $I_{DD}$ : all ports measured with OSCIN = $V_{SS}$ - 7 Standard temperature range is 0° to 70°C. Extended temperature (-40° to 85°C, -40° to 125°C) version and a 25°C only version available. - 8 Wait lob is affected linearly by OSCIN capacitance. - 9 Typical curves of lob (supply current) versus for (internal frequency) are given on figures 12.5., 12.6.a, and 12.6.b.. # Table 10.5. DC ELECTRICAL CHARACTERISTICS $(V_{DD}=3.3\ V_{dc}\pm10\%,\ V_{SS}=0\ V_{dc},\ T_{A}=T_{L}$ to $T_{H}$ unless otherwise noted) | Symbol | Characteristics | Min. | Тур. | Max. | Unit | |-----------------|--------------------------------------------------------------|----------------------|------|---------------------|------| | V <sub>OL</sub> | Output Voltage, Load ≤ 10.0 μA | | | 0.1 | V | | V <sub>OH</sub> | | V <sub>DD</sub> -0.1 | | | V | | | Output High Voltage | | | | | | $V_{OH}$ | (I LOAD = 0.2 mA) PA0-PA7,PB5-PB7,PC0-PC7,OCMP (See Fig.9.2) | V <sub>DD</sub> -0.3 | | | ٧ | | $V_{OH}$ | (I <sub>LOAD</sub> = 0.4 mA)PD1-PD4 (See Fig. 9.3) | V <sub>DD</sub> -0.3 | | | V | | $V_{\text{OL}}$ | Output Low Voltage (See Fig. 9.4) | | | | V | | | (I LOAD = 0.4 mA) PA0-PA7,PB5-PB7,PC0-PC7,OCMP | | | 0.3 | | | VIH | Input High Voltage | | | ! | | | | PA0-PA7,PB5-PB7,PC0-PC7,PD5,PD7,ICAP,IRQ,RESET,OSC1 | 0.7xV <sub>DD</sub> | | V <sub>DD</sub> | V | | V <sub>IL</sub> | Input Low Voltage | | | | | | | PA0-PA7,PB5-PB7,PC0-PC7,PD5,PD7,ICAP,IRQ,RESET,OSC1 | Vss | | 0.2xV <sub>DD</sub> | V | | V <sub>RM</sub> | Data Retention Mode (0 to 70°C) | 2 | | | ٧ | | | Supply Current (See Notes) | | | | | | $I_{DD}$ | Run (Fosc = 2.1 MHz) | | 1.0 | 2.5 | mA | | $I_{DD}$ | Wait (Fosc = 2.1 MHz) | | 0.5 | 1.4 | mA | | | Stop | | | | | | $I_{DD}$ | -40 to 85°C | | 1 | 5 | μΑ | | $I_{DD}$ | −40 то 125°C | | 1 | 5 | μА | | lı∟ | I/O Ports Hi-Z Leakage Current | | | | μА | | | PA0-PA7,PB5-PB7,PC0-PC7,PD5-PD7 | | | ± 10 | | | I <sub>IN</sub> | Input Current : RESET, IRQ, ICAP, OSC1, PD0, PD5, PD7 | | | ± 1 | μА | | Cout | Capacitance : Ports (as Input or Output) | | | 12 | pF | | CIN | RESET, IRQ, ICAP, OSC1, PD5, PD7 | | | 8 | pF | - 1 All values show reflect average measurements - 2 Typical values at midpiont of voltage range, 25°C only - 3 Wait I<sub>DD</sub>: timer system active. - 4 Run (Operating) loo, wait loo: measured using external square wave clock source (f osc = 2.1 MHz) all inputs 0.2V from rail, no DC loads, less than 50 pF on all outputs, C<sub>L</sub> = 20 pF on OSCOUT. - 5 Wait, stop $I_{DD}$ : all ports configured as inputs, $V_{IL} = 0.2V$ , $V_{IH} = V_{DD} 0.2V$ - Stop I<sub>DD</sub>: all ports measured with OSCIN = V<sub>SS</sub> - 7 Standard temperature range is 0° to 70°C. Extended temperature (-40° to 85°C, -40° to 125°C) version. - 8 Wait IDD is affected linearly by OSCIN capacitance. - 9 Typical curves of I<sub>DD</sub> (supply current) versus f<sub>OP</sub> (internal frequency) are given on figures 12.5., 12.6.a, and 12.6.b.. Figure 10.5 . Typical Current vs Internal Frequency for Run and Wait Modes Figure 10.6a. Maximun IDD vs Frequency for VDD = 5.0 Vdc Figure 10.6b. Maximun IDD vs Frequency for VDD = 3.3 Vdc ## Table 10.6. CONTROL TIMING (Maximum Bus Speed = 4MHz) $(V_{DD} = 5.0 V_{dc} \pm 10\%, V_{SS} = 0 V_{dc}, T_A = T_L \text{ to } T_H)$ | Symbol | Characteristics | Min. | Тур. | Max. | Unit | |----------------------------------|-----------------------------------------------------------------|-------|------|------|------| | | Frequency of option | | | | | | fosc | Crystal Option | | | 8 | MHz | | fosc | External Option | dc | | 8 | MHz | | | Internal Operating Frequency | | | | | | $f_{OP}$ | Crystal (fosc + 2) | | | 4 | MHz | | f <sub>OP</sub> | External Clock (fOSC ÷ 2) | dc | | 4 | MHz | | toyo | Clock Time | 125 | | | ns | | toxov | Crystal Oscillator Start-up Time (See Fig.5.1) | | | 50 | ms | | tiLCH | Stop Recovery Start-up Time (Crystal oscillator) (See Fig.12.2) | | | 50 | ms | | t <sub>RL</sub> | RESET Pulse Width (See Fig.5.1) | 1.5 | | | toyo | | | Timer | | | | | | trest | Resolution** | 2/4/8 | | | toyo | | $t_{TH}, t_{TL}$ | Input Capture Pulse Width (See Fig.12.3) | 125 | | | ns | | tTLTL | Input Capture Pulse Period (See Fig.12.3) | *** | | | toyo | | tilii | Interrupt Pulse Width Low (Edge-triggered) (See Fig.5.6) | 125 | | | ns | | t <sub>ILIL</sub> | Interrupt Pulse Period (See Fig.5.6) | * | | · | toyo | | t <sub>OH</sub> ,t <sub>OL</sub> | OSCIN Pulse Width | 45 | | | ns | The minimum preiod t<sub>ILIL</sub> should not be less than the number of cycles times it takes to execute the interrupt service routine plus 21t<sub>CYC</sub>. Depending of the timer input clock mask option (fop/2, fop/4, fop/8) the resolution can be 2 t cyc, 4 tcyc, 8 tcyc. The minimum period t<sub>TLTL</sub> should not be less than the number of cycles times it takes to execute the capture interrupt service routine plus 24 t<sub>CYC</sub>. Figure 10.2. Stop Recovery Timing Diagram - 1 Represents the internal gating of the OSCIN pin. - 2 INT pin edgde-sensitive mask option. - 3 INT pin level and edge sensitive mask option. Figure 10.3. Timer Relationship #### Table 10.7. CONTROL TIMING $(V_{DD} = 3.3 V_{dc} \pm 10\%, V_{SS} = 0 V_{dc}, T_A = T_L \text{ to } T_H)$ | Symbol | Characteristics | Min. | Тур. | Max. | Unit | |----------------------------------|-----------------------------------------------------------------|---------|------|------|------| | | Frequency of Option | | | | | | fosc | Crystal Option | | | 2 | MHz | | fosc | External Option | dc | | 2 | MHz | | | Internal Operating Frequency | | | | | | $f_{OP}$ | Crystal (fosc + 2) | | | 1 | MHz | | fop | External Clock (fOSC + 2) | dc | | 1 | MHz | | toyo | Clock Time | 1000 | | | ns | | toxov | Crystal Oscillator Start-up Time (See Fig.5.1) | | | 50 | ms | | tilch | Stop Recovery Start-up Time (Crystal oscillator) (See Fig.12.2) | | | 50 | ms | | t <sub>RL</sub> | RESET Pulse Width (See Fig.5.1) | 1.5 | | | toyo | | | Timer | | | | | | tRESL | Resolution** | 2/4.0/8 | | | toyo | | $t_{TH}, t_{TL}$ | Input Capture Pulse Width (See Fig.12.3) | 250 | | | ns | | tTLTL | Input Capture Pulse Period (See Fig.12.3) | *** | | | tcyc | | tiLiH | Interrupt Pulse Width Low (Edge-triggered) (See Fig.5.6) | 250 | | | ns | | till | Interrupt Pulse Period (See Fig.5.6) | * | | | toyo | | t <sub>OH</sub> ,t <sub>OL</sub> | OSCIN Pulse Width | 200 | | | ns | The minimum preiod till should not be less than the number of cycles times it takes to execute the interrupt service routine plus 21teys. Depending of the timer input clock mask option (for 12, for 14, for 18) the resolution can be 2 t evc. 4 tevc. 8 tevc. The minimum period from should not be less than the number of cycles times it takes to execute the capture interrupt service routine plus 24 tevc. ## Table 10.10. DC ELECTRICAL CHARACTERISTICS FOR LOW VOLTAGE OPERATION $(V_{DD} = 2.4 V_{dc} - 3.6 V_{dc}, V_{SS} = 0 V_{dc}, T_A = T_L \text{ to } T_H \text{ unless otherwise noted})$ | Symbol | Characteristics | Min. | Тур. | Max. | Unit | |-----------------|--------------------------------------------------------------|----------------------|------|---------------------|------| | $V_{OL}$ | Output Voltage, Load ≤ 10.0 μA | | | 0.1 | V | | V <sub>OH</sub> | | V <sub>DD</sub> -0.1 | | | V | | | Output High Voltage | | | | | | $V_{OH}$ | (I LOAD = 0.2 mA) PA0-PA7,PB0-PB7,PC0-PC7,OCMP (See Fig.9.2) | | | | V | | $V_{OH}$ | (I LOAD = 0.4 mA)PD1-PD4 (See Fig. 9.3) | V <sub>DD</sub> -0.3 | | | V | | VoL | Output Low Voltage (See Fig. 9.4) | VDD-0.3 | | | V | | | (I LOAD = 0.4 mA) PA0-PA7,PB0-PB7,PC0-PC7,PD1-PD4,OCMP | | | 0.3 | | | VIH | Input High Voltage | | | | | | | PA0-PA7,PB0-PB7,PC0-PC7,PD0-PD5,PD7,ICAP,IRQ,RESET,OSC1 | 0.7xV <sub>DD</sub> | | V <sub>DD</sub> | V | | VIL | Input Low Voltage | | | | | | | PA0-PA7,PB0-PB7,PC0-PC7,PD0-PD5,PD7,ICAP,IRQ,RESET,OSC1 | Vss | | 0.2xV <sub>DD</sub> | V | | $V_{RM}$ | Data Retention Mode (0 to 70°C) | 20 | | | V | | | Supply Current (2.4Vdc at 500kHz) | | | | | | IDD | Run (See Fig.12.5) | | | 750 | μΑ | | $I_{DD}$ | Wait (See Fig.12.5) | | ĺ | 400 | μΑ | | | Stop (See Fig.12.5) | | | | | | IDD | 0 to 70°C | | 1 | 5.0 | μА | | IIL | I/O Ports Hi-Z Leakage Current | | | | μА | | | PA0-PA7,PB0-PB7,PC0-PC7,PD1-PD4 | | | ± 10 | | | I <sub>IN</sub> | Input Current : RESET, IRQ, ICAP, OSC1, PD0, PD5, PD7 | | | ± 1 | μА | | Cout | Capacitance : Ports (as Input or Output) | | | 12 | pF | | CIN | RESET, IRQ, ICAP, OSC1, PD0-PD5, PD7 | | | 8 | pF | - All values show reflect average measurements - 2 - National States and relief a wareage interests. Typical values at midpiont of voltage range, 25°C only Wait lob : only timer system active (SPE=TE=RE=0) if SPI, SCI active (SPE= TE= RE=1) add 10% current draw. - Run (Operating) IDD, wait IDD: measured using external square wave clock source (f osc = 1.0 MHz) all inputs 0.2V from rail, no DC loads, less than 50 pF on all outputs, CL = 20 pF on OSC2. - Wait, stop $I_{DD}$ : all ports configured as inputs, $V_{IL}$ = 0.2V, $V_{IH}$ = $V_{DD}$ -0.2V - Stop IDD : all ports measured with OSC1 = Vss - Standard temperature range is 0° to 70°C. Extended temperature (-40° to 85°C) range is available. - Wait IDD is affected linearly by OSC2 capacitance. # Table 10.12. CONTROL TIMING FOR LOW VOLTAGE OPERATION $(V_{DD} = 2.4 V_{dc} - 3.6 V_{dc}, V_{SS} = 0 V_{dc}, T_A = T_L \text{ to } T_H)$ | Symbol | Characteristics | Min. | Тур. | Max. | Unit | |-------------------|-----------------------------------------------------------------|-------|------|------|------| | fosc | Frequency of option | | | | MHz | | | Crystal Option | | | 1.0 | | | | External Option | dc | | 1.0 | | | fop | Internal Operating Frequency | | | | MHz | | | Crystal (fosc + 2) | | } | 0.5 | | | | External Clock (fosc ÷ 2) | dc | | 0.5 | | | toyo | Clock Time | 2000 | | | ns | | toxov | Crystal Oscillator Start-up Time (See Fig.5.1) | | | 50 | ms | | tiLCH | Stop Recovery Start-up Time (Crystal oscillator) (See Fig.12.2) | | | 50 | ms | | t <sub>RL</sub> | RESET Pulse Width (See Fig.5.1) | 1.5 | | | tcyc | | | Timer | | | | | | t <sub>RESL</sub> | Resolution** | 2/4.8 | | | toyo | | $t_{TH}, t_{TL}$ | Input Capture Pulse Width (See Fig.12.3) | 250 | | | ns | | ttltl | Input Capture Pulse Period (See Fig.12.3) | *** | | | tcyc | | tilsH | Interrupt Pulse Width Low (Edge-triggered) (See Fig.5.6) | 500 | | | ns | | tilli | Interrupt Pulse Period (See Fig.5.6) | * | | | tcyc | | ton,tol | OSCIN Pulse Width | 400 | | | ns | #### Notes: - The minimum period tiul should not be less than the number of cycles times it takes to execute the interrupt service routine plus 21tcyc. - Depending of the timer input clock mask option (fop/2, fop/4, fop/8) the resolution can be 2 t cyc, 4 tcyc, 8 tcyc. - The minimun period truπ should not be less than the number of cycles times it takes to execute the capture interrupt service routine plus 24 t<sub>Cyc</sub>. # Figure 10.5. Maximum $I_{DD}$ vs Frequency for $V_{DD}$ = 2.4 $V_{dc}$ #### ST8002 ORDERING FORM | 1 | ) U | lser | R | MC | Co | ntent | t | |---|-----|------|---|----|----|-------|---| |---|-----|------|---|----|----|-------|---| The hexadecimal object file is recommended to be sent in an hexadecimal file (assembler output), stored on a PC/DOS, 360K Double Sided 5 1/4 floppy disk. If the floppy media can not be provided by the customer, the ROM file can be also sent in a 27xx EPROM memory, where all unused bytes must be left erased to "FF". | 2) Mask Option List & application information | | |-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------| | Oscillator: Crystal/Resonator Resistor | Interrupt trigger: Edge only sensitive Level & Edge sensitive | | Timer internal clock source : ☐ Standard (Fop/4) ☐ Slow (Fop/8) ☐ Fast (Fop/2) | Frequency of operation (Fop): Oscillator frequency = Fosc =MHz Internal operation Fop = Fosc/2 =MHz | | PORT A Input pull downs: (100 K Ohms typ.) PA7 PA6 PA5/PA4 PA3/PA2/PA1/PA0 | PORT C Input pull downs : (100 K Ohms typ.) ☐ PC7 ☐ PC6 ☐ PC5/PC4 ☐ PC3/PC2/PC1/PC0 | | Halt Mode : ☐ Used ☐ Not Used | Wait Mode : ☐ Used ☐ Not Used | | Voltage range: □ standard 4.5V/5.5V □ low 2.7V/3.3V □ extended 3V/6V □ otherV | Temperature: ☐ standard 0/70 C ☐ extended -40/85 C ☐ other | | 3) Packaging DIL plastic 28 S028 | 4) Marking ST LOGO, Date Code, Assy code ST8002XX/YY (ST part number) | | <ul><li>☐ Wafer on membrane</li><li>☐ Sawed dice (waffle box)</li></ul> | (customer id, 11 characters). | | COMPANY/NAME : | SIGNATURE: | 50 ## **ORDERING INFORMATION** | PART NUMBER | PACKAGE | TEMPERATURE | |-------------|------------------|-------------| | ST8002-B1 | PLASTIC DIL 28 | 0°C/70°C | | ST8002-B6 | PLASTIC DIL 28 | -40°C/+85°C | | ST8002-M1 | SMALL OUTLINE 28 | 0°C/70°C | | ST8002-M6 | SMALL OUTLINE 28 | -40°C/+85°C | <sup>\*</sup> NOTE : Each ROM content is identified by two alphabetic characters xx to be added to the sales type (i.e. ST8108 B1/xx). | Information furnished is believed to be accurate and reliable. However, SGS-THOMSON Microelectronics assumes no responsability for the consequences of use of such information nor for any intringement of patents or other rights of third parties which may results from its use. No license is granted by implication or otherwise under any patent or patent rights of SGS-THOMSON Microelectronics. Specifications mentioned in this publication are subject to change without notice. This publication supersedes and replaces all informations previously supplied. | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | © 1990 SGS-THOMSON Microelectronics - Printed in France - All Rights Reserved | | SGS-THOMSON Microelectronics GROUP OF COMPANIES Australia - Brazil - China - France - Hong Kong - Italy - Japan - Korea - Malaysia - Malta - Morocco - The Netherlands - Singapore - Spain - Sweden - Switzerland - Taiwan - United Kingdom - U.S.A West Germany | | Printed by NTI - AGL Partenaires - Belcodène - France | 036550 🗹 \_ 🖺 -