ROCKWELL/DIGITAL COMM R6500 Microcomputer System T-49-17-06 # R65012 One-Chip Microprocessor # SECTION 1 INTRODUCTION #### SUMMARY The Rockwell R65012 is a complete, high performance 8-bit NMOS-3 microcomputer on a single chip and is compatible with all members of the R6500 family. The R65012 consists of an enhanced 6502 CPU, an internal clock oscillator, 192 bytes of Random Access Memory (RAM), and versatile interface circuitry. The interface circuitry includes two 16-bit programmable timer/counters, 32 bidirectional input/output lines (including four edgesensitive lines and input latching on one 8-bit port), a full-duplex serial I/O channel, ten interrupts, and bus expandability. The R65012 can be thought of as a modified R6501 and the major feature differences are shown in bold. The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make the R65012 a leading candidate for microcomputer applications. Rockwell supports development of the R65012 with the Low Cost Emulator (LCE) Development System and the R6500/\* Family of Personality Modules. Complete in-circuit emulation with the R6500/\* Family of Personality Modules allows total system test and evaluation. This product description assumes that the reader is familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Document Order No. 201). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Document Order No. 202). #### **FEATURES** - Enhanced 6502 CPU - Four new bit manipulation instructions Set Memory Bit (SMB) Reset Memory Bit (RMB) Branch on Bit Set (BBS) Branch on Bit Reset (BBR) - Binary arithmetic mode only - 13 addressing modes - True indexing - Stack on page one - Page select bit for zero page instructions - 192-byte static RAM - 32 bidirectional, TTL-compatible I/O lines (four ports) - One 8-bit port may be tri-stated under software control - One 8-bit port may have latched inputs under software control - Internal pull-up resistors on ports PA and PB - . Two 16-bit programmable counter/timers, with latches - Pulse width measurement - Asymmetrical pulse generation - Pulse generation - Interval timer - Event counter - Retriggerable interval timer - Serial Port - Full-duplex asynchronous operation mode - One stop bit only - Selectable 5- to 8-bit characters - Wake-up feature - Synchronous shift register mode - Standard programmable bit rates programmable up to 62.5K bits/sec @ 1 MHz - Ten interrupts - Four edge-sensitive lines; two positive, two negative - Reset and non-maskable interrupt - Two counter underflows - Serial data received and serial data transmitted - · Bus expandable to 64K bytes of external memory Document No. 29400N02 **Product Description** Order No. 402 November 1988 9000-2254 ## FEATURES (Cont'd) - Flexible clock circuitry - 3 MHz (R65012B), 2 MHz (R65012A) or 1 MHz (R65012) internal operation - Crystal or clock input - 0.66 $\mu s$ minimum instruction execution time at 3 MHz - Single +5V power supply - 12 mW standby power for 32 bytes of the 192-byte RAM - Available in 64-pin plastic QUIP and 68-pin PLCC packages ## **ORDERING INFORMATION** # SECTION 2 INTERFACE REQUIREMENTS T-49-17-06 This section describes the interface requirements for the R65012. Figure 2-1 and 2-2 show the interface and the pin assignments for both devices. Table 2-1 describes the function of each pin. Figure 2-1. R65012 Interface Diagram Figure 2-2. R65012 Pin Assignments Table 2-1. R65012 Pin Descriptions T-49-17-06 | | 1 | Pi | n No. | | |-----------------|-----|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Signal Name | 1/0 | 64-Pin QUIP | 68-Pin PLCC | Description | | Vcc | 1 | 21 | 22 | Power. Main power supply. +5V. | | V <sub>RR</sub> | 1 | 43 | 46 | RAM Retention Power. Separate power pin for RAM. In the event that Vcc power is off, this power retains RAM data. +5V. | | Vss | | 44 | 48 | Ground. Signal and power ground (OV). | | XTLI | 1 | 42 | 45 | Crystal In. Crystal or clock input for internal clock oscillator. Allows input of X1 clock signal if XTLO is connected to Vss, or of X4 (R65012A) or X2(R65012A) clock if XTLO is floated. | | XTLO | 0 | 41 | 44 | Crystal Out. Crystal output from internal clock oscillator. | | RES | I | 6 | 7 | RESET. The Reset input is used to initialize the device. This signal must not transition from low to high for at least eight cycles after Vcc reaches operating range and the internal oscillator has stabilized. | | ф2 | 0 | 45 | 49 | Phase 2 Clock. Clock signal output at internal frequency. | | NMI | 1 | 23 | 25 | Non-Maskable Interrupt. A negative going edge on the Non-Maskable Interrupt be generated with the CPU. | | PA0-PA7 | 1/0 | 39-32 | 42-35 | Port A. General purpose I/O Port A. | | PB0-PB7 | 1/0 | 31-24 | 34-30, 28-26 | Port B. General purpose I/O Port B. | | PC0-PC7 | 1/0 | 54-61 | 58-65 | Port C. General purpose I/O Port C. | | PD0-PD7 | 1/0 | 62-64, 1-5 | 66, 67, 1-6 | Port D. General purpose I/O Port D. | | | | | | Four 8-bit ports used for input/output. Each line of Ports A, B and C consists of an active transistor to Vss and a passive pull-up to Vcc. Port D functions as either an 8-bit input or an 8-bit output port, it has active pull-up and pull-down transistors. | | A0-A12, A15 | 0 | 20-8, 7 | 21-9, 8 | Address Lines. Fourteen address lines used to address a complete 65K byte external address space. Note: A13 and A14 are sourced through PC6 and PC7 when in the Full Address Mode. | | DB0-DB7 | 1/0 | 53-46 | 57-50 | Data Lines. Eight bidirectional data bus lines used to transmit data to and from external memory. | | SYNC | 0 | 22 | 24 | SYNC. SYNC is a positive going signal for the full clock cycle whenever the CPU is performing an op code fetch. | | R/W | 0 | 40 | 43 | READ/WRITE. R/W controls the direction of data transfer between the CPU and the external 65K byte address space. The signal is high when reading or low when writing. | **One-Chip Microprocessor** # SECTION 3 SYSTEM ARCHITECTURE T-49-17-06 This section provides a functional description of the R65012. Functionally, the R65012 consists of a CPU, RAM, four 8-bit parallel I/O ports, a serial I/O port, dual counter/latch circuits, a mode control register, an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3-1. #### NOTE Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation. ### 3.1 CPU LOGIC The R65012 internal CPU is a standard 6502 configuration with an 8-bit Accumulator register, two 8-bit index registers (X and Y); an 8-bit Stack Pointer register, an arithmetic and logic unit (ALU), a 16-bit Program Counter, and standard Instruction register/decode and internal timing control logic. ### 3.1.1 Accumulator The accumulator is a general purpose 8-bit register that stores the results of most arithmetic and logic operations. In addition, the accumulator usually contains one of the two data words used in these operations. ### 3.1.2 Index Registers There are two 8-bit index registers, X and Y. Each index register can be used as a base to modify the address data program counter and thus obtain a new address—the sum of the program counter contents and the index register contents. When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory. Indexing greatly simplifies many types of programs, especially using those data tables. ### 3.1.3 Stack Pointer The Stack Pointer is an 8-bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal interrupt request (IRQ), or the external non-maskable interrupt input (NMI). The Stack Pointer must be initialized by the user program. The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI, and RTS instructions use the stack and Stack Pointer. The stack can be envisioned as a deck of cards which may be accessed only from the top. The address of a memory location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus and data are read from the memory location addressed by the Stack Pointer. The stack is located on page one, i.e., memory locations 01FF-0100. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 01FF. ### 3.1.4 Arithmetic And Logic Unit (ALU) All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle. Each bit of the ALU has two inputs. These inputs can be tled to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs. ## 3.1.5 Program Counter The 16-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order 8 bits of the Address Bus and the higher (most significant) byte of the Program Counter (PCH) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory. ## 3.1.6 Instruction Register and Instruction Decode Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register, then decoded along with timing Figure 3-1. Detailed Block Diagram and interrupt signals to generate control signals for the various registers. #### 3.1.7 Timing Control The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to T0 each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit. ### 3.1.8 Interrupt Logic Interrupt logic controls the sequencing of three interrupts; RES, NMI and IRQ. IRQ is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions. ### 3.2 NEW INSTRUCTIONS In addition to the standard R65012 instruction set, four new bit manipulation instructions have been added to the R65012. The added instructions and their format are expiained in the following paragraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions. The four added instructions do not impact the CPU processor status register. These operate on data in page zero or page two. The page is selected by the CLD or SED instruction. ### 3.2.1 Set Memory Blt (SMB m, Addr.) This instruction sets to "1" one of the 8-bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and one of eight bits to be set. The second byte of the instruction designates address (0-255) of the byte to be operated upon. ## 3.2.2 Reset Memory Bit (RMB m, Addr.) This instruction is the same operation and format as SMB instruction except a reset to "0" of the bit results. ## 3.2.3 Branch On Bit Set Relative (BBS m, Addr, DEST) This instruction tests one of eight bits designated by a 3-bit immediate field with in the first byte of the instruction. The second byte designates the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction specifies the 8-bit relative address to which the instruction branches if the bit tested is a "1". If the bit tested is not set, the next sequential instruction is executed. ## 3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST) This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a "0". ## 3.3 READ-ONLY-MEMORY (ROM) The R65012 has no ROM and its Reset vector is at FFFC. ## 3.4 RANDOM ACCESS MEMORY (RAM) The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R65012 provides a separate power pin (VRR) which may be used for standby power for 32 bytes located at 0040-005F. In the event of the loss of VCC power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the VRR pin. If the RAM data retention is not required, then VRR must be connected to VCC. During operation VRR must be at the VCC level. For the RAM to retain data upon loss of V<sub>CC</sub>, V<sub>RR</sub> must be supplied within operating range and RES must be driven low at least eight $\underline{\phi2}$ clock pulses before V<sub>CC</sub> falls out of operating range. RES must then be held low while V<sub>CC</sub> is out of operating range and until at least eight $\underline{\phi2}$ clock cycles after V<sub>CC</sub> is again within operating range and the internal $\underline{\phi2}$ oscillator is stabilized. V<sub>RR</sub> must remain within V<sub>CC</sub> operating range during normal operation. When V<sub>CC</sub> is out of operating range, V<sub>RR</sub> must remain within the V<sub>RR</sub> retention range in order to retain data. Figure 3-2 shows typical waveforms. Figure 3-2. Data Retention Timing ## **One-Chip Microprocessor** ### 3.5 CLOCK OSCILLATOR The R65012 has been configured for a crystal oscillator, a countdown network, and for Master Mode Operation. A reference frequency can be generated with the on-chip oscillator using either an external crystal or an external oscillator. The oscillator reference frequency passes through an internal countdown network to obtain the internal operating frequency. The on-chip oscillator is designed for a parallel resonant crystal connected between XTLI and XTLO pins. The equivalent oscillator circuit is shown in Figure 3-3a, A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance (CL), series resistance (Rs) and the crystal resonant frequency (F) must meet the following two relations: $$(C + 27) = 2C_L \text{ or } C = 2C_L - 27 \text{ pF}$$ $R_S \le R_{SMAX} = \frac{2 \times 10^6}{(FC_L)^2}$ where: F is in MHz; C and CL are in pF; R is in ohms. To select a parallel resonant crystal for the oscillator, first select the load capacitance from a crystal manufacturer's catalog. Next, calculate R<sub>SMAX</sub> based on F and C<sub>L</sub>. The selected crystal must have a R<sub>S</sub> less than R<sub>SMAX</sub>. For example, if $C_L = 22 \text{ pF}$ for a 4 MHz parallel resonant crystal, then $C = (2 \times 22) - 27 = 17 pF$ (use standard value of 18 pF) The series resistance of the crystal must be less than RSMAX = $$\frac{2 \times 10^6}{(4 \times 22)^2}$$ = 258 ohms Internal timing can also be controlled by driving the XTLI pln with an external frequency source. Figure 3-3b shows typical connections. If XTLO is left floating, the external source is divided by the internal countdown network. However, if XTLO is tied to Vss, the internal countdown network is bypassed causing the chip to operate at the frequency of the external source. ## 3.6 MODE CONTROL REGISTER (MCR) The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the R65012 in any application. Initializing this register is one of the first actions of any software program. The Mode Control Register bit assignment is shown in Figure 3-4. Figure 3-3. Clock Oscillator Input Options Figure 3-4. Mode control Register ## 3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER) An interrupt request (IRQ) can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts cause the interrupt request to remain active until all interrupting conditions have been serviced and cleared. ( ## One-Chip Microprocessor T-49-17-06 Figure 3-5. Interrupt Enable and Flag Registers The Interrupt Flag register contains the information that indicates which I/O or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address 0011. Edge detect IFR bits may be cleared by executing a RMB instruction at address location 0010. The RMB X, (0010) instruction reads FF, modifies bit X to a "0", and writes the modified value at address location 0011. In this way IFR bits set to a "1" after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. A logic "1" is ignored when writing to edge detect IFR bits. Each IFR bit has corresponding bit in the Interrupt Enable Register which can be set to a "1" by writing a "1" in the respective bit position at location 0012. Individual IER bits may be cleared by writing a "0" in the respective bit position, or by RES. If set to a "1", an IRQ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-5 and the functions of each bit are explained in Table 3-1. Figure 3-6. Processor Status Register Table 3-1. Interrupt Flag Register Bit Codes | Bit Code | Function | |----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IFR 0: | PA0 Positive Edge Detect Flag—Set to a '1' when a positive goning edge is detected on PA0. Cleared by RMB 0 (0010) instruction or by RES. | | IFR 1: | PA1 Positive Edge Detect Flag—Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by RES. | | IFR2: | PA2 Negative Edge Detect Flag—Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB 2 (0010) instruction or by RES. | | IFR 3: | PA3 Negative Edge Detect Flag—Set to a 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or y RES. | | IFR 4: | Counter A Underflow Flag—Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. | | IFR 5: | Counter B Underflow Flag—Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by RES. | | IFR 6: | Receiver Interrupt Flag—Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1. Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by RES. | | IFR 7: | Transmitter Interrupt Flag—Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1, Cleared when the Transmitter Status bits (SCSR 6 &7) are cleared or by RES. | ## One-Chip Microprocessor The use of Counter A Mode Select is shown in Section 6.1. The use of Counter B Mode Select is shown in Section 6.2. The use of Port B Latch Enable is shown in Section 4.4 The use of Port D in Tri-State Enable is shown in Section 4.6. The use of bus Mode Select is shown in Section 4.5 and 4.6. ### 3.8 PROCESSOR STATUS REGISTER The 8-bit Processor Status Register, shown in Figure 3-6, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R65012 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections. ### 3.8.1 Carry Bit (C) The Carry Bit (C) can be consipergagitated considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations. The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC. ### 3.8.2 Zero Bit (Z) The Zero Bit (Z) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R65012 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA. ### 3.8.3 Interrupt Disable Bit (I) The Interrupt Disable Bit (I) controls the servicing of an interrupt request (IRQ). If the I Bit is reset to logic 0, the IRQ signal will be serviced. If the bit is set to logic 1, the IRQ signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET (RES), IRQ, or Non-Maskable Interrupt (NMI) signal is detected. The I Bit is cleared by the Clear Interrupt Mask (CLI) instruction and is set by the Set Interrupt Mask (SEI) instruction. This bit is set by the BRK instruction. The return from Interrupt (RTI) and Pull Processor Status (PLP) instructions also affect the I bit. ### 3.8.4 Zero Page Bank Select Bit (D) This bit is used to bank select the zero page. When this bit is set to logic 1, instructions that operate on zero page memory locations will operate on memory locations 0200 through 02FF of external RAM. When this bit is cleared to logic 0, instructions that operate on zero page memory locations will operate on locations 0000 through 00FF of internal memory. ### CAUTION The Zero Page Bank Select Bit will either set or clear in an unpredictable manner upon power application. This bit must be initialized to the desired state by the user program or erroneous results may occur. ### 3.8.5 Break Bit (B) $\overline{\text{Ihe}}$ Break Bit (B) indicates the condition which caused the $\overline{\text{IRQ}}$ service routine to be entered. If the IRQ service routine was entered because the CPU executed a BRK command, the Break Bit is set to logic 1. If the IRQ routine was entered as the result of an IRQ signal being generated, the B Bit is cleared to logic 0. There are no instructions which can set or clear this bit. ### 3.8.6 Overflow Bit (V) The Overflow Bit (V) indicates that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits $(-128 \le n \le 127)$ . This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7) is changed because the result exceeds +127 or -128; otherwise the bit is cleared to logic 0. The V Bit is also be cleared by the Clear Overflow (CLV) instruction. The Overflow Bit may also be used with the BIT instruction. The BIT instruction—which may be used to sample interface devices—allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions affecting the V flag are ADC, BIT, CLV, PLP, RTI and SBC. ## **One-Chip Microprocessor** ### 3.8.7 Negative Bit (N) The Negative Bit (N) indicates that the sign bit (bit 7) in the resulting value of a data movement or data arithmetic operation is set to logic 1. If the sign bit is set to logic 1, the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA. T-49-17-06 T-49-17-06 # SECTION 4 PARALLEL INPUT/OUTPUT PORTS & BUS MODES The devices have 32 I/O lines grouped into four 8-bit ports (PA, PB, PC, and PD). Ports A through C may be used either for input or output individually or in groups of any combination. Port D may be used as all inputs or all outputs. Multifunction I/O's such as Port A and Port C are protected from normal port I/O instructions when they are programmed to perform a multiplexed function. Internal pull-up resistors (FETs with an impedance range of $3K \le R_L \le 12K$ ohm) are provided on all port pins except Port D. The direction of the 32 I/O lines is controlled by four 8-bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, thus simplifying I/O handling. The I/O addresses are shown in Table 4-1. Table 4-1. I/O Port Addresses | Port | Address | |------|---------| | Α | 0000 | | В | 0001 | | С | 0002 | | D | 0003 | ## 4.1 INPUTS Inputs for Ports A, B, and C are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to I/O input lines. A low (<0.8V) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high (>2.0V) input will cause a logic 1 to be read. An RES signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs. Port D may only be all inputs or all outputs. All inputs is selected by setting bit 5 of the Mode control Register (MCR5) to a \*0\*. The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers. Read/Modify/Write instructions can be used to modify the operation of PA, PB, PC, & PD. During the Read cycle of a Read/Modify/Write instructions, the Port I/O register is read. For all other read instruction the port input lines are read. Read/Modify/Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB. ### **4.2 OUTPUTS** Outputs for Ports A through D are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high (>2,4V) output while a logic 0 will force a low (<0.4V) output. Port D all outputs are selected by setting MCR5 to a "1". ### 4.3 PORT A (PA) Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as standard parallel 8-bit, bit independent, I/O port or as serial channel I/O lines, counter I/O lines, or an input data strobe for the Port B input latch option. Table 4-2 tabulates the control and usage of Port A. In addition to their normal I/O functions, PA0 and PA1 can detect positive going edges and PA2 and PA3 can detect negative going edges. A proper transition on these plns will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detected is one-half the $\phi 2$ clock rate. ## 4.4 PORT B (PB) Port B can be programmed as an 8-bit, bit-independent I/O port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-3 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided through PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port B is shown in Appendix E.3. T-49-17-06 ## Table 4-2. Port A Control and Usage | | PAO | I/O | PORT B LA | TCH MODE | ] | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | |--------------------|----------------------------------------------------|------------------------|----------------------------------------------------|-----------------------------------|----------------------------------------|-----------------------------------------------------------------------------------------------|--|--| | | MCR4 | 1 = 0 | MCR | 4 = 1 | 1 | | | | | | SIGI | NAL | SIGI | NAL | 1 | | | | | | NAME | TYPE | NAME | TYPE | 1 | | | | | PA0 (2) | PA0 | 1/0 | PORT B<br>LATCH STROBE | INPUT (1) | | | | | | | | | | | - | | | | | PA1 (2) | PA1-P | | | | | | | | | PA2 (3)<br>PA3 (3) | SIGI | | | | | | | | | . 40 (0) | NAME<br>PA1 | TYPE | | | | * * * * * * * * * * * * * * * * * * * * | | | | | PA2<br>PA3 | 1/O<br>1/O<br>1/O | | | | | | | | | PA4 | I I/O | | COUNTER | R A I/O | <u> </u> | | | | PA4 | MCR0 = 0<br>MCR1 = 0<br>SCCR7 = 0<br>RCVR S/R MODE | | MCR0 = 1<br>MCR1 = 0<br>SCCR7 = 0<br>RCVR S/R MODE | | SCCR7 = 0<br>SCCR6 = 0<br>MCR1 = 1 | | | | | | ***** | 4) (5)<br>NAL | | 4)<br>NAL | <del></del> | SIGNAL | | | | | NAME | TYPE | NAME | TYPE | NAME | TYPE | | | | | PA4 I/O | | CNTA | OUTPUT | CNTA | INPUT (1) | | | | | | · · · · · · · · | SERIAL I/O SHIFT | REGISTER CLOCK | < | <del></del> | | | | | | SCCR7 = 1<br>SCCR5 = 1 | | RCVR | S/R MODE =<br>(4) | 1 | | | | | | SIGNAL | | | SIGNAL | | | | | | NAME | | TYPE | NAME | TYPE | | | | | | XMTR CLO | CK . | OUTPUT | RCVR CLC | ск | INPUT (1) | | | | | PAS | i VO | | COUNTE | B B I/O | | | | | | MCR: | 3 = 0 | MCR3<br>MCR2 | = 0 | 1 | MCR3 = 1<br>MCR2 = X | | | | PA5 | · · · · · · · · · · · · · · · · · · · | NAL | | NAL | SIGNAL | | | | | | NAME | TYPE | NAME | TYPE | NAME | TYPE | | | | | PA5 | 1/0 | CNTB | OUTPUT | CNTB | INPUT (1) | | | | | PAG | 3 1/0 | XMTR | AL I/O<br>OUTPUT | (2) POSITIV<br>(3) NEGATIVE (4) RCVR S | VARE BUFFER FLOAT VE EDGE DETECT IVE EDGE DETECT B/R MODE = 1 WHEN | | | | | 0000 | | I SCCF | ₹7 = 1 | | · SCCR5 · SCCR4 = 1 | | | | PA6 | SCCF | | 810 | NAL | | following made combi- | | | | PA6 | SIG | NAL | | NAL TYPE | nations | PA4 is available as an | | | | PA6 | SIG<br>NAME | TYPE | NAME | TYPE | nations<br>Input Or | PA4 is available as an niv pin: | | | | PA6 | SIG | NAL | | | nations Input Or SCCR7• +SCCR | PA4 is available as an any pin:<br>SCCR6-SCCR5-MCR1<br>7-SCCR6-SCCR4-MCR1 | | | | PAG | NAME PA6 | TYPE | NAME<br>XMTR | TYPE | nations Input Or SCCR74 + SCCR + SCCR | PA4 is available as an<br>nly pin:<br>SCCR6-SCCR5-MCR1 | | | | | NAME PA6 | TYPE I/O | NAME<br>XMTR<br>SERI<br>RCVR | TYPE OUTPUT | nations Input Or SCCR74 + SCCR + SCCR | PA4 is available as an any pin:<br>SCCR6-SCCR5-MCR1<br>7-SCCR6-SCCR4-MCR1<br>7-SCCR6-SCCR5 | | | | PA6 | SIG<br>NAME<br>PA6 | NAL TYPE VO | NAME XMTR SERI RCVR SCCI | TYPE OUTPUT AL I/O INPUT | nations Input Or SCCR74 + SCCR + SCCR | PA4 is available as an<br>nly pin:<br>SCCR6-SCCR5-MCR1<br>7-SCCR6-SCCR4-MCR1<br>7-SCCR6-SCCR5 | | | | | SIG<br>NAME<br>PA6 | NAL | NAME XMTR SERI RCVR SCCI | TYPE OUTPUT AL I/O INPUT R6 = 1 | nations Input Or SCCR74 + SCCR + SCCR | SCCR6-SCCR5-MCR1<br>7-SCCR6-SCCR4-MCR1<br>7-SCCR6-SCCR5 | | | ## One-Chip Microprocessor T-49-17-06 Table 4-5. Port D Control and Usage Table 4-3. Port B Control and Usage | | MCH | Mode<br>14 = 0 | Latch<br>Mode <sup>2</sup><br>MCR4 = 1 | | | | | |-------------|----------------|-----------------------------|----------------------------------------|----------------|--|--|--| | Pin<br>Name | Signal<br>Name | Signal<br>Type <sup>1</sup> | Signal<br>Name | Signal<br>Type | | | | | PB0 | PB0 | 1/0 | PB0 | INPUT | | | | | PB1 | PB1 | 1/0 | PB1 | INPUT | | | | | P82 | PB2 | 1/0 | P82 | INPUT | | | | | PB3 | P83 | I/O | PB3 | INPUT | | | | | PB4 | PB4 | 1/0 | PB4 | INPUT | | | | | PB5 | PB5 | 1/0 | PB5 | INPUT | | | | | P86 | PB2 | 1/0 | PB6 | INPUT | | | | | PB7 | PB2 | 1/0 | PB7 | INPUT | | | | NOTES: 1. Resistive Pull-Up, Active Buffer Pull-Down 2. Input data is stored in Port B latch by PA0 Pulse ## 4.5 PORT C (PC) Port C can be programmed as an I/O port, as part of the full address bus. When operating in the Full Address Mode, PC6 and PC7 serve as A13 and A14 with PC0-PC5 operating as normal I/O pins. Table 4-4 shows the Port C control and usage. Table 4-4. Port C Control and Usage | | | Address<br>lode | Normal Mode | | | | | |-------------|----------------|---------------------|----------------------|-----------------------------|--|--|--| | | | R7 = 0<br>R6 = 0 | MCR7 = 0<br>MCR6 = 1 | | | | | | Pin<br>Name | Signal<br>Name | Signal<br>Type | Signal<br>Name | Signal<br>Type <sup>1</sup> | | | | | PC0 | PC0 | 1/01 | PC0 | 1/0 | | | | | PC1 | PC1 | 1/01 | PC1 | 1/0 | | | | | PC2 | PC2 | 1/01 | PC2 | 1/0 | | | | | PC3 | PC3 | I/O <sup>1</sup> | PC3 | 1/0 | | | | | PC4 | PC4 | I/O <sup>1</sup> | PC4 | ΪΟ | | | | | PC5 | PC5 | I/O <sup>1</sup> | PC5 | 1/0 | | | | | PC6 | A13 | OUTPUT <sup>2</sup> | PC6 | Ϊ/O | | | | | PC7 | A14 | OUTPUT <sup>2</sup> | PC7 | 1/0 | | | | NOTES: 1. Resistive Pull-Up, Active Buffer Pull-Down 2. Input data is stored in Port B latch by PA0 Pulse ## 4.6 PORT D (PD) Port D can be programmed as an I/O port, an 8-bit tri-state data bus. Mode selection for Port D is made by the Mode Control Register (MCR). The Port D output drivers can be selected as tri-state drivers by setting bit 5 of the MCR to 1. Table 4-5 shows the necessary settings for the MCR to achieve the various modes for Port D. | | | I Mode | Norma | i Mode | | | | |-------------|-----|------------------|----------------|-----------------------------|--|--|--| | ł | | 17 = 0<br>16 = X | MCR7 = 0 | | | | | | | | 15 = 0 | | 6 = X<br>5 = 1 | | | | | Pin<br>Name | 1 | | Signal<br>Name | Signal<br>Type <sup>2</sup> | | | | | PD0 | PD0 | INPUT | PD0 | OUTPUT | | | | | PD1 | PD1 | INPUT | PD1 | OUTPUT | | | | | PD2 | PD2 | INPUT | PD2 | OUTPUT | | | | | PD3 | PD3 | INPUT | PD3 | OUTPUT | | | | | PD4 | PD4 | INPUT | PD4 | OUTPUT | | | | | PD5 | PD5 | INPUT | PD5 | OUTPUT | | | | | PD6 | PD6 | INPUT | PD6 | OUTPUT | | | | | PD7 | PD7 | INPUT | PD7 | OUTPUT | | | | NOTES: 1. Tri-State Buffer is in High Impedance Mode 2. Tri-State Buffer is in Active Mode ### 4.7 BUS MODES A special attribute of Port C and Port D is their capability to be configured via the Mode Control Register (see Section 3.6) into four different modes. In the Full Address Mode, the separate address and data bus are used in conjunction with PC6 and PC7, which automatically provide A13 and A14. The remaining ports perform the normal I/O function. In the Normal Mode, all ports serve as I/O. The address and data bus are still functional but without A13 and A14. Since the internal RAM and registers are in the 00XX location, A15 can be used for chip select and A0-A12 used for selecting 8K of external memory. Figures 4-1a and 4-1b show the possible configurations of the two bus modes. Figure 4-2 shows a memory map of the part as a function of the Bus Mode and further shows which addresses are active or inactive on each of the three possible buses. Figure 4-1. R65012 Bus Mode Configurations Figure 4-2. R65012 Memory Map # SECTION 5 SERIAL INPUT/OUTPUT CHANNEL T-49-17-06 The device provides a full duplex serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5K bits per second (at $\phi$ 2 = 1 MHz). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled. Figure 5-1. Serial Communication Control Register Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter A is forced into an interval timer mode whenever the serial I/O is enabled in a mode requiring an internal clock. Whenever Counter A is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port. Refer to Counter A (paragraph 6.1) for a table of hexadecimal values to represent the desired data rate. ### 5.1 TRANSMITTER OPERATION (XTMR) The XTMR operation and the transmitter related control/status functions are enabled by bit 7 of the Serial Com- Figure 5-2. SIO Data Modes munications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one stop bit and, when enabled, a parity bit to the transmitted data. A word of transmitted data (In asynchronous parity mode) can have 5, 6, 7, or 8 bits of data. The nine data modes are shown in Figure 5-2. When parity is disabled, the 5, 6, 7, or 8 bits of data are terminated with one stop bit. In the S/R mode, eight data bits are always shifted out. Bits character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underrruns in the S/R mode the SO output and shift clock are held in a high state. The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCSR5, SCSR6 and SCSR7. IFR7 = SCSR6 (SCSR5 + SCSR7) ## One-Chip Microprocessor T-49-17-06 ## 5.2 RECEIVER OPERATION (RCVR) The receiver and its selected control and status functions are enabled when SCCR-6 is set to a "1". In the ASYN mode, data format must have a start bit, the appropriate number of data bits, a parity bit (if enabled), and one stop bit. Refer to paragraph 5.1 for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for SYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-half the bit time after a low level is detected on the Receive Data Input. Framing error, overrun, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits. Any of the above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1. Figure 5-3. ASYN Receive Data Timing In the S/R mode, an external shift clock must be provided at CA (PA4) pin along with 8 bits of serial data (LSB first) at the SI input (PA7). The maximum data rate using an external shift clock is one-eighth the internal clock rate. Refer to Figure 5-4 for S/R Mode Timing. Figure 5-4. S/R Mode Timing A RCVR interrupt (IFR6) is generated whenever any of SCSR0-3 are true. ## 5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR) The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows: - SCSR 0: Receiver Data Register Full Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by RES and is disabled if SCCR 6 = 0. The SCSR 0 bit will not be set to a logic 1 if the received data contains an error condition; instead, a corresponding error bit will be set to a logic 1. - SCSR 1: Over-Run Error Set to a logic 1 when a new character is transferred from the Receiver Shift Register with the last character still in the Receiver Data Register. This bit is cleared by reading the receiver Data Register or by RES, - SCSR 2: Parity Error Set to logic 1 when the RCVR is in the ASYN Mode, Parity Enable bit is set, and the received data has a parity error. This bit is cleared by reading the Receiver Data Register or by RES. - SCSR 3: Framing Error Set to a logic 1 when the received data contains a zero bit after the last data or parity bit in the stop bit slot. Cleared by reading the Receiver Data Register or by RES (ASYN Mode only). - SCSR 4: Wake-Up Set to a logic 1 by writing a "1" in bit 4 of address: 0016. The Wake-Up bit is cleared by RES or when the receiver detects a string of ten consecutive 1's. When the Wake-Up bit is set, SCSR0 through SCSR3 are inhibited. - SCSR 5: End of Transmission Set to a logic 1 by writing a "1" in bit position 5 of address: 0016. The End of Transmission bit is cleared by RES or upon writing a new data word into the Transmitter Data Register. When the End-0f-Transmission bit is true the Transmitter Register Empty bit is disabled until a Transmitter Under-Run occurs. - SCSR 6: Transmitter Data Register Empty Set to a logic 1 when the contents of the Transmitter Data Register are transferred to the Transmitter Shift Register. Cleared upon writing new data into the Transmit Data Register. This bit is initialized to a logic 1 by RES. T-49-17-06 # SCSR 7: Transmitter Under-Run - Set to a l SCSR 7: Transmitter Under-Run - Set to a logic 1 when the last data bit is transmitted if the transmitter is In a S/R Mode or when the last stop bit is transmitted if the XMTR is in the ASYN Mode while the Transmitter Data Register Empty Bit is set. Cleared by a transfer of new data into the Transmitter Shift Register or by RES. Figure 5-5. SCSR Bit Allocations ## **5.4 WAKE-UP FEATURE** In a multi-distributed microprocessor or microcomputer applications, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows non-selected DPU's to Ignore the remainder of the message until the beginning of the next message by setting the Wake-Up bit. As long as the Wake-Up flag is true, the Receiver Data Register Full flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of eleven consecutive 1's which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data. ## **SECTION 6 COUNTER/TIMERS** T-49-17-06 The device contains two 16-bit counters (Counter A and Counter B) and three 16-bit latches associated with the counters. Counter A has one 16-bit latch and Counter B has two 16-bit latches. Each counter can be independently programmed to operate in one of four modes: #### Counter A #### Counter B - · Pulse Width Measurement - · Retriggerable Interval Counter - Pulse Generation - Asymetrical Pulse - · Interval Timer - Generation Interval Timer - Event Counter - Event Counter Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4-2). #### 6.1 COUNTER A Counter A consists of a 16-bit counter and a 16-bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either $\phi 2$ clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001A or location 0018 for the lower Counter A. A read at location 0018 also clears the Counter A Underflow Flag (IFR4). The 16-bit latch contains the counter initialization value and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch A at location 0018. In either case, the contents of the accumulator are copied into the applicable latch register. Counter A can be started at any time by writing to address: 001A. The contents of the accumulator will be copied into the Upper Latch A before the contents of the 16-bit latch are transferred to Counter A. Counter A is set to the latch value whenever Counter A underflows. When Counter A decrements from 0000, the next counter value will be the latch value-not FFFF-and the Counter A Underflow Flag (IFR4) will be set to a "1". This bit may be cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. Counter A operates in any of four modes. These modes are selected by the Counter A Mode Control bits in the Control Register. The Interval Timer, Pulse Generation, and Pulse Width Measurement Modes are $\ensuremath{\phi2}$ clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line. The Counter is set to the Interval Time Mode (00) when a RES signal is generated. ### 6.1.1 Interval Timer In the Interval Timer mode, the Counter is initialized to the Latch value by either of two conditions: | MCR1<br>(bit 1) | MCRO<br>(bit 0) | Mode | | |-----------------|-----------------|-------------------------|--| | 0 | 0 | Interval Timer | | | 0 | 1 | Pulse Generation | | | 1 | 0 | Event Counter | | | 1 | 1 | Pulse Width Measurement | | - 1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF). - 2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter. The Counter value is decremented by one count at the 62 clock rate. The 16-bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore 1 µs to 65.535 ms at the 1 MHz φ2 clock rate, or 0.5 μs to 32,767 ms at the 2 MHz \$\phi 2\$ clock rate. Time intervals greater than the maximum counter value can be easily measured by counting IRQ interrupt requests in the counter IRQ interrupt routine. When Counter A decrements from 0000, the Counter A Underflow (IFR4) is set to logic 1. If the Counter A Interrupt Enable Bit (IER4) is also set, an IRQ interrupt request will be generated. The Counter A Underflow bit in the interrupt Flag Register can be examined in the IRQ interrupt routine to determine that the IRQ was generated by the Counter A Underflow. While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit. A timing diagram of the Interval Timer Mode is shown in Figure 6-1. ## One-Chip Microprocessor COUNTER UNDERFLOW FLAG Figure 6-1. Interval Timer Timing Diagram #### 6.1.2 Pulse Generation Mode In the Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs or a write is performed to address 001A. The normal output waveform is a symmetrical squarewave. The CA output is initialized high when entering the mode and transitions low when writing to 001A. Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow. A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition. #### 6.1.3 Event Counter Mode In this mode, the CA is used as an Event Input line, and the Counter decrements with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \$2 clock rate. The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs. Figure 6-2 is a timing diagram of the Event Counter Mode. Figure 6-2. Event Counter Mode # 6.1.4 Pulse Width Measurement Mode 7-49-17-06 This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the 62 clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state. The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4. A timing diagram for the Pulse Width Measurement Mode is shown in Figure 6-3. Figure 6-3. Pulse Width Measurement ### 6.1.5 Serial I/O Data Rate Generation Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter A is forced to operate at the internal clock rate. Counter A is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2). Table 6-1 identifies the values to be loaded in Counter A for selecting standard data rates with a \$2 clock rate of 1 MHz and 2 MHz. Although Table 6-1 identifies only the more common data rates, any data rate from 1 to 62.5K bps can be selected by using the formula: $$N = \frac{\phi 2}{16 \times bps} -1$$ where = decimal value to be loaded into Counter A Ν using its hexadecimal equivalent. φ2 the clock frequency (1 MHz or 2 MHz) = the desired data rate. bps #### NOTE In Table 6-1 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of 1.5% or less are acceptable. A revised clock rate is included in Table 6-1 for those baud rates which fall outside this limit. Table 6-1. Counter A Values for Baud Rate Selection T-49-17-06 | Standard<br>Baud<br>Rate | | lexadecima<br>Value | l | | Actual<br>Baud<br>Rate At | | Clock Rate<br>Needed<br>To Get<br>Standard<br>Baud Rate | | | | |--------------------------|-------|---------------------|------|---------|---------------------------|---------|---------------------------------------------------------|--------|--------|--| | | 1 MHz | 2 MHz 3 MHz | | 1 MHz | 2 MHz | 3 MHz | 1 MHz | 2 MHz | 3 MHz | | | 50 | 04E1 | 09C3 | 0EA5 | 50.00 | 50.00 | 50.00 | 1.0000 | 2.0000 | 3.0000 | | | 75 | 0340 | 0682 | 09C3 | 75.03 | 74.99 | 75.20 | 1.0000 | 2.0000 | 3.0000 | | | 110 | 0237 | 046F | 06A8 | 110.04 | 110.04 | 109.97 | 1.0000 | 2.0000 | 3.0000 | | | 150 | 01A0 | 0340 | 04E1 | 149.88 | 150.06 | 150.00 | 1.0000 | 2.0000 | 3.0000 | | | 300 | 00CF | 01A0 | 0270 | 300.48 | 299.76 | 300.00 | 1.0000 | 2.0000 | 3.0000 | | | 600 | 0067 | 00CF | 0138 | 600.96 | 600.95 | 599.04 | 1.0000 | 2.0000 | 3.0000 | | | 1200 | 0033 | 0067 | 0096 | 1201.92 | 1201.92 | 1201.92 | 1.0000 | 2.0000 | 3.0000 | | | 2400 | 0019 | 0033 | 004D | 2403.85 | 2403.85 | 2403.85 | 1.0000 | 2.0000 | 3.0000 | | | 3600 | 0010 | 0021 | 0033 | 3676.47 | 3676.47 | 3605.77 | 0.9792 | 1.9584 | 3.0000 | | | 4800 | 000C | 0019 | 0026 | 4807.69 | 4807.69 | 4807.69 | 1.0000 | 2.0000 | 3.0000 | | | 7200 | 0008 | 0010 | 0019 | 6944.44 | 7352.94 | 7211.54 | 1.0368 | 1.9584 | 3.0000 | | | 9600 | 0006 | 000C | 0013 | 8928.57 | 9615.38 | 9375.00 | 1.0752 | 2.0000 | 3.0720 | | #### 6.2 COUNTER B Counter B consists of a 16-bit counter and two 16-bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either \$2 clock pulses or external events depending on the counter mode selected. The contents of Counter B may be read any time by executing a read at location 001D or 001C for the Lower Counter B. A read at location 001C also clears the Counter B Underflow Flag. Latch B contains the counter initialization value and can be loaded at any time by executing a write to the Upper Latch B at location 001D and the Lower Latch B at location 001C. In each case, the contents of the accumulator are copied into the applicable latch register. Counter B can be initialized at any time by writing to address 001E. The contents of the accumulator is copied into the Upper Latch B before the value in the 16-bit Latch B is transferred to Counter B. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5) will be set to a "1" whenever Counter B underflows by decrementing from 0000. IFR 5 may be cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by Counter B operates in the same manner as Counter A in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation mode. Mode Control Register bits MCR2 and MCR3 select the four Counter B modes in a similar manner and coding as MCR0 and MCR1 select the modes of Counter A. ### 6.2.1 Retriggerable Interval Timer Mode When operating in the Retriggerable Interval Timer mode. Counter B is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the CB line. Figure 6-4 illustrates the operation. Figure 6-4. Counter B Retriggerable Interval Timer Mode #### 6.2.2 Asymmetrical Pulse Generation Mode Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized. In this mode, the 16-bit Latch B is initialized with a value which corresponds to the duration between pulses (referred to as D in the following descriptions). The 16-bit Latch C is initialized with a value corresponding to the desired pulse width (referred to as P in the following descriptions). The initialization sequence for Latch B and C and the starting of a counting sequence are as follows: - The lower 8 bits of P are loaded into LLB by writing to address 001C; the upper 8 bits of P are loaded into ULB and the full 16 bits are transferred to Latch C by writing to address location 001D. At this point both Latch B and Latch C contain the value of P. - The lower 8 bits of D are loaded into LLB by writing to address 001C; the upper 8 bits of D are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the con- ## One-Chip Microprocessor T-49-17-06 tents of the 16-bit Latch B to be downloaded into trie Counter B and the CB output to go low as shown in Figure 6-5. 3. When Counter B underflow occurs, the contents of the Latch C are loaded into the Counter B and the CB output toggles to a high level, staying high until another underflow occurs. Latch B is then downloaded and the CB output toggles to a low level repeating the whole process. Figure 6-5. Counter B Pulse Generation # SECTION 7 POWER ON/INITIALIZATION CONSIDERATIONS T-49-17-06 ### 7.1 POWER ON TIMING After application of V<sub>CC</sub> and V<sub>RR</sub> power to the device, $\overline{\text{RES}}$ must be held low for at least eight $\phi 2$ clock cycles after V<sub>CC</sub> reaches operating range and the internal oscillator has stablized. This stabilization time is dependent upon the input V<sub>CC</sub> voltage and performance of the internal oscillator. The clock can be monitored at $\phi 2$ (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms. Figure 7-1. Power Turn-On Timing Detail ## 7.2 POWER-ON RESET When RES goes from low to high, the device sets the Interrupt Mask Bit—bit 2 of the Processor Status Register—and initiates a reset vector fetch at address FFFC and FFFD to begin user program execution. All of the I/O ports (PA, PB, PC, PD) are forced to the high (logic 1) state. All bits of the Control Register are cleared to logic 0 causing the Interval Timer Counter Mode (mode 00) to be selected and all interrupt enabled bits to be reset. ## 7.3 RESET (RES) CONDITIONING When $\overline{\text{RES}}$ is driven from low to high, the device is put in a reset state causing the registers and I/O ports to be configured as shown in Table 7-1. All RAM and other CPU registers will initialized in a random, non-repeatable, data pattern. Table 7-1. RES initialization of I/O Ports and Registers | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------------------|---|---|---|---|---|---|----|----| | Registers | | | | | | | | | | Processor Status | _ | _ | _ | _ | _ | 1 | | | | Mode Control (MCR) | 0 | 0 | 0 | 0 | 0 | 0 | 0. | 0. | | Int. Enable (IER) | 0 | 0 | 0 | 0 | 0 | | Ō. | Ō | | Int. Flag (IFR) | 0 | 0 | 0 | Ó | 0 | Ō | 0 | 0 | | Ser. Com. Control (SCCR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Ports | | | | | | | - | Ĭ | | PA Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | PB Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | PC Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | PD Latch | 1 | 1 | 1 | 1 | 1 | 1 | í | i. | ### 7.4 INITIALIZATION Any initialization process for the device should include a RES, as indicated in the preceding paragraphs. After stabilization of the internal clock (if a power on situation), an initialization routine should be executed to perform (as a minimum) the following functions: - 1. The Stack Pointer should be set - 2. Clear or Set Decimal Mode - 3. Set or Clear Carry Flag - 4. Set up Mode Controls as required - 5. Clear Interrups A typical initialization subroutine could be as follows: - LDX Load stack pointer starting address into X Register - TXS Transfer X Register value to Stack Pointer - CLD Zero Page Bank Select (Clear Decimal Mode) - SEC Set Carry Flag - .... Set-up Mode Control and - special function registers - .... and clear RAM as required - CLI Clear Interrupts ## **One-Chip Microprocessor** T-49-17-06 # APPENDIX A ENHANCED R6502 INSTRUCTION SET This appendix contains a summary of the enhanced R6502 instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, (Order No. 202). The four instructions notated with an asterisk (\*) are added instructions to enhance the the standard 6502 instruction set. ## A.1 INSTRUCTION SET IN ALPHABETIC SEQUENCE | Mnemonic | Description | Mnemonic | Description | |----------|--------------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADC | Add Memory to Accumulator with Carry | LDA | Load Accumulator with Memory | | AND | "AND" Memory with Accumulator | LDX | Load Index X with Memory | | ASL | Shift Left One Bit (Memory or Accumulator) | LDY | Load Index Y with Memory | | ASL | Still Let One bit (Mariery of Accountages) | LSR | Shift One Bit Right (Memory or Accumulator) | | BBR* | Branch on Bit Reset Relative | | N- Oline | | BBS* | Branch on Bit Set Relative | NOP | No Operation | | BCC | Branch on Carry Clear | | TO CARROLL TO THE ADDITION OF THE PROPERTY | | BCS | Branch on Carry Set | ORA | "OR" Memory with Accumulator | | BEQ | Branch on Result Zero | · · | | | BIT | Test Bits in Memory with Accumulator | PHA | Push Accumulator on Stack | | BMI | Branch on Result Minus | PHP | Push Processor Status on Stack | | BNE | Branch on Result not Zero | PLA | Pull Accumulator from Stack | | BPL. | Branch on Result Plus | PLP | Pull Processor Status from Stack | | BRK | Force Break | | | | BVC | Branch on Overflow Clear | RMB* | Reset Memory Bit | | | Branch on Overflow Set | ROL | Rotate One Bit Left (Memory or Accumulator) | | BVS | Branch on Overliow Sec | ROR | Rotate One Bit Right (Memory or Accumulator) | | | 0 0 555 | RTI | Return from Interrupt | | CLC | Clear Carry Flag | RTS | Return from Subroutine | | CLD | Zero Page Bank Select - Page Zero | l uis | Heldin Bolii Gabiodinio | | CLI | Clear Interrupt Disable Bit | 000 | Subtract Memory from Accumulator with Borrow | | CLV | Clear Overflow Flag | SBC | | | CMP | Compare Memory and Accumulator | SEC | Set Carry Flag | | CPX | Compare Memory and Index X | SED | Zero Page Bank Select-Page Two | | CPY | Compare Memory and Index Y | SEI | Set Interrupt Disable Status | | | · · · · · | SMB* | Set Memory Bit | | DEC | Decrement Memory by One | STA | Store Accumulator in Memory | | DEX | Decrement Index X by One | STX | Store Index X in Memory | | DEY | Decrement Index Y by One | STY | Store Index Y in Memory | | ULI | Bedrament mask 1 sy sine | ll . | ★ 類子なる | | EOR | *Exclusive-Or* Memory with Accumulator | TAX | Transfer Accumulator to Index X | | EUN | Excidence Mention with Accountaints | TAY | Transfer Accumulator to Index Y | | INIO | Increment Memory by One | TSX | Transfer Stack Pointer to Index X | | INC | | TXA | Transfer Index X to Accumulator | | INX | Increment Index X by One | TXS | Transfer Index X to Stack Register | | INY | Increment Index Y by One | TYA | Transfer Index Y to Accumulator | | JMP | Jump to New Location | | | | JSR | Jump to New Location Saving Return Address | : [] | · · | | _ | _ | τ- | INSTRUCTION | | | | | | | | | -49-17-06 | |------------------|----------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--------------------|----------------|-------------------------------------------------------------------|----------------------------------------------------|----------------|----------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PHUCESSON STATUS | - | 2 | 0.0 | | | | | | · (i) - | <br> | | r 6<br>cycles<br>Bytes | | i so | ~ | ļ- | <i></i> | | | | | | § · · · | | | Memory Bit 6 Add Add Subtract And Or Exclusive Or Number of cycles Number of cycles | | COOES | 5 4 3 2 | 8 | | | <br> | | | Restored | (Restored) | <br> | | Memory Bit 6<br>Add<br>Subtract<br>And<br>Or<br>Exclusive Or<br>Number of c | | ដូខ | 12 | ١. | | | | | | <u>.</u> | ď. | | | Memory<br>Add<br>Subtract<br>And<br>Or<br>Exclusive<br>Number | | 3 | - | > | > | | • • • • • | • • • • • | | • • • • • • • | • > • | | | 1 1 1 1 1 1 1 1 1 | | <u> </u> | 1 | z | ZZZ · · · · · · · · · · · · · · · · · · | · · · · · · | · · Z Z Z Z | Z Z Z Z Z Z | 2220 . 2 | z · · z · z z | · z · | | ZZZZ·Z | ] | | | - | <u> </u> | *# | | | | | | | 6 | | <b>Ž.</b> : < > ≯ c * | | | ā | ۰ | 79 | | | | | 29 | | 67 | | ] | | | à | 5 | 5.F | | | | | | | 6 | | - | | | 9 | ┢ | 7. P. | | | | | | | | | | | | ğ | ⊢ | | | | | | | | 5 | | - SE 2 | | | 8 | Ľ | * # # | | | | | | | 69 | | Da G | | | ĕ | ٨ | ¥. ¥ | | | | | 27 | | - <del>5</del> | | 1 \$ 8 E | | | BIT ADDRESSING (OP BY | - | 7.9 | | | | | - 2 | | | | Index X Index Y Accumulator Memory per effective address Memory per stack pointer Salecter zero page memory bit Memory Bit 7 | | | E | - | 38 | | | | | | | | | 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 | | | ┝ | ١. | | | | | | 6 | | - 8 | | ×>==================================== | | | Z. PAGE, Y | - | | | | | <u> </u> | | | ~ | | Index X<br>Index X<br>Accumulator<br>Memory per<br>Memory per<br>Selecter zero<br>Memory Bit X | | | ž | _ | | | | | <del></del> | | | • | | 2 | | | ~ | ð | | | | | | | | - 8 | | 18 | | | ដូ | ٠ | | | | | п | | | | | ] <u> </u> | | | INDIRECT | | | | | | <u></u> | | | | | 4 | | | | ठै | | | | | 8 | | | | | ] | | | RELATIVE | Ŀ | 000 00 | | | | | | | | | 1 | | | 3 | = | 22 22 | | | | | | | | | 4 | | | 트 | å | 885 88 | 5 85 | | | | | | | | | | | ١- | • | 8.8 | | n | | <u> </u> | | | | | 1 | | ۰, | ABS, | ٤ | 4.4 | | | 4 | <del></del> | | - 4 | <del>-</del> | | 1 | | ĕ | Ľ | ð | 92 | | 8 | - S | 88 9 | 2 | Œ | ů. | | ٠. | | ᅙ | × | Ŀ | 8 0 0 | | ი ი | e e | <u></u> | | e9 | 6 | | j | | ≥ ′^ | ABS, X | ٩ | 447 | | * ^ | 4 1 | 4 4 4 4 | | 4 | ٠, | | ] . | | ž | ┺ | ð | 58 = | | 8 8 | 3 # | 8 8 8 | 3 N.K | 6 | 8 | | | | ADDRESSING MODES | Z. PAGE, X | ٠ | ~~~ | | 0 0 | N N | ~ ~~ | | ~ | 04 04 | | 1 | | Ü | Š | ٠ | 4 4 9 | | + 0 | 4.00 | 4 40 4 | 90 00 | 4 | 4 4 | | 1 | | ᅙ | 12 | 9 | 5 8 5 | | 8 8 | 88 | 8 88 8 | 2 88 | £ | 8 2 | | 1. | | ₹ | <u></u> | • | ~ ~ | | N | 2 | N 0 | , | ~ | N | | 1 | | | (IND) | = | <b>37 S</b> | | 40 | v | vo v | , | v | ø | | 1 | | | ₹ | ð | 2.6 | | ā | 2 | 5 5 | : | Œ | 5 | | 1 | | | | • | 2.2 | | N | | 2 0 | , | ~~~~ | | <del></del> | † | | | (IND. X) | ٥ | 9 | | φ | | · · | , | | | | | | | E | 8 | 21 | | - 5 | | ₹ 8 | | <u> </u> | | <del></del> | + | | | <b>1</b> | Ť | · | | | | | | <del></del> | | | 1 | | | IMPLIED | ٤ | | ~ ~~ | . ~ | N N N N | ~ | 444 | 99 00 | . ~ | ~~~~~ | 1 | | | ≧ | ð | | 8 28 | 3 8 3 | 3 <b>8</b> 8 8 | 4 | <b>488%</b> | \$ 8 % f | 2 20 | <b>\$8888</b> | 1 | | | Н | • | | | | | | | | | | 4 | | | ACCUM | - | 8 | | | | ~ | | | | | 1 | | | ğ | 8 | ₹0 | | | | \$ | 55 | | | | 1 | | | | ٦ | ~ ~ ~ | | ~~~ | | 4 | | | 0.00 | | 1 | | | ¥ | - | nn n | | 0000 | 6 | 0 0 0 0 0 | | <del>8</del> - | 888 | | 1 | | | 읉 | ð | 25 00 25 | | | ₹ <del>8</del> | | | | | | 1 | | | 2 | ۴ | ବ୍ୟପ ଶ | | 8448 | | 5858 5 | | | 882 | | | | | MMEDIATE ABSOLUTEZERO PAGE | - | 440 4 | | 4440 | 4 m | 204440 4<br>222222 | | n | 000 | | 8 | | | [율 | å | 92% % | | | | | | 4 | 4.4.4 | | }<br>} | | | 볿 | °. | ν ο ν ο . · · · · · · · · · · · · · · · · · · | | 8888 | ₽ ₩ | <b>58484 8</b> | | <u> </u> | 888 | | . 8 | | | 3 | ÷ | 2.2 | | 0 0 0 | ~ | 000 6 | | ~ | | | 8 a a | | | 1 | u do | <del></del> | | 000 | | 200 | | ~ | | | Ber Sign | | _ | ĮĒ, | ĮŌ, | \$ X | | 888 | <del></del> | 255 | | 8 | | | Tiener Constitution | | | | | E | | | | . 1 | qī | | | | S 0 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | ğ | A (4)(1) (1) (2) (3) (4) (4) (5) (6) (6) (7) (7) (7) (8) (7) (8) (9) (9) (9) (9) (9) (9) (9) (9) (9) (9 | | | | 8 | ش∾ٰځو اړ | ε | | | List is in the second | | | | OPERATION | 4 7 3 3 0 0 2 | 0 0 -<br>z >> | | ε | i | · <sub>구구</sub> 취취 "벡 | ~ | _ | | of 1842 Sec. 18 | | | | Ř | 04 8888 88 | 8 8 8 | € ₹ | ***** | 23555 E | S S S S | لَ و _ | Ð. | | 0 4 5 7 8 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 | | | | ٦ | A-M-C-A (4)(1) A-M-A (1) A-M-A (1) A-M-A (1) Banch on M-0 (3) Banch on M-1 (3) Banch on Z-1 (2) Banch on Z-1 (2) Banch on Z-1 (2) A-M-A (1) Banch on Z-1 (2) Banch on Z-1 (2) | Brach on N-0<br>Brach on V-0<br>Brach on V-1<br>0 -C | <b>?≥≥≥</b> ÷. | * | Jump to New Loc Lump Sub MA (1) MX (1) MX (1) MY (1) No Operation | S-1-S MS-A<br>S-1-S MS-A<br>S-1-S M3-P<br>O-M, (5) | E & ≥ O C | + * * * * * | <u> </u> | Page<br>bran<br>bran<br>bran<br>hode | | | | _ | <<0 d d d d d d d d d d d d d d d d d d | 8 8 8 8 9 9 9 | n d x > 5 | ×× ₹ ≥ × × | 332252 | يرا م م م م الير | @ € < | TT 4 * } | 440××× | N N N N N N N N N N N N N N N N N N N | | | | | | | | | | | | | | . ~~~ ~ E E T | | | | 2 | 7-0 | | | | | 7. | | 5 | | 8888838 | | | | MINEMONIC | ADC<br>AND<br>ASA(0-7)]<br>BBS((0-7)]<br>BCS<br>BCS<br>BCS<br>BIT<br>BMI | ·×0.000 | ~ <b>a</b> ~ ~ ~ ~ | ~~~ | | 2-0)#k | | (r-a)*k | | NOTES 1. Add 1 to N if page boundary is crossed 2. Add 1 to N if branch occurs to same page Add 2 to N if branch occurs to different page Add 2 to N if branch occurs to different page 4. If in decimal mode 2 flag is invalid accumulation mast be acceled for branch occurs. 5. Effects 6-bit data field of the specified zero page address. | ## One-Chip Microprocessor ## A.3 INSTRUCTION CODE MATRIX T-49-17-06 | | | | | | | | | | | | | | | _ | _ | _ | 552.5 | |-----|-------------------|------------------|--------------|--------------|--------------|--------------|--------------|------------|----------------|---------------|----------------|--------------|-----------------|-----------------|-------------|----------------|---------| | LS | 6D 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | | 0 | E . | F | ì | | MSD | вяк | ORA | | | | ORA | ASL | RMB0 | PHP | ORA | ASL | 1 | l | ORA<br>ABS | ASL<br>ABS | BBR0<br>ZP | 0. | | 0 | lmplied | (IND, X) | 1 | | 1 1 | ZP | ZP | 2P<br>2 5 | Implied<br>1 3 | IMM<br>2 2 | Accum<br>1 2 | | - 1 | 3 4 | 3 6 | 3 5** | | | | 1 7 | 2 6 | | | <del> </del> | 2 3 | 2 5 | | CLC | ORA | | - | | ORA | ASL | BBR1 | | | | BPL | ORA | | | } | ORA<br>ZP. X | ASL<br>ZP, X | RMB1<br>ZP | Implied | ABS. Y | , | - 1 | ŀ | ABS, X | ABS, X | ZP | t | | 1 | Relative | (IND), Y<br>2 5' | | | 1 | 2 4 | 2 6 | 2 5 | 1 2 | 3 4 | | | | 3 4* | 3 7 | 3 5** | F | | | JSR | AND | | | BIT | AND | ROL | RMB2 | PLP | AND | ROL | | BIT | AND | ROL | BBR2 | 2 | | 2 | Absolute | | | İ | ZP | ZP | ZP | ZP | Implied | IMM<br>2 2 | Accum<br>1 2 | | ABS<br>3 4 | ABS<br>3 4 | ABS<br>3 6 | 3 5" | * | | | 3 6 | 26 | | | 2 3 | 2 3 | 2 5 | 2 5 | 1 ,4 | | - | | | AND | ROL | BBR3 | | | | ВМІ | AND | | | 1 1 | AND<br>ZP, X | ROL<br>ZP, X | RM83<br>ZP | SEC<br>Implied | AND<br>ABS, Y | | | | ABS, X | ABS, X | ZP | 3 | | 3 | Relative<br>2 2** | (IND, Y)<br>2 5* | | | 1 | 2 4 | 2 6 | 2 5 | 1 2 | 3 4* | | | | 3 4* | 3 7 | 3 5" | | | | RTI | EOR | | - | + | EOR | LSR | RM84 | PHA | EOR | LSR | | JMP | EOR | LSR | BBR4<br>ZP | 4 | | 4 | Implied | (IND. X) | | | 1 | ZP | ZP | ZP | Implied | IMM | Accum<br>1 2 | | ABS | ABS<br>3 4 | ABS<br>3 6 | 3 5** | 1 | | | 1 6 | 2 6 | | L | | 2 3 | 2 5 | 2 5 | 1 3 | 2 2 | ' | | • • | EOR | LSR | BBR5 | 1 | | | BVC | EOR | İ | 1 | | EOR | LSR<br>ZP. X | RMB5 | CLI | EOR<br>ABS, Y | ļ. | | İ | ABS, X | ABS, X | ZP | 5 | | 5 | Relative | (IND), Y | 1 | 1 | ' | ZP, X | 2 6 | 2 5 | 1 2 | 3 4 | | | | 3 4* | 3 7 | 3 5** | 4 | | | RTS | ADC | <del> </del> | ├ | | ADC | ROR | RMB6 | PLA | ADC | ROR | | JMP | ADC | ROR | BBR6 | 8 | | 6 | Implied | | | <b>\</b> | Ì | ŻP | ZP | ZP | Implied | IMM | Accum<br>1 2 | l | Indirect<br>3 5 | ABS<br>3 4 | ABS<br>3 6 | 3 5" | | | _ | 1 8 | 2 6 | | <u> </u> | | 2 3 | 2 5 | 2 5 | 1 4 | 2 2 | \ | <del> </del> | + | ADC | ROR | BBR7 | ٦. | | | BVS | ADC | | 1 | ì | ADC | ROR | RM87 | SEI<br>Implied | ADC<br>ABS, Y | - | 1 | 1 | ABS, X | ABS, X | ZP | .7 | | 7 | Relative | (IND, Y) | | | Ì | ZP, X | ZP, X | 2 5 | 1 2 | 3 4* | 1 | 1 | 1 | 3 4 | 3 7 | 3 5" | _ | | | | | ┼ | ┼─ | STY | STA | STX | SMB0 | DEY | 1 | TXA | | STY | STA | STX | BBS0 | | | 8 | 1 | STA<br>(IND, X) | 1 | 1 | ZP | ZP | ZP | ZP | Implied | - | implied | 1 | ABS | ABS<br>3 4 | ABS<br>3 4 | 3 5** | 8 | | • | - | 2 6 | | ļ | 2 3 | 2 3 | 2 3 | 2 5 | 1 2 | <u> </u> | 1 2 | ┼ | 13 - | STA | 1 3 7 | BBS1 | | | | BCC | STA | | | STY | STA | STX | SMB1<br>ZP | TYA | STA<br>ABS, Y | TXS<br>Implied | | 1 | ABS, X | 1 | ZP | 9 | | 9 | Relativ | | | | ZP, X | ZP, X | ZP, Y | 2 5 | 1 2 | 3 5 | 1 2 | | İ | 3 5 | | 3 5** | | | | | | LDX | + | LDY | LDA | LDX | SMB2 | TAY | LDA | TAX | | LDY | LDA | LDX | BBS2 | | | | LDY | LDA<br>(IND, X) | 1 | 1 | ZP | ZP | ZP | ZP | Implied | | Implied | | ABS<br>3 4 | ABS | ABS | . ZP | . ^ | | • | 2 2 | 2 6 | 2 2 | | 2 3 | 2 3 | 2 3 | 2 5 | 1 2 | 2 2 | 1 2 | | | | LDX | BBS3 | | | | BCS | LDA | | | LDY | LDA | LDX | SMB3 | CLV | LDA<br>ABS, Y | TSX Implied | . 1 | LDY<br>ABS, 2 | LDA<br>( ABS, ) | | ZP. | В | | E | | | <b>'</b> \ | - | ZP, X | ZP, X | ZP, Y | 2 5 | Implied | 3 4" | 1 2 | 1 | 3 4 | | 3 4* | | | | | 2 2 | | + | + | CPY | CMP | DEC | SMB4 | INY | CMP | DEX | | CPY | CMP | DEC | B854 | | | ( | CPY | | , | | ZP | ZP | ZP | ZP | Implied | i imm | Implied | 1 | ABS | ABS | ABS<br>3.6 | 3 5° | . C | | ` | 2 2 | | <b>'</b> | | 2 3 | 2 3 | 2 5 | 2 5 | 1 2 | 2 2 | 1 2 | | 3 4 | | | - <del> </del> | | | | BNE | СМР | | | | СМР | DEC | SMB5 | | CMP<br>ABS, | | | - | CMP<br>ABS. | DEC<br>ABS. | | " D | | ( | Relati | | <b>′</b> | | Ì | ZP, X | | | Implied | 3 A' | | 1 | ı | 3 4 | | | | | | 2 2 | | $\dashv$ — | +- | CPX | SBC | INC | SMB6 | INX | SBC | NOP | | СРХ | SBC | INC | BBS | _ | | | CPX<br>E IMM | | ا ه | - | ZP | ZP | ZP | ZP | Implie | | | | ABS | | | | | | | 2 2 | | 1 | | 2 3 | 2 3 | 2 5 | 2 5 | 1 2 | 2 2 | 1 2 | 4— | 3 4 | | <del></del> | | —. | | | BEC | SBC | | | | SBC | | SMB | | | | | - 1 | SBC<br>ABS, | | | | | | F Relati | | | - | ļ | ZP, > | | | Implie<br>1 2 | | | - 1 | 1 | 3 4 | | | <u></u> | | | 2 2 | | | | | | | 7 | 8 | 9 | A | В | c | D | E | F | | | | 0 | 1 | 2 | 3 | 3 4 | 5 | 6 | ′ | 0 | 9 | ^ | _ | • | _ | | | | | | | | 0 | _ | | | | | | | | | | | | | | | | | | BRI | . [ , | -OP Code | | | | | | | | | | | 1 | | | | | 0 | Impli | 3d - | -Addressin | g Mode | • • L.! | Cuala- | | | | | | | | | | | | | | 1 | <u>'</u> - | -Instruction | i Bytes; | machine | cycles | | | | | | | | | • • | | | | | | | | | | | | | | | | | | | | \*Add 1 to N if page boundary is crossed. \*Add 1 to N if branch occurs to same page; add 2 to N if branch occurs to different page. # APPENDIX B KEY REGISTER SUMMARY T-49-17-06 **CPU** Registers **Mode Control Register** Serial Communications Control Register ## **Processor Status Register** Interrupt Enable and Flag Registers Serial Communications Status Register ## **One-Chip Microprocessor** T-49-17-06 # APPENDIX C ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS ## C.1 I/O AND INTERNAL REGISTER ADDRESSES | ADDRESS<br>(HEX) | READ | WRITE | | |----------------------------------------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--| | 001F<br>1E<br>1D<br>1C | Lower Counter B Upper Counter B Lower Counter B, CLR Flag | Upper Latch B, Cntr B←Latch B, CLR Flag<br>Upper Latch B, Latch C←Latch B<br>Lower Latch B. | | | 1B<br>1A<br>19<br>18 | Lower Counter A Upper Counter A Lower Counter A, CLR Flag | Upper Latch A, Cntr A←Latch A, CLR Flag<br>Upper Latch A<br>Lower Latch A | | | 17<br>16<br>15 | Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register | Serial Transmitter Data Register<br>Serial Comm. Status Reg. Bits 4 & 5 only<br>Serial Comm. Control Register<br>Mode Control Register | | | 13<br>12<br>11<br>0010 | Interrupt Enable Register<br>Interrupt Flag Register<br>Read FF | Interrupt Enable Register Clear Int Flag (Bits 0-3 only, Write 0's only) | | | 0F<br>0E<br>0D<br>0C<br>0B<br>0A<br>09<br>08 | These addresses are reser operation over the external | RESERVED ved and are used by the CPU during Read and Write Data Bus (D0-D7). | | | 03<br>02<br>01<br>0000 | Port D<br>Port C<br>Port B<br>Port A | Port D<br>Port C<br>Port B<br>Port A | | C.3 MULTIPLE FUNCTION PIN ASSIGNMENTS—PORT C AND PORT D | Full Address | VO Port | |--------------|----------| | Mode | Function | | PC0 | PC0 | | PC1 | PC1 | | PC2 | PC2 | | PC3 | PC3 | | PC4 | PC4 | | PC5 | PC5 | | A13 | PC6 | | A14 | PC7 | | PD0 | PD0 | | PD1 | PD1 | | PD2 | PD2 | | PD3 | PD3 | | PD4 | PD4 | | PD5 | PD5 | | PD6 | PD6 | | PD7 | PD7 | ## **One-Chip Microprocessor** # APPENDIX D ELECTRICAL SPECIFICATIONS T-49-17-06 ## **MAXIMUM RATINGS\*** | Parameter | Symbol | Value | Unit | |---------------------------------------------------------|-----------|------------------------------------------------------------|------| | Supply Voltage | VCC & VRR | -0.3 to +7.0 | Vdc | | Input Voltage | Vin | -0.3 to +7.0 | Vdc | | Operating Temperature Range<br>Commercial<br>Industrial | TA | T <sub>L</sub> to T <sub>H</sub><br>0 to +70<br>-40 to +85 | °C | | Storage Temperature Range | TstG | -55 to + 150 | °C | \* NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. ## DC CHARACTERISTICS (Vcc = 5.0V $\pm$ 5%; VRR = Vcc; Vss = 0V; Ta= TL to TH unless otherwise specified) | Parameter | Symbol | Min | Тур | Max | Unit | Test Conditions | |-------------------------------------------------------|--------|--------------|------|------------|------|--------------------------------------------------------------| | RAM Standby voltage (Retention Mode) | Van | 3.0 | _ | Vcc | V | | | RAM Standby Current (Retention Mode) | IRR | _ | 4 | | mA | T <sub>A</sub> = 25°C | | Input High Voltage All Except XTLI XTLI | VIH | +2.0<br>+4.0 | - | Vcc<br>Vcc | | | | Input Low Voltage | VIL | -0.3 | - | +0.8 | V | | | Input Leakage Current<br>RES, NMI | liN | - | | ±10.0 | μА | Vin = 0 to 5.0V | | Input Low Current PA, PB, PC, PD | IIL | - | -1.0 | -1.6 | mA | V <sub>IL</sub> = 0.4V | | Output High Voltage (Except XTLO) | Voн | +2.4 | _ | Vcc | V | $I_{LOAD} = -100 \mu A$ | | Output Low Voltage | Vol | _ | - | +0.4 | V | ILOAD = 1.6 mA | | I/O Port Pull-Up Resistance PA0-PA7, PB0-PB7, PC0-PC7 | RL | 3.0 | 6.0 | 1.5 | Kohm | | | Output Leakage Current (Three-State Off) | lout | | | ±10 | μΑ | | | Input Capacitance XTLI, XTLO All Others | Cin | - | | 50<br>10 | . pF | TA = 25C<br>V <sub>IN</sub> = 0V<br>f = 1.0 MHz | | Output Capacitance (Three-State Off) | Соит | - | _ | 10 | pF | T <sub>A</sub> = 25°C<br>V <sub>IN</sub> = 0V<br>f = 1.0 MHz | | Power Dissipation (Outputs High) | Po | - | 750 | 1100 | mW | T <sub>A</sub> = 0°C | ## Notes: <sup>1.</sup> Typical values measured at T<sub>A</sub> = 25°C and V<sub>CC</sub> = 5.0V. <sup>2.</sup> Negative sign indicates outward current flow, positive indicates inward flow. T-49-17-06 ## **APPENDIX E** TIMING REQUIREMENTS AND CHARACTERISTICS ## E.1 GENERAL NOTES - 1. $Vcc = 5V \pm 5\%$ , $0^{\circ}C \le T_{A} \le 70^{\circ}C$ - 2. A valid Vcc RES sequence is required before proper operation is achieved. - 3. All timing reference levels are 0.8V and 2.0V, unless otherwise specified. - 4. All time units are nanoseconds, unless otherwise - 5. All capacitive loading is 130 pF maximum, except as noted below: PA, PB - 50 pF maximum PC (I/O Modes Only) - 50 pF maximum PC6, PC7 (Full Address Mode) - 130 pF maximum ## **E.2 CLOCK TIMING** | Symbol | | 1 | 2 | MHz | 3 MHz | | | |----------|--------------------------------------------|------------|--------------|--------------------------------------------------|--------------|-------------------|--------------| | | Parameter Parameter | Min | Max | Min | Max | Min | Max | | Toyc | Cycle Time | 1000 | 10 µs | 500 | 10 µs | 333 | 10 μs | | TPWX1 | XTLI Input Clock Pulse Width<br>XTLO = Vss | 500<br>±25 | - | 250<br>±10 | - | 167<br>±10 | | | TPW02 | Output Clock Pulse Width at MinimumTcyc | TPWX1 | Tpwx1<br>±25 | Tpwx1 | Tpwx1<br>±20 | T <sub>PWX1</sub> | Tpwx1<br>±20 | | TR, TF | Output Clock Rise, Fall Time | | 25 | <del></del> | 15 | | | | TIP, TIF | Input Clock Rise, Fall Time | - | 10 | <del> </del> | 10 | | 15<br>10 | ## **One-Chip Microprocessor** T-49-17-06 E.3 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING | | T | 1 1 1 | lHz | 2 M | Hz | 3 MHz | | |--------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------|---------------------------------|-------------------|---------------------------------|-------------------------------|-------------------------------| | Symbol | Parameter | Min | Max | Min | Max | Min | Max | | Teow <sup>1</sup> Temos <sup>1</sup> Tenow | Internal Write to Peripheral Data Valid PA, PB, PC (TIL) PA, PB, PC (CMOS) PD | 1 - | 500<br>1000<br>175 | - | 500<br>1000<br>150 | | 333<br>666<br>135 | | T <sub>POSU</sub> | Peripheral Data Setup Time<br>PA, PB, PC<br>PD | 200<br>50 | <u>-</u> | 200<br>50 | - | 150<br>50 | | | Трна | Peripheral Data Hold Time<br>PA, PB, PC<br>PD | 75<br>10 | - | 75<br>10 | - | 75<br>10 | - | | TEPW | PA0-PA3 Edge Detect Pulse Width | Tcyc | - | Toyo | | Toyo | | | Tcpy<br>Tcp | Counters A and B<br>PA4, PA5 Input Pulse Width<br>PA4, PA5 Output Delay | Таус | 500 | Тсус | 500 | Tcyc | 333 | | TPBLW<br>TPLSU<br>TPBUH | Port B Latch Mode<br>PAO Strobe Pulse Width<br>PB Data Setup Time<br>PB Data Hold Time | T <sub>CYC</sub><br>175<br>30 | -<br>-<br>- | Toyo<br>150<br>30 | | T <sub>CYC</sub><br>150<br>30 | | | Tpow <sup>1</sup> Tcmos <sup>1</sup> Tcpw Tpow <sup>1</sup> Tcmos <sup>1</sup> | Serial I/O PA6 XMTR (TTL) PA6 XMTR (CMOS) PA4 RCVR SR Clock Width PA4 XMTR Clock –S/R Mode (TTL) PA4 XMTR Clock –S/R Mode (CMOS) | -<br>4 Toyo<br>-<br>- | 500<br>1000<br>-<br>500<br>1000 | 4 Teye | 500<br>1000<br>-<br>500<br>1000 | 4 Tcyc | 333<br>666<br>-<br>333<br>666 | ## E.3.1 I/O, Edge Detect, Counter, and Serial I/O Timing T-49-17-06 ## E.4 MICROPROCESSOR TIMING (D0-D7, A0-A12, A15, SYNC, R/W) | | | 11 | 2 ! | VHz ( | 3 MHz | | | |--------|-------------------------------------------------------|-----|------|----------------|--------------------------------------------------|-----|--------------------------------------------------| | Symbol | Parameter | Min | Max | Min | Max | Min | Max | | TRWS | R/W Setup Time | - | 255 | | 140 | | 110 | | POAT | A0-A12, A15 Setup Time | _ | 150 | T - | 140 | | 110 | | Tosu | D0-D7 Data Setup Time | 50 | | 35 | _ | 25 | ··· | | THR | D0-D7 Read Hold Time | 10 | | 10 | <del>1 - 1</del> | 10 | | | THW | D0-D7 Write Hold Time | 30 | | 30 | <del> </del> | 30 | <del> </del> | | TMOS | D0-D7 Write Output Delay | | 175 | + - | 110 | | 110 | | TSYN | SYNC Setup Time | _ | 225 | <del> _</del> | 175 | | 110 | | THA | A0-A12, A15 Hold Time | 30 | _ | 30 | <del> </del> | 30 | 110 | | THRW | R/W Hold Time | 30 | | 30 | <del> </del> | 30 | <del> </del> | | TACC | External Memory Access Time TACC = TCYC -TF-TADS-TDSU | - | TACC | - | TACC | | TACC | | Твүн | SYNC Hold Time | 30 | | 30 | <del> _ </del> | 30 | <del> </del> | ## E.4.1 Microprocessor Timing Diagram **One-Chip Microprocessor** PACKAGE DIMENSIONS T-49-17-06 ## PACKAGE DIMENSIONS (CONT'D) T-49-17-06