October 1980 # **INS8070-Series Microprocessor Family** # **General Description** The INS8070-Series of microprocessors (hereinafter referred to as the 70-Series Family) is intended for use in systems requiring the economy of a single chip, the flexibility of multiprocessing bus architecture and the power of 16-bit arithmetic operations. Designed for simplicity and low-cost implementation for stand-alone multiprocessing and DMA systems, the members of the 70-Series family include: INS6670 - 64 Bytes of RAM, no ROM INS6672 - 64 Bytes of RAM, 2.5K ROM The 70-Series family comprises bus-oriented microprocessors with on-board ROM and RAM and built-in multi-processing logic. Low-cost systems containing data may occupy the same bus and still run at full speed, as their external bus requirements are confined to the occasional access of data. Such systems include terminals, intelligent peripherals and multiprocessing systems (e.g., the solution of polynomials in real-time). For very high-volume users, the instruction set, ROM and RAM size may be tailored to fit the necessary applications. The 70-Series family is fabricated using National's Standard N-channel, silicon gate, depletion load, MOS technology. All the devices are housed in standard 40-pip.dual-in-line packages. # **Features** - On-Board ROM - On-Board RAM (Executable) - 8-Bit Data Bus - 16-Bit Address Bus (64K Addressing Capability) - Comprehensive Set of 8 and 16-Bit Arithmetic, Logic and Stack Manipulation Instructions - Hardware 16 x 16 Bit Multiply (37 μs) and Divide (42 μs) - Built-in Multiprocessing and DMA Logic - Interfaces with Memory and Standard INS8080 Peripherals at Any Clock Speed - On-Chip Clock Generation - Single Instruction Character Search and Single Instruction ASCII to Decimal Conversion - Full Hardware and Software Development Systems Available on STARPLEX \*\* and ISE \*\* - Single 5-Volt Supply - MICROBUS™ Compatible # 70-Series Family to MICROBUS Configuration (e l RE\$3638 ORIG -3638 © 1980 National Semiconductor Corp. STARPLEX, (SE are trademarks of National Semiconductor Corp. µPG-FL5M110/Printed in U.S.A # **Absolute Maximum Ratings** NOTE: Maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended and should be limited to those conditions specified under DC electrical characteristics. # **DC Electrical Characterisitics** $(T_A = 0^{\circ}C \text{ to } +70^{\circ}C, V_{CC} = +5V \pm 5\%)$ | Parameter | Min. | Тур | Max | Units | Conditions | |------------------------------------------------------------------------------------------------------------------|------|--------|-----|-------|--------------------------------------------| | INPUT SPECIFICATIONS | | | | | | | All Input Pins Except Vcc and GND,<br>NRST, and Sense Inputs SA and SB<br>(See Note 1.)<br>Logic 1 Input Voltage | 2.0 | | | V | | | Logic 0 Input Voltage | | | 8.0 | V | | | Inputs with Schmitt Trigger Input Stage (NRST, SA, SB) VT + Positive Going Threshold Voltage | | | 2.4 | v | | | V <sub>T</sub> - Negative Going Threshold<br>Voltage | 0.8 | | ' | v | | | Hysteresis (V <sub>T</sub> + - Vτ-) | 0.2 | | | V | | | Input Capacitance (All pins except Voc and GND) | | 6 | | pF | | | Supply Current Icc | | 100 mA | | mA | T <sub>A</sub> = 25° C<br>Outputs unloaded | NOTE 1: SA and SB are not buffered by the Schmitt Trigger in the interrupt path and meet the normal Input Voltage specifications when used as Interrupt Inputs. | OUTPUT SPECIFICATIONS | | | | | |-------------------------------------------------------------------------------|--------|---------|----|---------------------------------| | TRI-STATE® Pins (NWDS, NRDS, DB7-DB0,<br>AD15-AD00)<br>Logic 1 Output Voltage | 2.4 | | | Ιουτ = -100 μΑ | | Logic 0 Output Voltage | | 0.4 | V | Ιουτ = 1.6 mA | | TRI-STATE Output Current | | <br>±10 | μА | 0 < Vout < Vcc | | FLAG 1-3, NENOUT<br>Logic 1 Output Voltage | Vcc -1 | | v | Ιουτ = -100 μΑ | | Logic 1 Output Voltage | 1.5 | | V | lout = -1 mA | | Logic 0 Output Voltage | | <br>0.4 | v | ∮ <sub>OUT</sub> = 1.6 mA | | NBREQ<br>Logic 0 Output Voltage | | 0.4 | v | l <sub>OUT</sub> = 1.6 mA | | Logic 1 Output Current | | ±10 | μΑ | 0 <vout<vcc< td=""></vout<vcc<> | | XOUT<br>Logic 1 Output Voltage | 2.4 | | v | I <sub>OUT</sub> = -100 μA | | Logic 0 Output Voltage | | 0.4 | V | I <sub>OUT</sub> = 1.6 mA | # **AC Electrical Characteristics** $(T_A = +25^{\circ}C, V_{GC} = +5V \pm 5\%, GND = OV)$ | Parameter | Min. | Тур | Max. | Unit | Test Conditions<br>(See Note) | |-----------------------------------------------------|---------|-----|------|------|------------------------------------------------------------------------------------| | EXTERNAL MEMORY<br>f <sub>x</sub> (Input Frequency) | 1.0 | | 4.0 | MHz | Note: tx is the period (1) fx of the XIN input. When $f_x = 4MHz$ , $tx = 250ns$ . | | Read Cycle | | | | | | | tro | 4tx-50 | 4tx | | ns | | | tasr | tx-150 | tx | | ns | | | tahr | tx- 75 | tx | | nş | | | tos | 400 | | 600 | ns | | | to <sub>H</sub> | | 0 | | ns | | | tad | | 2tx | | ns | | | thereo | -50 | 25 | | ns | | | THNENIN | 0 | | | ns | | | Write Cycle | | | | | | | twn | 3tx-100 | 3tx | | ns | | | tasw | 2tx-150 | 2tx | | ns | | | tahw | tx- 50 | tx | | ns | | | tws | 2tx-200 | 2tx | | ns | | | twн | tx- 50 | tx | | ns | | | tad | | 2tx | | ns | | | thereq | -50 | 25 | | ns | | | thnenin | 0 | | | ns | | | EXTERNAL READ/WRITE CYCLE EXTENSION | | | | | See Figure 3 | | toi (HOLD) Read Cycle | | | 2tx | ns | | | Write Cycle | | | tx | ns | | | tw (HOLD) | | | 20 | ns | | | ts (HOLD) | 2tx | | _ | ns | | | t <sub>D2</sub> (HOLD) | | 3tx | | ns | | | t <sub>D3</sub> (HOLD) | | 4tx | | ns | | | Capacitances | | | | | | | Output Load (Xout) | | 30 | | ρF | | | All Other Output Pins | | 75 | 1 | ρF | | # **INS807X Functional Pin Description** The following describes the function of all INS807X input/output pins. For brevity, the INS807X designator is used to refer to all members of the family. | members of the family. | | , , , , , , , , , , , , , , , , , , , | |------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | INPUT SIGNALS | | | Reset | (NRST) | Active low RESET input. This pin initializes the INS807X by resetting the program counter (PC) and the stack pointer (SP) to zero (low). All bits in the Status Register (except SA and SB) are also reset to zero. This input is buffered by a T <sup>2</sup> L compatible Schmitt Trigger, allowing slow rise and fall times. | | Hold | (NHOLD) | Active low external memory cycle extend input for slow memories and slow peripherals. Also used for single memory cycle execution. NHOLD affects READ/WRITE cycles to external memory only. | | Sense A/Interrupt A | (SA/INTA) | Provides a T2L compatible Schmitt Trigger buffered sense input which sets/resets the Sense A bit (SA) in the status register. When interrupts are enabled (IE = 1 in the STATUS register) this pin also acts as a trailing edge triggered interrupt input. | | Sense B/Interrupt B | (SB/INTB) | Similar operation as SA/INTA. Since SA/INTA has priority over SA/INTB, if both arrive simultaneously, Interrupt A will be serviced first. | | Enable Input | (NENIN) | Active low bus enable input to the on-chip bus allocation logic. For DMA and multiprocessing applications this logic allows bus access to be granted or denied to the INS807X. Devices which can share the bus include other INS807X processors, INS8060 processors, DP8350 CRT Controller and DMA logic. NENIN affects INS807X operation as follows: | | | | <ol> <li>if NENIN is high, INS807X sets NENOUT high and is denied<br/>access to the bus.</li> </ol> | | | | <ol> <li>If NENIN is low and the INS807X is holding NBREQ low,<br/>INS807X sets NENOUT high and is granted access to the<br/>bus.</li> </ol> | | | | <ol> <li>If NENIN and NBREQ are both low and the INS807X is not<br/>holding NBREQ low, INS807X sets NENOUT low, and is<br/>denied access to the bus.</li> </ol> | | Power | - | V <sub>CC</sub> = +5V, Pin 40 | | | | Vss = GND, Pin 20 | | | OUTPUT SIGNALS | | | Address Bus | (A15 - A0) | TRI-STATE* address outputs for all external memory READ and WRITE operations. These outputs are normally in high-impedance state except during external memory READ and WRITE operations (Refer to Timing Waveforms.) | | Write Data Strobe | (NWDS) | TRI-STATE active low WRITE strobe output. NWDS goes low during an external memory WRITE operation. NWDS is in the high-impedance state when an external memory WRITE operation is not in progress. (Refer to Write Cycle Timing.) | | Read Data Strobe | (NRDS) | TRI-STATE active low READ strobe output. NRDS goes low during an external memory READ operation. NRDS is in the high-impedance state when an external memory READ operation is not in progress. (Refer to Read Cycle Timing.) | | Enable Output | (NENOUT) | Active low bus enable output from the on-chip bus allocation logic. INS807X controls NENOUT as follows: | | | | <ol> <li>If NBREQ is low but INS807X is not holding it low,<br/>NENOUT = NENIN.</li> </ol> | - If NEBREQ is low and INS807X is holding it low, NENOUT = high. - 3) If NBREQ = h)gh, NENOUT = high. Flags 1, 2, 3 (F1, F2, F3) Flag outputs which can be set high/low by writing into the corresponding flag bits of the status register. corresponding mag bits of the status register # BIDIRECTIONAL SIGNALS **Bus Request** (NBREQ) (XIN, XOUT) Bidirectional Bus Request input/output. NBREQ serves as an input/output to/from the on-chip bus allocation logic. When NBREQ is high (NBREQ acts as an input) and the processor requires use of the bus, the processor issues a bus request by pulling NBREQ low (NBREQ acts as an output.) Data Bus (Do - Dr) Bidirectional TRI-STATE data bus input/output. These lines are normally in the high-impedance state except during external memory READ and WRITE operations. They provide input data during external memory READ; they provide output data during external memory WRITE. Clock Inputs On-chip clock generator input/outputs (see figure 1). The on-chip clock generator will operate with external crystal or RC inputs connected between $X_{\rm IN}$ and $X_{\rm OUT}$ . The on-chip clock generator may be disabled by supplying a T²L level clock input on $X_{\rm IN}$ . In all modes a buffered T²L level clock output is always available at $X_{\rm OUT}$ . # PIN CONFIGURATION # A. External Clock Input #### **EXTERNAL CLOCK PARAMETERS** # B. Resistor Capacitor Feedback Network #### Approximate Oscillator Frequency vs RC Time Constant where: R is in KΩ C is in pf t is in ns # C. Crystal with Low Pass Filter (Above 1 MHz) Typical values for Crystal with Low Pass Filter Network | Crystal | Rp | C <sub>1</sub> | R <sub>1</sub> | |----------|-------|----------------|----------------| | 2 MHz | 100kΩ | 56pF | 1kΩ | | 3.58 MHz | 100kΩ | 27pF | 1kΩ | | 4 MHz | 100kΩ | 27pF | 1kΩ | XTAL is parallel resonant with maximum series resonance equal to $\text{1k}\Omega$ # D. Crystal with Low Pass Filter (1 MHz or Below) NOTE: The values of R & C are determined by the operating frequency and crystal type. FIGURE 1. Frequency Control Networks for On-Chip Oscillator 18-4 ## **FUNCTIONAL DESCRIPTION** The 8072, 8070 are members of a single chip, generalpurpose microprocessor family containing 2.5K and 0K bytes, respectively, of on-board ROM and 64 bytes of on-board RAM. They may be used in stand-alone, DMA (Direct Memory Access), and multiprocessor applications. Communication between the 70-Series family and external memory/peripheral devices is effected via a 16-bit address bus and an 8-bit bidirectional data bus. READ and WRITE strobe outputs from INS807X - (NRDS, NWDS) indicate when valid input/output data are present on the 8-bit data bus. The remaining input/output signals shown in the block diagram are dedicated to initialization, clock generation, bus management, interrupt request, input/output cycle extension, and user-definable interface functions. #### **Drivers and Receivers** Equivalent circuits for INS807X drivers and receivers are shown in *Figure 2*. All inputs have static charge protection circuits consisting of an RC filter and voltage clamp. These devices should still be handled with care, as the protection circuits can be destroyed by excessive static charge. ## I/O Control Logic The I/O Control Logic generates the basic timing for internal/external memory READ/WRITE operations. This includes extension of external READ/WRITE cycles in order to accommodate slow memory/peripherals. #### Instruction Decode and Control PLA: During normal operation, the INS807X repeatedly fetches and executes instructions stored in internal ROM/RAM or in external memory. Instruction access and execution are carried out under the control of an internal microprogram stored in a Programmable Logic Array (PLA). #### **Bus Access Control** Before the INS807X can initiate data transfers with external peripherals or external memory, it must have access to the external address and data buses. Three of the INS807X I/O pins are associated with bus access control: NBREQ, NENIN and NENOUT. For simple stand-alone applications, the NENOUT signal can be ignored; the NENIN pin should be grounded or connected to NBREQ. The NBREQ pin must be connected to VCC through an external pullup resistor. #### **Extended Bus Access Timing Considerations** There are four possible permutations of data and instruction accesses: - a. Instruction and data both internal - b. Instruction and data both external - c. Instruction internal, data external - d. Instruction external, data internal For an external instruction, a number of microcycles equal to the number of bytes fetched by the instruction must be added to the total internal execution time. For external data, a number of microcycles equal to the number of data bytes fetched or written must be added to the total instruction execution time. The appropriate combination should be selected and the correct number of microcycles added to the execution time. Exceptions to this general rule are: - a. Immediate data treated as part of the instruction - Increment, Decrement and Load one data byte is accessed twice therefore, two microcycles must be added. - One byte call three separate areas of memory are addressed. - 1) Single byte call - 1) Address - 3) Stack Therefore, each area must be defined as internal or external. NOTE: Stack accesses must also be factored, as they are normally treated as data. #### External READ/WRITE Cycle Extension As shown in Figure 3, the NHOLD signal may be set low following the leading edge of the READ strobe (NRDS) or the WRITE strobe (NWDS). Setting NHOLD low causes the INS807X to extend an external I/O (READ or WRITE) cycle. When an external I/O cycle is extended, the INS807X address, data and strobe lines are held active until the NHOLD signal is returned high. There is no restriction for the maximum duration of NHOLD in the low state. Thus, NHOLD can be utilized in a variety of ways, ranging from accommodation of slow memories/peripherals to single READ/WRITE cycle execution for software debug purposes. FIGURE 3. Extended Input/Quiput Timing Using NHOLD #### Interrupt Servicing When interrupts are enabled (IE = 1 in the STATUS register), pins SA/INTA and SB/INTA act as vectored interrupts. Both inputs are edge triggered, and are activated by the high to low logic transition. (Edge triggered interrupts offer the advantage of not requiring an interrupt acknowledge signal to remove the interrupt service request, as required by level triggered interrupts.) Interrupt service requests are latched when they occur, and are recognized prior to each instruction fetch. When an interrupt is recognized, the contents of the program counter are pushed onto the stack, saving the return address. The interrupt enable bit (IE) in the STATUS register is automatically reset, disabling further interrupts from being recognized, but interrupts occurring during this time will still be latched. The processor then fetches the next instruction from a predetermined memory location. The location for interrupt A is 000416 and location for interrupt B is 0007<sub>16</sub>.(Refer to Figure 4.) The instructions stored in these vector locations are normally BRANCH or JUMP instructions, causing the processor to begin execution of the appropriate service subroutine. The interrupt service subroutines may be of arbitrary length and may be located anywhere in memory. Since the Interrupt Enable bit (IE) is automatically cleared at the start of interrupt service, Interrupt A cannot normally interrupt itself or Interrupt B, and vice versa, unless interrupts are re-enabled in the service subroutine. Since interrupt requests are latched, an interrupt request will never be lost even though it occurs during servicing of the other interrupt. Interrupt service subroutines should always be concluded with an interrupt enable instruction (ORS = $01_{16}$ ) immediately followed by a return instruction (RET). This sequence causes the processor to resume main program execution at the point where it was interrupted. ## interrupt Timing and Interrupt Priority Interrupts are latched when they occur and are sampled prior to each instruction fetch. Thus, when an interrupt occurs during execution of an instruction, the instruction in process must be completed before the interrupt will be recognized. This results in an Interrupt Recognize Latency Time (IRLT), which is a function of the time at which the asynchronous interrupt occurs. The minimum value for the IRLT is 9 microcycles, and the maximum value is equal to the duration of the longest program instruction (in microcycles) plus 9 microcycles. ## Interrupt A Always has Priority Over Interrupt B If both interrupts occur during the IRLT, Interrupt A will always be recognized first, even though Interrupt B may have occured slightly earlier. In order for Interrupt B to be recognized before Interrupt A, Interrupt B must occur prior to Interrupt A by an amount greater than the maximum value of the IRLT. If several interrupt requests occur on the same pin during the IRLT, they will be treated as a single interrupt request. If two interrupt requests occur on the same pin spaced apart by a time duration greater than the IRLT, they will be treated as two separate requests. For this case, if the second interrupt occurs during interrupt service, service will not be interrupted unless interrupts have been re-enabled by the interrupt service routine. The Interrupt Service Latency Time (ISLT) is the time duration measured from the active edge of the interrupt request to the start of execution of the first instruction in the interrupt service routine. When interrupts are enabled, the ISLT is equal to the IRLT plus 8 microcycles or 5 microcycles, depending upon whether a JUMP or BRANCH instruction is stored at the vector memory locations 0004<sub>16</sub> and 0007<sub>16</sub>. FIGURE 4. Interrupt Transfer Locations # **70-SERIES FAMILY** | | | | | | | | | | ADDRESS | ING | |-----------------------------------------|-------|------------------|---------|----------|---------|------------|---------|-----------|-----------------------------------------|---------| | INSTRUCTION | MNE- | FIRST<br>OPERAND | SECOND | PC | POI | NTER RELAT | LINE | | | AUTO-II | | MC | MONIC | | OPERAND | RELATIVE | SP | P2 | P3 | IMMEDIATE | DIRECT | P2 | | | | | | OP # | OP - # | OP # | OP - # | OP ~ # | OP ~ # | OP ~ # | | | | Α | | C0 7 2 | C1 7 2 | C2 7 2 | C3 7 2 | C4 5 2 | C5 7 2 | C6 8 2 | | | | EA | | 80 10 2 | 81 10 2 | 82 10 2 | 83 10 2 | 84 8 3 | 85 10 2 | 86 11 2 | | | | т | | A0 10 2 | A1 10 2 | A2 10 2 | A3 10 2 | A4 8 3 | A5 10 2 | A6 11 2 | | | | SP | | | | | | 25 8 3 | | | | | | P2 | | | | | | 26 8 3 | | | | | | P3 | | | | | | 27 B 3 | | | | | | А | E | | | | | | | | | | | E | A | | | | | | | | | | | Α | s | | | | | | | | | LOAD | LD | S | A | | | | | | | | | | | EA | PC | | | | | | | | | | | EA | SP | | | | | | | | | | | EA | P2 | | | | | | | | | | | EA | P3 | | | | | | | | | | | SP | EA | | | | | | • • • • • • • • • • • • • • • • • • • • | | | | | P2 | EA | | - | | | | | | | | | P3 | EA | | | | | | | | | | | т | EA | | | | | | | | | | | EA | т | | | | | | | | | exopt. | P.T. | Α | | C8 7 2 | C9 7 2 | CA 7 2 | CB 7 2 | | CD 7 2 | CE 8 2 | | STORE | ST | EA | | 88 10 2 | 89 10 2 | 8A 10 2 | 8B 10 2 | | 8D 10 2 | BE 11 2 | | | | A | - | F0 7 2 | F1 7 2 | F2 7 2 | F3 7 2 | F4 7 2 | F5 7 2 | F6 B 2 | | ADD | ADD | Α | E | | | | | | | | | | | EA | | B0 10 2 | B1 10 2 | 82 10 2 | B3 10 2 | B4 10 2 | B5 10 2 | B6 11 2 | | | | Α | | F8 7 2 | F9 7 2 | FA 7 2 | FB 7 2 | FC 7 2 | FD 7 2 | FE 8 2 | | SUBTRACT | SUB | A | E | | | | | | | | | | | EA | | B5 10 2 | 69 10 2 | BA 10 2 | BB 10 2 | BC 10 2 | BD 10 2 | BE 11 2 | | MULTIPLY | MPY | EA | т | | | | | | | | | DIVIDE | DIV | EA | Т | | | | | | | | | | | Α | | D0 7 2 | D1 7 2 | D2 7 2 | D3 7 2 | D4 7 2 | D5 7 2 | D6 8 2 | | AND AND | AND | А | E | | | | | | | | | | | s | | | | | | 39 5 2 | | | | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | А | | D8 7 2 | D9 7 2 | DA 7 2 | DB 7 2 | DC 7 2 | DD 7 2 | DE 8 2 | | OR | OR | А | E | | | | | | | | | | | s | | | | | | 3B 5 2 | | | | | | A | | E0 7 2 | E1 7 2 | E2 7 2 | E3 7 2 | E4 7 2 | E5 7 2 | E6 8 2 | | EXCLUSIVE-OR | XOR | A . | E | | | ' - | | | · E | | 2/20/1998 14:15 # 70-SERIES FAMILY INS" | | | | | | | | | | ADDRESSING | | | |-----------------------------------------|----------|---------|-------|----------|--------|--------|------------|-----------|------------|--------|-------| | | MNE- | FIRST | FIRST | SECOND | PC | POIN | NTER RELAT | IVE | | | AUTO- | | | MONIC | OPERAND | 1 | RELATIVE | SP | P2 | P3 | IMMEDIATE | DIRECT | P2 | | | | | | | OP ~ # | OP~# | OP ~# | OP - # | OP~# | OP - # | OP ~ # | | | | | Α | E | | | | | | | | | | | | EA | 5P | | | | | | | | | | EXCHANGE REGISTERS | XCH | EA | P2 | | | | | | | | | | | | EA | Р3 | | | | | | | | | | | | A | | | | | | | | | | | SHIFT RIGHT | SR | EA | | | | | | | | | | | SHIFT RIGHT WITH | SRL | А | | | | | | | | | | | ROTATE RIGHT | RA | А | | | | | | | | | | | ROTATE RIGHT WITH | RRL | A | | | | | | | | | | | | _ | A | | | | | | | | | | | SHIFT LEFT | SL | EΑ | | | | | | | | | | | SEARCH AND SKIP IF<br>CHARACTER MATCHED | SSM | | | | | | | | | | | | BRANCH IF NOT DIGIT | BND | 1- | | 2D 2 | | | | | | | | | | <u> </u> | A | | | | | | | | | | | | | ΕA | | | | | | | | | | | PUSH | PUSH | PG | | | | | | | | | | | | Pź | P2 | | | | | | | | | | | | | P3 | | | | | | | | | | | PUSH AND LOAD | | P2 | | | | | | 22 15 3 | | | | | IMMEDIATE | PLI | P3 | | | | ľ | | 23 15 3 | | | | | | | А | | | | | | | | | | | | 505 | EA | | | | | | | | | | | POP | POP | P2 | | | | | | | | | | | | | P3 | | | | | | | | | | | BRANCH UNCONDITIONAL | BRA | | | 74 5 2 | | 76 5 2 | 77 5 2 | | | | | | BRANCH POSITIVE | ВР | | | 64 5 2 | | 66 5 2 | 67 5 2 | | | | | | BRANCH ZERO | BZ | | | 6C 5 2 | | 6E 5 2 | 6F 5 2 | | | | | | BRANCH NOT ZERO | BNZ. | 1 | | 7C 5 2 | | 7E 5 2 | 7F 5 2 | | | | | | JUMP UNCONDITIONAL | JMP | | | | | | | | | | | | JUMP TO SUBROUTINE | JSR | | | | | | | | | | | | CALL | GALL | 0 - 15 | | | | | | | | | | | RETURN | RET | 1 | | | | | | | | | | | LOAD PC | LD | PC | EA | | | | | | | | | | EXCHANGE PC | XCH | PC | EA | | | | | | | | | | INCREMENT AND LOAD | ILD | A | | 90 8 2 | 91 8 2 | 92 8 2 | 93 8 2 | | 95 8 2 | 96 9 2 | | | DECREMENT AND LOAD | OLD | A | | 98 8 2 | 99 8 2 | 9A 8 2 | 9B 8 2 | | 9D 8 2 | 9E 9 i | | | NO OPERATION | NOP | | | | | | | | | | | # INS807X Architecture and Internal Registers As shown in the block diagram (Figure 5), INS807X contains the equivalent of 18, 8-bit registers; their functions are described below: 2/20/1998 14:15 Program Counter: PC The program counter is a 16-bit register that contains the address of the instruction to be executed. The program counter is incremented before each instruction fetch. The program counter contents may also be replaced by the contents of a specified memory location if the last instruction was a branch, jump, or jump to subroutine instruction. This causes execution to continue from the program specified location rather than from the next sequential location. The PC may also be exchanged with the contents of the Extended Accumulator (EA). Pointer Registers: (SP, P2, P3) The three pointers, SP, P2, and P3 are 16-bit registers that may be modified under program control. A pointer which has been loaded with a given address can reference up to 256 memory or I/O bytes without being modified. This is accomplished using pointer relative addressing. The stack pointer, SP, may be used as a general purpose pointer and/or to point to the top of a RAM-resident stack that is implicitly referenced by the CALL, JSR, RET, PUSH, POP and PLI instructions. Under program control, this stack may be located anywhere in memory and may be of arbitrary length. In addition to the stack referenced by the stack pointer (SP), pointers P2 and P3 may also be used to reference other stacks. This is accomplished using auto-indexed addressing. Accumulator: AC The 8-bit Accumulator Register (AC) is the primary working register of the INS807X and contains the results of all single byte (8-bit) arithmetic and logic operations. Its contents may also be shifted, rotated, exchanged with the Extension Register (E) and moved on and off the stack using the PUSH and POP instructions. Extension Register: E The 8-bit Extension Register (E) is used for temporary storage, to perform arithmetic and logic operations in conjunction with the Accumulator (AC) and combined with the accumulator to form the Extended Accumulator (EA). (For 16-bit operations.) Double Precision Accumulator Register: EA The 16-bit Double Precision Accumulator Register (EA) is the primary double byte working register of the INS807X. It is formed by the concatenation of the 8-bit Accumulator Register (AC) and the 8-bit Extension Register (E). All double byte words are transferred between (EA) and memory in two single byte transfers. **Temporary Register:** T The 16-bit Temporary Register (T) is used for temporary storage of double byte words. It is also used to hold the 16-bit multiplier and the 16-bit divisor in multiplication/division. The (T) register may be loaded directly from memory and its contents may also be transferred to/from the (EA) register. Status Register: S The 8-bit Status Register (S) is used to store the following status bits: Carry/Link (CY/L), 2's Complement Overflow (OV), Sense B (SB), Sense A (SA), flags (F1, F2, F3) and the Interrupt Enable bit (IE). The bit positions of the status register are shown below: ## Bit positions (CY/L) goes high to indicate a carry output following execution of an addition/subtraction instruction. Status register bits 1, 2 and 3 are buffered and connected to the flag output pins F1, F2, and F3. These pins are particularly useful for direct I/O control and for execution of serial I/O operations in conjunction with the SA and SB sense inputs. SA and SB are Schmitt triggered buffered inputs which may be tested under software control. They form bits 4 and 5 of the Status Register and are read-only bits. All other Status Register bits may be both written to or read from using the AND S and the OR S instructions, respectively. The Interrupt Enable bit (IE), in the Status Register may be set/reset under program control by the OR S and AND S instructions. When set high, IE enables interrupts A and B. When IE is low, both interrupts are disabled. Following a hardware reset via the NRST pin, IE is automatically set low, disabling both interrupts. NOTE: All Status Register bits except for SA and SB are latched. When set to a specified state under program control, they will remain in that state until again modified under program control. Instruction Register: This instruction register is not accessible to the programmer. During the fetch cycle of each instruction, this register is loaded with the 8-bit instruction op code retrieved from memory. Auxiliary Register and Data I/O Register: These 8bit registers are not accessible to the programmer. They are used for temporary storage of input/output bytes transmitted over the 8-bit bidirectional data bus. Address Register: The 16-bit address register is not accessible to the programmer. It is used for temporary storage of the 16-bit address transmitted during a memory READ/WRITE cycle. **Arithmetic Logic Unit (ALU):** The Boolean operations provided by the ALU include AND, OR, and XOR. The ALU also performs increment, decrement, add, subtract, multiply, divide, shift and rotate operations. FIGURE 5. INS8070-Series Block Diagram # **INSTRUCTION SET** The INS870X instruction set consists of 192 instructions which can be grouped into nine general catagories; - 1) Register Load/Store Instructions. - Register to Register Exchange Instructions. - Arithmetic Operations: Add, Subtract, Multiply and Divide. - 4) Boolean Operations: AND, OR, Exclusive OR. - 5) Shift and Rotate Instructions. - 6) Stack PUSH/POP Instructions. - 7) Program Counter Modification Instructions. - 8) Text Processing Instructions. - 9) Miscellaneous Instructions. A listing of the complete instruction set is provided in Figure 6 (see pages 11, 12). In this figure, the symbol OP refers to the hexadecimal OP code for each instruction. The symbol BY refers to the number of memory bytes required for each instruction. The symbol RW refers to the number of READ plus WRITE operations required to execute each instruction. Note that OP, BY and RW depend upon the addressing mode specified. The symbol MC in Figure 6, refers to the number of microcycles required to execute each instruction. (One microcycle equals 1 µsec when the processor is operating at an oscillator frequency of 4 MHz.) The numbers appearing under the symbol MC apply to the case where the op code and all operands are fetched/stored from internal ROM or RAM. When external memory is accessed additional microcycles must be added, because external memory I/O requires an additional microcycle per READ or WRITE operation. In addition to data READ and WRITE, external READ operations to fetch the op code and displacement (if required) must be taken into consideration. #### INSTRUCTION FORMAT All INS807X instructions fall into three catagories; single, double, and triple byte. *Figure 6* indicates the basic format for all three instruction catagories. FIGURE 6. Instruction Byle Formats #### SPECIALIZED INSTRUCTIONS NOTE: The number of microcycles (MC) and read/ write (RW) operations for the SSM and BND instructions are not listed in the instruction set because the values of these numbers are data dependent. # Search and Skip if Character Matched (SSM) Instruction The SSM instruction searches memory for a character that matches the one present in the accumulator, using indexed addressing. The address where the search begins may be specified by pointers P2 or P3. The number of memory locations searched is 256. The search is conducted by using the specified pointer to indicate the address of the character to be tested. The pointer is automatically incremented by 1 after each test. If a match is found within the allowable 256 searches, the next two program bytes will be skipped. In this case, the instruction is concluded with the specified pointer pointing to an address one greater than that for which the match occurred. If a match is not found within the allowable 256 searches, the next instruction in sequence will be executed. In this case, the specified pointer will have been incremented by one less than the number of searches allowed (255). ## Branch If Not Digit (BND) Instruction The two byte BND instruction tests the ASCII character present in the accumulator to determine whether or not it represents the ASCII equivalent of a decimal digit (30<sub>16</sub>-39<sub>16</sub>). If it does not, a PC relative branch is executed using the second byte of the instruction as displacement. In this case, the contents of the accumulator are not altered. If the accumulator does contain the ASCII equivalent of a decimal digit, the accumulator contents are converted to the 8-bit binary equivalent of the decimal digit (00<sub>16</sub> - 09<sub>16</sub>). ## One Byte Call Instructions The CALL and JSR instructions are similar in that both allow the user to invoke a subroutine. A major difference, however, is that the CALL instruction occupies only one byte, whereas the JSR instruction occupies three bytes. The CALL instruction utilizes indirect addressing and allows the user to invoke up to 16 subroutines. Each of the 16 subroutines may be of arbitrary length and located anywhere in memory. The two byte pointer address for each subroutine is stored in two consecutive memory locations, starting at 3210 (2016). The values of the subroutine starting addresses stored in these indirect locations should be one less. than the memory location where the subroutine actually begins. Subroutines invoked via a one byte CALL are exited in the normal manner using a RET instruction. # **Multiply Instruction** The INS807X multiplication instruction (MULT) multiplies a signed 16-bit multiplicand by a signed 16-bit multiplier, generating a signed 32-bit product. The signed 16-bit multiplicand may be positive or negative and is stored in the double byte accumulator EA. (EA = the concatenation of register E and A.) The signed 16-bit multiplier must be positive and is stored in the 16-bit register T. The signed 32-bit product is stored in the EA and T registers, replacing the original multiplier and multiplicand. The most significant 16 bits of the product are stored in the EA register, and the least significant 16 bits of the product are stored in the T register. In shorthand notation, the multiplication instruction may be written as follows: NOTE: The subscripts represent bit positions of the product. The multiplication instruction is executed in only 37 micro-seconds at an oscillator frequency of 4 MHz. #### **Divide Instruction** The INS807X divide instruction divides a 16-bit dividend by a 16-bit divisor, generating a 16-bit quotient. Since the divide instruction is an integer divide, the magnitude of the dividend must be greater than the magnitude of the divisor, which must be nonzero. The 16-bit dividend can be an unsigned number in the range $0_{10}$ - $65,535_{10}$ or a signed positive number in range 0<sub>10</sub> - 32,767<sub>10</sub>. The divisor can be an unsigned number in the range 0<sub>10</sub> - 32,767<sub>10</sub> or a signed, positive number in the range 0<sub>10</sub> - 32,767<sub>10</sub>. Thus, the divide instruction will divide a signed dividend by a signed divisor, when both quantities are positive. It will also divide an unsigned dividend in the range 0<sub>10</sub> - 65,535<sub>10</sub> by an unsigned divisor in the range 0<sub>10</sub> -32,767<sub>10</sub>. Before division can be performed, a 16-bit dividend must be stored in the EA register and a 16-bit divisor. must be stored in the Tregister. After division has been executed, a 16-bit quotient is stored in the EA register, replacing the original dividend; the divisor which has been stored in the T register is lost. The division instruction is executed in only 42 microseconds at an oscillator frequency of 4 MHz. #### **Memory Allocation** Figure 7 shows INS807X memory allocation, (decimal and hexadecimal address) for the National Semiconductor 70-Series family. #### INITIALIZATION The recommended power-up initialization sequence for the INS807X is as follows: - Apply power (GND and Vcc) and set NRST low. When NRST goes low the following occurs: - a) Any in-process operations are automatically aborted. - b) The READ/WRITE (NRDS/NWDS) strobes, address bus and data bus are set to the TRI-STATE (high Z) condition. - The Program Counter (PC), Stack Pointer (SP), and Status Register (S) are automatically cleared. - Ample time should be allowed for the oscillator and internal clocks to stabilize. The minimum time that NRST must remain low is 4 Tc, where Tc is the period of one microcycle. (NOTE: For a crystal controlled oscillator, 250 mS are typically required for crystal warmup and stabilization.) - To commence program execution, NRST must be set high. The first instruction will be fetched from location 0001<sub>16</sub>. This will occur within 13 To after NRST has gone high. Normal program execution will continue as long as NRST remains high. In order to allow this signal to have slow rise/fall times without any adverse affects, NRST is buffered by a T<sup>2</sup>L compatible Schmitt trigger. This allows the inexpensive RC power-on reset circuit of Figure 8 to be used to initialize the INS807X. FIGURE 8. Reset implementation ## Interfacing With External Peripherals Data are transferred on the INS807X external data bus during execution of external memory reference instructions. This enables the INS807X to use its entire memory reference class of instructions, including arithmetic and logic, to implement input/output (I/O) to external peripherals. Since all memory reference instructions are available for peripheral I/O, efficient service routines can be written that execute faster and require fewer memory bytes. The INS807X can implement serial I/O efficiently via its two sense inputs (SA/INTA, SB/INTB) and three flag outputs (F1, F2, F3). Using these, two independent serial I/O channels can be implemented under software control using one sense input and one flag output per channel. Devices which can use this feature include teletypewriters, terminals, and modems. ## **APPLICATIONS** The 70-Series family of microprocessors is especially useful for the following applications. Terminals, personal computers and Viewdata sets. (These three applications contain identical requirements for data display via a CRT.) System cost is drastically reduced by simplified buffering and synchronization requirements between the display controller, system RAM and CPU. Typically a dumb terminal may be implemented with less than 18 IC's. intelligent ROMs - The INS807X system shown fulfills two functions: (1) generate addresses for the floppy disk controller (2) control floppy disk controller. This provides a system that does not require a DMA controller or a processor-specific firmware package for the file processing. This system therefore releases more memory for user programs and allows increased flexibility. Multiprocessing Systems - Through the use of the onboard executable RAM, and by taking advantage of the high-speed 16-bit arithmetic operations, real-time solutions of polynomials become extremely simple and economical # • INTELLIGENT ROMS - . TERMINAL - . PERSONAL COMPUTERS - VIEWDATA ## . MULTIPROCESSING SYSTEMS # INPUT MEDIUM: **EPROM** PAPER TAPE EPROM: 2716 Total No. of EPROMS 2708 # IMPORTANT - EPROM LABELLING Only one customer program may be included in a single order. The following method must be used to identify the EPROMs comprising a program. The EPROMs used for storing a custom program are designated as shown: 2716: BLOCK A 0-2047 BLOCK B 2048 - 4095 2708: BLOCK A 0 - 1023 BLOCK B 1024 - 2047 BLOCK C 2048 - 3071 BLOCK D 3072 - 4095 b) All EPROMs must be labelled (stickers, paint, etc) with this block designation plus a customer identification number. For example a 4K custom program contained in two 2716's would be labelled: Customer I.D. Customer I.D. B 0-2047 2048-4095 #### Paper Tape Tapes may only be submitted in binary complement format. The following information should be written on the paper tape. 2/20/1998 14:15 Company Name Company I.D. No. NSC Part No. A Punch = ("1" or "0") This is logic (POS or NEG) NOTE 1: Tape must be blank except for the data words. NOTE 2: Tape must start with a rubout character. NOTE 3: Data is comprised of two words, the first being the actual Data and the second being the complement of the data. # **Binary Complement Format** ## Verification The customer can use software (the listing) or hardware (EPROMs) to verify the program. He will receive a verification listing and a set of EPROMs programmed and tested with tapes generated by the NSC Mask Programming System (MPS). He will be asked for a GO/NO GO response within a week after receipt of the listing and EPROMs. #### **Verification Listing** The verification listing has five sections: - A cover sheet with provision for "STOP, DO NOT PROCEED" or "VERIFICATION CERTIFIED" signatures. - A description of the logic designations and assumptions used to process the data. - 3. A listing of the data submitted by the customer. - 4. An error summary. - A definition of the standard logic definitions for the ROM and the reduced form of the data. This list shows the output word corresponding to each address coded three ways - binary, octal, and hexadecimal. # Ordering Information for Custom Programmed Parts The following information must be submitted with each customer microcomputer program. An order will not be processed unless it is accompanied by this information. This form acts as a Traveler from Customer through Customer Service to ROM programming. Please retain a copy of this form to compare against the verification listing. The form will be sent back to the customer by Customer Service. | | | | National Microcomputer Part Number | |----------------------|-------|-----|---------------------------------------------| | | | | ROM Letter Code (National Use Only) | | Name | | | Date | | Address | | | Customer Print or I.D. No. | | City | State | Zip | Purchase Order No. | | Telephone ( ) | | | Name of person National can contact (Print) | | Authorized Signature | | | Date | # **INS8070-Series Microprocessor Family** National Semiconductor Corporation 2900 Semiconductor Drive 2900 Semiconductor Drive Santa Clara, California 95051 Tel. (408) 737-5000 TWX (910) 339-9240 National Semiconductor Gribh Elsenheimerstrasse 61711 8000 Munchen 21 West Germany Tel (089)576091 Telex 05-22772 MS International Inc., Japan Miyake Building 1-9 Yotsuya, Shinjuku-ku 160 Tokyo, Japan Tel. (03) 355-3711 TWX 232-2015 MSCJ J National Semiconductor (Neng Kang) Ltd. 8th Floor. Cheung Kong Electronic Bidg. 4 Hing Yip Street Kwun Tong Kowlson. Hong Kong Tel. 3-899235 Telex. 73866 NSEHK HX Cable. NAT SEMI MS Electronics Da Brasil Avda Brigadero Faria Lima 844 II Andar Conjunio 1104 Jardim Paulistano Sao Paulo, Brasil Telex 1121008 CABINE SAO PAULO MS Electronics Pty. Ltd. Cnr. Stud Rd. & Min. Highway Bayswater. Victoria 3153 Australia 1ei 03-729-6333 Telex. 32096 National does not assume any responsibility for use of any circuity described, no circuit patent licenses are implied, and National reserves the right at any time without notice, to change said circuity