# Hitachi Single-Chip Microcomputer H8/3103 HD6483103 Hardware Manual # Notice When using this document, keep the following in mind: - 1. This document may, wholly or partially, be subject to change without notice. - 2. All rights are reserved: No one is permitted to reproduce or duplicate, in any form, the whole or part of this document without Hitachi's permission. - 3. Hitachi will not be held responsible for any damage to the user that may result from accidents or any other reasons during operation of the user's unit according to this document. - 4. Circuitry and other examples described herein are meant merely to indicate the characteristics and performance of Hitachi's semiconductor products. Hitachi assumes no responsibility for any intellectual property claims or other problems that may result from applications based on the examples described herein. - 5. No license is granted by implication or otherwise under any patents or other rights of any third party or Hitachi, Ltd. - 6. MEDICAL APPLICATIONS: Hitachi's products are not authorized for use in MEDICAL APPLICATIONS without the written consent of the appropriate officer of Hitachi's sales company. Such use includes, but is not limited to, use in life support systems. Buyers of Hitachi's products are requested to notify the relevant Hitachi sales offices when planning to use the products in MEDICAL APPLICATIONS. # Contents | Pretace | | | | |-----------------------------------------|----|--|--| | Section 1 Overview | 3 | | | | 1.1 Overview | 3 | | | | 1.2 Block Diagram | 5 | | | | 1.3 Pin Arrangement and Functions | 6 | | | | 1.3.1 Pin Arrangement | 6 | | | | 1.3.2 Pin Functions | 7 | | | | Section 2 CPU | 9 | | | | 2.1 Overview | 9 | | | | 2.1.1 Features | 9 | | | | 2.1.2 CPU Registers | 10 | | | | 2.2 Register Descriptions | 11 | | | | 2.2.1 General Registers | 11 | | | | 2.2.2 Control Registers | 11 | | | | 2.2.3 Initial Register Values | 13 | | | | 2.3 Data Formats | 13 | | | | 2.3.1 Data Formats in General Registers | 14 | | | | 2.3.2 Memory Data Formats | 15 | | | | 2.4 Addressing Modes | 16 | | | | 2.4.1 Addressing Modes | | | | | 2.4.2 Effective Address Calculation | 18 | | | | 2.5 Instruction Set | 21 | | | | 2.5.1 Data Transfer Instructions | | | | | 2.5.2 Arithmetic Operations | 25 | | | | 2.5.3 Logic Operations | 26 | | | | 2.5.4 Shift Operations | 26 | | | | 2.5.5 Bit Manipulations | 28 | | | | 2.5.6 Branching Instructions | | | | | 2.5.7 System Control Instructions | 34 | | | | 2.5.8 EEPROM Write Instruction | | | | | 2.6 Operating States | 36 | | | | 2.6.1 Overview | 36 | | | | 2.6.2 Program Execution State | 36 | | | | 2.6.3 Exception-Handling State | | | | | 2.6.4 Power-Down State | | | | | 2.7 Exception Handling | | |-----------------------------------------|----| | 2.7.1 Overview | 37 | | 2.7.2 Reset | 38 | | 2.7.3 Interrupts | 38 | | 2.7.4 Reset Start Timing | 39 | | 2.8 Power-Down State | 40 | | 2.8.1 Overview | 40 | | 2.8.2 Transition to Sleep Mode | 40 | | 2.8.3 Exit from Sleep Mode | 41 | | 2.9 Basic Timing | 43 | | 2.9.1 On-Chip Memory (RAM, ROM, EEPROM) | 43 | | 2.9.2 Register Field (I/O, EEPROM) | 43 | | 2.9.3 Non-Existent Addresses | 43 | | Section 3 Memory Map | 45 | | Section 4 RAM | 47 | | 4.1 Overview | | | 4.1.1 Block Diagram | | | Section 5 ROM | 40 | | 5.1 Overview | | | 5.1.1 Block Diagram | | | Section 6 EEPROM | 51 | | 6.1 Overview | | | 6.1.1 Features | | | 6.1.2 Block Diagram | | | 6.1.3 Memory Organization | | | 6.1.4 Register Configuration | | | 6.2 Register Descriptions | | | 6.2.1 EEPROM Control Register (ECR) | | | 6.2.2 EEPROM Protection Register (EPR) | | | 6.3 EEPROM Read Operation. | 55 | | 6.4 EEPROM Write and Erase Operations | 55 | | 6.4.1 Write/Erase Sequence | 55 | | 6.4.2 Rewrite | 57 | | 6.4.3 Erase | 57 | | 6.4.4 Overwrite | | | 6.5 Write/Erase Protection | | | 6.5.1 Protect Bits | | | 6.5.2 Protection Procedure | 59 | | 6.5.3 Reading the Protect Bits | 59 | | 6.6 Notes | 60 | |------------------------------------------|----| | Section 7 I/O Port | 63 | | 7.1 Overview | 63 | | 7.1.1 Block Diagram | 63 | | 7.1.2 Register Configuration | 64 | | 7.2 Register Descriptions | 64 | | 7.2.1 Data Register (DR) | | | 7.2.2 Data Direction Register (DDR) | 65 | | 7.3 Pin Functions | 66 | | Section 8 Clock Pulse Generator | 67 | | 8.1 Overview | 67 | | Section 9 Security | 69 | | Section 10 Electrical Characteristics | 71 | | 10.1 Absolute Maximum Ratings | 71 | | 10.2 Electrical Characteristics | 71 | | 10.2.1 DC Characteristics (5 V) | 71 | | 10.2.2 AC Characteristics (5 V) | 73 | | 10.2.3 DC Characteristics (3 V) | 75 | | 10.2.4 AC Characteristics (3 V) | 76 | | Appendix A Instruction Set | 79 | | Appendix B Operation Code Map | 87 | | Appendix C Register Field | 89 | | C.1 Register Field (1) | | | C.2 Register Field (2) | 90 | | Appendix D I/O Port Block Diagram | 93 | | Appendix E Comparison with H8/3102 | 95 | | Appendix F H8/3103 DP-64S Pin Assignment | 97 | | Appendix G External Dimensions | 99 | iv HITACHI # **Preface** The H8/3103 is a single-chip microcomputer built around a high-speed H8/300 CPU core. On-chip facilities include 16-kbyte EEPROM, 20-kbyte ROM, 512-byte RAM, and two I/O ports. On-chip EEPROM makes the H8/3103 ideal for applications requiring nonvolatile data storage, including smart cards and portable data banks. Security functions protect data in the on-chip ROM and EEPROM against external reading and writing. This manual describes the H8/3103 hardware. For details of the instruction set, refer to the *H8/300 Series Programming Manual*. # Section 1 Overview #### 1.1 Overview The H8/3103 is a single-chip microcomputer unit (MCU) built around a high-speed H8/300 CPU core. A 16-kbyte EEPROM, 20-kbyte ROM, 512-byte RAM, and 2-bit I/O port are integrated onto the H8/3103 chip. Operating at a maximum 5-MHz internal clock rate at 5 V, the H8/300 CPU rapidly executes bit-manipulation instructions, arithmetic and logic instructions, and data transfer instructions. Security functions protect the data in the ROM and EEPROM. Table 1.1 lists the features of the H8/3103. **Table 1.1** Features | Item | Specification | |------|-----------------------------------------------------------------------------------------| | CPU | H8/300 CPU | | | Two-way general register configuration | | | Sixteen 8-bit registers, or | | | Eight 16-bit registers | | | High-speed operation | | | <ul> <li>Maximum clock rate: 5 MHz (with 10-MHz external clock input at 5 V)</li> </ul> | | | <ul> <li>Add/subtract: 0.4 μs</li> </ul> | | | <ul> <li>Multiply/divide: 2.8 μs</li> </ul> | | | Streamlined, concise instruction set | | | <ul> <li>Instruction length: 2 or 4 bytes</li> </ul> | | | <ul> <li>Register-register arithmetic and logic operations</li> </ul> | | | <ul> <li>MOV instruction for data transfer between registers and memory</li> </ul> | | | Instruction set features | | | <ul> <li>Multiply instruction (8 bits × 8 bits)</li> </ul> | | | <ul> <li>Divide instruction (16 bits ÷ 8 bits)</li> </ul> | | | Bit-accumulator instructions | | | <ul> <li>Register-indirect specification of bit positions</li> </ul> | Table 1.1 Features (cont) | Item | Specification | | | | | |------------------|--------------------------------------------------------------------------------------------|--|--|--|--| | On-chip memory | EEPROM | | | | | | | 16 kbytes | | | | | | | Written using EEPMOV instruction | | | | | | | Page write (1 to 64 bytes) | | | | | | | Page erase (64 bytes) | | | | | | | <ul> <li>Protected against accidental writing and erasing</li> </ul> | | | | | | | On-chip voltage pumping circuit | | | | | | | ROM | | | | | | | 20 kbytes | | | | | | | RAM | | | | | | | • 512 bytes | | | | | | I/O ports | Two general-purpose input/output ports (I/O-1/IRQ also used for interrupt) | | | | | | Interrupt | One external interrupt line: I/O-1/IRQ | | | | | | | Used for interrupt input in sleep mode | | | | | | Power | Single-voltage power supply | | | | | | | • 4.5 V to 5.5 V | | | | | | | • 2.7 V to 3.3 V | | | | | | Clock frequency | External clock input | | | | | | range | • $f_{CLK} = 1 \text{ MHz to } 10 \text{ MHz } (V_{CC} = 4.5 \text{ V to } 5.5 \text{ V})$ | | | | | | | • $f_{CLK} = 1 \text{ MHz to 5 MHz (V}_{CC} = 2.7 \text{ V to 3.3 V)}$ | | | | | | | Internal clock frequency is one-half the external clock frequency | | | | | | Power-down state | Sleep mode | | | | | | Security | Low frequency detector | | | | | | | Low voltage detector | | | | | | | Illegal address detector | | | | | # 1.2 Block Diagram Figure 1.1 shows an internal block diagram of the H8/3103. Figure 1.1 Block Diagram # 1.3 Pin Arrangement and Functions ## 1.3.1 Pin Arrangement Figure 1.2 shows the standard COB pattern. Figure 1.3 shows the bonding pad arrangement of the H8/3103 chip. Figure 1.2 Standard COB Pattern (Electrode Surface) Figure 1.3 Bonding Pad Arrangement #### 1.3.2 Pin Functions Table 1.2 lists the functions of the H8/3103 pins. **Table 1.2 Pin Functions** | Туре | Symbol | I/O | Name and Description | |--------------|---------------------|-----|----------------------------------------------------------------------------------| | Power supply | V <sub>cc</sub> | I | Power supply: 4.5 V to 5.5 V or 2.7 V to 3.3 V | | | V <sub>ss</sub> | I | Ground: 0 V | | Clock | CLK | I | Clock: External clock input | | Reset | RES*1 | I | Reset: Low input resets the chip. | | Ports | I/O-1/ĪRQ*2 | I/O | I/O port 1: One-bit data input/output port. Software can select input or output. | | | | | Interrupt: In sleep mode, this port can receive interrupt input. | | | I/O-2* <sup>2</sup> | I/O | I/O port 2: One-bit data input/output port. Software can select input or output. | Notes: 1. An input pull-up MOS is connected to the RES pin as shown in figure 1.4. Figure 1.4 Block Diagram of RES Pin - 2. The I/O-1/IRQ and I/O-2 pins can be used as I/O ports and the I/O-1/IRQ pin can be used as an interrupt input pin. When these pins are not used, they should be left open. Input pull-up MOS's are connected to these pins. - See section 7, I/O Port, for I/O-1/IRQ and I/O-2 specification details. # Section 2 CPU #### 2.1 Overview The H8/3103 has an H8/300 CPU: an 8-bit central processing unit with a speed-oriented architecture featuring sixteen general registers. This section describes the CPU features and functions, including a concise description of the addressing modes and instruction set. For further details on the instructions, see the *H8/300 Series Programming Manual*. #### 2.1.1 Features The main features of the H8/300 CPU are listed below. - Two-way register configuration - Sixteen 8-bit general registers, or - Eight 16-bit general registers - Instruction set with 55 basic instructions\*, including: - Multiply and divide instructions - Powerful bit-manipulation instructions - EEPROM write instruction - Eight addressing modes Register direct: Register indirect: Register indirect with displacement: Register indirect with post-increment or pre-decrement: Register indirect with post-increment or pre-decrement: Register indirect with post-increment or pre-decrement: Register indirect with post-increment or pre-decrement: Register indirect with post-increment or pre-decrement: Register indirect with displacement: Re Memory indirect:64-kbyte address space Note: \* The H8/300 CPU has 57 basic instructions, but the H8/3103 uses only 55 of them. The MOVFPE and MOVTPE instructions are not used. @@aa:8 - High-speed operation - All frequently-used instructions are executed in two to four states - Maximum clock rate is 5 MHz (with 10-MHz external clock input at 5 V) • 8- or 16-bit register-register add or subtract: 0.4 $\mu s$ • $8 \times 8$ -bit multiply: 2.8 $\mu s$ • $16 \div 8$ -bit divide: 2.8 $\mu s$ - Power-down mode - SLEEP instruction ## 2.1.2 CPU Registers Figure 2.1 shows the register structure of the H8/300 CPU. There are two groups of registers: general registers and control registers. Figure 2.1 CPU Registers ## 2.2 Register Descriptions #### 2.2.1 General Registers All the general registers can be used as both data registers and address registers. When used as data registers, they can be accessed as 16-bit registers (R0 to R7), or the high bytes (R0H to R7H) and low bytes (R0L to R7L) can be accessed separately as 8-bit registers. When used as address registers, the general registers are accessed as 16-bit registers (R0 to R7). Registers R4L, R5, and R6 have special functions when the EEPMOV (EEPROM write) instruction is executed. R7 also functions as the stack pointer, used implicitly by hardware in processing exceptions and subroutine calls. In assembly-language coding, R7 can also be denoted by the symbol SP. As indicated in figure 2.2, SP (R7) points to the top of the stack. Figure 2.2 Stack Pointer #### 2.2.2 Control Registers The CPU control registers include a 16-bit program counter (PC) and an 8-bit condition code register (CCR). - (1) **Program Counter (PC):** This 16-bit register indicates the address of the next instruction the CPU will execute. All instructions are fetched 16 bits (1 word) at a time, so the least significant bit of PC is ignored (always regarded as 0). - (2) Condition Code Register (CCR): This 8-bit register contains internal CPU status information, including the interrupt mask bit (I) and half-carry (H), negative (N), zero (Z), overflow (V), and carry (C) flags. **Bit 7—Interrupt Mask Bit (I):** Masks interrupts when set to 1. This bit is set to 1 at the beginning of exception handling. **Bit 6—User Bit (U):** Can be written and read by software for its own purposes (using the LDC, STC, ANDC, ORC, and XORC instructions). **Bit 5—Half-Carry Flag (H):** When the ADD.B, ADDX.B, SUB.B, SUBX.B, CMP.B, or NEG.B instruction is executed, this flag is set to 1 if there is a carry or borrow at bit 3, and is cleared to 0 otherwise. The H flag is used implicitly by the DAA and DAS instructions. When the ADD.W, SUB.W, or CMP.W instruction is executed, the H flag is set to 1 if there is a carry or borrow at bit 11, and is cleared to 0 otherwise. **Bit 4—User Bit (U):** Can be written and read by software for its own purposes (using the LDC, STC, ANDC, ORC, and XORC instructions). Bit 3—Negative Flag (N): Indicates the most significant bit (sign bit) of data. Bit 2—Zero Flag (Z): Set to 1 to indicate zero data, and cleared to 0 to indicate non-zero data. **Bit 1—Overflow Flag (V):** Set to 1 when an arithmetic overflow occurs, and cleared to 0 at other times. **Bit 0—Carry Flag (C):** Set to 1 when a carry occurs, and cleared to 0 otherwise. Used by: - Add instructions, to indicate a carry - Subtract instructions, to indicate a borrow - Shift and rotate instructions, to store the value shifted out of the end bit The carry flag is also used as a bit accumulator by bit manipulation instructions. Some instructions leave some or all of the flag bits unchanged. The LDC, STC, ANDC, ORC, and XORC instructions enable the CPU to load and store CCR, and to set or clear selected bits by logic operations. The N, Z, V, and C flags are used as branching conditions for conditional branching (Bcc) instructions. Refer to the *H8/300 Series Programming Manual* for the action of each instruction on the flag bits. ## 2.2.3 Initial Register Values When the CPU is reset, the program counter (PC) is loaded from the vector table and the I bit in CCR is set to 1. The other CCR bits and the general registers are not initialized. In particular, the stack pointer (R7) is not initialized. To prevent program crashes the stack pointer should be initialized by software, by the first instruction executed after a reset. #### 2.3 Data Formats The H8/300 CPU can process 1-bit data, 4-bit (BCD) data, 8-bit (byte) data, and 16-bit (word) data. - Bit manipulation instructions operate on 1-bit data specified as bit n (n = 0, 1, 2, ..., 7) in a byte operand. - All arithmetic instructions except ADDS and SUBS can operate on byte data. - The MOV.W, ADD.W, SUB.W, CMP.W, ADDS, SUBS, MULXU (8 bits $\times$ 8 bits), and DIVXU (16 bits $\div$ 8 bits) instructions operate on word data. - The DAA and DAS instructions perform decimal arithmetic adjustments on byte data in packed BCD form. Each nibble of the byte is treated as a decimal digit. ## **2.3.1** Data Formats in General Registers Data of all the sizes above can be stored in general registers as shown in figure 2.3. Figure 2.3 Register Data Formats #### 2.3.2 Memory Data Formats Figure 2.4 indicates the data formats in memory. Word data stored in memory must always begin at an even address. In word access the least significant bit of the address is regarded as 0. If an odd address is specified, no address error occurs but the access is performed at the preceding even address. This rule affects the MOV.W instruction, and also applies to instruction fetching. Figure 2.4 Memory Data Formats When the stack is accessed using R7 as an address register, word access should always be performed. When CCR is pushed on the stack, two identical copies of CCR are pushed to make a complete word. When they are restored, the lower byte is ignored. ## 2.4 Addressing Modes #### 2.4.1 Addressing Modes The H8/300 CPU supports the eight addressing modes listed in table 2.1. Each instruction uses a subset of these addressing modes. **Table 2.1 Addressing Modes** | No. | Addressing Mode | Symbol | |-----|---------------------------------------|-----------------| | (1) | Register direct | Rn | | (2) | Register indirect | @Rn | | (3) | Register indirect with displacement | @(d:16, Rn) | | (4) | Register indirect with post-increment | @Rn+ | | | Register indirect with pre-decrement | @-Rn | | (5) | Absolute address | @aa:8 or @aa:16 | | (6) | Immediate | #xx:8 or #xx:16 | | (7) | Program-counter relative | @(d:8, PC) | | (8) | Memory indirect | @@aa:8 | (1) **Register Direct—Rn:** The register field of the instruction specifies an 8- or 16-bit general register containing the operand. Only the MOV.W, ADD.W, SUB.W, CMP.W, ADDS, SUBS, MULXU (8 bits $\times$ 8 bits), and DIVXU (16 bits $\div$ 8 bits) instructions have 16-bit operands. - (2) **Register Indirect**—@**Rn:** The register field of the instruction specifies a 16-bit general register containing the address of the operand. - (3) **Register Indirect with Displacement**—@(**d:16, Rn**): The instruction has a second word (bytes 3 and 4) containing a displacement which is added to the contents of the specified general register to obtain the operand address. This mode is used only in MOV instructions. For the MOV.W instruction, the resulting address must be even. #### (4) Register Indirect with Post-Increment or Pre-Decrement—@Rn+ or @-Rn: - Register indirect with post-increment— @Rn+ The @Rn+ mode is used with MOV instructions that load registers from memory. The register field of the instruction specifies a 16-bit general register containing the address of the operand. After the operand is accessed, the register is incremented by 1 for MOV.B or 2 for MOV.W. For MOV.W, the original contents of the 16-bit general register must be even. - Register indirect with pre-decrement—@-Rn The @-Rn mode is used with MOV instructions that store register contents to memory. The register field of the instruction specifies a 16-bit general register which is decremented by 1 or 2 to obtain the address of the operand in memory. The register retains the decremented value. The size of the decrement is 1 for MOV.B or 2 for MOV.W. For MOV.W, the original contents of the 16-bit general register must be even. - (5) Absolute Address—@aa:8 or @aa:16: The instruction specifies the absolute address of the operand in memory. The absolute address may be 8 bits long (@aa:8) or 16 bits long (@aa:16). The MOV.B and bit manipulation instructions can use 8-bit absolute addresses. The MOV.B, MOV.W, JMP, and JSR instructions can use 16-bit absolute addresses. For an 8-bit absolute address, the upper 8 bits are assumed to be 1 (H'FF). The address range is H'FF00 to H'FFFF (65280 to 65535). **(6) Immediate**— **#xx:8 or #xx:16:** The instruction contains an 8-bit operand (#xx:8) in its second byte, or a 16-bit operand (#xx:16) in its third and fourth bytes. Only MOV.W instructions can contain 16-bit immediate values. The ADDS and SUBS instructions implicitly contain the value 1 or 2 as immediate data. Some bit manipulation instructions contain 3-bit immediate data in the second or fourth byte of the instruction, specifying a bit number. (7) **Program-Counter Relative**—@(**d:8, PC**): This mode is used in the Bcc and BSR instructions. An 8-bit displacement in byte 2 of the instruction code is sign-extended to 16 bits and added to the program counter contents to generate a branch destination address. The possible branching range is –126 to +128 bytes (–63 to +64 words) from the current address. The displacement should be an even number. (8) Memory Indirect—@@aa:8: This mode can be used by the JMP and JSR instructions. The second byte of the instruction code specifies an 8-bit absolute address. The word located at this address contains the branch destination address. The upper 8 bits of the absolute address are assumed to be 0 (H'00), so the address range is from H'0000 to H'00FF (0 to 255). Note that addresses H'0000 to H'0007 (0 to 7) are located in the vector table. If an odd address is specified as a branch destination or as the operand address of a MOV.W instruction, the least significant bit is regarded as 0, causing word access to be performed at the address preceding the specified address. See section 2.3.2, Memory Data Formats, for further information. #### 2.4.2 Effective Address Calculation Table 2.2 shows how effective addresses are calculated in each of the addressing modes. Arithmetic and logic instructions use register direct addressing (1). The ADD.B, ADDX, SUBX, CMP.B, AND, OR, and XOR instructions can also use immediate addressing (6). Data transfer instructions can use all addressing modes except program-counter relative (7) and memory indirect (8). Bit manipulation instructions use register direct (1), register indirect (2), or absolute (5) addressing to specify a byte operand, and 3-bit immediate addressing (6) to specify a bit position in that byte. The BSET, BCLR, BNOT, and BTST instructions can also use register direct addressing (1) to specify the bit position. **Table 2.2 Effective Address Calculation** **Table 2.2** Effective Address Calculation (cont) Legend: reg, regm, regn: General registers op: Operation field disp: Displacement IMM: Immediate data abs: Absolute address ## 2.5 Instruction Set The H8/3103 can use a total of 55 instructions, shown grouped by function in table 2.3. Note: The H8/300 CPU has 57 basic instructions, but the H8/3103 uses only 55 of them. The MOVFPE and MOVTPE instructions are not used. **Table 2.3** Instruction Set | Function | Instructions | Types | |-----------------------|-----------------------------------------------------------------------------------|----------| | Data transfer | MOV, PUSH* <sup>1</sup> , POP* <sup>1</sup> | 1 | | Arithmetic operations | ADD, SUB, ADDX, SUBX, INC, DEC, ADDS, SUBS, DAA, DAS, MULXU, DIVXU, CMP, NEG | 14 | | Logic operations | AND, OR, XOR, NOT | 4 | | Shift | SHAL, SHAR, SHLL, SHLR, ROTL, ROTR, ROTXL, ROTXR | 8 | | Bit manipulation | BSET, BCLR, BNOT, BTST, BAND, BIAND, BOR, BIOR, BXOR, BIXOR, BLD, BILD, BST, BIST | 14 | | Branch | Bcc*2, JMP, BSR, JSR, RTS | 5 | | System control | SLEEP, LDC, STC, ANDC, ORC, XORC, NOP, RTE | 8 | | EEPROM write | EEPMOV | 1 | | | | Total 55 | Notes: 1. POP Rn is identical to MOV.W @SP+, Rn. PUSH Rn is identical to MOV.W Rn, @-SP 2. Bcc is a conditional branch instruction in which cc represents a condition code. HITACHI 21 Tables 2.4 to 2.11 give a concise summary of the instructions in each functional group. The following notation is used in these tables to describe the operations performed. ## **Operation Notation** | Rd | General register (destination) | |---------------|--------------------------------| | Rs | General register (source) | | Rn | General register | | (EAd) | Destination operand | | (EAs) | Source operand | | CCR | Condition code register | | N | N (negative) bit of CCR | | Z | Z (zero) bit of CCR | | V | V (overflow) bit of CCR | | С | C (carry) bit of CCR | | PC | Program counter | | SP | Stack pointer | | #IMM | Immediate data | | disp | Displacement | | + | Addition | | _ | Subtraction | | × | Multiplication | | ÷ | Division | | ^ | AND logical | | V | OR logical | | $\oplus$ | Exclusive OR logical | | $\rightarrow$ | Move | | 7 | Not | | :3, :8, :16 | 3-, 8-, or 16-bit length | | | | ## 2.5.1 Data Transfer Instructions Table 2.4 describes the data transfer instructions. **Table 2.4 Data Transfer Instructions** | Instruction | Size* | Function | |-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MOV | B/W | $(EAs) \rightarrow Rd, Rs \rightarrow (EAd)$ | | | | Moves data between two general registers or between a general register and memory, or moves immediate data to a general register. The Rn, @Rn, @(d:16, Rn), @aa:16, #xx:16, @-Rn, and @Rn+addressing modes are available for byte or word data. The #xx:8 and @aa:8 addressing modes are available for byte data only. Specify word-size operands for @-R7 and @R7+. | | POP | W | @SP+ → Rn | | | | Pops a 16-bit general register from the stack. Identical to MOV.W @SP+, Rn. | | PUSH | W | $Rn \rightarrow @-SP$ | | | | Pushes a 16-bit general register onto the stack. Identical to MOV.W Rn, @-SP. | Note: \* Size: Operand size B: Byte W: Word Figure 2.5 shows the object code formats of the data transfer instructions. Figure 2.5 Data Transfer Instruction Object Code Formats ## 2.5.2 Arithmetic Operations Table 2.5 describes the arithmetic instructions. **Table 2.5** Arithmetic Instructions | Instruction | Size* | Function | |-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADD | B/W | $Rd \pm Rs \rightarrow Rd, Rd + \#IMM \rightarrow Rd$ | | SUB | | Performs addition or subtraction on data in two general registers, or addition on immediate data and data in a general register. Immediate data cannot be subtracted from data in a general register. Word data can be added or subtracted only when both words are in general registers. | | ADDX | В | $Rd \pm Rs \pm C \to Rd, \ Rd \pm \# IMM \pm C \to Rd$ | | SUBX | | Performs addition or subtraction with carry or borrow on byte data in two general registers, or on immediate data and data in a general register. | | INC | В | $Rd \pm 1 \rightarrow Rd$ | | DEC | | Increments or decrements a general register. | | ADDS | W | $Rd \pm 1 \rightarrow Rd$ , $Rd \pm 2 \rightarrow Rd$ | | SUBS | | Adds or subtracts immediate data to or from data in a general register. The immediate data must be 1 or 2. | | DAA | В | Rd decimal adjust $ ightarrow$ Rd | | DAS | | Decimal-adjusts 4-bit BCD data in a general register by referring to CCR. | | MULXU | В | $Rd \times Rs \rightarrow Rd$ | | | | Performs 8-bit $\times$ 8-bit unsigned multiplication on data in two general registers, providing a 16-bit result. | | DIVXU | В | $Rd \div Rs \rightarrow Rd$ | | | | Performs 16-bit ÷ 8-bit unsigned division on data in two general registers, providing an 8-bit quotient and 8-bit remainder. | | CMP | B/W | Rd – Rs, Rd – #IMM | | | | Compares data in a general register with data in another general register or with immediate data, and sets CCR according to the result. Word data can be compared only between two general registers. | | NEG | В | $0 - Rd \rightarrow Rd$ | | | | Obtains the two's complement (arithmetic complement) of data in a general register. | Note: \* Size: Operand size B: Byte W: Word ## 2.5.3 Logic Operations Table 2.6 describes the instructions that perform logic operations. **Table 2.6** Logic Operation Instructions | Instruction | Size* | Function | |-------------|-------|-----------------------------------------------------------------------------------------------------------------| | AND | В | $Rd \wedge Rs \rightarrow Rd$ , $Rd \wedge \#IMM \rightarrow Rd$ | | | | Performs a logical AND operation on a general register and another general register or immediate data. | | OR | В | $Rd \lor Rs \rightarrow Rd$ , $Rd \lor \#IMM \rightarrow Rd$ | | | | Performs a logical OR operation on a general register and another general register or immediate data. | | XOR | В | $Rd \oplus Rs \to Rd, \ Rd \oplus \#IMM \to Rd$ | | | | Performs a logical exclusive OR operation on a general register and another general register or immediate data. | | NOT | В | $\neg Rd \rightarrow Rd$ | | | | Obtains the one's complement (logical complement) of general register contents. | Note: \* Size: Operand size B: Byte ## 2.5.4 Shift Operations Table 2.7 describes the shift instructions. **Table 2.7 Shift Instructions** | Instruction | Size* | Function | |-------------|-------|----------------------------------------------------------------------| | SHAL | В | $Rd ext{ shift} o Rd$ | | SHAR | | Performs an arithmetic shift operation on general register contents. | | SHLL | В | $Rd ext{ shift} o Rd$ | | SHLR | | Performs a logical shift operation on general register contents. | | ROTL | В | $Rd \ rotate \rightarrow Rd$ | | ROTR | | Rotates general register contents. | | ROTXL | В | Rd rotate through carry $\rightarrow$ Rd | | ROTXR | | Rotates general register contents through the C (carry) bit. | Note: \* Size: Operand size B: Byte 26 Figure 2.6 Arithmetic, Logic, and Shift Instruction Object Code Formats # 2.5.5 Bit Manipulations Table 2.8 describes the bit-manipulation instructions. **Table 2.8 Bit-Manipulation Instructions** | Instruction | Size* | Function | |-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BSET | В | $1 \rightarrow (\text{sbit-No.} > \text{of } < \text{EAd} >)$ | | | | Sets a specified bit in a general register or memory to 1. The bit number is specified by 3-bit immediate data or the lower three bits of a general register. | | BCLR | В | $0 \rightarrow (\text{sbit-No.> of } \text{EAd>})$ | | | | Clears a specified bit in a general register or memory to 0. The bit number is specified by 3-bit immediate data or the lower three bits of a general register. | | BNOT | В | $\neg$ ( <bit-no.> of <ead>) <math>\rightarrow</math> (<bit-no.> of <ead>)</ead></bit-no.></ead></bit-no.> | | | | Inverts a specified bit in a general register or memory. The bit number is specified by 3-bit immediate data or the lower three bits of a general register. | | BTST | В | $\neg$ ( <bit-no.> of <ead>) <math>\rightarrow</math> Z</ead></bit-no.> | | | | Tests a specified bit in a general register or memory and sets or clears the Z flag accordingly. The bit number is specified by 3-bit immediate data or the lower three bits of a general register. | | BAND | В | $C \land (\ of\ ) \to C$ | | | | ANDs the C flag with a specified bit in a general register or memory and stores the result in the C flag. | | BIAND | В | $C \wedge [\neg (\text{ of })] \rightarrow C$ | | | | ANDs the C flag with the inverse of a specified bit in a general register or memory and stores the result in the C flag. The bit number is specified by 3-bit immediate data. | | BOR | В | $C \lor (\;of\;) \to C$ | | | | ORs the C flag with a specified bit in a general register or memory and stores the result in the C flag. | | BIOR | В | $C \vee [\neg \ (\ of\ )] \to C$ | | | | ORs the C flag with the inverse of a specified bit in a general register or memory and stores the result in the C flag. The bit number is specified by 3-bit immediate data. | Note: \* Size: Operand size B: Byte **Table 2.8 Bit-Manipulation Instructions (cont)** | Size* | Function | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | В | $C \oplus (\text{-bit-No} \text{ of -EAd}) \rightarrow C$ | | | Exclusive-ORs the C flag with a specified bit in a general register or memory and stores the result in the C flag. | | В | $C \oplus [\neg \ (\text{\rm cit-No.> of })] \to C$ | | | Exclusive-ORs the C flag with the inverse of a specified bit in a general register or memory and stores the result in the C flag. The bit number is specified by 3-bit immediate data. | | В | $($<br>bit-No.> of <ead><math>) \rightarrow C</math></ead> | | | Transfers a specified bit in a general register or memory to the C flag. | | В | $\neg$ ( <bit-no.> of <ead>) <math>\rightarrow</math> C</ead></bit-no.> | | | Transfers the inverse of a specified bit in a general register or memory to the C flag. | | | The bit number is specified by 3-bit immediate data. | | В | $C \rightarrow (\text{sbit-No.> of } \text{})$ | | | Transfers the C flag value to a specified bit in a general register or memory. | | В | $\neg \ C \to (\ of\ )$ | | | Transfers the inverse of the C flag value to a specified bit in a general register or memory. The bit number is specified by 3-bit immediate data. | | | B<br>B<br>B | Note: \* Size: Operand size B: Byte **Note on Bit Manipulation Instructions:** BSET, BCLR, BNOT, BST, and BIST are read-modify-write instructions. They read a byte of data, modify one bit in the byte, then write the modified byte back to the same address. | Step | | Operation | |------|--------|-------------------------------------------------------| | 1 | Read | Read data (1 byte) at a specified address | | 2 | Modify | Modify one specified bit in the read data | | 3 | Write | Write the modified data back to the specified address | Figure 2.7 shows the object code formats of the bit manipulation instructions. Figure 2.7 Bit Manipulation Instruction Object Code Formats Figure 2.7 Bit Manipulation Instruction Object Code Formats (cont) # 2.5.6 Branching Instructions Table 2.9 describes the branching instructions. **Table 2.9 Branching Instructions** | Instruction | Size | Function | Function | | | | | | |-------------|------|-----------------|--------------------------------------------------------------------------------|---------------------------|--|--|--|--| | Bcc | _ | Branches to a s | Branches to a specified address if condition cc is true. | | | | | | | | | The branching | The branching conditions are listed below. | | | | | | | | | Mnemonic | Description | Condition | | | | | | | | BRA (BT) | Always (true) | Always | | | | | | | | BRN (BF) | Never (false) | Never | | | | | | | | BHI | High | C ∨ Z = 0 | | | | | | | | BLS | Low or same | C ∨ Z = 1 | | | | | | | | BCC (BHS) | Carry clear<br>(high or same) | C = 0 | | | | | | | | BCS (BLO) | Carry set (low) | C = 1 | | | | | | | | BNE | Not equal | Z = 0 | | | | | | | | BEQ | Equal | Z = 1 | | | | | | | | BVC | Overflow clear | V = 0 | | | | | | | | BVS | Overflow set | V = 1 | | | | | | | | BPL | Plus | N = 0 | | | | | | | | BMI | Minus | N = 1 | | | | | | | | BGE | Greater or equal | N ⊕ V = 0 | | | | | | | | BLT | Less than | N ⊕ V = 1 | | | | | | | | BGT | Greater than | $Z \vee (N \oplus V) = 0$ | | | | | | | | BLE | Less or equal | $Z \vee (N \oplus V) = 1$ | | | | | | JMP | | Branches unco | nditionally to a specified | address. | | | | | | BSR | _ | | Branches to a subroutine at a specified displacement from the current address. | | | | | | | JSR | _ | Branches to a s | subroutine at a specified | address. | | | | | | RTS | _ | Returns from a | subroutine. | | | | | | Figure 2.8 Branching Instruction Object Code Formats # 2.5.7 System Control Instructions Table 2.10 describes the system control instructions. **Table 2.10 System Control Instructions** | Instruction | Size* | Function | |-------------|-------|-----------------------------------------------------------------------------------| | RTE | _ | Returns from an exception-handling routine. | | SLEEP | _ | Causes a transition to the power-down state. | | LDC | В | $Rs \to CCR, \ \ \#IMM \to CCR$ | | | | Moves immediate data or general register contents to the condition code register. | | STC | В | $CCR \rightarrow Rd$ | | | | Copies the condition code register to a specified general register. | | ANDC | В | $CCR \land \#IMM \rightarrow CCR$ | | | | Logically ANDs the condition code register with immediate data. | | ORC | В | $CCR \lor \#IMM \to CCR$ | | | | Logically ORs the condition code register with immediate data. | | XORC | В | $CCR \oplus \#IMM \rightarrow CCR$ | | | | Logically exclusive-ORs the condition code register with immediate data. | | NOP | _ | $PC + 2 \rightarrow PC$ | | | | Only increments the program counter. | Note: \* Size: Operand size B: Byte Figure 2.9 shows the object code formats of the system control instructions. Figure 2.9 System Control Instruction Object Code Formats # 2.5.8 EEPROM Write Instruction Table 2.11 describes the EEPROM write instruction. **Table 2.11 EEPROM Write Instruction** | Instruction | Size | Function | | |-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|--| | EEPMOV | _ | If R4L _ 0 then | | | | | repeat @R5+ $\rightarrow$ @R6+, R4L – 1 $\rightarrow$ R4L | | | | | until $R4L = 0$ | | | | | else next; | | | | | Transfers a data block to EEPROM according to parameters set in general registers R4L, R5, and R6. | | | | | R4L: size of block (bytes) R5: starting source address R6: starting destination address | | | | | Execution of the next instruction begins as soon as the EEPROM write operation is completed. The transfer cannot cross an EEPROM page boundary. | | Figure 2.10 shows the object code format of the EEPROM write instruction. Figure 2.10 EEPROM Write Instruction Object Code Format # 2.6 Operating States #### 2.6.1 Overview The CPU operates in three states: the program execution state, exception-handling state, and power-down state. Figure 2.11 summarizes these states. Figure 2.12 shows the state transitions. Figure 2.11 Operating States Figure 2.12 State Transitions # 2.6.2 Program Execution State In this state the CPU executes program instructions in normal sequence. # 2.6.3 Exception-Handling State This is a transitory state entered in response to a reset or interrupt. In interrupt exception handling, the stack pointer is referenced and the program counter and condition code register are saved. #### 2.6.4 Power-Down State The power-down state consists of a sleep mode. Sleep mode is entered from the program execution state when the SLEEP instruction is executed. Operation of the CPU, clocks, and all other on-chip supporting modules is halted. The on-chip supporting modules enter the reset state, but the contents of CPU registers and on-chip RAM are retained as long as the specified voltage is supplied. The I/O port DR and DDR values are also retained. Sleep mode is exited by low input at the $\overline{RES}$ pin or I/O-1/ $\overline{IRQ}$ pin. # 2.7 Exception Handling #### 2.7.1 Overview In the H8/3103, exception handling is performed in response to a reset or interrupt. Table 2.12 summarizes the exception handling priority order and timing. Table 2.13 describes the exception vector table. Table 2.12 Exception Handling Priority Order and Timing | Priority | Cause | <b>Detection Timing</b> | Start of Exception Handling Sequence | |-----------|--------------------|--------------------------|----------------------------------------------------------------------| | High<br>↑ | Reset | Synchronized with clock | Instruction execution stops and reset processing starts immediately. | | ↓<br>Low | Interrupt<br>(IRQ) | Falling edge is detected | Interrupt exception handling starts immediately. | **Table 2.13 Exception Vector Table** | | | Vect | or Address | |--------------------------|----------------------|-----------|------------| | Description | <b>Vector Number</b> | PC (High) | PC (Low) | | Reset | 0 | H'0000 | H'0001 | | Reserved for system use* | 1 | H'0002 | H'0003 | | Reserved for system use* | 2 | H'0004 | H'0005 | | Interrupt (IRQ) | 3 | H'0006 | H'0007 | Note: \* Software should not access these addresses. #### 2.7.2 **Reset** The H8/3103 begins reset exception handling when the $\overline{RES}$ input changes from low to high. At power-up, $\overline{RES}$ should be held low for at least 20 external clock cycles after the input clock signal (CLK) stabilizes. Similarly, when the chip is reset during operation, $\overline{RES}$ should be held low for at least 20 external clock cycles. $\overline{RES}$ should also be low whenever power is switched on or off. When a low-to-high transition of $\overline{RES}$ is detected, the CPU begins reset exception handling, which in the H8/3103 consists of the following steps: - 1. The low-to-high transition of the $\overline{RES}$ input is detected. - 2. The internal status of the CPU and the registers of the on-chip supporting modules are initialized. In CCR, the I bit is set to 1 but other bits are left unchanged. - 3. The reset vector is read from addresses H'0000 to H'0001 in the vector table and loaded into the program counter. Program execution then starts from the loaded address (start address). #### 2.7.3 Interrupts In sleep mode only, the $I/O-1/\overline{IRQ}$ pin functions as an interrupt pin, and is capable of input. The IRQ interrupt uses falling edge detection, and an interrupt request is accepted if the I bit in CCR is cleared to 0. See section 7, I/O Port, for I/O-1/IRQ specification details. The interrupt sequence consists of the following steps. - When the interrupt request is accepted, a transition takes place from sleep mode to the exception-handling state. The program counter and condition code register are saved on the stack as shown in figure 2.13. The program counter address saved on the stack is the address of the first instruction that will be executed after the return from the interrupt-handling routine. - 2. The I bit in the condition code register is set to 1. - 3. The address of the interrupt-handling routine is read from the vector table entry corresponding to the interrupt vector and loaded into the program counter, and execution of the interrupt-handling routine begins. The maximum number of clocks from interrupt request acceptance to the start of the interrupt-handling routine is 35 external clocks. Figure 2.13 Stack before and after Interrupt Exception-Handling Sequence # 2.7.4 Reset Start Timing Table 2.14 shows the difference in the reset starting timing specification between the H8/3103 and the H8/3103 emulator. **Table 2.14 Reset Start Timing Difference** | Item | H8/3103 | H8/3103 Emulator | |----------------------------------|----------------------------|-------------------| | Number of clocks for reset start | 200 external clocks (max.) | 5 external clocks | The number of clocks for a reset start specifies the time from the rising edge of $\overline{RES}$ to the reset vector fetch cycle. Note that the H8/3103 and H8/3103 emulator have different specifications in this regard. # 2.8 Power-Down State #### 2.8.1 Overview The H8/3103 has a sleep mode, a power-down state in which CPU functions are halted to conserve power. Table 2.15 summarizes the conditions for transition to sleep mode, the state of the CPU and onchip supporting modules in sleep mode, and the conditions for exit from sleep mode. **Table 2.15 Power-Down State** | | | States | | | | | | | | |---------------|---------------------------------|---------|---------|--------------|------|------------|-----------------------------------------------------------------------------|-------------|--------------------------| | Mode | Entering<br>Procedure | Clock | CPU | CPU<br>Reg's | RAM | DR,<br>DDR | I/O Ports | ECR,<br>EPR | Exiting<br>Methods | | Sleep<br>mode | Execute<br>SLEEP<br>instruction | Stopped | Stopped | Held | Held | Held | High-level<br>output set<br>by pull-up<br>MOS (data<br>output<br>inhibited) | Initialized | • RES<br>• I/O-1/<br>IRQ | #### 2.8.2 Transition to Sleep Mode Sleep mode is entered by executing the SLEEP instruction. In sleep mode the CPU, clock, and on-chip supporting functions halt, so power consumption is reduced to an extremely low level. As long as the necessary voltage is supplied, however, the contents of CPU registers and RAM and the I/O port registers (DR and DDR) are held. I/O- $1/\overline{IRQ}$ becomes an interrupt input line. The I/O- $1/\overline{IRQ}$ and I/O-2 lines should be kept high during sleep mode. Figure 2.14 shows the sequence for transition to sleep mode. Figure 2.14 Transition to Sleep Mode (Example) #### 2.8.3 Exit from Sleep Mode Exit from sleep mode is effected by input to the $I/O-1/\overline{IRQ}$ or $\overline{RES}$ pin. # 1. Exit by interrupt In sleep mode the $I/O-1/\overline{IRQ}$ pin can receive interrupt signals. When a high-to-low transition occurs in the input, the external clock is supplied to the CPU and on-chip supporting modules, sleep mode ends, and interrupt exception handling starts. The external clock must be stable when the interrupt signal goes low. Figure 2.15 shows the transition sequence from sleep mode to interrupt handling. Figure 2.16 shows the timing of an interrupt in sleep mode. #### 2. Exit by reset If the $\overline{RES}$ input goes low during sleep mode, the external clock is supplied to the CPU and on-chip supporting modules. Next, when the $\overline{RES}$ input goes high, the CPU begins reset exception handling. The $\overline{RES}$ input should be held low for at least 20 stable external clock cycles. Figure 2.15 Recovery from Sleep Mode (Example) Note: The $\overline{RES}$ , I/O-1/ $\overline{IRQ}$ , and I/O-2 lines must be held high during sleep mode. Figure 2.16 Interrupt Timing in Sleep Mode # 2.9 Basic Timing The CPU operates on the system clock ( $\phi$ ). The interval from one rising edge of the system clock to the next is called a "state." The memory access cycle or bus cycle consists of two states. # 2.9.1 On-Chip Memory (RAM, ROM, EEPROM) The data bus is 16 bits wide. Both byte and word access are supported. # 2.9.2 Register Field (I/O, EEPROM) The upper 8 bits of the internal data bus are used to access these registers. The data bus is accordingly 8 bits wide. #### 2.9.3 Non-Existent Addresses User programs must not access non-existent addresses. Section 3, Memory Map, indicates the types of access possible at each address. # Section 3 Memory Map Figure 3.1 shows a memory map of the H8/3103. Figure 3.1 Memory Map # Section 4 RAM # 4.1 Overview The H8/3103 has 512 bytes of on-chip static RAM. The RAM is connected to the CPU by a 16-bit data bus. Both byte data and word data are accessed in two states, enabling rapid data transfer. If word access is performed at an odd address in RAM, the word at the preceding even address is accessed. Normally an even address should be specified for word data. # 4.1.1 Block Diagram Figure 4.1 shows a block diagram of the RAM. Figure 4.1 RAM Block Diagram # Section 5 ROM # 5.1 Overview The H8/3103 has 20 kbytes of on-chip ROM. The ROM is connected to the CPU by a 16-bit data bus. Both byte data and word data are accessed in two states, enabling rapid data transfer. If word access is performed at an odd address in ROM, the word at the preceding even address is accessed. Normally an even address should be specified for word data. #### 5.1.1 Block Diagram Figure 5.1 shows a block diagram of the ROM. Figure 5.1 ROM Block Diagram # Section 6 EEPROM #### 6.1 Overview The H8/3103 has 16 kbytes of electrically writable and erasable EEPROM on-chip. Both data and program code can be stored in the EEPROM. #### 6.1.1 Features The features of the EEPROM are listed below. • Capacity: 16 kbytes Organization: 64 bytes $\times$ 256 pages Allocated on the CPU address space - Written by a special block data transfer instruction - EEPMOV instruction: rewrites, overwrites (1 to 64 bytes), or erases a page (64 bytes) at a time. - Protection features prevent accidental writing and erasing - Write/erase protection can be designated by protect bits. - Low voltage detection - Control registers prevent inadvertent writing and erasing. - On-chip voltage pumping circuit - Generates the high voltages required for writing and erasing - Built-in oscillator and timer - The write/erase sequence is controlled using an independent oscillator. EEPROM write/erase timing does not depend on the external clock. - Write/erase time (typical): 10 ms (Rewrite) 5 ms (Erase, overwrite) Rewrite endurance: 10<sup>5</sup> times Data retention time: 10 years #### 6.1.2 Block Diagram Figure 6.1 shows a block diagram of the EEPROM. The built-in timer generates the write/erase sequence. The clock pulses for this timer are obtained from an on-chip oscillator and are independent of the CPU clock. Changing the CPU clock rate (external clock) does not affect the EEPROM write/erase timing. The voltage pumping circuit generates the high voltages needed for writing and erasing. No external high-voltage power supply is required. Figure 6.1 EEPROM Block Diagram # **6.1.3** Memory Organization The EEPROM has a $16384 \times 8$ -bit organization, and is further organized into 64-byte pages. There are 256 pages as shown in figure 6.2. Figure 6.2 EEPROM Memory Organization # 6.1.4 Register Configuration Writing and erasing of the EEPROM are controlled by the registers listed in table 6.1. **Table 6.1 EEPROM Registers** | Register | Abbr. | R/W | Initial Value | Address | |----------------------------|-------|-----|---------------|---------| | EEPROM control register | ECR | R/W | H'FF | H'FFF8 | | EEPROM protection register | EPR | R/W | H'FF | H'FFF9 | # **6.2** Register Descriptions #### **6.2.1 EEPROM Control Register (ECR)** ECR is an 8-bit register that controls the type of write or erase operation performed on the EEPROM. **Bits 7 to 2—Reserved:** These bits cannot be written and are always read as 1. Although not used at present, reserved bits may be used in the future. **Bits 1 and 0—Operation Control 1 and 0 (OC1 and OC0):** These bits select the type of EEPROM write/erase operation. Four operations can be selected by OC1 and OC0 as follows. | Bit 1: OC1 | Bit 0: OC0 | Description | | |------------|------------|----------------------|-----------------| | 0 | 0 | Rewrite | | | | 1 | Overwrite | | | 1 | 0 | Page erase | | | | 1 | Write/erase disabled | (Initial value) | To prevent unintended writing and erasing, the OC1 and OC0 bits are both set to 1 automatically at a reset and at the end of a write or erase operation. They are also set to 1 automatically whenever an internal voltage drop is detected. It is accordingly necessary to clear one or both of these bits before every write or erase operation. #### **6.2.2 EEPROM Protection Register (EPR)** Initial value: 1 Read/Write: R/W EPR is an 8-bit register that enables the writing of EEPROM write/erase protect bits. Bit 7—Protect Bit Mode (PBM): This bit selects the EEPROM data area or protection area. The protection area is selected when the $\overline{PBM}$ bit is cleared to 0. The data area is selected when the $\overline{PBM}$ bit is set to 1. Writing the $\overline{PBM}$ bit automatically sets both the OC1 and OC0 bits in ECR to 1, disabling writing or erasing of the EEPROM. At the end of a write or erase operation in the protection area, the $\overline{PBM}$ bit itself is automatically set to 1, selecting the data area. The protect bits are allocated at the same addresses as the first bytes of pages 0 to 255 of the EEPROM data area. Each page of the EEPROM can be protected individually. See section 6.5, Write/Erase Protection, for further information on the protection area and data area. | Bit 7: PBM | Description | | |------------|------------------------------|----------| | 0 | Protection area is selected | | | 1 | Data area is selected value) | (Initial | **Bits 6 to 0—Reserved:** These bits cannot be written and are always read as 1. Although not used at present, reserved bits may be used in the future. ECR and EPR are initialized by the SLEEP instruction. After exiting sleep mode, software must set up these registers again before writing to EEPROM. # **6.3 EEPROM Read Operation** The EEPROM is read directly by the CPU, using the same instructions as for reading ROM or RAM. The read data is sent to the CPU via a 16-bit bus. If word access is performed at an odd address, the word at the preceding even address is read. # **EEPROM Write and Erase Operations** #### 6.4.1 Write/Erase Sequence The EEPROM is written or erased using the EEPMOV block data transfer instruction. The EEPMOV instruction transfers a block of data stored in RAM to a single page in EEPROM. The data transfer from RAM to EEPROM is controlled by parameters set in CPU registers R4L, R5, and R6 as shown in figure 6.3. The transfer is made by first setting parameters in registers R4L, R5, and R6 and control bits in EPR and ECR, then executing the EEPMOV instruction. Figure 6.3 Block Transfer to EEPROM Figure 6.4 indicates the contents of the three parameter registers used by the EEPMOV instruction. Table 6.2 describes the parameters and their valid ranges of values. Figure 6.4 EEPMOV Parameters **Table 6.2 EEPMOV Parameters and Their Valid Ranges** | Register | Name | Description | Valid Range | Final Value | |----------|-------------------------|-------------------------------------------------|---------------------------|-------------| | R4L | Byte counter | Byte length of block to be written in EEPROM | 1 to 64<br>(H'01 to H'40) | H'00 | | R5 | RAM address register | Starting address of source block in RAM | H'FDC0 to H'FFBF | R5 + R4L | | R6 | EEPROM address register | Starting address of destination block in EEPROM | H'6000 to H'9FFF | R6 + R4L* | Note: \* When an EEPROM write operation ends at the last address on a page, the EEPROM address register (R6) reverts to the first address on that page. Example: If R6 = H'6000 and R4L = H'40, the final value of R6 is H'6000. If R6 = H'607F and R4L = H'01, the final value of R6 is H'6040. If the parameters are set to values outside the valid ranges in table 6.2 when the EEPMOV instruction is executed, or if the byte counter (R4L) and EEPROM address register (R6) are set so as to cross a page boundary, the write or erase operation may not be performed as intended. In addition, the final values left in the registers after instruction execution may not be the values indicated in table 6.2. Figure 6.5 shows the sequence to be performed by software for writing or erasing the EEPROM. Figure 6.5 EEPROM Write/Erase Sequence After an EEPMOV instruction, the CPU does not execute the next instruction until the writing or erasing of EEPROM data has ended. EEPROM data cannot be written or erased by instructions other than EEPMOV. #### 6.4.2 Rewrite A single rewrite operation can modify the values of 1 to 64 contiguous bytes located in the same EEPROM page. A rewrite operation is restricted to a single page. The byte counter (R4L) and EEPROM address register (R6) should be set so that the operation does not cross a page boundary. To perform a rewrite operation, clear both OC1 and OC0 to 0. #### **6.4.3** Erase When the EEPMOV instruction is executed with OC1 = 1 and OC0 = 0, the relevant EEPROM page is erased. The entire page containing the byte addressed by the EEPROM address register (R6) is erased. All data in the page is changed to 1. The byte counter (R4L) and RAM address register (R5) can be set to any valid values. Figure 6.6 EEPROM Erase Operation # 6.4.4 Overwrite When the EEPMOV instruction is executed with OC1 = 0 and OC0 = 1, the transferred data is overwritten on the old data. After an overwrite operation, the EEPROM contains the logical AND of the old data and the overwritten data. Figure 6.7 Results of Overwrite Operations (Examples) #### 6.5 Write/Erase Protection #### 6.5.1 Protect Bits EEPROM data can be protected from accidental writing and erasing. Each 64-byte page can be protected individually. Each page has its own protect bits. Write/erase protection is conferred by writing a protection code (H'78) in the protect bits. Once a page is protected, the protection cannot be removed. The protect bits for a page have the same address as the first data byte in the page. The $\overline{PBM}$ bit in EPR selects either the protection or data area. The protection area is selected when $\overline{PBM} = 0$ ; the data area is selected when $\overline{PBM} = 1$ . Figure 6.8 shows how the protect bits are allocated to pages. Figure 6.9 shows an example of write/erase protection. Figure 6.8 Allocation of Protect Bits Figure 6.9 Example of Write/Erase Protection #### **6.5.2** Protection Procedure To protect a page, software must set the EPR and ECR registers, then write the protection code (H'78) in the protect bits. The protection procedure is given next. Figure 6.10 shows a flowchart. - 1. Clear the PBM bit in EPR to 0 to select the protection area. The OC1 and OC0 bits in ECR will then be automatically set to 1, disabling EEPROM writing and erasing. - 2. Clear the OC1 bit in ECR to 0. The OC0 bit may be set to either 1 or 0. - 3. Execute the EEPMOV instruction to write the protection code, H'78, in the protect bits. The address of the protect bits is the same as the top byte address in the page to be protected. After the protection code has been written, EPR automatically reverts to select the data area, and ECR is set to the write/erase-disabled state (OC1 = OC0 = 1). Steps 1 to 3 must be carried out for each page protected. Figure 6.10 Protection Flowchart # 6.5.3 Reading the Protect Bits When the PBM bit in EPR is cleared to 0, the protect bits can be read. The protect bits for a protected page are read as H'FC. The protect bits for an unprotected page are read as H'FF. #### 6.6 Notes When using the EEPROM, note the following points. - (1) Write/Erase Abort: If a reset signal shorter than the minimum pulse width is input, the EEPROM is reset (aborting any write or erase operation in progress and initializing the control registers). The CPU and other circuits may or may not continue to operate correctly. - (2) EEPMOV Execution with Invalid Register Settings: If registers R4L and R6 are set so as to cross a page boundary, the EEPROM write or erase operation is performed within the page including the initial address in R6. Example: If: R4L = H'40 R5 = H'FF00 R6 = H'6030 Then the block data transfer is performed as follows: RAM addresses H'FF00 to H'FF0F $\rightarrow$ EEPROM addresses H'6030 to H'603F RAM addresses H'FF10 to H'FF3F $\rightarrow$ EEPROM addresses H'6000 to H'602F - (3) Rewrite/Overwrite Operations: Rewrite/overwrite operations are executed in 32-byte or 64-byte units depending on address and the number of bytes to be written into the EEPROM. The rewrite/overwrite unit is selected automatically. Figure 6.11 shows the rewrite/overwrite operation areas. - Case 1: Rewrite/overwrite to the first 32 bytes in a page If the rewrite/overwrite addresses are specified within the first 32 bytes in a page, only the first 32-byte area is rewritten/overwritten. The second 32-byte area is not rewritten/overwritten. - Case 2: Rewrite/overwrite to the second 32 bytes in a page If the rewrite/overwrite addresses are specified within the second 32 bytes in a page, only the second 32-byte area is rewritten/overwritten. The first 32-byte area is not rewritten/overwritten. - Case 3: Rewrite/overwrite to 64 bytes in a page If the rewrite/overwrite addresses are specified within the first and second 32 bytes, a 64-byte area is rewritten/overwritten. Figure 6.11 Rewrite/Overwrite Operations # Section 7 I/O Port # 7.1 Overview The H8/3103 has a two-bit-wide I/O port. Software can select whether to use each I/O bit for data input or output. The I/O port has a data register (DR) for latching output data, and a data direction register (DDR) for specifying input or output. # 7.1.1 Block Diagram Figure 7.1 shows an I/O port block diagram. DR and DDR can be accessed only by byte access. Figure 7.1 I/O Port Block Diagram # **7.1.2** Register Configuration Table 7.1 lists the I/O port registers. Table 7.1 I/O Port Registers | Name | Abbr. | R/W | Address | |-------------------------|-------|-----|---------| | Data register | DR | R/W | H'FFFE | | Data direction register | DDR | W | H'FFFF | # **7.2** Register Descriptions #### 7.2.1 Data Register (DR) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|-----|---|---|---|---|---|---| | | DR7 | DR6 | _ | _ | _ | | | _ | | Initial value: | _ | _ | _ | _ | _ | _ | _ | _ | | Read/Write: | R/W | R/W | _ | _ | _ | _ | _ | _ | The data register latches the output data. **Bit 7—Data Register Bit 7 (DR7):** Latches I/O port output data. When DDR7 = 1 (selecting output), the value of the DR7 bit is output on the I/O-1 line. When DR is read, if DDR7 = 0 (input), the logic level of the I/O-1 line is read directly. If DDR7 = 1 (output), the value in the DR7 latch is read. The value of DR7 after a reset is undetermined. **Bit 6—Data Register Bit 6 (DR6):** Latches I/O port output data. When DDR6 = 1 (selecting output), the value of the DR6 bit is output on the I/O-2 line. When DR is read, if DDR6 = 0 (input), the logic level of the I/O-2 line is read directly. If DDR6 = 1 (output), the value in the DR6 latch is read. The value of DR6 after a reset is undetermined. **Bits 5 to 0—Reserved:** These bits cannot be written, and are always read as 1. Although not used at present, reserved bits may be used in the future. # 7.2.2 Data Direction Register (DDR) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|------|------|---|---|---|---|---|---| | | DDR7 | DDR6 | _ | _ | _ | _ | | _ | | Initial value: | 0 | 0 | _ | _ | _ | _ | _ | _ | | Read/Write: | W | W | _ | _ | _ | _ | _ | _ | The data direction register specifies the direction (input or output) of the I/O port. **Bit 7—Data Direction Register Bit 7 (DDR7):** Specifies the direction of the I/O-1 line: 1 selects output; 0 selects input. This bit can be written but not read. If read, it always returns the value 1, regardless of its true value. A reset clears this bit to 0, making I/O-1 an input port. **Bit 6—Data Direction Register Bit 6 (DDR6):** Specifies the direction of the I/O-2 line: 1 selects output; 0 selects input. This bit can be written but not read. If read, it always returns the value 1, regardless of its true value A reset clears this bit to 0, making I/O-2 an input port. Bits 5 to 0—Reserved: These bits cannot be written, and are always read as 1. Although not used at present, reserved bits may be used in the future. The DR and DDR contents are held in sleep mode as long as the necessary voltage is supplied, but the I/O ports are placed in the output-disabled state, with input pull-up MOS connected, regardless of the value in the I/O port direction register (DDR). # 7.3 Pin Functions The I/O-1/IRQ pin has a dual function as an external-interrupt pin. This pin functions as an external interrupt input pin during sleep mode. $I/O-1/\overline{IRQ}$ becomes an interrupt input pin during sleep mode regardless of the DDR value, and the falling edge of the $I/O-1/\overline{IRQ}$ pin becomes an external interrupt request signal to the CPU. An input pull-up MOS is connected to the $I/O-1/\overline{IRQ}$ pin to avoid an erroneous interrupt request when the input is at high-impedance. An input pull-up MOS is similarly connected to the I/O-2 pin. The input pull-up MOS's are always switched on, even during sleep mode. To decrease the input pull-up MOS current, a high level should be input to the $I/O-1/\overline{IRQ}$ and I/O-2 pins during sleep mode. If the pin is not being used either as an I/O port or as an external interrupt input, it should be left open (in this case, the pin is pulled high by the input pull-up MOS). ## Section 8 Clock Pulse Generator #### 8.1 Overview The H8/3103 includes an on-chip divider circuit that generates the system clock ( $\phi$ ) from an external clock input. The external clock is input at the CLK pin. The system clock frequency is one-half the external clock frequency. Figure 8.1 Block Diagram of Clock Pulse Generator Figure 8.2 Relationship of System Clock and External Clock Input # Section 9 Security The H8/3103 has the following security functions. When an error is detected, all the internal functions are reset. To recover from the error detection state, enter the reset state by inputting a low level to the $\overline{\text{RES}}$ pin. - Low frequency detector - Low voltage detector - Illegal address detector ## Section 10 Electrical Characteristics ### **10.1** Absolute Maximum Ratings | Item | Symbol | Rating | Unit | |-----------------------|------------------|--------------------------|------| | Power supply voltage | V <sub>cc</sub> | -0.3 to +7.0 | V | | Input voltage | V <sub>in</sub> | $-0.3$ to $V_{cc}$ + 0.3 | V | | Operating temperature | T <sub>opr</sub> | -25 to +85 | °C | | Storage temperature | T <sub>stg</sub> | -25 to +85 | °C | Note: Permanent damage may occur to the chip if maximum ratings are exceeded. Normal operation should be under the recommended operating conditions. Exceeding these conditions could affect the reliability of the device. #### 10.2 Electrical Characteristics #### 10.2.1 DC Characteristics (5 V) Conditions: $V_{cc} = 4.5$ to 5.5 V, $V_{ss} = 0$ V, $T_a = -25$ to +85 °C, unless otherwise specified. | Item | | Symbol | Min | Тур | Max | Unit | Test Conditions | |--------------------------------|----------|-----------------|---------------------|-----|-----------------------|------|---------------------------------------------------| | Input high voltage | RES | V <sub>IH</sub> | $V_{cc} \times 0.8$ | _ | V <sub>cc</sub> + 0.3 | V | | | | CLK | _ | $V_{cc} \times 0.7$ | _ | V <sub>cc</sub> + 0.3 | _ | | | | I/O port | _ | $V_{cc} \times 0.7$ | _ | V <sub>cc</sub> + 0.3 | _ | | | Input low voltage | RES | V <sub>IL</sub> | -0.3 | _ | 0.66 | V | | | | CLK | <del>_</del> | -0.3 | _ | 0.5 | _ | | | | I/O port | _ | -0.3 | | 0.825 | _ | | | Output high voltage | I/O port | V <sub>OH</sub> | 3.85 | _ | V <sub>cc</sub> | V | I <sub>OH</sub> = -20 μA | | Output low voltage | I/O port | V <sub>oL</sub> | 0 | _ | 0.4 | V | I <sub>OL</sub> = 1 mA | | Input leakage current | CLK | I <sub>in</sub> | _ | _ | 10 | μΑ | $V_{in} = 0.5 \text{ to } V_{cc} - 0.5 \text{ V}$ | | Input pull-up<br>MOS current*1 | RES | -I <sub>p</sub> | _ | _ | 150 | μΑ | V <sub>in</sub> = 0 V | | | I/O port | _ | _ | _ | 150 | _ | | #### 10.2.1 DC Characteristics (5 V) (cont) Conditions: $V_{cc} = 4.5$ to 5.5 V, $V_{ss} = 0$ V, $T_a = -25$ to +85°C, unless otherwise specified. | Item | | Symbol | Min | Тур | Max | Unit | Test Conditions | |-----------------------|-------------------|-----------------|-----|-----|-----|------|----------------------------------------------------------------------------| | Current dissipation*2 | Normal operation* | I <sub>cc</sub> | _ | _ | 20 | mA | 5 MHz < f <sub>CLK</sub> * <sup>4</sup> ≤ 10<br>MHz | | | | | _ | _ | 10 | mA | 1 MHz $\leq$ f <sub>CLK</sub> * <sup>4</sup> $\leq$ 5 MHz | | | Sleep<br>mode | _ | _ | _ | 100 | μA | Vin (I/O port) = $V_{cc} - 0.5 \text{ V to } V_{cc}^{*1}$ | | Pin capacitance*5 | | C <sub>p</sub> | _ | _ | 15 | pF | Vin = 0 V,<br>$f_{CLK}^{*4} = 1 \text{ MHz},$<br>$Ta = 25^{\circ}\text{C}$ | Notes: 1. The input pull-up MOS in the RES and I/O port pins are always in the on-state, even in sleep mode. To reduce the input pull-up MOS current, the I/O port pins should be kept high during sleep mode. When the I/O port pins are not used, they should be left open (unconnected). - 2. Current dissipation assumes that $V_{\text{IHmin}} = V_{\text{CC}} 0.5 \text{ V}$ , $V_{\text{ILmax}} = 0.5 \text{ V}$ , and all output lines are unloaded. - 3. Normal operation means an operating mode other than sleep mode. In normal operation, CLK should be input according to the DC and AC characteristics. - 4. $f_{CLK}$ is the external clock frequency. - 5. Pin capacitance is the value in the die state. #### 10.2.2 AC Characteristics (5 V) Conditions: $V_{CC} = 4.5$ to 5.5 V, $V_{ss} = 0$ V, $T_a = -25$ to +85 °C unless otherwise specified. | Symbol | Min | Тур | Max | Unit | <b>Test Conditions</b> | |-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------| | t <sub>cyc</sub> | 0.1 | _ | 1.0 | μs | Figure 10.1 | | t <sub>ch</sub> | 0.4 | _ | 0.6 | t <sub>cyc</sub> | Figure 10.1 | | $t_{\scriptscriptstyle{\text{CL}}}$ | 0.4 | _ | 0.6 | t <sub>cyc</sub> | Figure 10.1 | | $\mathbf{t}_{Cf}$ | _ | _ | $0.09^{*1}$ | t <sub>cyc</sub> | Figure 10.1 | | $t_{cr}$ | _ | _ | $0.09^{*1}$ | t <sub>cyc</sub> | Figure 10.1 | | t, | _ | _ | 1.0 | μs | Figure 10.2 | | t <sub>r</sub> | _ | _ | 1.0 | μs | Figure 10.2 | | t <sub>RWL</sub> | 20 | _ | _ | t <sub>cyc</sub> | Figure 10.3 | | t <sub>on</sub> | 0 | _ | _ | ms | Figure 10.3 | | $\mathbf{t}_{off}$ | 0 | _ | _ | ms | Figure 10.3 | | $\mathbf{t}_{EPW}$ | _ | 10* <sup>2</sup> | 15 | ms | Rewrite | | | _ | 5* <sup>2</sup> | 8 | ms | Erase, overwrite | | t <sub>clkh</sub> | 20 | _ | _ | t <sub>cyc</sub> | Figure 10.4 | | t <sub>clks</sub> | 20 | _ | _ | t <sub>cyc</sub> | Figure 10.4 | | $\mathbf{t}_{IRQW}$ | 200 | _ | _ | ns | Figure 10.4 | | | $\begin{array}{c} t_{\rm cyc} \\ t_{\rm CH} \\ \end{array}$ $\begin{array}{c} t_{\rm CH} \\ t_{\rm CL} \\ \end{array}$ $\begin{array}{c} t_{\rm CI} \\ t_{\rm Cr} \\ \end{array}$ $\begin{array}{c} t_{\rm r} \\ t_{\rm r} \\ \end{array}$ $\begin{array}{c} t_{\rm RWL} \\ t_{\rm on} \\ \end{array}$ $\begin{array}{c} t_{\rm CHKH} \\ \end{array}$ $\begin{array}{c} t_{\rm CLKH} \\ t_{\rm CLKS} \\ \end{array}$ | $\begin{array}{c cccc} t_{\rm cyc} & 0.1 \\ t_{\rm CH} & 0.4 \\ t_{\rm CL} & 0.4 \\ t_{\rm CL} & 0.4 \\ t_{\rm C_{\rm I}} & - \\ t_{\rm C_{\rm T}} & - \\ t_{\rm I} & - \\ t_{\rm r} & - \\ t_{\rm RWL} & 20 \\ t_{\rm on} & 0 \\ t_{\rm off} & 0 \\ t_{\rm EPW} & - \\ - \\ t_{\rm CLKH} & 20 \\ t_{\rm CLKS} & 20 \\ \end{array}$ | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | Notes: 1. It is assumed that there is no noise on the CLK pin, and the rise and fall of CLK are straightforward. 2. The H8/3103 emulator EEPROM write time is the typical value. Figure 10.1 CLK Input Waveform ( $V_{\rm cc}$ = 4.5 V to 5.5 V) Figure 10.2 I/O Port Input Waveform ( $V_{cc}$ = 4.5 V to 5.5 V) Figure 10.3 Power On/Off and $\overline{RES}$ Input Timing ( $V_{cc}$ = 4.5 V to 5.5 V) Figure 10.4 Interrupt Timing in Sleep Mode ( $V_{cc}$ = 4.5 V to 5.5 V) #### 10.2.3 DC Characteristics (3 V) Conditions: $V_{cc} = 2.7$ to 3.3 V, $V_{ss} = 0$ V, $T_a = -25$ to +85°C unless otherwise specified. | Item | | Symbol | Min | Тур | Max | Unit | <b>Test Conditions</b> | |--------------------------------|--------------------|-----------------|---------------------|-----|-----------------------|------|----------------------------------------------------------------------------| | Input high voltage | RES | V <sub>IH</sub> | $V_{cc} \times 0.8$ | _ | V <sub>cc</sub> + 0.3 | V | | | | CLK | =' | $V_{cc} \times 0.7$ | _ | V <sub>cc</sub> + 0.3 | _ | | | | I/O port | =' | $V_{cc} \times 0.7$ | _ | V <sub>cc</sub> + 0.3 | _ | | | Input low voltage | RES | $V_{IL}$ | -0.3 | _ | $V_{cc} \times 0.2$ | V | | | | CLK | - | -0.3 | _ | $V_{cc} \times 0.2$ | _ | | | | I/O port | - | -0.3 | _ | $V_{cc} \times 0.2$ | _ | | | Output high voltage | I/O port | V <sub>OH</sub> | $V_{cc} \times 0.7$ | _ | V <sub>cc</sub> | V | I <sub>OH</sub> = -20 μA | | Output low voltage | I/O port | V <sub>oL</sub> | 0 | _ | 0.4 | V | I <sub>OL</sub> = 1 mA | | Input leakage current | CLK | I <sub>in</sub> | _ | _ | 10 | μΑ | $V_{in} = 0.5 \text{ to } V_{CC} - 0.5 \text{ V}$ | | Input pull-up<br>MOS current*1 | RES | -I <sub>p</sub> | _ | _ | 150 | μΑ | V <sub>in</sub> = 0 V | | | I/O port | - | _ | _ | 150 | _ | | | Current dissipation*2 | Normal operation*3 | I <sub>cc</sub> | _ | _ | 6 | mA | $1 \text{ MHz} \le f_{\text{CLK}}^{*4} \le 5 \text{ MHz}$ | | | Sleep<br>mode | - | _ | _ | 100 | μΑ | Vin (I/O port) = $V_{cc} - 0.5 \text{ V to } V_{cc}^{*1}$ | | Pin capacitance*5 | | C <sub>p</sub> | _ | _ | 15 | pF | Vin = 0 V,<br>$f_{CLK}^{*4} = 1 \text{ MHz},$<br>$Ta = 25^{\circ}\text{C}$ | Notes: 1. The input pull-up MOS in the RES and I/O port pins are always in the on-state, even in sleep mode. To reduce the input pull-up MOS current, the I/O port pins should be kept high during sleep mode. When the I/O port pins are not used, they should be left open (unconnected). - 2. Current dissipation assumes that $V_{\text{IHmin}} = V_{\text{CC}} 0.5 \text{ V}$ , $V_{\text{ILmax}} = 0.5 \text{ V}$ , and all output lines are unloaded. - 3. Normal operation means an operating mode other than sleep mode. In normal operation, CLK should be input according to the DC and AC characteristics. - 4. $f_{CLK}$ is the external clock frequency. - 5. Pin capacitance is the value in the die state. #### 10.2.4 AC Characteristics (3 V) Conditions: $V_{cc} = 2.7$ to 3.3 V, $V_{ss} = 0$ V, $T_a = -25$ to +85°C unless otherwise specified. | Item | Symbol | Min | Тур | Max | Unit | <b>Test Conditions</b> | |-----------------------------|-------------------|-----|------------------|-------------------------------------------|------------------|------------------------| | Clock cycle time | t <sub>cyc</sub> | 0.2 | _ | 1.0 | μs | Figure 10.5 | | Clock high width | t <sub>ch</sub> | 0.4 | _ | 0.6 | t <sub>cyc</sub> | Figure 10.5 | | Clock low width | t <sub>CL</sub> | 0.4 | _ | 0.6 | t <sub>cyc</sub> | Figure 10.5 | | Clock fall time | t <sub>Cf</sub> | _ | _ | $0.09 \times t_{\text{cyc}}^{\text{*}^1}$ | ns | Figure 10.5 | | | | | | 50*1 | | | | Clock rise time | t <sub>Cr</sub> | _ | _ | $0.09 \times t_{\text{cyc}}^{\text{*}^1}$ | ns | Figure 10.5 | | | | | | 50*1 | _ | | | I/O port input fall time | t <sub>f</sub> | | _ | 1.0 | μs | Figure 10.6 | | I/O port input rise time | t, | _ | _ | 1.0 | μs | Figure 10.6 | | RES pulse width | t <sub>RWL</sub> | 20 | _ | _ | t <sub>cyc</sub> | Figure 10.7 | | Power-on time | t <sub>on</sub> | 0 | _ | _ | ms | Figure 10.7 | | Power-off time | t <sub>off</sub> | 0 | _ | _ | ms | Figure 10.7 | | EEPROM write time | t <sub>EPW</sub> | _ | 10* <sup>2</sup> | 15 | ms | Rewrite | | | | _ | 5* <sup>2</sup> | 8 | ms | Erase, overwrite | | Clock hold time | t <sub>CLKH</sub> | 20 | _ | _ | t <sub>cyc</sub> | Figure 10.8 | | Clock setup time | t <sub>CLKS</sub> | 20 | | | t <sub>cyc</sub> | Figure 10.8 | | Interrupt pulse width (IRQ) | t <sub>IRQW</sub> | 400 | _ | _ | ns | Figure 10.8 | Notes: 1. The larger value is taken as the max. value. It is assumed that there is no noise on the CLK pin, and the rise and fall of CLK are straightforward. <sup>2.</sup> The H8/3103 emulator EEPROM write time is the typical value. Figure 10.5 CLK Input Waveform ( $V_{cc}$ = 2.7 V to 3.3 V) Figure 10.6 I/O Port Input Waveform ( $V_{cc}$ = 2.7 V to 3.3 V) Figure 10.7 Power On/Off and $\overline{RES}$ Input Timing ( $V_{cc}$ = 2.7 V to 3.3 V) Figure 10.8 Interrupt Timing in Sleep Mode ( $V_{\rm cc}$ = 2.7 V to 3.3 V) # Appendix A Instruction Set ## **Operation Notation** | Rd8/16 | 8- or 16-bit general register (destination) | |---------------|---------------------------------------------| | Rs8/16 | 8- or 16-bit general register (source) | | Rn8/16 | 8- or 16-bit general register | | CCR | Condition code register | | N | N (negative) flag of CCR | | Z | Z (zero) flag of CCR | | V | V (overflow) flag of CCR | | С | C (carry) flag of CCR | | PC | Program counter | | SP | Stack pointer | | #xx:3/8/16 | 3-, 8-, or 16-bit immediate data | | d:8/16 | 8- or 16-bit displacement | | @aa:8/16 | 8- or 16-bit absolute address | | + | Addition | | _ | Subtraction | | × | Multiplication | | ÷ | Division | | ^ | AND logical | | <u> </u> | OR logical | | $\oplus$ | Exclusive OR logical | | $\rightarrow$ | Move | | $\overline{}$ | Not | | | | #### **Condition Code** #### Notation | <b>\$</b> | Changed according to the execution result | |-----------|-------------------------------------------| | * | Undetermined value | | 0 | Always cleared to 0 | | _ | Previous value remains unchanged | **Table A.1** Instruction Set | | | | | | | | | | lod | | | | | | | | | | | |------|-----------------------|--------------|----------|----------|-----|-------------|-----------|----------|------------|-----|---|----------------------|----------|---|----------|----------|---|---|---------------| | | Mnemonic | Operand Size | #xx:8/16 | Rn | @Rn | @(d:16, Rn) | @-Rn/@Rn+ | @aa:8/16 | @(d:8, PC) | @aa | | Operation | | | | on | | | No. of States | | MOV | MOV.B #xx:8, Rd | В | <b>#</b> | 2 | 0 | 0 | 0 | 0 | 0 | (9) | ı | #xx:8 → Rd8 | <u> </u> | H | N | <b>Z</b> | 0 | C | <b>Ž</b> | | | MOV.B Rs, Rd | В | F | 2 | Н | | | $\vdash$ | $\vdash$ | H | H | Rs8 → Rd8 | + | | 1 | 1 | 0 | | 2 | | | MOV.B @Rs. Rd | В | | F | 2 | | | | $\vdash$ | | - | @Rs16 → Rd8 | + | | 1 | 1 | 0 | | 4 | | | MOV.B @(d:16, Rs), Rd | В | | $\vdash$ | - | 4 | | $\vdash$ | $\vdash$ | | | @(d:16, Rs16) → Rd8 | + | L | <b>1</b> | 1 | 0 | | 6 | | | MOV.B @Rs+, Rd | В | | | | 7 | 2 | | | | | @Rs16 → Rd8 | + | L | <b>1</b> | 1 | 0 | | 6 | | | MOV.B GROT, Ru | | | | | | _ | | | | | Rs16+1 → Rs16 | | | * | * | ľ | | ľ | | | MOV.B @aa:8, Rd | В | | $\vdash$ | Н | | | 2 | $\vdash$ | | - | @aa:8 → Rd8 | + | L | 1 | 1 | 0 | | 4 | | | MOV.B @aa:16, Rd | В | | | Н | | | 4 | $\vdash$ | | - | @aa:16 → Rd8 | + | | 1 | 1 | 0 | | 6 | | | MOV.B & QRd | В | | $\vdash$ | 2 | | | - | $\vdash$ | | | Rs8 → @Rd16 | + | L | <b>1</b> | 1 | 0 | | 4 | | | MOV.B Rs, @(d:16, Rd) | В | | | - | 4 | | | H | | | Rs8 → @(d:16, Rd16) | + | L | 1 | 1 | 0 | | 6 | | | MOV.B Rs, @-Rd | В | | | Н | 7 | 2 | | $\vdash$ | | | Rd16–1 → Rd16 | + | L | 1 | 1 | 0 | | 6 | | | MOV.B No, & Nu | | | | | | _ | | | | | Rs8 → @Rd16 | | | * | * | ľ | | ľ | | | MOV.B Rs, @aa:8 | В | | $\vdash$ | | | | 2 | $\vdash$ | | - | Rs8 → @aa:8 | + | | 1 | 1 | 0 | | 4 | | | MOV.B Rs. @aa:16 | В | | | Н | | | 4 | | | | Rs8 → @aa:16 | + | | 1 | 1 | 0 | | 6 | | | MOV.W #xx:16, Rd | w | 4 | | | | | Ė | | | | #xx:16 → Rd | + | | 1 | 1 | 0 | | 4 | | | MOV.W Rs, Rd | W | Ė | 2 | | | | | | | | Rs16 → Rd16 | + | L | 1 | 1 | 0 | | 2 | | | MOV.W @Rs, Rd | w | | | 2 | | | | | | | @Rs16 → Rd16 | + | | 1 | 1 | 0 | | 4 | | | MOV.W @(d:16, Rs), Rd | w | | $\vdash$ | Н | 4 | | | $\vdash$ | | _ | @(d:16, Rs16) → Rd16 | + | | 1 | 1 | 0 | | 6 | | | MOV.W @Rs+, Rd | w | | | Н | | 2 | | $\vdash$ | T | | @Rs16 → Rd16 | + | E | 1 | 1 | 0 | | 6 | | | | | | | | | | | | | | Rs16+2 → Rs16 | | | Ť | ľ | | | | | | MOV.W @aa:16, Rd | W | | | | | | 4 | | | | @aa:16 → Rd16 | 1_ | _ | 1 | 1 | 0 | _ | 6 | | | MOV.W Rs, @Rd | W | | | 2 | | | | | | | Rs16 → @Rd16 | 1= | E | 1 | 1 | 0 | | 4 | | | MOV.W Rs, @(d:16, Rd) | W | | | | 4 | | | | T | Т | Rs16 → @(d:16, Rd16) | † | E | 1 | 1 | 0 | = | 6 | | | MOV.W Rs, @-Rd | w | | | | | 2 | | Т | | | Rd16–2 → Rd16 | † | E | 1 | 1 | 0 | | 6 | | | | | | | | | | | | | | Rs16 → @Rd16 | | | | ľ | | | | | | MOV.W Rs, @aa:16 | W | | | | П | | 4 | | | | Rs16 → @aa:16 | 1- | L | 1 | 1 | 0 | _ | 6 | | POP | POP Rd | W | | | | П | 2 | | | | | @SP → Rd16 | † | L | 1 | 1 | 0 | _ | 6 | | | | | | | | | | | | | | SP+2 → SP | | | | | | | | | PUSH | PUSH Rs | w | Т | | | П | 2 | | | T | | SP−2 → SP | † | E | 1 | 1 | 0 | _ | 6 | | | | | | | | | | | | | | Rs16 → @SP | | | ľ | | | | | **Table A.1** Instruction Set (cont) | | | | | | | | | g M | | | | | | | | | | | | |-------|------------------|--------------|----------|----|-----|-------------|-----------|----------|------------|-----|---|-------------------------------------------------------|---|-----|------|-----|-----------|----------|-----------| | | Mnemonic | Operand Size | #xx:8/16 | | @Rn | @(d:16, Rn) | @-Rn/@Rn+ | @aa:8/16 | @(d:8, PC) | @aa | | Operation | С | on | diti | on | Co | de | of States | | | 1.00 D # . 0 D ! | +- | - | Rn | (9) | (0) | (9) | (9) | (9) | (9) | Ц | D 10 11 0 D 10 | 1 | H | N | - | ٧ | Ĉ | Š | | ADD | ADD.B #xx:8, Rd | В | 2 | _ | | | | | | _ | | Rd8+#xx:8 → Rd8 | _ | 1 | 1 | 1 | 1 | 1 | 2 | | | ADD.B Rs, Rd | В | | 2 | | | | | | _ | | Rd8+Rs8 → Rd8 | | 1 | 1 | 1 | 1 | 1 | 2 | | | ADD.W Rs, Rd | W | | 2 | | | | | | L | L | Rd16+Rs16 → Rd16 | | (1) | 1 | 1 | <b>\$</b> | 1 | 2 | | ADDX | ADDX.B #xx:8, Rd | В | 2 | | | | | | | L | | Rd8+#xx:8+C → Rd8 | | \$ | 1 | (2) | \$ | 1 | 2 | | | ADDX.B Rs, Rd | В | | 2 | | | | | | | | Rd8+Rs8+C → Rd8 | _ | 1 | 1 | (2) | \$ | 1 | 2 | | ADDS | ADDS.W #1, Rd | W | | 2 | | | | | | | | Rd16+1 → Rd16 | _ | _ | _ | _ | _ | _ | 2 | | | ADDS.W #2, Rd | W | | 2 | | | | | | | | Rd16+2 → Rd16 | _ | _ | _ | _ | _ | _ | 2 | | INC | INC.B Rd | В | | 2 | | | | | | | | Rd8+1 → Rd8 | | _ | 1 | 1 | \$ | _ | 2 | | DAA | DAA.B Rd | В | | 2 | | | | | | | | Rd8 decimal adjust → Rd8 | _ | * | 1 | 1 | * | (3) | 2 | | SUB | SUB.B Rs, Rd | В | | 2 | | | | | | | | Rd8–Rs8 → Rd8 | _ | \$ | 1 | 1 | \$ | 1 | 2 | | | SUB.W Rs, Rd | W | | 2 | | | | | | | | Rd16–Rs16 → Rd16 | _ | (1) | 1 | 1 | \$ | <b>1</b> | 2 | | SUBX | SUBX.B #xx:8, Rd | В | 2 | | | | | | | | | Rd8-#xx:8-C $\rightarrow$ Rd8 | _ | \$ | 1 | (2) | \$ | <b>1</b> | 2 | | | SUBX.B Rs, Rd | В | | 2 | | | | | | | | $Rd8-Rs8-C \rightarrow Rd8$ | _ | \$ | 1 | (2) | \$ | <b>1</b> | 2 | | SUBS | SUBS.W #1, Rd | w | | 2 | | | | | | | | Rd16–1 → Rd16 | _ | _ | _ | _ | _ | _ | 2 | | | SUBS.W #2, Rd | w | | 2 | | | | | | | | Rd16–2 → Rd16 | _ | _ | _ | F | _ | _ | 2 | | DEC | DEC.B Rd | В | | 2 | | Г | | | | | Г | Rd8–1 → Rd8 | _ | _ | 1 | 1 | <b>1</b> | _ | 2 | | DAS | DAS.B Rd | В | | 2 | | | | | | Г | | Rd8 decimal adjust → Rd8 | _ | * | 1 | 1 | * | _ | 2 | | NEG | NEG.B Rd | В | | 2 | | | | | | | | $0-Rd \rightarrow Rd$ | _ | 1 | 1 | 1 | <b>1</b> | 1 | 2 | | CMP | CMP.B #xx:8, Rd | В | 2 | | | | | | | | | Rd8-#xx:8 | _ | 1 | 1 | 1 | \$ | <b>1</b> | 2 | | | CMP.B Rs, Rd | В | | 2 | | Г | | | | Г | Г | Rd8-Rs8 | _ | 1 | 1 | 1 | \$ | 1 | 2 | | | CMP.W Rs, Rd | w | | 2 | Г | | | | | Г | Г | Rd16-Rs16 | = | (1) | 1 | 1 | \$ | 1 | 2 | | MULXU | MULXU.B Rs, Rd | В | | 2 | | | | | | | | Rd8×Rs8 → Rd16 | _ | _ | _ | E | _ | _ | 14 | | DIVXU | DIVXU.B Rs, Rd | В | | 2 | | | | | | | | Rd16÷Rs8 → Rd16<br>(RdH: remainder,<br>RdL: quotient) | - | _ | (5) | (6) | - | _ | 14 | | AND | AND.B #xx:8, Rd | В | 2 | | | | | | | | | Rd8∧#xx:8 → Rd8 | _ | _ | 1 | 1 | 0 | _ | 2 | | | AND.B Rs, Rd | В | | 2 | | | | | | | Г | Rd8∧Rs8 → Rd8 | _ | _ | 1 | 1 | 0 | _ | 2 | | OR | OR.B #xx:8, Rd | В | 2 | | | Г | | | | | Г | Rd8∨#xx:8 → Rd8 | _ | _ | 1 | 1 | 0 | _ | 2 | | | OR.B Rs, Rd | В | | 2 | | | | | | | Г | Rd8∨Rs8 → Rd8 | _ | _ | 1 | 1 | 0 | | 2 | | XOR | XOR.B #xx:8, Rd | В | 2 | | | | | | | | | Rd8⊕#xx:8 → Rd8 | _ | _ | 1 | 1 | 0 | | 2 | | | XOR.B Rs, Rd | В | | 2 | | Т | Г | | | | Т | Rd8⊕Rs8 → Rd8 | _ | _ | 1 | 1 | 0 | | 2 | | NOT | NOT.B Rd | В | | 2 | | | | T | | | Г | $\overline{\text{Rd8}} \rightarrow \text{Rd}$ | E | _ | 1 | 1 | 0 | | 2 | **Table A.1** Instruction Set (cont) | | | | | | | res | | | | | | | | | | | | | | |-------|-------------------|--------------|----------|---|-----|-------------|-----------|----------|------------|-----|---|---------------------------------|---|-----|-----------|----------|----------|----|---------------| | | Mnemonic | Operand Size | #xx:8/16 | | - | @(d:16, Rn) | @-Rn/@Rn+ | @aa:8/16 | @(d:8, PC) | @aa | | Operation | С | one | diti | on | Со | de | No. of States | | | | å | ×<br># | 문 | @Rn | <u>@</u> | 9 | @<br>a | e | 9 | 1 | | ı | н | N | z | v | С | ş | | SHAL | SHAL.B Rd | В | | 2 | | | | | | | | $C \xrightarrow{b_7} b_0$ | - | _ | <b>\$</b> | 1 | 1 | \$ | 2 | | SHAR | SHAR.B Rd | В | | 2 | | | | | | | | b <sub>7</sub> b <sub>0</sub> | - | _ | 1 | 1 | 0 | \$ | 2 | | SHLL | SHLL.B Rd | В | | 2 | | | | | | | | $C \leftarrow b_7 \qquad b_0$ | - | _ | 1 | 1 | 0 | \$ | 2 | | SHLR | SHLR.B Rd | В | | 2 | | | | | | | | 0 | - | _ | 1 | 1 | 0 | \$ | 2 | | ROTXL | ROTXL.B Rd | В | | 2 | | | | | | | | C b <sub>7</sub> b <sub>0</sub> | - | _ | 1 | 1 | 0 | \$ | 2 | | ROTXR | ROTXR.B Rd | В | | 2 | | | | | | | | b <sub>7</sub> b <sub>0</sub> C | - | _ | \$ | 1 | 0 | \$ | 2 | | ROTL | ROTL.B Rd | В | | 2 | | | | | | | | C b <sub>7</sub> b <sub>0</sub> | - | _ | \$ | 1 | 0 | \$ | 2 | | ROTR | ROTR.B Rd | В | | 2 | | | | | | | | b <sub>7</sub> b <sub>0</sub> C | - | _ | 1 | 1 | 0 | \$ | 2 | | BSET | BSET #xx:3, Rd | В | | 2 | | | | | | | | (#xx:3 of Rd8) ← 1 | F | E | _ | <u> </u> | <u> </u> | _ | 2 | | | BSET #xx:3, @Rd | В | | | 4 | | | | | | | (#xx:3 of @Rd16) ← 1 | - | _ | _ | _ | _ | _ | 8 | | | BSET #xx:3, @aa:8 | В | | | | | | 4 | | | | (#xx:3 of @aa:8) ← 1 | E | _ | | | _ | | 8 | | | BSET Rn, Rd | В | | 2 | | | | | | | | (Rn8 of Rd8) ← 1 | F | _ | _ | _ | _ | _ | 2 | | | BSET Rn, @Rd | В | | | 4 | | | | | | | (Rn8 of @Rd16) ← 1 | - | _ | _ | _ | _ | _ | 8 | | | BSET Rn, @aa:8 | В | | | | | | 4 | | | | (Rn8 of @aa:8) ← 1 | E | _ | _ | E | | _ | 8 | | BCLR | BCLR #xx:3, Rd | В | | 2 | | | | | | | | (#xx:3 of Rd8) ← 0 | - | _ | _ | - | _ | _ | 2 | **Table A.1** Instruction Set (cont) | | | | | | | | | | lod | | | | | | | | | | | |-------|--------------------|--------------|---------|----------|-----|-------------|-----------|----------|------------|-----|---|----------------------------------------------------|----------|--------|---|---|----------|---|--------------| | | Mnemonic | Operand Size | cx:8/16 | Rn | @Rn | @(d:16, Rn) | @-Rn/@Rn+ | @aa:8/16 | @(d:8, PC) | @aa | | Operation | | | | | Со | | No of States | | BCLR | BCLR #xx:3, @Rd | В | # | ~ | 4 | 0 | 0 | 0 | 0 | (9) | 1 | (#xx:3 of @Rd16) ← 0 | _ | H<br>_ | N | | ٧ | С | Z | | DOLK | BCLR #xx:3, @aa:8 | В | | $\vdash$ | _ | | | 4 | $\vdash$ | | _ | (#xx:3 of @aa:8) ← 0 | Н | | | | | | 1 8 | | | BCLR Rn, Rd | В | | 2 | | _ | | - | $\vdash$ | | | (Rn8 of Rd8) ← 0 | $\vdash$ | | | | | | 2 | | | BCLR Rn, @Rd | В | | - | 4 | | | H | | | | (Rn8 of @Rd16) ← 0 | H | | | | | | 8 | | | BCLR Rn, @aa:8 | В | | $\vdash$ | - | | | 4 | $\vdash$ | | | (Rn8 of @aa:8) ← 0 | H | | | | | | 1 8 | | BNOT | BNOT #xx:3, Rd | В | | 2 | | | | - | $\vdash$ | | H | (#xx:3 of Rd8) ← (#xx:3 of Rd8) | H | | | | | | 1 | | DIVOI | BNOT #xx:3, @Rd | В | | - | 4 | | | H | $\vdash$ | | - | (#xx:3 of @Rd16) ← | Н | | | | | | 1 | | | BIOT #XX.0, GIA | ٦ | | | - | | | | | | | (#xx3 of @Rd16) | | | | | | | ľ | | | BNOT #xx:3. @aa:8 | В | | | | | | 4 | | | | (#xx:3 of @aa:8) ← | | | | | | | | | | BIVOT #XX.5, @dd.0 | ٦ | | | | | | - | | | | (#xx:3 of @aa:8) | | | | | | | ľ | | | BNOT Rn, Rd | В | | 2 | | | | $\vdash$ | $\vdash$ | | - | (Rn8 of Rd8) ← (Rn8 of Rd8) | | | _ | _ | | | 1 | | | BNOT Rn, @Rd | В | | F | 4 | | | $\vdash$ | $\vdash$ | | H | (Rn8 of @Rd16) ← | | | _ | | | | 1 | | | 2.101 1.11, 0.10 | ٦ | | | ľ | | | | | | | (Rn8 of @Rd16) | | | | | | | ` | | | BNOT Rn, @aa:8 | В | | | | | | 4 | | | | (Rn8 of @aa:8) ← | Н | | | | | E | | | | | - | | | | | | ` | | | | (Rn8 of @aa:8) | | | | | | | | | BTST | BTST #xx:3. Rd | В | | 2 | | | | | | | | (#xx:3 of Rd8) → Z | | | | 1 | | | 1 | | | BTST #xx:3, @Rd | В | | $\vdash$ | 4 | | | $\vdash$ | $\vdash$ | | Н | (#xx:3 of @Rd16) → Z | | | _ | 1 | | | | | | BTST #xx:3. @aa:8 | В | | | | | | 4 | | | | (#xx:3 of @aa:8) → Z | | | _ | 1 | | | | | | BTST Rn, Rd | В | | 2 | | | | | $\vdash$ | | | (Rn8 of Rd8) → Z | Ħ | | _ | 1 | | | 1 | | | BTST Rn, @Rd | В | | Н | 4 | | | H | Н | | | (Rn8 of @Rd16) → Z | | | _ | 1 | | _ | | | | BTST Rn, @aa:8 | В | | | | | | 4 | | | | (Rn8 of @aa:8) → Z | | _ | _ | 1 | | _ | 1 | | BLD | BLD #xx:3, Rd | В | | 2 | | | | | | | | (#xx:3 of Rd8) → C | | | = | Ė | | 1 | 1 | | | BLD #xx:3, @Rd | В | | | 4 | | | | | | Г | (#xx:3 of @Rd16) → C | | | _ | _ | | 1 | 1 | | | BLD #xx:3, @aa:8 | В | | | | | | 4 | | | | (#xx:3 of @aa:8) → C | | _ | _ | _ | _ | 1 | 1 | | BILD | BILD #xx:3, Rd | В | | 2 | | | | | | | | (#xx:3 of Rd8) → C | | | _ | _ | _ | 1 | 1 | | | BILD #xx:3, @Rd | В | | | 4 | | | | | | | (#xx:3 of @Rd16) → C | | | _ | = | <u> </u> | 1 | | | | BILD #xx:3, @aa:8 | В | | | | | | 4 | | | Г | (#xx:3 of @aa:8) → C | | | = | = | | 1 | - | | BST | BST #xx:3, Rd | В | Т | 2 | | | | | | | | C → (#xx:3 of Rd8) | Ħ | Ξ | = | = | | E | 1 | | | BST #xx:3, @Rd | В | | | 4 | П | | | | | | C → (#xx:3 of @Rd16) | Ħ | | _ | = | | | | | | BST #xx:3, @aa:8 | В | | | | | | 4 | | | | C → (#xx:3 of @aa:8) | | | _ | _ | <u> </u> | _ | | | BIST | BIST #xx:3, Rd | В | | 2 | | | | | | | T | $\overline{C} \rightarrow (\#xx:3 \text{ of Rd8})$ | | | | _ | | _ | 1 | **Table A.1** Instruction Set (cont) | | | | Addressing Mode/<br>Instruction Length | | | | | | | | | | | | | | | | | | |-------|--------------------|----------------|----------------------------------------|----------------|---|--------------------|-----------|---------|---|-----|---|-------------------------------------------------------------------------------|------------------------|---|----------------|---|---|---|-----------|--------| | | Mnemonic | | | #xx:8/16<br>Rn | | @Rn<br>@(d:16, Rn) | | aa:8/16 | | @aa | | Operation Branch | | | Condition Co | | | | | | | BIST | BIST #xx:3, @Rd | ⊕ Operand Size | # | ~ | 4 | 0 | @-Rn/@Rn+ | 0 | 0 | @ | 1 | $\overline{C} \rightarrow (\#xx:3 \text{ of } @$ | Condition | ı | Н | N | z | ٧ | С | 8<br>8 | | ыы | | В | | | 4 | H | | | | | H | <u> </u> | | F | _ | _ | _ | = | F | ⊢ | | BAND | BIST #xx:3, @aa:8 | В | | 2 | | H | | 4 | | | H | $\overline{C} \rightarrow (\#xx:3 \text{ of } \mathbb{C})$ | | F | = | _ | F | = | | 2 | | DAIND | BAND #xx:3, Rd | В | | 2 | 4 | | | | | | H | C∧(#xx:3 of Rdi | | | _ | _ | | _ | ↓ | 6 | | | BAND #xx:3, @Rd | В | | | 4 | - | | 4 | | | H | C∧(#xx:3 of @F | | F | _ | _ | F | Ξ | Ŀ. | 6 | | DIAND | BAND #xx:3, @aa:8 | _ | | _ | | H | L | 4 | | | H | C∧(#xx:3 of @a | | F | _ | _ | F | = | <b>\$</b> | ļ., | | BIAND | BIAND #xx:3, Rd | В | | 2 | | H | L | | | | L | C∧(#xx:3 of Rdi | | _ | _ | _ | | _ | <b>1</b> | 2 | | | BIAND #xx:3, @Rd | В | | | 4 | | | | | | L | C∧(#xx:3 of @ F | | F | | _ | | | <b>1</b> | 6 | | | BIAND #xx:3, @aa:8 | В | | _ | | | | 4 | | | | C∧(#xx:3 of @ a | | E | | _ | | _ | <b>1</b> | 6 | | BOR | BOR #xx:3, Rd | В | | 2 | | _ | | | | | L | C∨(#xx:3 of Rdi | | _ | _ | _ | | _ | 1 | 2 | | | BOR #xx:3, @Rd | В | | | 4 | L | | | | | L | C∨(#xx:3 of @Rd16) → C | | E | _ | _ | | _ | <b>1</b> | 6 | | | BOR #xx:3 @aa:8 | В | | | | | | 4 | | | L | | C∨(#xx:3 of @aa:8) → C | | _ | _ | | _ | 1 | 6 | | BIOR | BIOR #xx:3,Rd | В | | 2 | | | | | | | | $C\lor(\#xx:3 \text{ of } Rd8) \to C$ $C\lor(\#xx:3 \text{ of } @Rd16) \to C$ | | E | _ | _ | | _ | 1 | 2 | | | BIOR #xx:3,@Rd | В | | | 4 | | | | | | | | | E | _ | _ | | _ | 1 | 6 | | | BIOR #xx:3,@aa:8 | В | | | | | | 4 | | | | C∨(#xx:3 of @aa:8) → C | | _ | _ | _ | _ | _ | \$ | 6 | | BXOR | BXOR #xx:3,Rd | В | | 2 | | | | | | | L | C⊕(#xx:3 of Rd | | _ | _ | _ | | _ | \$ | 2 | | | BXOR #xx:3,@Rd | В | | | 4 | | | | | | L | C⊕(#xx:3 of @I | | _ | _ | _ | _ | _ | \$ | 6 | | | BXOR #xx:3,@aa:8 | В | | | | | | 4 | | | | C⊕(#xx:3 of @a | aa:8) → C | _ | _ | _ | _ | _ | \$ | 6 | | | BIXOR #xx:3,Rd | В | | 2 | | | | | | | | C⊕(#xx:3 of Rd | (8) → C | _ | _ | _ | _ | _ | \$ | 2 | | | BIXOR #xx:3,@Rd | В | | | 4 | | | | | | | C⊕(#xx:3 of @ I | Rd16) → C | _ | _ | _ | _ | _ | \$ | 6 | | | BIXOR #xx:3,@aa:8 | В | | | | | | 4 | | | | C⊕(#xx:3 of @a | aa:8) → C | _ | _ | _ | | _ | \$ | 6 | | Bcc | BRA d:8(BT d:8) | | | | | | | | 2 | | | PC ← PC+d:8 | | _ | _ | _ | _ | _ | | 4 | | | BRN d8(BF d:8) | | | | | | | | 2 | | | PC ← PC+2 | | _ | _ | _ | _ | _ | | 4 | | | BHI d:8 | _ - | | | | | | | 2 | | | if true then | C∨Z=0 | _ | _ | _ | _ | _ | _ | 4 | | | BLS d:8 | | | | | | | | 2 | | | PC ← PC+d:8 | C∨Z=1 | _ | - | _ | _ | _ | _ | 4 | | | BCC d:8(BHS d:8) | | | | | | | | 2 | | L | else next | C=0 | E | | _ | | | | 4 | | | BCS d:8(BLO d:8) | 1- | | | | | | | 2 | | | ] [ | C=1 | - | _ | _ | _ | _ | _ | 4 | | | BNE d:8 | | | | | | | | 2 | | | ] [ | Z=0 | E | $\overline{-}$ | _ | _ | _ | _ | 4 | | | BEQ d:8 | _ | | | | | | | 2 | | | ] [ | Z=1 | E | _ | _ | _ | _ | _ | 4 | | | BVC d:8 | _ | | | | | | | 2 | | | ] [ | V=0 | _ | _ | _ | _ | _ | _ | 4 | | | BVS d:8 | _ | | | | | | | 2 | | | 1 | V=1 | _ | _ | _ | _ | _ | _ | 4 | | | BPL d:8 | <u> </u> | | | | | | | 2 | | Г | 1 1 | N=0 | _ | _ | _ | _ | _ | _ | 4 | **Table A.1** Instruction Set (cont) | | | | | | | | | | lod | | | | | | | | | | | | |-------|-----------------|---|-----|----|-----|-------------|-------------|----------|----------|-----|---|-----------------------|---------------------|-----|---|--------------|----------|---|----------|---------| | | Mnemonic | | | Rn | _ | @(d:16, Rn) | @-Rn/@Rn+ | @aa:8/16 | 1:8, PC) | @aa | | Operat | | Con | | ndition Code | | | | of Stat | | | | | XX# | 몺 | @Rn | @ | <b> -</b> @ | @a | @(d:8, | 0 | 1 | | Branch<br>Condition | ı | н | N | z | v | С | ģ | | Bcc | BMI d:8 | | | | | | | | 2 | | | if true then | N=1 | _ | _ | _ | _ | _ | _ | 4 | | | BGE d:8 | | | | | | | | 2 | | | PC ← PC+d:8 | N⊕V=0 | _ | _ | _ | _ | _ | - | 4 | | | BLT d:8 | | | | | | | | 2 | | | else next | N⊕V=1 | F | _ | _ | F | _ | _ | 4 | | | BGT d:8 | | | | | | | | 2 | | | | Z∨(N⊕V)=0 | _ | _ | _ | _ | _ | _ | 4 | | | BLE d:8 | | | | | | | | 2 | | | | Z∨(N⊕V)=1 | _ | _ | _ | _ | _ | _ | 4 | | JMP | JMP @Rn | | | | 2 | | | | | | | PC ← Rn16 | | _ | - | _ | _ | _ | _ | 4 | | | JMP @aa:16 | _ | | | | | | 4 | | | | PC ← aa:16 | | _ | _ | _ | _ | _ | _ | 6 | | | JMP @@aa:8 | | | | | | | | | 2 | | PC ← @aa:8 | | F | Ε | _ | _ | - | _ | 8 | | BSR | BSR d:8 | | | | Г | | | | 2 | | | $SP-2 \rightarrow SP$ | | F | Ε | _ | F | _ | _ | 6 | | | | | | | | | | | | | | PC → @SP | | | | | | | | | | | | | | | | | | | | | | PC ← PC+d:8 | | | | | | | | | | JSR | JSR @Rn | - | | | 2 | | | | | | | SP-2 → SP | | _ | Ε | _ | _ | _ | _ | 6 | | | | | | | | | | | | | | PC → @SP | | | | | | | | | | | | | | | | | | | | | | PC ← Rn16 | | | | | | | | | | | JSR @aa:16 | | | | | | | 4 | | | | SP-2 → SP | | E | E | _ | _ | _ | _ | 8 | | | | | | | | | | | | | | PC → @SP | | | | | | | | | | | | | | | | | | | | | | PC ← aa:16 | | | | | | | | | | | JSR @@aa:8 | | | | Г | | | | | 2 | | SP-2 → SP | | E | Ε | _ | F | = | = | 8 | | | | | | | | | | | | | | PC → @SP | | | | | | | | | | | | | | | | | | | | | | PC ← @aa:8 | | | | | | | | | | RTS | RTS | _ | | | | | | | | | 2 | PC ← @SP | | L | E | _ | _ | _ | _ | 8 | | | | | | | | | | | | | | $SP+2 \rightarrow SP$ | | | | | | | | | | RTE | RTE | | | | | | | | | | 2 | CCR ← @SP | | 1 | 1 | 1 | 1 | 1 | 1 | 10 | | | | | | | | | | | | | | $SP+2 \rightarrow SP$ | | | | | | | | | | | | | | | | | | | | | | PC ← @ SP | | | | | | | | | | | | | | | | | | | | | | SP+2 → SP | | | | | | | | | | SLEEP | SLEEP | _ | | | | | | | П | | 2 | Transit to sleep | mode | E | E | _ | <u> </u> | _ | _ | 2 | | LDC | LDC #xx:8, CCR | В | 2 | | | | | | П | | | #xx:8 → CCR | | 1 | 1 | 1 | 1 | 1 | <b>1</b> | 2 | | | LDC Rs, CCR | В | | 2 | | | | | | | | Rs8 → CCR | | 1 | 1 | 1 | 1 | 1 | <b>1</b> | 2 | | STC | STC CCR, Rd | В | | 2 | | | | | | | | CCR → Rd8 | | Ė | Ė | Ė | Ė | Ė | Ė | 2 | | ANDC | ANDC #xx:8, CCR | В | 2 | | Н | Н | | | П | Н | | CCR∧#xx:8 → | CCR | 1 | 1 | 1 | 1 | 1 | 1 | 2 | **Table A.1** Instruction Set (cont) | | | | | Addressing Mode/<br>Instruction Length | | | | | | | | | | | | | | | | |--------|-----------------|--------------|----------|----------------------------------------|-----|-------------|-----------|----------|------------|-----|---|------------------------------------------------------------------------------------------------------|---|----|----|-----------|---|---|-----| | | Mnemonic | Operand Size | #xx:8/16 | | r. | @(d:16, Rn) | @-Rn/@Rn+ | @aa:8/16 | @(d:8, PC) | @aa | | Operation Condition Co | | Со | de | of States | | | | | | | ĕ | ¥ | 몺 | @Rn | <u></u> | 9 | @<br>9 | 0 | 9 | 1 | | ı | н | N | z | v | С | ġ | | ORC | ORC #xx:8, CCR | В | 2 | | | | | | | | | $CCR \lor \#xx:8 \to CCR$ $\updownarrow$ $\updownarrow$ $\updownarrow$ $\updownarrow$ $\updownarrow$ | | \$ | 1 | 2 | | | | | XORC | XORC #xx:8, CCR | В | 2 | | | | | | | | | CCR⊕#xx:8 → CCR ↑ ↑ | | 1 | 1 | \$ | 1 | 2 | | | NOP | NOP | _ | | | | | | | | | 2 | PC ← PC+2 | - | _ | F | $\vdash$ | _ | F | 2 | | EEPMOV | EEPMOV | _ | | | | | | | | | 4 | if R4L≠0 then | _ | _ | _ | _ | _ | _ | (4) | | | | | | | | | | | | | | Repeat @R5 → @R6 | | | | | | | | | | | | | | | | | | | | | R5+1 → R5 | | | | | | | | | | | | | | | | | | | | | R6+1 → R6 | | | | | | | | | | | | | | | | | | | | | R4L−1 → R4L | | | | | | | | | | | | | | | | | | | | | Until R4L=0 | | | | | | | | | | | | | | | | | | | | | else next | | | | | | | | Notes: The number of states is the number of states required for execution when the instruction and its operands are located in on-chip memory. - (1) Set to 1 when there is a carry or borrow from bit 11; otherwise cleared to 0. - (2) If the result is zero, the previous value of the flag is retained; otherwise the flag is cleared to 0. - (3) Set to 1 if decimal adjustment produces a carry; otherwise the value prior to the calculation is retained. - (4) The maximum write time is 15 ms. - (5) Set to 1 when the divisor is negative; otherwise cleared to 0. - (6) Set to 1 when the divisor is zero; otherwise cleared to 0. # Appendix B Operation Code Map Table B.1 is a map of the operation codes contained in the first byte of the instruction code (bits 15 to 8 of the first instruction word). Some pairs of instructions have identical first bytes. These instructions are differentiated by the first bit of the second byte (bit 7 of the first instruction word). **Table B.1** Operation Code Map | HI | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | А | В | С | D | Е | F | |----|--------------|--------------|---------------|---------------|----------|-------|---------------|---------------|-----|-----|-----|--------|--------|----------|-----------|--------| | 0 | NOP | SLEEP | STC | LDC | ORC | XORC | ANDC | LDC | ΑI | DD | INC | ADDS | М | DV | ADDX | DAA | | 1 | SHLL<br>SHAL | SHLR<br>SHAR | ROTXL<br>ROTL | ROTXR<br>ROTR | OR | XOR | AND | NOT/<br>NEG | SI | JB | DEC | SUBS | CN | ИP | SUBX | DAS | | 2 | | | | | | | | | OV | | | | | | | | | 3 | | | | | | | | IVI | υv | | | | | | | | | 4 | BRA*2 | BRN*2 | вні | BLS | BCC*2 | BCS*2 | BNE | BEQ | BVC | BVS | BPL | вмі | BGE | BLT | BGT | BLE | | 5 | MULXU | DIVXU | | | RTS | BSR | RTE | | | | JMP | | | | JSR | | | 6 | BSET | BNOT | DCI D | BTST | | | | BST /<br>BIST | | | | МО | V*1 | | | | | 7 | BSEI | BNOT | BCLR | ВІЗІ | BOR BIOR | / | BAND<br>BIAND | BLD<br>BILD | | MOV | | EEPMOV | Bit ma | nipulati | ion instr | uction | | 8 | | | | | | | | Al | DD | | | | | | | | | 9 | | | | | | | | Al | DDX | | | | | | | | | Α | | | | | | | | С | MP | | | | | | | | | В | | | | | | | | S | UBX | | | | | | | | | С | | | | | | | | 0 | R | | | | | | | | | D | | XOR | | | | | | | | | | | | | | | | E | | AND | | | | | | | | | | | | | | | | F | | | | | | | | М | OV | | | | | | | | Notes: 1. The PUSH and POP instructions are identical to MOV instructions. 2. The BT, BF, BHS, and BLO instructions are identical to BRA, BRN, BCC, and BCS, respectively. # Appendix C Register Field ## C.1 Register Field (1) #### **Bit Names** | | Register | - | | | | | | | | _ | |---------|----------|-------|-------|-------|-------|-------|-------|-------|-------|----------| | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Module | | H'FFF8 | ECR | | | _ | _ | _ | _ | OC1 | OC0 | EEPROM | | H'FFF9 | EPR | PBM | | _ | _ | _ | _ | _ | _ | _ | | H'FFFE | DR | DR7 | DR6 | _ | _ | _ | _ | _ | _ | I/O port | | H'FFFF | DDR | DDR7 | DDR6 | _ | _ | _ | _ | _ | _ | _ | ## C.2 Register Field (2) ### ECR EEPROM Control Register **EEPROM** #### **EPR EEPROM** Protect Register **EEPROM** # Appendix D I/O Port Block Diagram Figure D.1 I/O Port Block Diagram # Appendix E Comparison with H8/3102 Table E.1 shows a comparison between H8/3102 and H8/3103. When an H8/3103 program is created by porting an existing H8/3102 program, the specification differences must be noted. Table E.1 Comparison between H8/3102 and H8/3103 | Item | | H8/3102 | H8/3103 | |---------|-------------------------------------------|----------------------------------------------------|---------------------------------| | CPU | | H8/300 CPU | H8/300 CPU | | | Number of clocks for reset start | 5 external clocks | 200 external clocks (max.) | | RAM | | 512 bytes | 512 bytes | | ROM | | 16 kbytes | 20 kbytes | | EEPR | ОМ | 8 kbytes | 16 kbytes | | | Organization | 32 bytes × 256 pages | 64 bytes × 256 pages | | | Low voltage detection indicator (PWR bit) | Yes<br>(bit 4 of EEPROM Control<br>Register (ECR)) | No | | I/O po | rts | 2 | 2 | | Power | r-down state | Sleep mode | Sleep mode | | Securi | ity | Low voltage detector | Low voltage detector | | | | Low frequency detector | Low frequency detector | | | | | Illegal address detector | | Electri | ical characteristics | Refer to the Electrical Charac | cteristics section for details. | ## Appendix F H8/3103 DP-64S Pin Assignment A working sample is available in 64-pin plastic shrink DIP (DP-64S) form. Figure F.1 H8/3103 DP-64S Pin Assignment ## Appendix G External Dimensions Figure G.1 shows the external dimensions of the H8/3103 microcomputer (COB standard pattern). The COB is mounted on a Tape and Reel. Figure G.1 External Dimensions ### H8/3103 Hardware Manual Publication Date: 1st Edition, November 1997 Published by: Semiconductor and IC Div. Hitachi, Ltd. Edited by: Technical Documentation Center Hitachi Microcomputer System Ltd. Copyright © Hitachi, Ltd., 1997. All rights reserved. Printed in Japan.