# SIGNETICS 8X300 EVALUATION KIT MANUAL # TABLE OF CONTENTS | 8X300KT100SK DATA SPECIFICATIONS | 3 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------| | 8X300 DATA SPECIFICATIONS | 10 | | INTERFACE COMPONENTS | | | 8T26A/8T28<br>8T31<br>8T32/33/35/36 | 27 | | MEMORY COMPONENTS | | | PROM | 39<br>43 | | SSI/MSI COMPONENTS | 47 | | 54/7400 | 49<br>50 | | APPLICATIONS MEMOS | 53 | | AH3 Input/Output Design AH4 8X300 Applications MP3 Understanding the 8X300 Instruction Set SP1 The 8X300 Cross Assembly Program 8X300 A Fast Microprocessor for Control Applications | 56<br>71<br>78 | | SMS DATA SPECIFICATIONS | | | SMS 3000 Microcontroller Simulator | 93 | #### DESCRIPTION The Signetics 8X300 Fixed Instruction Bipolar Microprocessor is a high performance microprocessor optimized for control and data movement applications. The unique features of the 8X300 IV bus and instruction set permit 8-bit parallel data to be rotated or masked before undergoing arithmetic or logical operations. Then, the data may be shifted and merged into any field of from 1 to 8 contiguous bits at the destination. The entire process of input, shifting, processing and output is accomplished in one instruction cycle time. The 250ns cycle time makes the 8X300 suited for high speed applications. The evaluation board contains all the elements which a designer needs to familiarize himself with the 8X300 for his systems applications. Included with the 8X300 are 4 I/O ports for external device interface, 256 bytes of temporary (working) data storage and 512 words of program storage, all properly connected to the 8X300 to allow immediate exercising of the board. For this purpose, the PROMs are preprogrammed with the I/O control, RAM control and RAM integrity diagnostic programs. With the remaining PROM space, the designer may enter his own benchmark, test or development routines The board design allows complete flexibility in access to the address, instruction and IV busses as well as all controls and signals of the 8X300. The IV bus, I/O port user connection, clock signals, control lines, address bus and instruction bus are wired to output pins, the board edge connector and flat cable connectors. The board layout permits variations and/or expansion of the basic design. In addition to the access to all signals for transfer off the board, a wire wrap area is provided so that the designer may add to the board circuitry as he desires. The addition may include memory, additional interfaces, or special circuits which meet specific user requirements Controls are also provided for diagnostic and instructional purposes by allowing various operating modes. In the WAIT mode, the program may be single stepped for ease of checkout. The one-shot instruction jamming allows control of the program start location, changes of program flow, changing or examining the internal registers, or testing of simple sequences. The repeated instruction jamming provides a means of repetitive execution of an instruction so that the I/O bus and the control lines may be examined without software changes. In both of these jam cases, the jammed instruction is selected by board-mounted switches. ### **Auxiliary Circuits** The 8X300 can be used with any bipolar (or TTL-compatible) ICs. It can directly address 8192 program instruction locations and up to 512 I/O ports. Memory paging may be employed for larger working storage. Typical auxiliary circuits include: | DEVICE | MFG | PART NUMBER | DESCRIPTION | QTY | |--------------------|-----------------|------------------|-----------------------|-----| | U14 | Signetics | N8X300I | Microprocessor | 1 | | U2-U9 | | N82S116B | RAM (256X1) | 8 | | U15-16 | | N82S115I | PROM (512X8) | 2 | | U13, U21, U26, U27 | | N8T32N | I/O Port (Tri-state) | 4 | | U1 | | N8T31N | Latch | 1 | | U10-U11 | | N8T26AB | Transceiver | 2 | | U17-U20 | | N74LS157B | Multiplexer | 4 | | U23, U25 | | N74LS74A | Flip-Flop | 2 | | U12 | | N74LS27A | NOR Gate | 1 | | U22, U24 | Signetics | N74LS00A | NAND Gate | 2 | | Q1 | _ | 2N5320 | Transistor | 1 | | Q2 | | 2N2222 | Transistor | 1 | | RN1-RN3 | Dale | CSP-10E-01-102-K | Resistor network | 3 | | R1, R3, R4 | 1 | 1k Ω 1/4W | Resistor | 3 | | R5 | | 4k Ω 1/4W | Resistor | 1 | | R2 | | 8kΩ 1/4W | Resistor | 1 | | C2-C20, C22-C30 | | 0.1μF | Capacitor | 29 | | C1, C21 | | 22µF | Capacitor | 2 | | Z1 | | 8.00 MHz | Crystal | 1 | | J104 | Berg | 65616-134 | Connector | 1 | | J101 | Berg | 65616-150 | Connector | 1 1 | | J105 | Berg | 65616-120 | Connector | 4 | | | Robinson-Nugent | ICN-163-53 | Socket | 2 | | | Robinson-Nugent | ICN-246-54 | Socket | 7 | | | Robinson-Nugent | SB-25 | Strip socket | 2 | | S1, S2 | Amp | 435640-5 | Dip switch | 2 | | S5, S6 | Alco | MSTS-104D | Toggle switch | 2 | | S3, S4 | Digitast | ST | Momentary switch | 2 | | | Smith | 230 (red) | Binding post | 1 | | | Smith | 230 (black) | Binding post | 1 | | | SAE | CPH 8100-100 | 50/100 edge connector | 1 | | | | | PC board | 1 1 | | | | | Packing case | 1 | | | | | Assembly manual | 1 | Table 1 KIT CONTENTS Program Storage 82S115 (512X8 PROM) 1/0 8T32/33 (8-Bit Synchronous Bidirectional I/O Port) 8T35/36 (8-Bit Asynchronous Bidirectional I/O Port) 8T31 (8-Bit Bidirectional I/O Port) 8T39 (Quad Bus Extender) Working Storage 82S116 (256X1 RAM) ### KIT ASSEMBLY The kit is designed to be assembled by a skilled technician. To aid assembly as well as the evaluation, the major board areas are identified and part placement is indicated directly on the PC board. The board has been solder masked so that it may be wave soldered and to avoid solder bridges if the board is hand soldered. Sockets are provided to mount the following parts: 8X300, 8T32 (4), 8T31, 82S115 (2), and the DIP Switches (2). Kit assembly is straightforward and may be accomplished in about four hours Figure 4 shows the component side of the board and the position and orientation of all parts. Assembly can be accomplished using this figure, the notes and observing the board markings. Figure 5 provides the schematic. ### **SOFTWARE** The PROMs furnished with the kit are programmed with diagnostics in the first 50 locations to assist in verifying that the assembled kit is working correctly. The remaining 462 locations may be programmed by the user. The diagnostics are separated into two parts: Locations 00-23 contain tests of the I/O ports and the interface to the RAM, locations 24-47 write all combinations of bits into all locations of RAM and test the data read back. Locations 50-61 contain a delay routine which is used by the memory test to allow monitoring of the test with an external LED array or logic analyzer. Execution of the first part should be checked in Single Step. Figures 1, 2 and 3 are flow diagrams for the diagnostic coding. ### **CONTROLS** ### Run/Wait With this switch in the WAIT position, the processor halts execution of instructions and holds all buses in their current state (MCLK will still be active). When the switch is returned to the RUN position, the processor will remain in the halted state until the STEP key is depressed. The processor then begins running normally and subsequent depressions of the STEP key have no effect. ### Single Step Instructions may be executed one at a time by depressing the STEP key while the processor is halted. Instructions can be read from either the PROM or the Instruction switches. ### Instruction Insertion Although instructions are normally fetched from the PROMs, the bank of DIP switches provides an alternate instruction source. The command that is set in the switches is jammed on the instruction bus for either 1 cycle or indefinitely, depending on the setting on the SINGLE/REPEAT switch. With the switch in the SINGLE position, the instruction encoded in the switches is placed on the bus for 1 cycle time when the INSERT key is pressed, then control returns to the PROMs. With the switch in the RE-PEAT position, the instruction will be executed repeatedly until the switch is returned to the SINGLE position. This feature allows examination of the control signals without changing the software. ### Connection to the I/O Ports The I/O ports are 8T32s programmed with addresses 1 through 4. It is recommended that $\overline{BOC}$ (J105 pin 18) be tied low for most tests and that $\overline{BIC}$ (J105 pin 20) be pulled low when data is to be entered to the port from an external device. This scheme allows output from the port to be monitored constantly yet data can be entered at any time since $\overline{BIC}$ overrides $\overline{BOC}$ (see 8T32 data sheet). ### USAGE By external means, a test pattern is loaded into each of the I/O ports. As the program is stepped through, each of the ports is read, cleared, then restored to verify proper connection of the control and data buses. If the connections are properly made, the test pattern that the user entered into Port 1 will be cleared after 10 steps and restored on the 11th. The other 3 ports are tested in sequence after 6 more steps per port. The memory is tested in a similar manner for continuity of the control signals by reading an address from Port 1 and a test pattern from Port 2, writing the pattern to the addressed location, reading the data back and writing it to Port 1. If the data in Port 1 matches the data in Port 2, the control interface to the RAM is verified. The flow diagram for this test is given in Figure 1. The next portion of the test exercises each location in the RAM with all possible combination of bits. If the pattern read back does not match the data written, the test will be repeated with the same address and pattern until successful. The RAM address being written is output to Port 1, the pattern to Port 2. S5 should be in the RUN mode for this test. The program includes a delay loop so that its progress may be monitored by a simple LED display connected to the 8T32 outputs (Ports 1 and 2). | PIN<br>NO. | FUNCTION | PIN<br>NO. | FUNCTION | |------------|-----------------|------------|--------------| | 1 | vċc | 2 | VCC | | 3 | vcc | 4 | vcc | | 5 | vcc | 6 | vcc _ | | 7 | | 8 | D07 (MSB) | | 9 | | 10 | D06 | | 11 | | 12 | D05 | | 13 | | 14 | D04 C DATA | | 15 | | 16 | D03 BUS | | 17 | | 18 | D02 | | 19 | | 20 | D01 | | 21 | | 22 | D00 (LSB) | | 23 | <del></del> | 24 | RESET | | 25 | | 26 | HALT | | 27 | | 28 | MCLK CONTROL | | 29 | | 30 | LB > BUS | | 31 | | 32 | RB | | 33<br>35 | | 34<br>36 | SC<br>WC | | 37 | GND | 38 | GND | | 39 | GIND | 40 | CLK OUT | | 41 | | 42 | CLK IN | | 43 | SPARE | 44 | SPARE | | 45 | SPARE | 46 | SPARE | | 47 | GND | 48 | GND | | 49 | 100 | 50 | | | 51 | 101 | 52 | | | 53 | GND | 54 | GND | | 55 | 104 | 56 | A00 ) | | 57 | 105 | 58 | A01 | | 59 | GND | 60 | GND | | 61 | 108 | 62 | A04 | | 63 | 109 | 64 | A05 | | 65 | GND | 66 | GND | | 67 | I12 | 68 | A08 | | 69 | I13 INSTRUCTION | 70 | A09 | | 71<br>73 | GND BUS | 72<br>74 | GND ADDRESS | | 75 | 114 | 74<br>76 | ROM EN BUS | | 77 | GND | 78 | GND | | 79 | III | 80 | A11 | | 81 | 110 | 82 | A10 | | 83 | GND | 84 | GND | | 85 | 107 | 86 | A07 | | 87 | 106 | 88 | A06 | | 89 | GND | 90 | GND | | 91 | 103 | 92 | A03 | | 93 | 102 | 94 | A02 | | 95 | GND | 96 | GND | | 97 | GND | 98 | GND | | 99 | GND | 100 | GND | | | | | | Table 2 J100 CONNECTIONS To begin the test sequence, the DIP switches are loaded with $700000_8$ (a jump to address 0), as shown in Figure 6. Switches S5 and S6 are placed in the WAIT and SINGLE positions respectively. After power is applied to the board, S4 must be pressed to insert the jump to 0. The system is now ready to be stepped through the diagnostic programs. A listing of the diagnostic coding is given in Table 3. # External Clock Synchronization The 8X300 board provides for clock synchronization with external logic by means of the "spare" IC location at the lower center part of the board. To drive the 8X300 from an external TTL level clock source, install an 8T98 driver in the "spare" location, place $100\,\Omega$ resistors at points A and B and $47\,\Omega$ resistors at points F and G. Trace C may be cut to reduce the loading on MCLK is desired. Signal is input on J100 pin 42. To synchronize external logic to the 8X300 with MCLK, install an 8T98 driver in the "spare" location. No traces need to be cut or jumpered. Signal is available on J100 pin 40. ### Use with MCSIM\* Remove 8X300 from PC board and plug MCSIM cable into J104. Set on-board controls to RUN. When power is applied, MCSIM is ready to run according to the usual MCSIM procedures. ### Use with SMS Monitor\* The 8X300 remains in the PC board when the SMS monitor is used. The panel connects to J104 and J101. Set the on-board controls to RUN and SINGLE, the procedure according to the monitor operating instructions. If the board is halted, depress the STEP switch to initiate. # JUMPERS FOR 82S114/82S115 PROMs The 8X300 Evaluation Board will accommodate either 82S114 or 82S115 PROMs. Determine which memory was included in this kit and connect the circuit according to the appropriate drawing in Figure 7. Use insulated wires approximately 0.5" long with all but 0.3" insulation stripped off. Put wires in place, solder and trim. <sup>\*</sup>Scientific Microsystems, 520 Clyde Avenue, Mt. View, Calif. 94043 | ADDRESS | CODE | 1 | NSTRUCTION | COMMENT | | | |------------|-------------------------|----------------|--------------------------|----------------------------|--|--| | TEST OF | TEST OF I/O PORTS & RAM | | | | | | | 000 | 6 06374 | 1 | XMIT -4, R6 | Initialize Counter | | | | 001 | 6 11000 | | XMIT 0, R11 | Initialize Port Register | | | | 002 | 6 00001 | | XMIT 1, AUX | Load Increment | | | | 003 | 1 06006 | Q1 | ADD R6, R6 | Incr Count | | | | 004 | 1 11011 | | ADD R11, R11 | Incr Port Number | | | | 005 | 0 11007 | e e | MOVE R11, IVL | Select Port | | | | 006 | 0 27001 | | MOVE LB, R1 | Read Port | | | | 007 | 6 27000 | İ | XMIT 0, LB | Clear Port | | | | 010 | 0 01027 | 1 | MOVE R1, LB | Write Port | | | | 011 | 5 06003 | 1 | NZT R6, Q1 | All Done ? | | | | 012 | 6 07001 | | XMIT 1, IVL | Address Port 1 | | | | 013 | 0 27001 | | MOVE LB, R1 | Read RAM Addr | | | | 014 | 6 07002 | | XMIT 2, IVL | Addr Port 2 | | | | 015 | 0 27002 | 1 | MOVE LB, R2 | Read RAM Data | | | | 016 | 0 01017 | 1 | MOVE R1, IVR | Addr RAM | | | | 017 | 0 02037 | | MOVE R2, RB | Write RAM | | | | 020 | 6 02000 | 1 | XMIT 0, R2 | Clear R2 | | | | 021 | 6 07001 | | XMIT 1, IVL | Addr Port 1 | | | | 022 | 0 37002 | ļ | MOVE RB, R2 | Read RAM | | | | 023 | 0 02027 | ļ | MOVE R2, LB | Output Data to Port 1 | | | | BEGINNI | NG OF MEM | ORY 1 | EST | | | | | 024 | 6 01000 | | XMIT 0, R1 | Initialize RAM Addr | | | | 025 | 6 07001 | Q2 | XMIT 1, IVL | Addr Port 1 | | | | 026 | 0 01027 | 1 | MOVE R1, LB | Output RAM Addr | | | | 027 | 0 27017 | 1 | MOVE LB, IVR | Addr RAM | | | | 030 | 6 02000 | | XMIT 0, R2 | Initialize RAM Data | | | | 031 | 6 07002 | | XMIT 2, IVL | Addr Port 2 | | | | 032 | 0 02027 | Q3 | MOVE R2, LB | Output RAM Data | | | | 033 | 0 02037 | | MOVE R2, RB | Write to RAM | | | | 034 | 0 02000 | | MOVE R2, AUX | Move Data to AUX | | | | 035 | 3 37000 | | XOR RB, AUX | Compare | | | | 036 | 5 00032 | | NZT AUX, Q3 | Test | | | | 037 | 6 11000 | | XMIT 0, R11 | Set up Return Indicator | | | | 040 | 7 00050 | | JMP DELAY | Delay for display purposes | | | | 041 | 6 00001 | | XMIT 1, AUX | Load Incr | | | | 042 | 1 02002 | | ADD R2, R2 | Incr Data | | | | 043 | 5 02032 | | NZT R2, Q3 | Done? | | | | 044 | 1 01001 | | ADD R1, R1 | Incr Addr | | | | 045 | 6 11001 | | XMIT 1, R11 | Set up Return Indicator | | | | 046 | 7 00050 | | JMP DELAY | Delay | | | | 047 | 7 00025 | וחבו גי | JMP Q2 | Repeat | | | | 050<br>051 | 6 03000<br>6 04000 | DELA | YXMIT 0, R3 | | | | | 051 | 6 00001 | 1 | XMIT 0, R4 | | | | | 052 | 1 03003 | D <sub>1</sub> | XMIT 1, Aux | | | | | 053<br>054 | 1 04004 | D1<br>D2 | ADD R3, R3<br>ADD R4, R4 | | | | | 055 | 5 04054 | 102 | NZT R4, D2 | | | | | 056 | 5 03053 | | NZT R4, D2<br>NZT R3, D1 | | | | | 057 | 4 11060 | RTN | XEC *+1, R11 | | | | | 060 | 7 00041 | ''' | JMP 041 | | | | | 061 | 7 00047 | 1 | JMP 047 | | | | Table 3 SYSTEM TEST ### INTRODUCTION ### A Microcomputer Designed for Control The 8X300 is a microcomputer designed for control. It features: ### **Execution Speed** - 250ns instruction execution time - Direct address capability—up to 8192 16-bit words of program memory - Eight 8-bit general purpose registers - Simultaneous data transfer and data edit in a single instruction cycle time - n-way branch or n-entry table lookup in 2 instruction cycle times - 8X300 instructions operate with equal speed on 1-bit, 2-bit, 3-bit, 4-bit, 5-bit, 6-bit, 7-bit, or 8-bit data formats The 8X300 instruction set features controloriented instructions which directly access variable length input/output and internal data fields. These instructions provide very high performance for moving and interpreting data. This makes the 8X300 ideal in switching, controlling, and editing applications. ### Direct Processing of External Data The 8X300 I/O system is treated as a set of internal registers. Therefore data from external devices may be processed (tested, shifted, added to, etc.) without first moving them to internal storage. In fact, the entire concept is to treat data at the I/O interface no differently than internal data. This concept extends to the software which allows variables at the input/output system to be named and treated in the same way as data in storage. # **Separate Program Storage** and Data Storage The storage concept of the 8X300 is to separate program storage from data storage. Program storage is implemented in read-only memory in recognition of the fact that programs for control applications are fixed and dedicated. The benefits of using read-only memory are that great speeds may be obtained at lower cost than if read/write memory were used, and that program instructions reside in a non-volatile medium and cannot be altered by system power failures. #### 8X300 Architecture Figure 1 of the 8X300 data sheet illustrates the 8X300 architecture. The 8X300 contains an Arithmetic Logic Unit (ALU), Program Counter, and an Address Register. Eight 8bit general purpose registers are also provided, including 7 working registers and an auxiliary register which performs as a working register and also provides an implied operand for many instructions. The 8X300 registers are shown in Figure 1 of the 8X300 data sheet and are summarized below: ### **Control Registers include:** - Instruction—A 16-bit register containing the current instruction - Program Storage Address Register (AR)—A 13-bit register containing the address of the current instruction being accessed from Program Storage - Program Counter (PC)—A 13-bit register containing the address of the next instruction to be read from Program Storage ### Data Registers include: - Working Registers (WR)—Seven 8-bit registers for data storage - Overflow (OVF)—A 1-bit register that retains the most significant bit position carry from ALU addition operation. Arithmetically treated as - Auxiliary (AUX)—An 8-bit register. Source of implied operand for arithmetic and logical instructions. May be used as a working register. A crystal external to the CPU is used to generate the CPU system clock. The CPU executes 8 instruction types. INTERPRETER 8X300 8X300-I ### **DESCRIPTION** The Signetics 8X300 Interpreter is a monolithic, high-speed microprocessor implemented with bipolar Schottky technology. As the central processing unit, CPU, it allows 16-bit instructions to be fetched, decoded and executed in 250ns. A 250ns instruction cycle requires maximum memory access of 65ns, and maximum I/O device access of 35ns. Interpreter instructions operate on 8-bit, parallel data. Logic is distributed along the data path within the Interpreter. Input data can be rotated and masked before being subject to an arithmetic or logical operation; and output data can be shifted and merged with the input data, before being output to external logic. This allows 1- to 8-bit I/O and data memory fields to be accessed and processed in a single instruction cycle. ### **PROGRAM STORAGE INTERFACE** Program Storage is typically connected to the A0-A12 (A12 is least significant bit) and I0-I15 signal lines. An address output on A0-A12 identifies one 16-bit instruction word in program storage. The instruction word is subsequently input on I0-I15 and defines the interpreter operations which are to follow. The Signetics 82S115 PROM, or any TTL compatible memory, may be used for program storage. ### I/O DEVICES INTERFACE An 8-bit I/O bus, called the Interface Vector (IV) data bus, is used by the Interpreter to communicate with 2 fields of I/O devices. The complementary $\overline{\text{LB}}$ and $\overline{\text{RB}}$ signals identify which field of the I/O devices is selected. Both I/O data and I/O address information can be output on the IV bus. The SC and WC signals are typically used to distinguish between I/O data and I/O address information as follows: ### sc wc - 1 0 I/O address is being output on IV - 0 1 I/O data is being output on IV bus - 0 0 I/O data is expected on the IV, bus, as input to the Interpreter - 1 1 Not generated by the Interpreter The Signetics 82SXXX series RAM, and the 8T32/33 may be attached to the IV bus. ### **FEATURES** - 185ns instruction decode and execute delay (with Signetics 8T32/33 I/O port) - Eight 8-bit working registers - Single instruction access to 1-bit, 2-bit, 3-bit . . . or 8-bit field on I/O bus - Separate instruction address, instruction, and I/O data busses - On-chip oscillator - Bipolar Schottky technology - TTL inputs and outputs - Tri-state output on I/O data bus - +5 volt operation from 0° to 70°C ### PIN CONFIGURATION ### **PIN DESCRIPTION** | PIN | SYMBOL | NAME AND FUNCTION | TYPE | |-----------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------| | 2-9, 45-49 | A0-A12: | Instruction address lines. A high level equals "1." These outputs directly address up to 8192 words of program storage. A12 is least significant bit. | Active high | | 13-28 | I0-I15: | Instruction lines. A high level equals "1." Receives instructions from Program Storage. $I_{15}$ is least significant bit. | Active high | | 33-36,<br>38-41 | IVBO-IVB7 | Interface Vector (IV) Bus. A low level equals "1." Bidirectional tri-state lines to communicate with I/O devices. IVB7 is least significant bit. | Three-state<br>Active low | | 42 | MCLK: | Master Clock. Output to clock I/O devices, and/or provide synchronization for external logic | | | 30 | WC: | Write Command. High level output indicates data is being output on the IV Bus. | Active high | | 29 | SC: | Select Command. High level output indicates that an address is being output on the IV Bus. | Active high | | 31 | LB: | Left Bank. Low level output to enable one of two sets of I/O devices (LB is the complement of RB). | Active low | | 32 | RB: | Right Bank. Low level output to enable one of two sets of I/O devices (RB is the complement of LB). | Active low | | 44 | HALT: | Low level is input to stop the Interpreter. | Active low | | 43 | RESET: | Low level is input to initialize the Interpreter. | Active low | | 10-11 | X1, X2: | Inputs for an external frequency determining crystal. May also be interfaced to logic or test equipment. | | | 50 | VR | Reference voltage to Pass Transistor. | | | 1 | VCR | Regulated output voltage from Pass Transistor. | | | 37 | VCC: | 5V power connection. | | | 12 | GND: | Ground. | | ### INSTRUCTION CYCLE Each interpreter operation is executed in 1 instruction cycle, which may be as short as 250ns. The Interpreter generates MCLK to synchronize external logic to the instruction cycle. Instruction cycles are subdivided into quarter cycles. MCLK is an output during the last quarter cycle. During the third quarter cycle of an instruction, an address is output on A0-A12, identifying the location in program storage of the next instruction word. This instruction word defines the next instruction, which must be input on I0-I15 during the first quarter cycle of the next instruction cycle (see Table 1). ### **Instruction Set Summary** The 16-bit instruction word input on I0-I15 is decoded by the instruction decode logic to implement events that are to occur during the remainder of the instruction cycle. Generally the 16-bit instruction word is decoded as follows: A detailed usage of the 13 "operand(s) specification" bits is given in following sections Three operation code bits allow for 8 instruction classes. The 8 instruction classes are summarized in Table 2. Each entry is referred to as an "instruction class" because the unique architecture of the Interpreter allows a number of powerful variations to be specified by the 13 operand (s) specification bits. A complete description of instruction formats and some instruction examples are provided in the Applications Guide. ### **Data Processing** The Interpreter architecture includes eight 8-bit working registers, an arithmetic logic unit (ALU), an overflow register, and the 8-bit IV Bus. Internal 8-bit data paths connect the registers and IV Bus to the ALU inputs, and the ALU output to the registers and IV Bus. Data processing logic is distributed along these internal 8-bit data paths. Rotate and mask logic precedes the ALU on the data entry path. Shift and merge logic precedes the ALU on the data output path. All 4 sets of logic can operate on 8 data bits in a single instruction cycle. (See Figure 2) When less than 8 bits of data are specified for output to the IV bus by the ALU, the data field (shifted if necessary) is inserted into the prior contents of the IV bus latches. The | INST. AND IV<br>BUS DATA<br>INPUT | DATA<br>PROCESSING | ADDR. AND IV | ADDR. AND IV<br>BUS DATA<br>VALID<br>MCLK=HIGH | |-----------------------------------|--------------------|--------------|------------------------------------------------| | ← ¼ cycle → | ← ¼ cycle → | ← ¼ cycle → | ← ¼ cycle → | Table 1 INSTRUCTION CYCLE IV bus latches contain data input at the start of an instruction. This data in the IV bus latches will be specified in the instruction as a) IV bus source data or b) data from an automatic read when the IV bus is specified as a destination. Therefore, IV bus bit positions outside an inserted bit field are unmodified. ### **Data Addressing** Sources and destinations of data are specified using a 5-bit octal number, as shown in Table 2. The source and/or destination of data to be operated upon is specified in a single instruction word. Referring to Table 3, the Auxiliary register (address 00) is the implied source of the second argument for ADD, AND or XOR operations. IVL and IVR are write-only registers used only as a destination. They have addresses and are treated as registers, but in reality they do not exist. When IVL is specified as a destination or the D field = 20-27<sub>8</sub>, then LB = 'low', RB = 'high' are generated; when IVR is specified as a destination or the D field = 30-37<sub>8</sub>, then RB = low, LB = 'high' are generated. When IVL or IVR is specified as the destination in an instruction, SC is also activated and data is placed on the IV bus. If IVL or IVR is specified as a source of data, the source data is all zeroes. # INSTRUCTION SEQUENCE CONTROL The Address Register and Program Counter are used to generate addresses for accessing an instruction. The Address Register is used to form the instruction address, and in all but 3 instructions (XEC, NZT, and JMP) the address is copied into the Program Counter. The instruction address is formed in 1 of 3 ways: - For all instructions but the JMP, XEC, and a satisfied NZT, the Program Counter is incremented by 1 and placed in the Address Register. - For the JMP instruction, the full 13-bit address field from the JMP instruction is placed into the Address Register and copied into the Program Counter. - For the XEC and NZT instructions, the high order 5- or 8-bits of the Program Counter are combined with 8- or 5lower-order bits of ALU output (XEC or NZT) and placed in the Address Register. For the NZT instruction, it is also copied into the Program Counter. | | | | | | → INSTRUCTION CYCLE → | | |-------------------------|------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|------------------------------------------------|---------------------------------------------------| | INSTRUCTION<br>MNEMONIC | OP<br>CODE | FORMATS | S DESCRIPTION | | Instruction<br>Input and<br>Data<br>Processing | Address/IV<br>Bus Output | | MOVE | 0 | Register to Register 0 23 78 10 11 15 0 S R D S≠07,17,20-378 D≠10,20-378 | (S) → D Move contents of register specified by S to register specified by D. Right rotate contents of register S by R places before operation. | SC =<br>WC =<br>LB/RB =<br>LB/RB = | 0<br>0<br>X<br>X | 1 if D = 07,17<br>0<br>1 if D = 17<br>0 if D = 07 | | | | IV Bus to Register: 0 | Move right rotated IV bus (source) data specified by S to register specified by D. L specifies the length of source data with most significant bits set to zero. | WC =<br>LB/RB = | 0<br>0<br>0 if S = 20-27<br>1 if S = 30-37 | 1 if D = 07,17<br>0<br>1 if D = 17<br>0 if D = 07 | | | | S=20-37 <sub>8</sub> D≠10,20-37 <sub>8</sub> Register to IV Bus: 0 23 78 10 11 15 0 S L D | Move contents of register specified<br>by S to the IV bus. Before placement<br>on IV bus, data is shifted as speci-<br>fied by D, and L bits merged with<br>destination IV bus data. | WC =<br>LB/RB = | 0<br>0<br>0 if D = 20-27<br>1 if D = 30-37 | 0<br>1<br>0 if D = 20-27<br>1 if D = 30-37 | | | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | Move right rotated IV bus data (sources) specified by S to the IV bus. Before placement on IV bus, data is shifted or specified by D and merged with original source data. L specifies the length of source data to be operated on. | SC =<br>WC =<br>LB/RB =<br>LB/RB = | 0<br>0<br>0 if S = 20-27<br>1 if S = 30-37 | 0<br>1<br>0 if D = 20-27<br>1 if D = 30-37 | | ADD | 1 | SAME AS MOVE | (S) plus (AUX) → D<br>Same as MOVE but contents of AUX<br>added to the source data. If carry<br>from most significant bit then<br>OVF = 1, otherwise OVF = 0 | | SAME AS<br>MOVE | | | AND | 2 | SAME AS MOVE | (S) ∧ (AUX) → D<br>Same as MOVE but contents of AUX<br>ANDed with source data. | | SAME AS<br>MOVE | | | XOR | 3 | SAME AS MOVE | (S) ⊕ (AUX) → D<br>Same as MOVE but contents of AUX<br>exclusive ORed with source data. | | SAME AS<br>MOVE | | | XEC | 4 | Register Immediate: 0 23 78 15 4 S I S≠07,17,20-378 I=000-3778 | Execute instruction at current page address offset by I + (S). Execute the instruction at the address determined by concatenating 5 high order bits of PC with the 8 bit sum of I and register specified by S. PC is not incremented. | WC =<br>LB/RB | 0<br>0<br>x | 0<br>0<br>x | | | | IV Bus immediate: 0 | Execute the instruction at the address determined by concatenating 8 high order bits of PC with the 5 bit sum of I and rotated IV bus data (source) specified by S. R/L specifies length of source data with most significant bits set to zero. PC is not incremented. | SC =<br>WC =<br><u>LB</u> /RB =<br><u>LB</u> /RB = | 0<br>0<br>0 if S = 20-27<br>1 if S = 30-37 | 0<br>0<br>x<br>x | Table 2 INSTRUCTION SET SUMMARY | | | | | | - INSTRUCTI | ON CYCLE → | |-------------------------|------------|--------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|------------------------------------------------|--------------------------------------------| | INSTRUCTION<br>MNEMONIC | OP<br>CODE | FORMATS | DESCRIPTION | I/O CONTROL<br>SIGNALS | Instruction<br>Input and<br>Data<br>Processing | Address/IV<br>Bus Output | | NZT | 5 | Register Immediate: 0 23 78 15 5 S I S≠07,17,20-378 I=000-3778 | If (S) = 0, jump to current page address offset by I; if S = 0, PC + 1 → PC If contents of register specified by S is non zero then transfer to address determined by concatenating 5 high order bits of PC with I; if contents of register specified by S is zero, increment PC. | SC =<br>WC =<br>LB/RB = | 0<br>0<br>x | 0<br>0<br>x | | ХМІТ | 6 | IV Bus Immediate: 0 | If right rotated IV bus data (source) is Non Zero then Transfer to address determined by concatenating 8 high order bits of PC with I; if contents of register specified by S is zero, increment PC. Transmit I - D | SC =<br>WC =<br>LB/RB =<br>LB/RB = | 0<br>0<br>0 if S = 20-27<br>1 if S = 30-37 | 0<br>0<br>x<br>x<br>x | | | | D ≠ 10, 20-37 <sub>8</sub> I=000-377 <sub>8</sub> | Transmit and store 8 bit binary pattern I to register specified by D. | WC =<br>LB/RB =<br>LB/RD = | 0<br>x<br>x | 0<br>1 if D = 17<br>0 if D = 07 | | | | 0 23 78 10 11 15<br>6 D L I<br>D=20-37 <sub>8</sub> I=00-37 <sub>8</sub> | Transmit binary pattern I to IV bus. Before placement on IV bus, literal I is shifted as specified by D and L bits merged with existing IV bus data. | SC =<br>WC =<br>LB/RB =<br>LB/RB = | 0<br>0<br>0 if D = 20-27<br>1 if D = 30-37 | 0<br>1<br>0 if D = 20-27<br>1 if D = 30-37 | | JMP<br>· | 7 | Address Immediate: 0 23 15 7 A A=00000-177778 | Jump to Program Address A Jump to program storage address A. A is stored in the address register (AR). | SC =<br>WC =<br>LB/RB = | 0<br>0<br>x | 0<br>0<br>x | ### NOTE - 1. RB is complement of LB. - 2. "0" = Low voltage "1" = High voltage x = Don't care Table 2 INSTRUCTION SET SUMMARY (Cont'd) INTERPRETER 8X300 8X300-I | S AND/OR D<br>FIELD<br>SPECIFICATION<br>(OCTAL) | SOURCE/DESTINATION | | | |-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 00<br>01 to 06<br>07<br>10<br>11 | Auxiliary Register (AUX) Work registers (R1 to R6) respectively IVL write-only "register" (destination only) Overflow status (OVF)—source only Working register (R11) IVR write-only "register" (destination only) | | | | 2N<br>(N = 0,1,2,<br>3,4,5,6,7) | a. If a source, IV bus data right rotated (7—N) bits and masked (specified by R/L). IV Bus Source Data 0 1 2 3 4 5 6 7 b. If a destination, IV bus data left shifted (7—N) bits and merged (specified by R/L). LB = 'low' and RB = 'high' generated. IV Bus Destination Data 0 1 2 3 4 5 6 7 | | | | 3N<br>(N = 0,1,2,<br>3,4,5,6,7) | a. If a source, IV bus data right rotated (7—N) bits and masked (specified by R/L). LB = 'high' and RB = 'low' generated. IV Bus Source Data 0 1 2 3 4 5 6 7 b. If a destination, IV bus data left shifted (7—N) bits and merged (specified by R/L). LB = 'high' and RB = 'low' generated. IV Bus Destination Data 0 1 2 3 4 5 6 7 | | | Table 3 DATA SOURCE DESTINATION ADDRESS # INTERPRETER INTERNAL REGISTERS Programmable Registers (all 8 bits): - AUX General working register. Contains second term for arithmetic or logical operations. - R1 General working register - R2 General working register - R3 General working register - R4 General working register - R5 General working register - R6 General working register - R11 General working register Other Registers: Address Register (AR) - A 13-bit register containing the address of the current instruction. - OVF The least-significant bit of this register is used to reflect over-flow status resulting from the most recent ADD operation (see Instruction Set Summary). Program Counter (PC) Normally contains the address of the current instruction and is incremented to obtain the next instruction address. Instruction Register (IR) Holds the 16-bit instruction word currently being executed. Table 4 INTERPRETER 8X300 8X300-I # SYSTEM DESIGN USING THE INTERPRETER Designing hardware around the 8X300 Interpreter reduces to selecting a program storage devicer (ROM, PROM, etc.), selecting I/O devices (IV byte, multiplexers, RAM, etc.), selecting clock mode (system driven or crystal controlled) and interfacing the Interpreter to these components, as shown in Figure 3. ### **System Clock** The Interpreter has an integrated oscillator which generates all necessary clock signals. The oscillator is designed to connect directly to a series resonant quartz crystal via pins X1 and X2. The crystal resonant frequency, f, is related to the desired cycle time, T, by the relationship f = 2/T. For a 250ns system, f = 8.00MHz. In lower speed applications where the cycle time need not be precisely controlled, a capacitor may be connected between X1 and X2 to drive the oscillator. Approximate capacitor values are given in Table 6. If cycle time is to be varied, X1 and X2 should be driven from complementary outputs of a pulse generator. Figure 4 shows a typical configuration. For systems where the Interpreter is to be driven from a master clock, the X1 and X2 lines may be interfaced to TTL logic as shown in Figure 5. | Туре: | Fundamental mode, series resonant | |-----------------------------------|-----------------------------------| | Impedance at Fundamental: | 35 ohms maximum | | Impedance at harmonics and spurs: | 50 ohms minimum | Table 5 CRYSTAL CHARACTERISTICS | Cx,pF | CYCLE TIME | |-------|-------------| | 100 | 300ns | | 200 | 500ns | | 500 | 1.1 $\mu$ s | | 1000 | 2.0µs | **Table 6 CLOCK CAPACITOR VALVES** # Halt, Reset Signals #### HALT A low level at the HALT input stops internal operation of the Interpreter at the start of the next instruction after HALT is applied (quarter cycle after MCLK). Since HALT is sampled at the start of each instruction cycle it is possible to prevent a cycle by applying HALT early in that cycle. HALT does not inhibit MCLK or affect any internal registers. Normal operation begins with the next complete cycle after the HALT input goes high. #### RESET: A low level at the RESET input sets the program counter and address register to zero. While RESET is low MCLK is inhibited. If RESET is applied during the last 2 quarter cycles, the MCLK during that cycle may be shortened. RESET should be applied for 1 full instruction cycle time to assure proper operation. When RESET input goes high an MCLK occurs prior to the resumption of normal processing. RESET does not affect the other internal registers. ### **EXAMPLE:** A specific example of a control system, using the 8X300 Interpreter—four 8T32/33 IV Bytes, and two 82S215 ROMs is shown in Figure 3. Only 8 components are required to build this system which contains 512 words of program storage, 32 TTL I/O connection points, and operates at a 250ns instruction cycle time. ### SYSTEM TIMING In systems with fast instruction cycle times, most Interpreter delays are strictly determined by internal gate propagation delays. Since some events are constrained to occur in certain quarter cycles, as system cycle times become slower, the delays will appear to increase due to gating with internal clocks. In the table of AC Electrical Characteristics, 2 columns are used: 1 to denote times which occur due to internal clock intervention and 1 to denote minimum delays for fast cycle times. When using Signetics 8T32/33/35/36 IV Bytes, selection of instruction cycle time involves calculating the maximum program storage access time. Assuming the instruction is available when MCLK falls, the I/O control lines are stable 35ns later. Signetics IV Bytes require another 35ns to disable a previously selected byte and enable the desired byte (assumes a change in bank signals). A 10ns margin has been added to the IV Byte enable for this evaluation to reflect the fact that most systems will have more capacitive loading than the 50pF test condition in the IV Byte specification and to allow for line delays. The system instruction cycle time for normal systems such as shown in Figure 7 is determined by Interpreter propagation delays, program storage access time, and IV Byte output enable times. Instruction cycle time is normally constrained by one or more of the following conditions: Instruction to LB/RB (input phase) and IV Byte output enable: TOE $\leq \frac{1}{2}$ cycle - 55ns (Figure 6). - Program storage access time and instruction to LB/RB (input phase) and IV Byte output enable and IV data (input phase) to address ≤ instruction cycle time (Figure 7). - Program storage access time and instruction to address ≤ instruction cycle time (Figure 8). The first constraint can be used to determine the minimum cycle time. Using the inequality 35ns + 35ns $\leq \frac{1}{2}$ cycle - 55ns implies $\frac{1}{2}$ cycle $\geq$ 125ns or an instruction time of 250ns. Program storage access time for a 250ns instruction cycle can be calculated from the second constraint. Noting that the specification for IV data (input phase) to address is 115ns: Program storage access time + 35ns + 35ns + 115ns $\leq 25$ 0ns implies program storage access time $\leq 65$ ns. The third constraint can be used to verify the maximum program storage access time. Noting that the specification for instruction to address is 185ns: Program storage access time + 185ns ≤ 250ns confirms that program storage access time 65ns is satisfactory. ### # AC ELECTRICAL CHARACTERISTICS V $_{CC}$ = 5V $\pm$ 5% and 0°C $\leqslant$ T $_{A}$ < 70°C | DELAY DESCRIPTION | PROPAGATION<br>DELAY TIME | CYCLE TIME<br>LIMIT | |-------------------------------------------------|---------------------------|------------------------------| | X1 falling edge to MCLK (driven from external | | | | pulse generator) | 75ns | | | MCLK to SC/WC falling edge (input phase) | 25ns | | | MCLK to SC/WC rising edge (output phase) | | 1/2 cycle + 25ns | | MCLK to LB/RB (input phase) | 35ns | | | Instruction to LB/RB output (input phase) | 35ns | | | MCLK to LB/RB (output phase) | | 1/ <sub>4</sub> cycle + 35ns | | MCLK to IV data (output phase) | 185ns | ½ cycle + 60ns | | IV data (input phase) to IV data (output phase) | 115ns | | | Instruction to Address | 185ns | 1/2 cycle + 40ns | | MCLK to Address | 185ns | ½ cycle + 40ns | | IV data (input phase) to Address | 115ns | | | MCLK to IV data (input phase) | | ½ cycle - 55ns | | MCLK to Halt falling edge to prevent | | | | current cycle | | 1/4 cycle – 40ns | | Reset rising edge to first MCLK | | 0 to 1 cycle | ### NOTE - 1. Reference to MCLK is to the falling edge when loaded with 300pF. - 2. Loading on Address lines is 150pF. # DC ELECTRICAL CHARACTERISTICS | | | | | LIMITS | | | |-----------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------|---------|-----------------------|---------------|--------------------------| | | PARAMETER | TEST CONDITIONS | Min | Тур | Max | UNIT | | v <sub>IH</sub> | High level input voltage<br>X1,X2<br>All others | | .6<br>2 | | | V | | v <sub>IL</sub> | Low level input voltage<br>X1,X2<br>All others | | | | .4<br>.8 | V<br>V | | V <sub>CL</sub> | Input clamp voltage<br>(Note 1) | V <sub>CC</sub> = 4.75V<br>I <sub>I</sub> = -10mA | | | -1.5 | V | | ЯΗ | High level input current X1,X2 All others | V <sub>CC</sub> = 5.25V<br>V <sub>IH</sub> = .6V<br>V <sub>CC</sub> = 5.25V<br>V <sub>IH</sub> = 4.5V | | 2700 | 50 | μ <b>Α</b><br>μ <b>Α</b> | | I <sub>IL</sub> | Low level input current X1,X2 IVBO-7 | V <sub>CC</sub> = 5.25V<br>V <sub>IL</sub> = .4V<br>V <sub>CC</sub> = 5.25V<br>V <sub>IL</sub> = .4V | | -2500<br>-140<br>-880 | -200<br>-1600 | μΑ<br>μΑ<br>μΑ | | v <sub>OL</sub> | HALT, RESET Low level output voltage | V CC = 5.25V<br>V IL = .4V<br>V CC = 5.25V<br>V IL = .4V | | -230 | -400 | μΑ | | OL | A0-A12 All others | V <sub>CC</sub> = 4.75V<br>I <sub>OL</sub> = 4.25mA<br>V <sub>CC</sub> = 4.75V<br>I <sub>OL</sub> = 16mA | | .35 | .55<br>.55 | v<br>v | | V <sub>ОН</sub> | High level output voltage | V <sub>CC</sub> = 4.75V<br>I <sub>OH</sub> = 3mA | 2.4 | | | V | | los | Short circuit output current (Note 2) | <b>)</b> | -30 | | -140 | mA | | v <sub>cc</sub> | Supply voltage | | 4.75 | 5 | 5.25 | V | | 1 <sub>CC</sub> | Supply current | V <sub>CC</sub> = 5.25V | | 300 | 450 | mA | | REG | Regulator control | V <sub>CC</sub> = 5.0V | -14 | | -21 | mA | | CR | Regulator current (Note 3) | V <sub>CR</sub> = 0 | | | 290 | mA | | V <sub>CR</sub> | Regulator voltage (Note 3) | V <sub>REG</sub> = 0V | 2.2 | | 3.2 | V | ### NOTES <sup>1.</sup> Crystal inputs X1 and X2 do not have clamp diodes. <sup>2.</sup> Only one output may be grounded at a time. 3. (Limits apply for $V_{CC}$ = 5V ± 5% and 0°C < T<sub>A</sub> < 70°C unless specified otherwise.) # INTERFACE COMPONENTS # DC ELECTRICAL CHARACTERISTICS | | | | | | 1 | NPUT \ | /OLTA | 3E | | | | | | | | | 0 | UTPUT | VOLTA | AGE | | |----------------------------------------|-----|-----|-----|------|-------------------------------------|--------|--------------------------------------------------|-------------------------------------------------|------------------------|--------------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------|------------------------------------------|-----|------------|-----------------------|-----|-------|-------|-----------------------------------------|-------------| | PARAMETER V <sub>IL</sub> (V) LOW LEVE | | | | CLAM | VIC<br>CLAMP VOLTAGE VOLTAGE RATING | | ATING | VTL (mV)20<br>LOW LEVEL<br>THRESHOLD<br>VOLTAGE | | VT <sub>H</sub> (mV) <sup>20</sup><br>HIGH LEVEL<br>THRESHOLD<br>VOLTAGE | | EL<br>LD | VOL (V) <sup>7</sup><br>LOW LEVEL | | L | | | | | | | | TEST CONDITIONS | | | | | | | V <sub>CC</sub> = MIN<br>I <sub>IN</sub> = -12mA | | V <sub>IN</sub> = 10mA | | V <sub>CC</sub> = MIN<br>V <sub>IN</sub> = 0.8V<br>I <sub>OL</sub> = -400\(\mu\)A | | V CC = MAX<br>V IN = 0.8V<br>I OH = 16mA | | 3 <b>V</b> | V <sub>CC</sub> = MIN | | | | | | | | Min | Тур | Max | 8T26A | | N/A | | | N/A | | | | -1.0 | | N/A | | 0.85 | | | | | 2 | | Driver I OL = 48m/ Receiver I OL = 20m/ | 0.5 | | 8T28 | | N/A | | | N/A | | | | -1.0 | | N/A | | 0.85 | | | | | 2 | | Driver OL =48m/ Receiver OL = 20m/ | 0.5 | | 8T31 | | N/A | | | N/A | | I <sub>IN</sub> = | -5mA | -1 | | N/A | | | N/A | | | N/A | | | 1 <sub>OL</sub> =20m/ | 0.55 | | 8T32 <sup>16</sup> | | | .8 | 2.0 | | | I <sub>IN</sub> = | -5mA | -1 | | N/A | | | N/A | | | N/A | | | I <sub>OL</sub> = 16m/ | Å<br> 0.55 | | 8T3316 | | | .8 | 2.0 | | | I <sub>IN</sub> = | -5mA | -1 | | N/A | | | N/A | | | N/A | | | 1 <sub>OL</sub> = 16m/ | 0.55 | | 8T35 <sup>16</sup> | | .8 | 2.0 | | | | I <sub>IN</sub> = | -5mA | _1 | | N/A | | | N/A | | | N/A | | | I OL = 16m. | A<br> 0.55 | | 8T36 <sup>16</sup> | | | .8 | 2.0 | | | I <sub>IN</sub> = | -5mA | -1 | | N/A | | | N/A | | | N/A | | | 1 <sub>OL</sub> = 16m/ | 0.55 | # INTERFACE COMPONENTS ### DC ELECTRICAL CHARACTERISTICS (Cont'd) | | | INPUT C | CURRENT | OUTPU | T CUR | RENT | | | POWER SUPPLY | | | | |----------------------------------------------------------------|-------------------------------------------------------------------|------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------------------------------------------------|-----------|----------------------------------------------------------------------|-------------|---------|---------------------------------|------------------------------------------------|-------|-----| | PARAMETER | V <sub>OH</sub> (V)<br>HIGH LEVEL | I <sub>IL</sub> (mA)<br>LOW LEVEL | Ι <sub>ΙΗ</sub> (μΑ)<br>HIGH LEVEL | I <sub>CBO</sub> (μΑ)<br>LEAKAGE<br>CURRENT | SH | IOS<br>ORT CIRC<br>CURREN | | POWER/ | CC<br>CURRENT<br>ION (mW/mA) | I <sub>CC</sub> (mA)<br>V <sub>IN</sub> = 2.0V | | | | TEST V <sub>CC</sub> = MIN CONDITIONS I <sub>OH</sub> = -160µA | | V <sub>CC</sub> = MAX<br>V <sub>IN</sub> = 0.4V | V <sub>CC</sub> = MAX<br>V <sub>IN</sub> = 4.5V | V <sub>IN</sub> = 2.0V | | V <sub>CC</sub> = MA<br>V <sub>IN</sub> = 0V<br>V <sub>OUT</sub> = 0 | , | | = MAX<br> = 0V<br> COMMERCIAL | ٧٥ | C = M | łAX | | | Min Typ Max | Min Typ Max | Min Typ Max | Min Typ Max | Min | Тур | Max | Typ Max | Тур Мах | Min | Тур | Max | | 8T26A | Driver<br>I OL = -10mA<br>2.4<br>Receiver<br>I OL = -100µA<br>3.5 | Driver<br>LOW Level<br>-200<br>LOW Level (Disabled)<br>-25<br>Receiver | Driver/Receiver<br>25 | HIGH Level V <sub>OUT</sub> = 2.4V 100 LOW Level V <sub>OUT</sub> = 0.5V -100 | 50<br>-30 | Driver<br>Receiver | -150<br>-75 | N/A | 457/87 | | N/A | | | | OL = -2.0mA<br>2.4 | -200 | | HIGH Level | -50 | Driver | -150 | N/A | 578/100 | | N/A | | | 8T28 | Driver<br>I OŁ = -10mA<br>2.4<br>Receiver | Driver<br>LOW Level<br>-200<br>LOW Level (Disabled) | Driver/Receiver<br>25 | 100<br>LOW Level<br>V <sub>OUT</sub> = 0.5V<br>-100 | -30 | Receiver | -75 | | | | | | | | I <sub>OL</sub> = -100μA<br>3.5<br>I <sub>OL</sub> = -2.0mA | -25<br>Receiver<br>-200 | | -10 | -20 | | -200 | N/A | N/A | | | 150 | | | 2.4 | | | N/A | 10 | UD Bus | | N/A | N/A | | 100 | 150 | | 8T31 | 1 <sub>OL</sub> =3.2mA<br>2.4 | V <sub>IN</sub> = 0.55V<br>-500 | V <sub>IN</sub> = 5.5V<br>100 | | 20 | IV Bus | | | | | | | | 8T32 <sup>16</sup> | <sup>1</sup> OH = 3.2mA<br>2.4 | V <sub>IL</sub> = .5V <sup>17</sup><br>-350 -550 | V <sub>IH</sub> = 5.25V <sup>17</sup><br><10 100 | N/A | 10 | UD Bus | | N/A | N/A | | 100 | 150 | | 8T3316 | I <sub>OH</sub> = 3.2mA<br>2.4 | V <sub>IL</sub> = .5V <sup>17</sup><br>-350 -550 | V <sub>IH</sub> =5.25V <sup>17</sup><br><10 100 | N/A | 10 | UD Bus | | N/A | N/A | | 100 | 150 | | 8T35 <sup>16</sup> | I <sub>OH</sub> = -3.2mA<br>2.4 | V <sub>IL</sub> = .5V <sup>17</sup><br>-350 -550 | V <sub>IH</sub> =5.25V <sup>17</sup><br><10 100 | N/A | 10 | UD Bus | | N/A | N/A | | 100 | 150 | | 8T36 <sup>16</sup> | I <sub>OH</sub> = -3.2mA<br>2.4 | V <sub>IL</sub> = .5V <sup>17</sup><br>-350 -500 | V <sub>IH</sub> =5.25V <sup>7</sup><br><10 100 | | 20 | | | | | | | | #### NOTES - 1. All voltage measurements are referenced to the ground terminal. Terminals not specifically referenced are left electrically open. - 2. All measurements are taken with ground pin tied to zero volts. - 3. Positive current is defined as into the terminal referenced. - 4. Precautionary measures should be taken to insure current limiting in accordance with absolute maximum ratings. - ${\bf 5.} \ {\bf Measurements} \ {\bf apply} \ {\bf to} \ {\bf each} \ {\bf gate} \ {\bf element} \ {\bf independently}.$ - 6. Output source current is supplied through a resistor to ground. - 7. Output sink current is supplied through a resistor to $V_{CC}$ . 8. Connect an external 1K 1% resistor to the output for this test. - 9. Not more than one output should be shorted at one time. - 10. Previous condition is a high level output state. - 11. Previous condition is a low level output state. - 12. Test each driver separately. - 13. For more electrical specifications see data sheet. - 14. $I_{CC}$ is dependent upon loading. $I_{CC}$ limit specified is for no-load test condition for both drivers. 15. With forced output current of 240 $\mu$ A, the output voltage must not exceed 0.15V. - 16. These limits do not apply during address programming. - 17. The input current includes the tri-state/open collector leakage current of the output driver on the data lines. - 18. Output leakage current is supplied through a 2K $\Omega$ resistor to 30V. - 19. Output sink current is supplied through a resistor to 30V. - 20. The differential input threshold voltage is defined as the maximum dc voltage duration from the reference level necessary to trigger the one shot. - 21. Common mode voltages that are confined within the dynamic range as specified will not cause false triggering of the one-shot. - 22. Hysterisis is defined as voltage difference between R input level at which output begins to go from "0" to "1" state and level at which output begins to go from "1" to "0." Refer to Hysterisis test circuit. - 23. V<sub>CC</sub> = +12.6V, V<sub>EE</sub> = 12.6V. 8T26A-B,F • 8T28-B,F ### **DESCRIPTION** The 8T26A/28 consists of four pairs of Tri-State logic elements configured as Quad Bus Drivers/Receivers along with separate buffered receiver enable and driver enable lines. This single IC Quad Transceiver design distinguishes the 8T26A/28 from conventional multi-IC implementations. In addition, the 8T26/28's ultra high speed while driving heavy bus capacitance (300pF) makes these devices particularly suitable for memory systems and bidirectional data buses. Both the Driver and Receiver gates have Tri-State outputs and low-current PNP inputs. Tri-State outputs provide the high switching speeds of totempole TTL circuits while offering the bus capability of open collector gates. PNP inputs reduce input loading to 200µA maximum. ### **APPLICATIONS** - Half-duplex data transmission - Memory interface buffers - . Data routing in bus oriented systems - · High current drivers - MOS/CMOS-to-TTL interface ### **PIN CONFIGURATION** ### **LOGIC DIAGRAM** ### **SWITCHING CHARACTERISTICS** | DADAMETED | | TEAT COMPLETIONS | 8T26A | 8T28 | | |-----------------------------------------|--------------|--------------------------------|-------|------|------| | PARAMETER | | TEST CONDITIONS | Max | Max | UNIT | | Propagation Delay toN | DOUT to ROUT | C <sub>1</sub> = 30pF, Note 9 | 14 | 17 | ns | | t <sub>OFF</sub> | DOUT to ROUT | <b>L</b> ' | - 14 | 17 | | | <sup>t</sup> ON | DIN to DOUT | C <sub>1</sub> = 300pF, Note 9 | 14 | 17 | ns | | <sup>t</sup> OFF | DIN to DOUT | <b>-</b> | 14 | 17 | | | Data Enable to Data Output tpzl | High Z to O | C <sub>1</sub> = 300pF, Note 9 | 25 | 28 | ns | | t <sub>PL</sub> 7 | O to High Z | <b>L</b> . | 20 | 23 | | | Receiver Enable to Receiver Output tpzL | High Z to O | C <sub>1</sub> = 30pF, Note 9 | 20 | 23 | ns | | tPLZ | O to High Z | _ | 15 | 18 | | 8T26A-B,F • 8T28-B,F ### **BLOCK DIAGRAM** # TYPICAL APPLICATIONS 8T26A-B,F • 8T28-B,F ### **AC TEST CIRCUITS AND WAVEFORMS** **OBJECTIVE SPECIFICATION** 8T31 N,F ### **DESCRIPTION** The 8T31 8-bit Bidirectional I/O Port is designed to function as a general purpose I/O interface element in minicomputers, microcomputers and other bus oriented digital systems. It consists of 8 clocked latches with two sets of bidirectional inputs/ outputs, Bus A (BA0-BA7) and Bus B (BB0-BB7). Each Bus has a write control line and a read control line. The two buses operate independently except for the case where the user is attempting to write data in from each bus simultaneously. In that case, the data on Bus A will be written into the latches while Bus B will be forced into a high impedance state. Data written into one Bus will appear inverted at the other Bus. A master enable (ME) is provided that enables or disables Bus B regardless of the state of the other inputs. A unique feature of the 8T31 is its ability to start up in a predetermined state. If the clock is maintained at a voltage less than .8V until the power supply reaches 3.5V, Bus A will always be all logic 1 levels, while Bus B will be all logic 0 levels. ### **PIN CONFIGURATION** ### **BLOCK DIAGRAM** # **FUNCTION TABLE** | | BUS A | | | | | | | | | | | | | |-------|------------|-----|---------------|----|------------------------------|--|--|--|--|--|--|--|--| | RBA | WBA | CLK | | | | | | | | | | | | | х | 0 | 1 | WRI | TE | (INPUT) | | | | | | | | | | 0 | 1 | Х | READ (OUTPUT) | | | | | | | | | | | | 1 | 1 1 X HI-Z | | | | | | | | | | | | | | BUS B | | | | | | | | | | | | | | | Ŕвв | WBB | WBA | CLK | ME | | | | | | | | | | | х | Х | Х | Х | 1 | HI-Z | | | | | | | | | | 1 | 0 | Χ | Χ | 0 | HI-Z | | | | | | | | | | Х | 1 | 0 | Χ | 0 | HI-Z | | | | | | | | | | 0 | 0 | Χ | Χ | 0 | READ | | | | | | | | | | × | 1 | 1 | 1 | 0 | (OUTPUT)<br>WRITE<br>(INPUT) | | | | | | | | | **OBJECTIVE SPECIFICATION** 8T31 N,F # **SWITCHING CHARACTERISTICS** | | PARAMETER | TECT CONDITIONS | | LIMITS | | | |----------------------------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------------------------|----------------------------------|----------------------------| | | PARAWEIEN | TEST CONDITIONS | Min | Тур | Max | UNIT | | tZL<br>tZH<br>tZL<br>tZH<br>tLZ<br>tHZ | Propagation Delay From Read<br>(RBB), Write (WBB) and Master<br>Enable (ME) to Bus B | C <sub>L</sub> = 300pF<br>C <sub>L</sub> = 300pF<br>C <sub>L</sub> = 30pF<br>C <sub>L</sub> = 30pF<br>C <sub>L</sub> = 30pF<br>C <sub>L</sub> = 30pF | | 27<br>29<br>17<br>14<br>13 | 45<br>50<br>30<br>25<br>20<br>30 | ns<br>ns<br>ns<br>ns<br>ns | | tSETUP<br>tHOLD1<br>tHOLD0 | Bus A Data Setup and Hold Times | | 0<br>10<br>25 | -10<br>4<br>16 | | ns<br>ns<br>ns | | tSETUP<br>tHOLD | Bus A Write Setup and Hold Times | | 30<br>0 | 20<br>-30 | | ns<br>ns | | tSETUP<br>tHOLD | Bus B Data Setup and Hold Times | | *<br>0 | | | ns<br>ns | | CIN | Input Capacitances<br>Control<br>Data | V <sub>IN</sub> = 0V<br>V <sub>IN</sub> = 0V<br>V <sub>IN</sub> = 3V | | | 6<br>12<br>9 | pF<br>pF<br>pF | <sup>\*</sup>The Bus B Data Setup Time is equal to the clock pulse width. # **CLOCK** **OBJECTIVE SPECIFICATIONS** 8T31 N,F # **AC WAVEFORMS** # **AC TEST CIRCUIT** # **TEST TABLE** | | S <sub>1</sub> | S <sub>2</sub> | |------|----------------|----------------| | tPHL | Closed | Closed | | tPLH | Closed | Closed | | tPL | Closed | Closed | | tPHZ | Closed | Closed | | tPZL | Closed | Open | | tPZH | Open | Closed | #### **TYPES** - 8T32 Tri-State, Synchronous User Port 8T33 Open Collector, Synchronous User - 8T35 Open Collector, Asynchronous User Port - 8T36 Tri-State, Asynchronous User Port #### DESCRIPTION The Interface Vector (IV) Byte is an 8-bit bidirectional data register designed to function as an I/O interface element in microprocessor systems. It contains 8 data latches accessible from either a microprocessor (IV) port or a user port. Separate I/O control is provided for each port. The 2 ports operate independently, except when both are attempting to input data into the IV Byte. In this case, the user port has priority. A unique feature of the 8T32/33/35/36 IV Byte is the way in which it is addressed. Each IV Byte has an 8-bit, field programmable address, which is used to enable the microprocessor port. When the SC control signal is high, data at the microprocessor port is treated as an address. If the address matches the IV Byte's internally programmed address, the microprocessor port is enabled, allowing data transfer through it. The port remains enabled until an address which does not match is presented, at which time the port is disabled (data transfer is inhibited). A Master Enable input (ME) can serve as a ninth address bit, allowing 512 IV Bytes to be individually selected on a bus, without decoding. The user port is accessible at all times, independent of whether or not the microprocessor port is selected. A unique feature of this family is their ability to start up in a predetermined state. If the clock is maintained at a voltage less than .8V until the power supply reaches 3.5V, the user port will always be all logic 1 levels, while the IV port will be all logic 0 levels. ### **ORDERING** The 8T32/33/35/36 may be ordered in preaddressed form. To order a preaddressed IV Byte, use the following part number format: N8TYY-XXX P -P= F Ceramic package NA Plastic package -XXX= Any address from 000 through 255 (decimal) 256 available addresses -YY= IV Byte version (32, 33, 35, 36) A stock of 8T32s and 8T36s with addresses 1 through 10 will be maintained. A small quantity of addresses 11 through 50 will also be available with a longer lead time. ### **FEATURES** - A field-programmable address allows 1 of 512 IV Bytes on a bus to be selected, without decoders. - Each byte has 2 ports, one to the user, the other to a microprocessor. IV Bytes are completely bidirectional. - Ports are independent, with the user port having priority for data entry. - A selected IV Byte de-selects itself when another IV Byte address is sensed. - User data input available as synchronous (8T32, 8T33) or as asynchronous (8T35, 8T36) function. - The User Data Bus is available with tristate (8T32, 8T36) or open collector (8T33, 8T35) outputs. - At power up, the IV Byte is not selected and the user port outputs are high. - Tri-state TTL outputs for high drive capability. - Directly compatible with the 8X300 Interpreter. - Operates from a single 5V power supply over a temperature range of 0°C to 70°C. ### **PIN CONFIGURATION** ### **BLOCK DIAGRAM** #### PIN DESCRIPTION | PIN | SYMBOL | NAME AND FUNCTION | TYPE | |-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------| | 1-8 | UD0-UD7: | User Data I/O Lines. Bidirectional data lines to communicate with user's equipment. Either tristate or open collector outputs are available. | Active high | | 16-23 | ī∇0-īV7: | Interface Vector (IV) Bus. Bidirectional data lines to communicate with controlling digital system (microprocessor). | Active low<br>three-state | | 10 | BIC: | Byte Input Control. User input to control writing into the IV Byte from the User Data Lines. | Active low | | 9 | BOC: | Byte Output Control. User input to control reading from the IV Byte onto the User Data Lines. | Active low | | 11 | MĒ: | Master Enable. System input to enable or dis-<br>able all other system inputs and outputs.<br>It has no effect on user inputs and outputs. | Active low | | 15 | WC: | Write Command. When WC is high and SC is low, IV Byte, if selected, stores contents of IV0-IV7 as data. | Active high | | 14 | SC: | Select Command. When SC is high and WC is low, data on IV0-IV7 is interpreted as an address. IV Byte selects itself if its address is identical to IV bus data; it de-selects itself otherwise. | Active high | | 13 | MCLK: | Master Clock. Input to strobe data into the latches. See function tables for details. | Active high | | 24 | VCC: | 5V power connection. | | | 12 | GND: | Ground. | · | | BIC | BOC | 110114 | USER DATA BUS FUNCTION | | | | | | |-------------|------------------|------------------|---------------------------------------------------|-----------------------------------------------------|--|--|--|--| | ВС | ВОС | MCLK | 8T32, 8T33 | 8T35, 8T36 | | | | | | H<br>L<br>L | L<br>X<br>X<br>H | X<br>H<br>L<br>X | Output Data<br>Input Data<br>Inactive<br>Inactive | Output Data<br>Input Data<br>Input Data<br>Inactive | | | | | H = High Level L = Low Level X = Don't care Table 1 USER PORT CONTROL FUNCTION | ME | sc | wc | MCLK | BIC | STATUS<br>LATCH | IV BUS<br>FUNCTION | |----|----|----|------|-----|-----------------|------------------------| | L | L | L | Х | Х | SET | Output Data | | L | L | Н | ) н | Н | SET | Input Data | | L | н | L | Н | Х | X | Input Address | | L | Н | Н | Н | L | Х | Input Address | | L | Н | Н | н | н | Х | Input Data and Address | | L | X | Н | L | Х | X | Inactive | | L | Н | X | L | X | X | Inactive | | L | L | Н | Н | L | Х | Inactive | | L | L | Х | X | Х | Not Set | Inactive | | н | X | Х | Х | Х | Х | Inactive | Table 2 MICROPROCESSOR PORT CONTROL FUNCTION ### **USER DATA BUS CONTROL** The activity of the User Data Bus is controlled by the BIC and BOC inputs as shown in Table 1. For the 8T32 and 8T33, User Data Input is a synchronous function with MCLK. A low level on the BIC input allows data on the User Data Bus to be written into the Data Latches only if MCLK is at a high level. For the 8T35 and 8T36, User Data Input is an asynchronous function. A low level on the BIC input allows data on the User Data Bus to be latched regardless of the level of the MCLK input. Note that when 8T35 or 8T36 IV Bytes are used with the 8X300 Interpreter care must be taken to insure that the IV Bus is stable when it is being read by the 8X300 Interpreter. To avoid conflicts at the Data Latches, input from the Microprocessor Port is inhibited when BIC is at a low level. Under all other conditions the 2 ports operate independently. # INTERFACE VECTOR BUS CONTROL As is shown in Table 2, the activity of the microprocessor port (IV Bus) is controlled by the ME, SC, WC and BIC inputs, as well as the state of an internal status latch. BIC is included to show user port priority over the microprocessor port for data input. Each IV Byte's status latch stores the result of the most recent IV Byte select; it is set when the IV Byte's internal address matches the IV Bus. It is cleared when an address that differs from the internal address is presented on the IV Bus. In normal operation, the state of the status latch acts like a master enable; the microprocessor port can transfer data only when the status latch is set. When SC and WC are both high, data on the IV Bus is accepted as data, whether or not the IV Byte was selected. The data is also interpreted as an address. The IV Byte sets its select status if its address matches the data read when SC and WC were both high; it resets its select status otherwise. ### **BUS OPERATION** Data written into the IV Byte from one port will appear inverted when read from the other port. Data written into the IV Byte from one port will not be inverted when read from the same port. ### **ADDRESS PROGRAMMING** The IV Byte is manufactured such that an address of all high levels (> 2V) on the IV Data Bus inputs matches the Byte's internal address. To program a bit so a low-level input (< 0.8V) matches, the following procedure should be used: - Set all control inputs to their inactive state (BIC = BOC = ME = V<sub>CC</sub>, SC = WC = MCLK = GND). Leave all IV Data Bus I/O pins open. - 2. Raise $V_{CC}$ to 7.75V $\pm$ .25V. - After V<sub>CC</sub> has stabilized, apply a single programming pulse to the User Data Bus bit where a low-level match is desired. The voltage should be limited to 18V; the current should be limited to 75mA. Apply the pulse as shown in Figure 1. - 4. Return V<sub>CC</sub> to 0V. (Note 6). - 5. Repeat this procedure for each bit where a low-level match is desired. - Verify that the proper address is programmed by setting the Byte's status latch (IV0-IV7 = desired address, ME = WC = L, SC = MCLK = H). If the proper address has been programmed, data presented at the IV Bus will appear inverted on the User Bus outputs. (Use normal V<sub>CC</sub> and input voltage for verification.) After the desired address has been programmed, a second procedure must be followed to isolate the address circuitry. The procedure is: - Set V<sub>CC</sub> and all control inputs to 0V. (V<sub>CC</sub> = BIC = BOC = ME = SC = WC = MCLK = 0V). Leave all IV Data Bus I/O pins open. - Apply a protect programming pulse to every User Data Bus pin, one at a time. The voltage should be limited to 14V; the current should be limited to 150mA. Apply the pulse as shown in Figure 2. - Verify that the address circuitry is isolated by applying 7V to each User Data Bus pin and measuring less than 1mA of input current. The conditions should be the same as in step 1 above. The rise time on the verification voltage must be slower than 100µs. # Absolute Maximum Ratings: Supply voltage (Note 1) ...... | Supply voltage (Note 1) | • • • • • • • • • • • • | " | |-------------------------|-------------------------|------| | Input Voltage (Note 1) | | 5.5\ | ### **AC ELECTRICAL CHARACTERISTICS** | | | TEST | | LIMITS | | | |------------------------------------------|---------------------------------------------------|-----------------------|----------------------------------|----------------|----------------|------| | PARAMETER | INPUT | CONDITION | Min | Тур | Max | UNIT | | t <sub>PD</sub> User data delay (Note 1) | UDX<br>MCLK*<br>BIC† | C <sub>L</sub> = 50pF | | 25<br>45<br>40 | 38<br>61<br>55 | ns | | <sup>t</sup> OE User output enable | вос | C <sub>L</sub> = 50pF | 18 | 26 | 47 | ns | | t <sub>OD</sub> User output disable | BIC<br>BOC | C <sub>L</sub> = 50pF | 18<br>16 | 28<br>23 | 35<br>33 | ns | | t <sub>PD</sub> IV data delay (Note 1) | IVBX<br>MCLK | C <sub>L</sub> = 50pF | ! | 38<br>48 | 53<br>61 | ns | | t <sub>OE</sub> IV output enable | ME<br>SC<br>WC | C <sub>L</sub> = 50pF | 14 | 19 | 25 | ns | | t <sub>OD</sub> IV output disable | ME<br>SC<br>WC | C <sub>L</sub> = 50pF | 13 | 17 | 32 | ns | | t <sub>W</sub> Minimum pulse width | MCLK<br>BIC† | | 40<br>35 | | | ns | | <sup>t</sup> SETUP Minimum setup time | UD <sup>II</sup><br>BIC*<br>IVX<br>ME<br>SC<br>WC | (Note 2) | 15<br>25<br>55<br>30<br>30<br>30 | | | ns | | <sup>t</sup> HOLD Minimum hold time | UDX¤<br>BIC*<br>IVX<br>ME<br>SC<br>SC | (Note 2) | 25<br>10<br>10<br>5<br>5<br>5 | | | ns | Applies for 8T32 and 8T33 only. ### NOTES: Applies for 8T35 and 8T36 only. Times are referenced to MCLK for 8T32 and 8T33, and are referenced to BIC for 8T35 and 8T36. <sup>1.</sup> Data delays referenced to the clock are valid only if the input data is stable at the arrival of the clock and the hold time requirement is met. 2. Set up and hold times given are for "normal" operation. BIC setup and hold times are for a user write operation. SC setup and hold times are for an IV Byte select operation. WC setup and hold times are for an IV Bus write operation. ME setup and hold times are for both IV write and select operations. # PROGRAMMING SPECIFICATIONS | | PARAMETER | TEST<br>CONDITIONS | LIMITS | | | | |------------------|---------------------------------------------------|-------------------------|--------------|-----|--------------|----------| | | | | Min | Тур | Max | UNITS | | V <sub>CCP</sub> | Programming supply voltage<br>Address<br>Protect | | 7.5 | 0 | 8.0 | V<br>V | | ICCP | Programming supply current | V <sub>CCP</sub> = 8.0V | | | 250 | mA | | | Max time V <sub>CCP</sub> > 5.25V | | | | 1.0 | s | | | Programming voltage<br>Address<br>Protect | | 17.5<br>13.5 | | 18.0<br>14.0 | V<br>V | | | Programming current<br>Address<br>Protect | | | | 75<br>150 | mA<br>mA | | | Programming pulse rise time<br>Address<br>Protect | | .1<br>100 | | 1 | μs<br>μs | | | Programming pulse width | | .5 | | 1 | ms | ### NOTES ### PARAMETER MEASUREMENT INFORMATION <sup>3.</sup> If all programming can be done in less than 1 second, VCC may remain at 7.75V for the entire programming cycle. # PARAMETER MEASUREMENT INFORMATION (Cont'd) ### **APPLICATIONS** Figure 3 shows some of the various ways to use the IV Byte in a system. By controlling the BIC and BOG lines, the Bytes may be used for the input and output of data, control, and status signals. IV Byte 1 functions bidirectionally for data transfer and IV Byte 2 provides a similar function for discrete status and control lines. IV Bytes 3 and 4 serve as dedicated output and input ports, respectively. # **BIPOLAR PROMS COMPONENTS** # **PROMS** # Field Programmable Read Only Memories Signetics offers the industry's broadest line of Bipolar High Performance PROMs. These PROMs are field programmable, which means that custom patterns are immediately available by following the provided fusing procedures. Signetics PROMs are supplied with all outputs at logical "0". Outputs are programmed to a logic "1" at any specified address by fusing a Ni-Cr link matrix. All PROMs are fully TTL compatible, and include on-chip decoding and chip enable functions for ease of memory expansion. Tri-state and open collector output functions are available, and low input currents reduce input buffer requirements. Most Signetics PROMs also have pin and performance compatible ROMs, offering the user the ultimate in flexibility and cost reduction. # THERMAL RATINGS | TEMPERATURE | MILI-<br>TARY | COM-<br>MERCIAL | |-------------------------------------------|---------------|-----------------| | Maximum junction | 175°C | 150°C | | Maximum ambient<br>Allowable thermal rise | 125° C | 75°C | | ambient to junction | 50°C | 75°C | # **ABSOLUTE MAXIMUM GUARANTEED RATINGS** | | PARAMETER | LIF | MITS | UNIT | |----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------------------------------------|------------------------------| | | TANAMETEN | Min | Max | | | T <sub>A</sub> T <sub>STG</sub> V <sub>IN</sub> VOUT VCC | Operating Ambient Temperature<br>S82S - Military Range<br>N82S - Commercial Range<br>Storage Temperature<br>Input Voltage<br>Output Voltage<br>Power Supply Voltage | -55<br>0<br>-65 | +125<br>+75<br>+150<br>+5.5<br>+5.5<br>+7 | °C<br>°C<br>°C<br>Vdc<br>Vdc | #### NOTES - 1. Stresses above those listed "Maximum, Guaranteed Ratings" may cause permanent damage to the device. This is a stress rating only, and functional operation of the device of these or any other condition above those indicated in the operation section of the device specifications is not implied. - 2. For operating at elevated temperatures, the device must be derated based on a +150°C maximum junction temperature and a thermal resistance of 160°C/W junction to ambient. - 3. For operating at elevated temperatures, the devices must be derated based on a + 160°C maximum junction temperature and a thermal resistance of 110°C/W junction to ambient. #### **AC TEST FIGURE** # MAXIMUM ALLOWABLE POWER DISSIPATION | MATERIAL | PACKAGE | # OF | θ JA <sup>1</sup> | P <sub>MAX</sub> | — mW | |----------------------|---------|------|-------------------|------------------|----------| | WATERIAL | PACRAGE | PINS | °C/W | 0 + 125°C | 0 + 75°C | | Plastic | В | 16 | 155 | | 480 | | | XA | 18 | 130 | 384 | 577 | | | l N | 24 | 100 | 500 | 750 | | | XF | 28 | 100 | 500 | 750 | | Plastic <sup>2</sup> | BA | 16 | 85 | 588 | 850 | | | XAS | 18 | 73 | 685 | >1000 | | | NA | 24 | 75 | 666 | 1000 | | | XFA | 28 | 75 | 666 | 1000 | | Cerdip | F | 16 | 90 | 556 | | | | | 18 | 90 | 556 | 835 | | | | 24 | 60 | 830 | >1000 | | Ceramic | 1 | 16 | 83 | 600 | 900 | | | | 24 | 50 | 1000 | >1000 | | · | | 28 | 50 | 1000 | >1000 | # NOTES - 1. On a mounted surface, in still air. - 2. Improved thermal characteristics due to built-in heat spreader. # **BIPOLAR PROMS COMPONENTS** # **ELECTRICAL CHARACTERISTICS** S82S Devices — -55°C $\leqslant$ T $_{A}$ $\leqslant$ +125°C, 4.5V $\leqslant$ V $_{CC}$ $\leqslant$ 5.5 N82S Devices — 0° C $\leqslant$ T A $\leqslant$ +75° C, 4.75V + V $\stackrel{\frown}{CC} \leqslant$ 5.25 | | | | | INPU | T VOL | TAGE | | | | | , 01 | JTPUT | VOLT | AGE | | INPU | T CUF | RENT | |--------------------|-----------------------|------|--------------|-----------------------|------------------------------|-----------|---------|--------------------------------------------------|------|-----|-----------------------------|------------|------|--------------------------------------|-------|-------------------------|--------|------| | PARAMETER8 | | | (V)<br>_EVEL | | V <sub>IH</sub> (V<br>IP VOL | )<br>TAGE | | V <sub>IC</sub> 1(V | | | OL <sup>2</sup> (V | | | OH <sup>6</sup> ( | | | IL (µA | | | TEST<br>CONDITIONS | V <sub>CC</sub> = Min | | | V <sub>CC</sub> = Max | | | ۷.<br>ا | I <sub>IN</sub> = -18mA<br>V <sub>CC</sub> = Min | | | L = 16<br>CC <sup>= N</sup> | mA<br>Iin | CE₁ | T = -2.<br>= CE <sub>2</sub><br>STOR | = "0" | V <sub>IN</sub> = 0.45V | | | | DEVICE | Mi | n Ty | р Мах | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | | 2048-BIT | | | | | | | | | | IC | )L = 9. | 6mA | | | | | | | | 82S114 N | | | .85 | 2.0 | | | | | -1.2 | | | 0.5 | 2.7 | 3.3 | | | | -100 | | 82S115 N | | | .85 | 2.0 | | | | | -1.2 | IC | L = 9. | 6mA<br>0.5 | 2.7 | 3.3 | | | | -100 | | DADAMET | ED8 | | INPU<br>JRRE | | | | Ol | JTPU | T CU | RRE | NT. | - | | | UPPI<br>JRRE | | CAPACITANCE | | | | | | | | |------------------|-----|-----------------|-----------------|-----|----------------|-------------------------|------|----------------|--------------|----------------------|------------------------|-------------------|-----------|-----|--------------|-----|-----------------|-----------------|------------|----------------|---------------|--------------|--|--| | PARAMET | EH° | | IH (μ/<br>iH LE | | | LK⁴ (/<br>EAKA | | | (OFF<br>Z ST | (μ <b>A</b> )<br>ATE | I <sub>O</sub><br>SHOF | S <sup>5</sup> (m | | ١c | C (m | A)3 | | IN (b | | | OUT⁴<br>UTPU | | | | | TEST<br>CONDITIO | NS | V <sub>,I</sub> | N = 5 | .5V | V <sub>O</sub> | CC = I<br>UT =<br>or CE | 5.5V | V <sub>O</sub> | C = I | Max<br>5.5V | v <sub>o</sub> | UT =<br>C = N | OV<br>lax | ۷٥ | C = N | Max | V <sub>II</sub> | N = 2.<br>C = 5 | .0V<br>.0V | ۷ <sub>0</sub> | C = 5<br>UT = | 5.0V<br>2.0V | | | | DEVICE | | Min | Тур | Max | | | 2048-B | ΙΤ | | | | | | | vol | JT = ( | 0.5V | | | | | | | | | | | , | | | | | 82S114 | Ν | | | 25 | | N/A | | | | -40 | -20 | | -70 | | 135 | 185 | | | 5 | | | 8 | | | | 82S115 | N | | | 25 | | N/A | | | | | | | | | | | | | | | | | | | # NOTES - 1. Test each input one at a time. - 2. Measured with the logic "0" stored. Output sink current is supplied through a resistor to $V_{\hbox{\footnotesize{CC}}}$ . - 3. I<sub>CC</sub> is measured with the write enable and chip enable inputs grounded; all other inputs at 4.5V, and the outputs open. - 4. Measured with $V_{IH}$ applied to $\overline{CE}$ . - 5. Duration of the short circuit should not exceed one second. - 6. Measured with $\overline{\text{CE}}_{(s)}$ = OV, and output(s) at logic "1." 7. All voltage values are with respect to network ground terminal. # **INPUT WAVEFORMS** # **INPUT PULSES** Measurements: All Circuit Delays are measured at the +1.5V level of inputs and outputs. # (UNLESS TYPICAL AC WAVEFORMS OTHERWISE SPECIFIED) N82S114-I · N82S115-I #### **DESCRIPTION** The 82S114 and 82S115 are fully TTL compatible, and include on-chip decoding and two chip enable inputs for ease of memory expansion. They feature Tri-State outputs for optimization of word expansion in bused organizations. A D-type latch is used to enable the Tri-State output drivers. In the TRANSPARENT READ mode, stored data is addressed by applying a binary code to the address inputs while holding STROBE high. In this mode the bit drivers will be controlled solely by CE1 and CE2 lines. In the LATCHED READ mode, outputs are held in their previous state (1, 0, or High-Z) as long as STROBE is low, regardless of the state of address or chip enable. A positive STROBE transition causes data from the applied address to reach the outputs if the chip is enabled, and causes outputs to go to the High-Z state if the chip is disabled. A negative STROBE transition causes outputs to be locked into their last Read Data condition if the chip was enabled, or causes outputs to be locked into the High-Z condition if the chip was disabled. # PIN CONFIGURATION # **BLOCK DIAGRAM** # AC ELECTRICAL CHARACTERISTICS 0°C ≤TA ≤+75°C, 4.75V ≤VCC ≤5.25V | | PARAMETER | TEST CONDITIONS | | LIMITS | | LINIT | |-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|---------------------------|----------------------|----------------|----------------------------| | | PARAMETER | TEST CONDITIONS | Min | Typ <sup>2</sup> | Max | UNIT | | T <sub>AA</sub><br>T <sub>CE</sub><br>T <sub>CD</sub> | Address Access Time<br>Chip Enable Access Time<br>Chip Disable Time | LATCHED or TRANSPARENT READ $R_1=270\Omega,\ R_2=600\Omega,\ C_L=30pF$ (Note 4) | | 35<br>20<br>20 | 60<br>40<br>40 | ns<br>ns<br>ns | | TADH<br>TCDH<br>TSW<br>TSL<br>TDL<br>TCDS | Address Hold Time Chip Enable Hold Time Strobe Pulse Width Strobe Latch Time Strobe Delatch Time Chip Enable Set-up Time | LATCHED READ ONLY $R_1 = 270\Omega, R_2 = 600\Omega, C_L = 30 pF \\ (\text{Note 5})$ | 0<br>10<br>30<br>60<br>40 | -10<br>0<br>20<br>35 | 30 | ns<br>ns<br>ns<br>ns<br>ns | #### NOTES - Positive current is defined as into the terminal referenced. - 2. Typical values are at $V_{\mbox{CC}}$ = $+5.0\mbox{V}$ and $T_{\mbox{A}}$ = $+25\mbox{°C}.$ - 3. No more than one output should be grounded at the same time and strobe should be disabled. Strobe is in "1" state. - 4. If the strobe is high, the device functions in a manner identical to conventional bipolar ROMs. The timing diagram shows valid data will appear TA nanoseconds after the address has changed and T<sub>CE</sub> nanoseconds after the output circuit is enabled. T<sub>CD</sub> is the time required to disable the output and switch it to an "off" or high impedance state after it has been enabled. - 5. In Latched Read Mode data from any selected address will be held on the output when strobe is lowered. Only when strobe is raised will new location data be transferred and chip enable conditions be stored. The new data will appear on the outputs if the chip enable conditions enable the outputs. # 82S114/115 MANUAL PROGRAMMER # **TIMING SEQUENCE** # PROGRAMMING SPECIFICATIONS (Testing of these limits may cause programming of device.) TA = +25°C | | | | | LIMITS | | | |--------------------|------------------------------------------------|--------------------------------------------------|------|--------|------|---------| | | PARAMETER | TEST CONDITIONS | Min | Тур | Max | UNIT | | Power Supp | ly Voltage | | | | | | | V <sub>CCP</sub> 1 | To Program | ICCP = 200 ± 25mA<br>(Transient or steady state) | 4.75 | 5.0 | 5.25 | ٧ | | V <sub>ССН</sub> | Upper Verify Limit | | 5.3 | 5.5 | 5.7 | V | | VCCL | Lower Verify Limit | | 4.3 | 4.5 | 4.7 | V | | V <sub>S</sub> 3 | Verify Threshold | | 0.9 | 1.0 | 1.1 | ٧ | | ICCP | Programming Supply Current | $V_{CCP} = +5.0 \pm .25V$ | 175 | 200 | 225 | mA | | ViL | Low Level Input Voltage | | 0 | 0.4 | 0.8 | V | | ViH | High Level Input Voltage | | 2.4 | | 5.5 | V | | | nt (FE <sub>1</sub> & FE <sub>2</sub> Only) | | | | 1 | | | ИĖ | Low Level Input Current | $V_{II} = +0.45V$ | | | -100 | $\mu$ A | | ЛН | High Level Input Current | V <sub>IH</sub> = +5.5V | j | | 10 | mA | | | nt (Except FE <sub>1</sub> & FE <sub>2</sub> ) | | 1 | | | | | Tr <u>i</u> | Low Level Input Current | V <sub>IL</sub> = +0.45V | | | -100 | $\mu$ A | | ÚН | High Level Input Current | V <sub>IH</sub> = +5.5V | | | 25 | $\mu$ A | | V <sub>OUT</sub> 2 | Output Programming Voltage | IOUT = 200 ± 20mA<br>(Transient or steady state) | 16.0 | 17.0 | 18.0 | ·V | | IOUT | Output Programming Current | V <sub>OUT</sub> = +17 ± 1V | 180 | 200 | 220 | mΑ | | TR | Output Pulse Rise Time | | 10 | | 50 | μs | | tp | FE <sub>2</sub> Programming Pulse Width | | 1 | | 1.5 | ms | | t <sub>D</sub> | Pulse Sequence Delay | | 10 | | | μs | | TPR | Programming Time | V <sub>CC</sub> = V <sub>CCP</sub> | | | 10 | sec | | TPS | Programming Pause | V <sub>CC</sub> = OV | 7 | | | sec | | T <sub>PR4</sub> | | | | | | | | | Programming Duty Cycle | | | | 60 | % | | TPR + TPS | | | | | | | # RECOMMENDED PROGRAMMING PROCEDURE The 82S114/115 are shipped with all bits at logical "0" (low). To write logical "1", proceed as follows: #### Set-up - a. Apply GND to pin 12. - b. Terminate all device outputs with a 10K resistor to VCC. - c. Set CE1 to logic "0", and CE2 to logic "1" (TTL levels). - d. Set Strobe to logic "1" level. # **Program-Verify Sequence** Step 1 Raise V<sub>CC</sub> to V<sub>CCP</sub>, and address the word to be programmed by applying TTL "1" and "0" logic levels to the device address inputs. - Step 2 After 10µs delay, apply to FE1 (pin 13) a voltage source of +5.0 ± 0.5V, with 10mA sourcing current capability. - Step 3 After 10µs delay, apply a voltage source of +17.0 ± 1.0V to the output to be programmed. The source must have a current limit of 200mA. Program one output at the time. - Step 4 After 10µs delay, raise FE2 (pin 11) from 0V to +5.0 ± 0.5V for a period of 1ms, and then return to 0V. Pulse source must have a 10mA sourcing current capability. - Step 5 After 10µs delay, remove +17.0V supply from programmed output. - Step 6 To verify programming, after 10µs delay, return FE1 to 0V. Raise V CC to V CCH = +5.5 ± .2V. The programmed output should remain in the "1" state. Again, lower V CC to V CCL = +4.5 ± .2V, and verify that the programmed output remains in the "1" state. - Step 7 Raise VCC to VCCP, and repeat steps 2 through 6 to program other bits at the same address. - Step 8 Repeat steps 1 through 7 to program all other address locations. #### NOTES - 1. Bypass V<sub>CC</sub> to GND with a 0.01 μF capacitor to reduce voltage spikes. - 2. Care should be taken to insure the 17 ± 1V output voltage is maintained during the entire fusing cycle. The recommended supply is a constant current source clamped at the specified voltage limit. - 3. $V_S$ is the sensing threshold of the PROM output voltage for a programmed bit. It normally constitutes the reference voltage applied to a comparator circuit to verify a successful fusing attempt. - 4. Continuous fusing for an unlimited time is also allowed, provided that a 60% duty cycle is maintained. This may be accomplished by following each Program Verify cycle with a Rest period ( $V_{CC}$ = 0V) of 3mS. # **TYPICAL FUSING PATH** # **AC WAVEFORMS** # BIPOLAR RAMS COMPONENTS #### **Random Access Memories** A complete line of Schottky-clamped TTL, read/write memory arrays is offered. All feature open collector or tri-state output options for optimization of word expansion in bused organizations. Memory expansion is further enhanced by full on-chip address decoding, chip enable function, and PNP input transistors which reduce input loading requirements. All devices offer high performance read access and write cycle times making these devices ideally suited in high speed memory applications such as "caches," buffers, scratch pads, writeable control store, main store, etc. #### **ABSOLUTE MAXIMUM GUARANTEED RATINGS** | | | LIN | MITS | | |----------------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------|----------------------------|-------------------------| | | PARAMETER | Min | UNIT | | | TA | Operating Ambient Temperature<br>S82S - Military Range<br>N82S - Commercial Range | -55<br>0 | +125<br>+75 | °C | | T <sub>STG</sub><br>V <sub>IN</sub><br>V <sub>OUT</sub><br>V <sub>CC</sub> | Storage Temperature<br>Input Voltage<br>Output Voltage<br>Power Supply Voltage | -65 | +150<br>+5.5<br>+5.5<br>+7 | °C<br>Vdc<br>Vdc<br>Vdc | #### NOTE Stresses above those listed under "Maximum, Guaranteed Ratings" may cause permanent damage to the device. This is a stress rating only, and functional operation of the device of these or any other condition above those indicated in the operation section of the device specifications is not implied. #### MAXIMUM ALLOWABLE POWER DISSIPATION | MATERIAL | PACKAGE | # OF | ⊕JA¹ | PMA | X -mW | |----------------------|---------|------|------|------------|----------| | MATERIAL | PACKAGE | PINS | °C/W | 0 + 125° C | 0 + 75°C | | Plastic | В | 16 | 155 | _ | 480 | | | XA | 18 | 130 | 384 | 577 | | | N | 24 | 100 | 500 | 750 | | | XF | 28 | 100 | 500 | 750 | | Plastic <sup>2</sup> | ВА | 16 | 85 | 588 | 850 | | | XAS | 18 | 73 | 685 | >100 | | | NA | 24 | 75 | 666 | 1000 | | | XFA | 28 | 75 | 666 | 1000 | | Cerdip | F | 16 | 90 | 556 | 835 | | | | 18 | 90 | 556 | 835 | | | | 24 | 60 | 830 | >1000 | | Ceramic | 1 | 16 | 83 | 600 | 900 | | | | 24 | 50 | 1000 | >1000 | | | | 28 | 50 | 1000 | >1000 | #### THERMAL RATINGS | TEMPERATURE | MILI-<br>TARY | COM-<br>MERCIAL | |------------------------------------------------------|------------------|-----------------| | Maximum junction<br>Maximum ambient<br>Allow thermal | 175° C<br>125° C | 150°C<br>75°C | | rise ambient<br>to junction | 50°C | 75° C | #### NOTES - 1. On a mounted surface, in still air. - Improved thermal characteristics due to built-in heat spreader. # **AC TEST LOAD AND WAVEFORMS** # BIPOLAR RAMS COMPONENTS # **ELECTRICAL CHARACTERISTICS** S82S Devices — -55°C $\leqslant$ TA $\leqslant$ +125°C, 4.5V $\leqslant$ VCC $\leqslant$ 5.5 N82S Devices — 0°C $\leqslant$ T A $\leqslant$ + 75°C, 4.75V $\leqslant$ V $_{CC}$ $\leqslant$ 5.25 | | | | | | INPU | L AOF. | TAGE | | | | | O! | JTPUT | VOLTA | AGE | | INPU | T CUF | RENT | |---------------|--------|-----|-----------------------------|--------------|------|--------|-------------|-------------------------------------------------|------------------------------|------------|-------------------------|----------------|---------------------------------------|--------------------|--------------------|--------|------|------------|--------------| | PARAME | ETER8 | | / <sub>IL</sub> (V<br>W LE\ | | | VIH (V | | | /IC <sup>1</sup> (V<br>P VOL | )<br>.TAGE | | OL²(V<br>W LEV | | ı | VOH <sup>6</sup> ( | | | IL (M | | | TES<br>CONDIT | - | ٧٥ | CC = V | <b>f</b> lin | V | CC = N | <b>f</b> ax | I <sub>IN</sub> = 12mA<br>V <sub>CC</sub> = Min | | | IOL = 16mA<br>VCC = Min | | JT = -2<br>= CE <sub>2</sub><br>" STO | <sub>2</sub> = "0" | VI | N = 0. | 45V | | | | DEVI | CE | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | <del> </del> | | Min | Тур | Max | Min | Тур | Max | | | 256-E | | | | | | | | | | | | | | | )H=-( | 3.2mA | | | | | 82S16 | S<br>N | | | 0.80<br>0.85 | 2.0 | | | | | -1.5 | | 0.35<br>0.35 | 0.5<br>0.45 | 2.4<br>2.6 | | | | -10<br>-10 | -250<br>-100 | | 82S17 | S<br>N | | | 0.80<br>0.85 | 2.0 | | | | | -1.5 | | 0.35<br>0.35 | 0.5<br>0.45 | | N/A | | | -10<br>-10 | -250<br>-100 | | 82S116 | | | | 0.85 | 2.0 | | | | | -1.5 | | 0.35 | 0.45 | 2.6 | H = -3 | .2mA | | -10 | -100 | | 82S117 | | | | 0.85 | 2.0 | | | | | -1.5 | | 0.35 | 0.45 | | N/A | | | -10 | -100 | | PARA | | ł | INPU<br>JRRE | | | | οι | JTPU | T CU | RREN | IT | | | _ | UPPI | | | C | APAC | ITAN | ICE | | |----------------------|------------|-----|----------------|------|-----|-------------------------|-----|------|------------------------------|--------------------------------|-----|---------------|-------------|-----|-------------------|------------|-----|-----------------|------|------|---------------|-------| | METE | R8 | | IH (µ<br>SH LE | | | OLK4(/<br>EAKA | | | OFF) <sup>4</sup> | | | S(mA | )⁵<br>RCUIT | Ic | C <sub>3</sub> (m | Α) | IN | PUT ( | pF) | ουτ | PUT | ⁴(pF) | | TEST<br>CONE<br>TION | ) <b>–</b> | ۷۱ | N = 5 | 5.5V | _Vo | C = N<br>UT =<br>or CE; | | | C = !<br>UT = | | | UT =<br>C = N | | ۷٥ | C = 1 | Иах | | N = 2.<br>C = 5 | | | C = !<br>UT = | | | DEVIC | CE | Min | Тур | Max | 256-B<br>82S16 | S<br>N | | 1 | 25 | | N/A | | Vol | 1<br>1<br>1T = 0<br>-1<br>-1 | 50<br>40<br>.45V<br>-50<br>-40 | -20 | | -70 | | 80<br>80 | 120<br>115 | | 5 | | | 8 | | | 82S17 | S<br>N | | 1 | 25 | | 1 | 40 | | N/A | | | N/A | | | 80<br>80 | 120<br>115 | | 5 | | | 8 | | | 82S116 | N | | 1 | 25 | | N/A | | ۷ou | 1<br>)T = 0<br> -1 | 40<br>.45V<br>-40 | -20 | | -70 | | 80 | 115 | | 5 | | | 8 | | | 82S117 | N | | 1 | 25 | | 1 | 40 | | ,N/A | | | N/A | | | 80 | 115 | | 5 | | | 8 | | - 1. Test each input one at the time. - 2. Measured with the logic "0" stored. Output sink current is supplied through a resistor to $V_{CC}$ . 3. $I_{CC}$ is measured with the write enable and chip enable inputs grounded; all other inputs at 4.5V, and the outputs open. - 4. Measured with $V_{IH}$ applied to $\overline{CE}$ . - 5. Duration of the short circuit should not exceed one second. 6. Measured with CE(s) = OV₁ and output(s) at logic "1." - 7. 10°C ≤ T<sub>A</sub> ≤ 75°C 8. All voltage values are with respect to ground terminal. - 9. The Operating Ambient Temperature Ranges are guaranteed with transverse air flow exceeding 400 linear feet per minute and a two minute warm-up. Typical thermal resistance values of the package at maximum temperature are: - ØJA Junction to Ambient at 400fpm air flow—50° C/Watt - ØJA Junction to Ambient—still air—90° C/Watt ØJA Junction to Case—20° C/Watt # BIPOLAR RAMS COMPONENTS # **AC TEST FIGURE** 45 N82S16 • 117 • 116 • 117-B,F • S82S16 • 17 • 116 • 117-F # **BLOCK DIAGRAM** # **PIN CONFIGURATION** # **TRUTH TABLE** | MODE | CE* | | | DOUT | | | | | | |-----------|-----|----|-----|-----------|-----------|--|--|--|--| | MODE | CE | WE | DIN | 82S16/116 | 82S17/117 | | | | | | READ | 0 | 1 | Х | STORED | STORED | | | | | | | | L | | DATA | DATA | | | | | | WRITE "0" | 0 | 0 | 0 | 1 | 1 | | | | | | WRITE "1" | 0 | 0 | 1 | 0 | 0 | | | | | | DISABLED | 1 | Х | Х | High-Z | 1 | | | | | <sup>\*&</sup>quot;0" = All $\overline{CE}$ inputs low; "1" = one or more $\overline{CE}$ inputs high. AC ELECTRICAL CHARACTERISTICS 0°C ≤T<sub>A</sub> ≤+75°C, 4.75V ≤V<sub>CC</sub> ≤5.25V | | PARAMETER | TEST CONDITIONS | | LIMITS | | UNIT | |-----------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------|-------------------|----------------------|----------------------|----------------------| | | PARAMETER | TEST CONDITIONS | Min | Typ¹ | Max | UNII | | Propagat | ion Delays | | | | | | | TAA<br>TCE<br>TCD<br>TWD | Address Access Time Chip Enable Access Time Chip Enable Output Disable Time Write Enable to Output Disable Time | $R_1 = 270\Omega$ $R_2 = 600\Omega$ $C_L = 30pF$ | | 30<br>15<br>15<br>30 | 40<br>25<br>25<br>40 | ns<br>ns<br>ns | | | -up Times | | | | | | | TWSA<br>TWSD<br>TWSC | Address to Write Enable Data In to Write Enable CE to Write Enable | | 0<br>25<br>0 | -5<br>15<br>-5 | | ns<br>ns<br>ns | | Write Hol | d Times | | | | | | | TWHA<br>TWHD<br>TWHC<br>TWP | Address to Write Enable Data In to Write Enable CE to Write Enable Write Enable Write Enable Pulse Width | | 0<br>0<br>0<br>25 | -5<br>-5<br>-5<br>15 | | ns<br>ns<br>ns<br>ns | X = Don't care. # SSI/MSI COMPONENTS # 54/74 ELECTRICAL CHARACTERISTICS (See Notes—Page 46) | | | | | | INPU | T VOL | TAGE | | | | | Οl | JTPUT | VOL | ΓAGE | | INPU | T CU | RRENT | |-----------------|----------|-----|------------------|-------------|------|-----------------|--------------|------|------------------|------|-----|---------------------------------------|----------|-----|-------------------------------------|------|------|-----------------|-------| | PARAME | TER | | VIL (V)<br>W LEV | | | VIH (V<br>3H LE | - | CLAM | VIC (VIP VOL | | | VOL ( | - | | VOH (<br>GH LE | | | IL (m. | • | | TEST<br>CONDITI | | V | cc = N | <b>f</b> in | ۷ | CC = M | <b>V</b> lin | | CC = M<br>= -12r | | ار | CC = <br>V IN =<br>DL = 16<br>OL = 0 | *<br>SmA | | CC =<br>V <sub>IN</sub> =<br>H = -4 | * | | C = N<br>N = 0. | | | | | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | | 54/7400 | 54<br>74 | | | 0.8 | .2 | | | | | -1.5 | | 0.22 | 0.4 | 2.4 | 3.3 | | | | -1.6 | | | | | | | | | | | | | | | | Io | H = -8 | 00μΑ | | | | | 54/7427 | 54<br>74 | | | 0.8 | 2 | | | | | -1.5 | | 0.22 | 0.4 | 2.4 | 3.3 | | | | -1.6 | | | 54 | | | | _ | | | | | | | | | | | | Pr | eset o | r D | | 54/7474 | 74 | | | 0.8 | 2 | | | İ | | -1.5 | | 0.22 | 0.4 | 2.4 | 3.5 | | | | -1.6 | | | | | | | | | | | | | | | | | | | Clea | ar or c | 1 | | j | | | | | | | | | | | | | | | | | | | -3.2 | | | - 4 | | | | | | | ] | | | | | | 10 | H = -8 | 00μΑ | | | | | 54/74147 | 54<br>74 | : | | 0.8 | 2 | | | | | -1.5 | | | 0.4 | 2.4 | | | | | -1.6 | | | | | IN | PUT C | URRE | NT | | | | | F | OWER | SUPI | PLY C | URRE | NT | | | | |----------|----------|------|-------------------------|-------------|------|-------------------------------------|-----|---------------------------|--------|------------|-----------|------------------|------|-------|--------|--------|----------------------|---------------------------|------------------| | PARAMI | TER | | I <sub>IH</sub> ( $\mu$ | - | i | I <sub>I</sub> (mA)<br>NPUT CURRENT | | IOS (MA)<br>SHORT CIRCUIT | | | ICCL (mA) | | | 1 | CCH (I | • | I OH (μA)<br>REVERSE | | | | TES | | | CC = 1<br>IN = 2 | | | CC = N<br>IN = 5. | | ٧٥ | CC = N | lax | | CC = N<br>IN = 5 | | | CC = ! | | V | CC = <br>VIN =<br>OH = { | Min<br>*<br>5.5V | | | | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | | 54/7400 | 54<br>74 | | | 40 | | | 1 | -20<br>-18 | | -55<br>-55 | | 12 | 33 | | 4 | 8 | | | | | 54/7427 | 54<br>74 | | | 40 | | | . 1 | -20<br>-18 | | -55<br>-55 | | 16 | 26 | | 10 | 16 | | | | | 54/7474 | 54<br>74 | Pres | D<br>ent or | 40<br>clock | | | | -20<br>-18 | | -57<br>-57 | - | 17 | 30 | | | | | | | | | | C | <br> ear | 80<br>120 | | | 1 | | | | | | | | | ļ<br>L | | | | | 54/74157 | 54<br>74 | | | 40 | | | 1 | -20<br>-18 | | -55<br>-55 | | 30 | 48 | | | | | | | signetics 47 # SSI/MSI COMPONENTS #### 54/74 ELECTRICAL CHARACTERISTICS NOTES - 1. All inputs grounded, outputs open. - 2. With all outputs open, ICC is measured with Q and Q outputs high in turn. At the time of measurement, the clock input is grounded. - 3. ICC is measured with outputs open, A = B grounded, and all other inputs at 4.5V. - ICC is measured with all outputs open. Both RO inputs grounded following momentary connection to 4.5V and all other inputs grounded. - 5. ICC is measured with all outputs and serial inputs open; A, B, C, and D inputs grounded, mode control at 4.5V and a momentary 3V then ground, applied to both clock inputs. - 6. ICC is measured with clear input grounded and all other inputs and outputs open. - ICC is measured with outputs open and 4.5V applied to all data and clear inputs; the measurement is made after a momentary ground, then 4.5V is applied to the clock. - 8. ICC is measured with inputs at 4.5V, outputs open. - ICCL is measured with clock input high, then again with the clock input low with all other inputs low and all outputs open. - 10. ICCH is measured with the load input high, then again with the load input low, with all other inputs high and all outputs open. - 11. ICC is measured with outputs open, serial inputs grounded, the clock input at 2.4V, and a momentary ground, then 4.5V applied to clear. - 12. ICC is measured under the following worst case conditions. 4.5V are applied to all data inputs and both enable inputs, all address inputs are grounded, and all outputs are open. - 13. With outputs open, ICC is measured for the following conditions: - Condition A—S0 through S3, M and A inputs are at 4.5V, all other inputs grounded. - Condition B-S0 through S3 and M are at 4.5V, all other inputs are grounded. - 14. ICC is measured with outputs open, clear and load inputs grounded, and all other inputs at 4.5V. - 15. With all outputs open, inputs A through D grounded, and 4.5V applied to S0, S1, clear and the serial inputs, ICC is tested with a momentary ground then 4.5V applied to the clock. - 16. With all outputs open, shift/load grounded and 4.5V applied to the J, K and data inputs, ICC is measured by applying a momentary ground, followed by 4.5V to clear, then applying a momentary ground followed by a 4.5V to clock. - 17. ICC is measured with the outputs open and all data and select inputs at 4.5V under the following conditions: - Condition A-Strobe grounded - Condition B-Strobe grounded - 18. ICC is measured with the outputs open and all data and select inputs at 4.5V under the following conditions: - Condition A-All inputs grounded. - Condition B-Output control at 4.5V, all inputs grounded. - 19. ICC is measured with all outputs open and all possible inputs grounded while achieving the stated output conditions. - 20. ICC is measured with one input of each gate at 4.5V, the other inputs grounded, and the outputs open. - 21. ICC is measured with outputs open under the following conditions: - Condition A-All inputs grounded. - Condition B-All B inputs low, other at 4.5V - Condition C-All inputs at 4.5V - 22. ICC is measured with the outputs open, the serial input and mode control at 4.5V, and the data inputs grounded under the following conditions: - Condition A—Output control at 4.5V and a momentary 3V then ground applied to clock input. - Condition B-Output control and clock input grounded. - 23. ICCL - 24. 54/74S ICC limits are per gate. # SPEED/PACKAGE AVAILABILITY 54 F,W 74 A,F 54H F,W 54LS F,W 74H A,F 74LS A,F 54S F,W 74S A,F # PIN CONFIGURATION # SWITCHING CHARACTERISTICS V<sub>CC</sub> = 5V, T<sub>A</sub> = 25°C | | | 54/74 | | | 54/74H | l | | 54/74L | s | | 54/749 | S | | |-----------------------------------------|-------------------------|-------|-----|------------------------|--------|-----|-----------------------------------------------|--------|-----|--------|----------------------|----------|----| | TEST CONDITIONS | CL = 15pF<br>RL = 400 Ω | | | CL = 25pF<br>RL = 280Ω | | | C <sub>L</sub> = 15pF<br>R <sub>L</sub> = 2kΩ | | | | UNIT | | | | PARAMETER | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | | | Propagation delay time tPLH Low-to-high | | 11 | 22 | | 5.9 | 10 | | 9 | 15 | 2<br>C | 3<br>L = 50pl<br>4.5 | 4.5<br>F | ns | | t <sub>PHL</sub> High-to-low | | 7 | 15 | | 6.2 | 10 | | 10 | 15 | 2<br>C | 3<br>L = 50pf<br>5 | 5 | ns | Load circuit and typical waveforms are shown at the front of section. # TRIPLESENDUT NORTGATE 541421 # SPEED/PACKAGE AVAILABILITY 54 F,W 54LS F,W 74 A,F 74LS A,F # SWITCHING CHARACTERISTICS V<sub>CC</sub> = 5V, T<sub>A</sub> = 25°C | TEST CONDITIONS | C | 54/74<br>L = 15p<br>L = 400 | | • | S<br>pF<br>Ω | UNIT | | |-----------------------------------------|-----|-----------------------------|-----|-----|--------------|------|----| | PARAMETER | Min | Тур | Max | Min | Тур | Max | | | Propagation delay time tPLH Low-to-high | | 7 | 11 | | 5 | 15 | ns | | tPHL High-to-low | | 10 | 15 | | 9 | 15 | ns | Load circuit and typical waveforms are shown at the front of section. # **PIN CONFIGURATION** # SPEED/PACKAGE AVAILABILITY | 54 | F,W | 74 | A,F | |------------|-----|------|-----| | 54H | F,W | 74H | A,F | | 54LS | F,W | 74LS | A,F | | <b>54S</b> | F,W | 74S | A,F | # **DESCRIPTION** These monolithic dual edge-triggered Dtype flip-flops feature individual D, clock, preset, and clear inputs. Preset and clear inputs are active-low and operate independently of the clock input. When preset and clear are inactive (high), information at the D input is transferred to the Q output on the positive-going edge of the clock pulse. Clock triggering occurs at a voltage level of the clock pulse and is not directly related to the transition time of the positive-going pulse. When the clock input is at either the high or low level, the D-input signal has no effect at the output. # **PIN CONFIGURATION** # FUNCTIONAL BLOCK DIAGRAM (Each Flip-Flop) # TRUTH TABLE (Each Flip-Flop) | | II | NPUTS | | оит | PUTS | |--------|-------|-------|---|----------------|--------------| | Preset | Clear | Clock | D | Q | Q | | L | Н | Х | х | Н | L | | Н | L | Х | Х | L | Н | | L | Ŀ | Х | Х | H* | H* | | н | Н | Ť | Н | H | L | | Н | Н | † | L | L | H | | Н | Н | L | X | Q <sub>0</sub> | _<br>G₀<br>H | H = high level (steady state) L = low level (steady state) \*This condition is nonstable. It will not remain after clear and preset return to their inactive (high) state. # **SWITCHING CHARACTERISTICS** V<sub>CC</sub> = 5V, T<sub>A</sub> = 25°C | | | | | | 54/74 | | | 54/741 | + | | 54/74L | .s | | 54/7 | <b>4</b> S | | |---------------------------------------------|--------------------------------------------------|------------------|--------------|----------|------------------|----------------|--------------|------------------|----------------|----------|-----------------|----------------|----------|-------------|------------------------|------| | TEST | CONDITIONS | | | | L = 15<br>L = 40 | • | | L = 25<br>L = 28 | | | L = 15<br>L = 2 | - | | CL= | • | | | PA | ARAMETER | FROM<br>INPUT | TO<br>OUTPUT | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | UNIT | | <sup>f</sup> Clock<br><sup>t</sup> w(Clock) | Clock frequency<br>Width of clock<br>input pulse | | | 15 | 25 | | 35 | 43 | | 25<br>25 | 33 | | 75 | 90 | | MHz | | | Clock high | | : | 30<br>37 | | | 15<br>13.5 | | | | | | 6<br>7.3 | | | ns | | tw(Clear) | Width of clear input pulse | | | 30 | | | 25 | | | 25 | | | 7 | | | ns | | <sup>t</sup> w(Preset | ) Width of preset input pulse | | | 30 | | | 25 | | | 25 | | | 7 | | | ns | | <sup>t</sup> Setup | Input setup time<br>High level<br>Low level | | | 20† | 15 | | 10 †<br>15 † | | | 25<br>20 | | | 31 | | i | ns | | <sup>t</sup> Hold<br>Propagati | Input hold time<br>on delay time | | | 51 | 2 | | 51 | | | 5 | | | 21 | | | ns | | tPLH | Low-to-high | Clear,<br>Preset | | | | 25 | | | 20 | | 8 | 25 | | 5 | 6 | ns | | | | | | | | | | | | | | | | 8 | CLK=1<br>13.5<br>CLK=0 | | | tPHL<br>tPHL<br>tPHL | High-to-low<br>Low-to-high<br>High-to-low | Clock | | 10<br>10 | 14<br>20 | 40<br>25<br>40 | 4 | 8.5<br>13 | 30<br>15<br>20 | | 16<br>8<br>16 | 40<br>25<br>40 | | 5<br>7<br>7 | 8<br>9<br>9 | ns | Load circuit and typical waveforms are shown at the front of section. # SPEED/PACKAGE AVAILABILITY 54 F,W 74 B,F 54LS F,W 54S F,W 74LS B,F 74S B,F # **BLOCK DIAGRAM** # PIN CONFIGURATION # TRUTH TABLE | | INPUTS | | | OUTPUT Y | |--------|--------|---|---|----------| | STROBE | SELECT | A | В | | | Н | Х | Х | Х | L | | L | L | L | Χ | L | | L | L | Н | Х | Н | | L | Н | Х | L | L | | L | н | Х | Н | Н | H = high level, L = low level, X = irrelevant # SWITCHING CHARACTERISTICS V<sub>CC</sub> = 5V, T<sub>A</sub> = 25°C | | | | 54/74 C L = 15pF R L = 400 Ω | | | 54/74LS<br>C <sub>L</sub> = 15pF<br>R <sub>L</sub> = 2kΩ | | | | 54/749 | <b>;</b> | | |------------------------------|---------------|--------------|--------------------------------|-----|-----|----------------------------------------------------------|-----|-----|-----|--------|----------|------| | TEST COND | ITIONS | | | | | | | | | | | | | PARAMETER | FROM<br>INPUT | TO<br>OUTPUT | Min | Тур | Max | Min | Тур | Max | Min | Тур | Max | UNIT | | Propagation delay time | | | | | | | | | | | | | | t <sub>PLH</sub> Low-to-high | Data | Any | | 9 | 14 | | 9 | 14 | | 5 | 7.5 | ns | | t PHL High-to-low | | | | 9 | 14 | | 9 | 14 | | 4.5 | 6.5 | | | tpl H Low-to-high | Enable | Any | | 13 | 20 | | | | | | | | | t <sub>PHL</sub> High-to-low | | | | 14 | 21 | | | | | | | | | tpl H Low-to-high | Select | Any | | 15 | 23 | | 15 | 23 | | 9.5 | 15 | | | t <sub>PHL</sub> High-to-low | | | | 18 | 27 | | 8 | 27 | | 9.5 | 15 | | | tpi⊣ Low-to-high | Strobe | Any | | | | | 13 | 20 | | 8.5 | 12.5 | | | t <sub>PHL</sub> High-to-low | | | | | | | 14 | 21 | | 7.5 | 12 | | Load circuit and typical waveforms are shown at the front of section. # **APPLICATIONS MEMOS** Signetics acknowledges the cooperation of Scientific Micro Systems, Inc. in the the preparation of this chapter of the manual. # **DESCRIPTION** Typical interfaces to the 8X300 employ the 8T32/33 or 8T35/36 bidirectional I/O ports. These devices provide a single connnection between the 8X300 and the user status control and data lines. Each interface is denoted as an Interface Vector and is field programmed to a specific address. # ADDRESSING DATA ON THE INTERFACE VECTOR The Interface Vector is comprised of general purpose 8-bit I/O registers called Interface Vector (IV) Bytes. The IV registers serve to select IV bytes. In order for an instruction to access (read or write) an IV byte, the address of that byte must be output to the IVL or IVR registers. Thus, two instructions are required to operate on an Interface Vector byte: # XMIT ADDRESS, IVL MACHINE INSTRUCTION Each of the two IV registers (IVL and IVR) may be set to select an IV byte, therefore two I/O ports may be active at one time—one on the Right Bank (IVR) and one on the Left Bank (IVL). Data may be input and output in one instruction following the selection of IV bytes: XMIT ADDRESS1,IVL XMIT ADDRESS2,IVR ADD LB, RB Once the IV byte is selected (addressed) it will remain selected until another address is output to the same IV register. Since an IV register (IVL, IVR) can be used only as a destination field of an instruction, any instruction sending data to IVL or IVR can be used to select an IV byte. From the user's standpoint, however, all IV byte outputs can be read by an external device regardless of whether they are selected or not. The address range of IVL and IVR is 0-255<sub>10</sub>. # ELECTRICAL CHARACTERISTICS OF THE INTERFACE VECTOR Each IV byte consists of 8 storage latches which hold data transferred between the Interpreter and the User System, 8 tri-state input/output lines and 2 input/output control lines, called Byte Input Control (BIC) and Byte Output Control (BOC) as shown in Figure 1. The control lines functions are summarized in Table 1. Table 2 contains a summary of the electrical characteristics of the IV byte. Working storage consisting of RAM may be connected to either or both left and right I/O banks. An example of such an arrangement is shown in Figure 4. Paging may be added to the memory to extend the addressability. | CONTRO | OL LINES | FUNCTION | |-------------------|-------------------|------------------------------------------------------------------------------------| | BOC<br>(low true) | BIC<br>(low true) | | | . H | · H | 8 I/O lines in high impedance state—disable | | L | Н | 8 I/O lines in output mode—8 bit storage latch data available in the output lines. | | X | 1 | 8 I/O lines in input mode—data can be read by Interpreter | Table 1 FUNCTIONS OF THE BIC AND BOC LINES | PARAMETER | | TEST CONDITIONS | | UNIT | | | |------------------------------------|---------------------------------------|------------------------|-----|------|------|-------| | | | | Min | Тур | Max | Oitii | | v <sub>IH</sub> | High level input voltage | | 2 | | 5.5 | V | | ٧ïL | Low level input voltage | | -1 | | 0.8 | V | | Vic | Input clamp voltage | I <sub>IL</sub> = -5mA | | | -1 | V | | V <sub>IC</sub><br>V <sub>OH</sub> | High level output voltage | I <sub>OH</sub> = 1mA | 2.4 | | | ٧ | | VOL | Low level output voltage | IOL = -16mA | | | 0.5 | V | | ЧН | High level input current <sup>1</sup> | V <sub>IH</sub> = 5.5V | - | 1 | 100 | uA | | l <sub>IL</sub> | Low level input current <sup>1</sup> | $V_{11} = 0.50V$ | | 1 | -800 | uΑ | | los | Output short circuit current | V <sub>OL</sub> = 0V | -20 | | -200 | mA | | C <sub>IN</sub> | Data input capacitance | V IL = 0V | | 1 | 12 | рF | NOTE Table 2 IV BYTE TERMINAL ELECTRICAL CHARACTERISTICS <sup>1.</sup> Input current is always present regardless of the state of BIC and BOC. # FLOPPY DISC INTERFACE # **DESCRIPTION** The 8X300 controls a floppy disc drive with a minimal amount of additional circuitry. In this example, byte assembly and disassembly are performed by the program ("bit banging") to reduce interface circuitry. Addition of such circuitry would increase hardware costs and decrease significantly peak processor utilization. Data is transferred to and from the floppy disc via I/O driver routines. These I/O driver routines provide a standard software interface to a floppy disc and require 180 words of program storage. When not transferring data to and from the disc, the 8X300 is available to service other devices such as keyboards, displays or data communication lines. Figure 1 illustrates the system. #### **DESIGN APPROACH** Data bytes are assembled or disassembled by sensing a clock, inputing data bit or generating clock, and outputing a data bit. Preamble patterns, track address, and other disc format requirements are implemented by programming. Disc drive head must be stepped to the desired track before data transfer is initiated. Disc drive status is monitored to determine any error conditions. A four step procedure is followed to implement the design: - Analyze interface. Analyze floppy disc relative to: Number of control/data lines, timing and data rates associated with each control/data line, and electrical characteristics of each control/data line. Determine any supplemental circuits needed for electrical compatibility (see Table 1). - Perform functional analysis. The functions to be programmed and any which require supplemental logic are determined. In this case, supplemental logic is utilized to process the 250ns pulses associated with DATA, CLOCK and WR DATA. Optional logic for byte assembly and disassembly also are shown. The programmed functions are: - a. Byte assembly/disassembly - Generate preamble, track address, timing and sector synchronization - c. Sense clock and disc status - d. Step head to desired track - Define the program to process input and to generate output (see Figure 2). - 4. Determine 8X300 configuration (see Table 2). | SIGNAL NAME | DATA<br>RATE-1 | SIGNAL<br>DURATION | ELECTRICAL CHARACTERISTICS | # IV<br>BITS | INTERFACE<br>REQUIRED | FUNCTION | |--------------|----------------|--------------------|----------------------------|--------------|-----------------------|----------------------------| | STEP IN | 20ms | .01-10ms | TTL with pullup | 1 | | Step head 1 track in | | STEP OUT | 20ms | .01-10ms | TTL with pullup | 1 | | Step head 1 track out | | LOAD HEAD | Level | 1 | TTL with pullup | 1 | | Load head | | UNSAFE RESET | Level | | TTL with pullup | 1 | | Clears unsafe condition | | WR ENB | Level | | TTL with pullup | 1 | | Enables write operation | | WR DATA | 2μs | .25µs | 50mA current | 1 | 2R,T | Data/clock to disc | | SECTOR | 5ms | 1ms | OC output | 1 | R | Sector indicated | | INDEX | 160ms | 1ms | OC output | 1 . | R | Begin of track indicator | | TRK00 | Level | | OC output | 1 | R | Head on track 00 | | UNSAFE | Levei | | OC output | 1 | R | Unsafe condition indicator | | WR PROTECT | Level | | OC output | 1 | R | Write protected disc | | DATA | 4μs | .25µs | OC output | 1 | R,2FF | Data from disc | | CLOCK | 4μs | .25µs | OC output | 1 | R,FF | Clock from disc | R = Resistor Table 1 INTERFACE ANALYSIS Through put: (a) Peak data rate: 250K bits/sec. (b) Peak processor utilization: 97.5%, including byte assembly/disassembly. (c) Peak processor utilization: 12.2%, with external byte assembly/disassembly. Figure 2 | ROM/PROM FOR PROGRAM STORAGE | WORKING STORAGE FOR DATA BUFFERS | IV BYTES FOR INPUT/OUTPUT INTERFACE | |------------------------------|----------------------------------|------------------------------------------------------------------| | Input Driver | 256 Bytes | 6 IV bits for output<br>7 IV bits for input<br>Total: 2 IV bytes | Table 2 8X300 CONFIGURATION T = Transistor FF = Flip-Flop # TELETYPE MULTIPLEXER # **DESCRIPTION** The 8X300 is easily interfaced to a teletype or similar asynchronous device. Processor utilization is less than .1%, even when used in a character assembly mode. A single 8X300 can be used as a multiplexer for many low speed asynchronous devices. For example, the 8X300 can be used as a front end multiplexer for a large computer system. Figure 3 illustrates the system. #### **DESIGN APPROACH** A basic teletype I/O driver routine receives, transmits and echoes a character. Character assembly/disassembly is implemented by sensing start bit, sampling data bit and generating output bit timing. A four-step procedure is followed to implement the design: - Analyze interface. Analyze teletype relative to: Number of control/data lines, timing and data rates associated with each control/data line, electrical characteristics of each control/data line, and determine any supplemental circuits needed for electrical compatibility (see Table 3). - Perform functional analysis. The functions to be programmed and any which require supplemental logic are determined. In this case, no supplemental logic is required. The programmed functions are: - a. Character assembly/disassembly - b. Sense start bit - Generate bit timing and simultaneous character echo - 3. Define the program to process input and to generate output (see Figure 4). - 4. Determine 8X300 configuration (see Table 4). | SIG-<br>NAL<br>NAME | DATA<br>RATE <sup>1</sup> | SIGNAL<br>DURA-<br>TION | CHARACTER- | l i | INTER-<br>FACE RE-<br>QUIRED | FUNCTION | |---------------------|---------------------------|-------------------------|------------------------------|-----|------------------------------|-----------------------------------------------| | TTY OUT | 9.09ms<br>9.09ms | 9.09ms<br>9.09ms | 20mA current<br>20mA current | 1 | 3R,T<br>4R,T,C | Data to TTY printer<br>Data from TTY keyboard | R = Resistor Table 3 INTERFACE ANALYSIS T = Transistor C = Capacitor | ROM/PROM FOR<br>PROGRAM STORAGE | WORKING STORAGE FOR DATA BUFFERS | IV BYTES FOR INPUT/OUTPUT INTERFACE | | |---------------------------------|----------------------------------|-------------------------------------------------------------------------------------------------------------|--| | Teletype driver | 2 bytes per Teletype | 1 IV bit, for output, per Teletype<br>1 IV bit for input, per Teletype<br>Total: 2 IV bytes per 8 Teletypes | | Table 4 8X300 CONFIGURATION # DATA CONCENTRATOR #### **DESCRIPTION** The 8X300 multiplexes multiple low speed terminals. It buffers the data in its working storage for efficient transmission over common carrier or other data link facilities. Single inquiry/response terminals are interfaced to a single half-duplex synchronous line via a Universal Asynchronous Receive/Transmit (UART) interface. This eliminates cabling to each terminal. The 8X300 transfers inquiry and response messages between terminals and a remote computer data base via a data communications line. Various communication data rates are accommodated by simple program modification. Figure 5 illustrates the system. #### **DESIGN APPROACH** The 8X300 polls each terminal requesting an input character or signaling an output character. Each character is transferred over a high speed (9600 baud) synchronous line whose data rate determines the scan time of the 8X300 multiplexing program. The multiplexer program formats polling messages, maintains status, generates and checks the Longitudinal Redundancy Character, performs character recognition, and buffers characters. Additional driver programs are required to communicate with the full duplex data communications line to-/from a remote computer data base. A four step procedure is followed to implement the design: - Analyze interface. Analyze UART relative to: Number of control/data lines, timing and data rates associated with each control/data line, electrical characteristics of each control/data line and determine any supplemental circuits needed for electrical compatibility (see Table 5) - Perform functional analysis. The functions to be programmed and any which require supplemental logic are determined. In this case, no supplemental logic is required. The programmed functions are: - a. Maintain current line status - b. Generate synchronization pattern, poll command, sense character synch - Resynchronize with clock and monitor modem and UART status - 3. Define the program to process input and to generate output (see Figure 6). - Determine the 8X300 configuration (see Table 6). | SIGNAL NAME | DATA RATE | SIGNAL<br>DURATION | ELECTRICAL<br>CHARACTERISTICS | # IV<br>BITS | INTERFACE<br>REQUIRED | FUNCTION | |-------------|-----------|--------------------|-------------------------------|--------------|-----------------------|----------------------------| | TR1-8 | 1.041ms | 1.2-10µs | TTL | 8 | - | Output data | | THRL | 1.041ms | 1.2-10µs | TTL | 1 | - | Load output data | | MR | level | | TTL | 1 | - | Master reset | | DRR | level | | TTL | 1 | - | Data received reset | | SFD | level | | TTL | 1 | - | Status flag disable | | RRD | level | | TTL | 1 | - | Receiver Register disable | | RR1-8 | 1.041ms | 1.041ms | TTL | 8 | - | Received data | | PE | level | Ì | TTL | 1 | - | Parity error | | FE | level | | TTL | 1 | - | Frame error | | OE | level | | TTL | 1 | - 1 | Over run error | | DR | level | | TTL | 1 | - | Data received flag | | THRE | level | | TTL | 1 | - 1 | XMTR holding reg. empty | | TRE | level | | TTL | 1 | - | Transmitter register empty | | CLOCK | 1.041ms | 1.041ms | TTL | 1 | - | Data rate clock | Table 5 INTERFACE ANALYSIS | ROM/PROM FOR<br>PROGRAM STORAGE | WORKING STORAGE FOR DATA BUFFERS | IV BYTES FOR INPUT/OUTPUT INTERFACE | |---------------------------------|----------------------------------|-------------------------------------| | Multiplexer driver 156 words | 32 bytes | 13 IV bits for output per UART | | Character processing 100 words | · | 15 IV bits for input per UART | | Total 256 words | | Total: 4 IV bytes per UART | Table 6 8X300 CONFIGURATION # REMOTE ALPHANUMERIC TERMINAL CONTROLLER # **DESCRIPTION** The 8X300 interfaces to simple keyboard/ display devices with a minimal amount of interface circuitry. The display may be buffered or the 8X300 system can supply buffering and refresh. In this example, the personality of the keyboard/display terminal is programmed into program storage to implement various editing and format functions. A single 8X300 can be used to control a local cluster of alphanumeric terminals since the processor utilization for a single terminal is very low. Messages to and from each terminal are transferred to a remote computer (interface not shown). Figure 7 illustrates the system. # **DESIGN APPROACH** A terminal driver routing inputs and buffers messages in working storage. The driver also performs character and line deletion functions and implements a flicker free display of the message. A special set of control characters are used to terminate a message and forward the message. A four step procedure is followed to implement the design: - Analyze interface. Analyze keyboard and display relative to: Number of control and data lines, timing and data rates associated with each control/data line, electrical characteristics of each control/data line and determine supplemental circuits needed for electrical compatibility. Here the interfaces are completely compatible electrically (see Table 7). - Perform function analysis. The functions to be programmed and any which require supplemental logic are determined. In this case, no supplemental logic is required. The programmed functions are: - a. Store a message input from keyboard - b. Update display to produce flicker free out- - c. Implement character delete, line delete editing functions - d. Recognize end of message control character. - Define the program to process input and to generate output (see Figure 8). - 4. Determine the 8X300 configuration (see Table 8) | SIGNAL NAME | DATA RATE¹ | SIGNAL<br>DURATION | ELECTRICAL<br>CHARACTERISTICS | # IV<br>BITS | INTERFACE<br>REQUIRED | FUNCTION | |-----------------------------------------------|-------------------------------------------|-------------------------------------------------------------|---------------------------------|------------------|-----------------------|--------------------------------------------------------------------------------------------------------------| | STROBE<br>KBDATA<br>ASCII<br>ROW<br>DIGIT SEL | level<br>level<br>level<br>level<br>level | 4msec (min)<br>4msec (min)<br>16.6msec (max)<br>200ns (min) | TTL<br>TTL<br>TTL<br>TTL<br>TTL | 1<br>7<br>6<br>3 | -<br>-<br>-<br>- | Input Character ready Keyboard input character Select character Select row of digit Select digit for display | Table 7 INTERFACE ANALYSIS | ROM/PROM<br>FOR PROGRAM STORAGE | WORKING STORAGE<br>FOR DATA BUFFERS | IV BYTES FOR INPUT/OUTPUT INTERFACE | |---------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------| | Keyboard/driver 140 words | 32 bytes per display | 41 IV bits for output per display<br>8 IV bits for input per display<br>Total: 7 IV bytes per display | Table 8 8X300 CONFIGURATION # **COMPUTER I/O BUS EMULATOR** # **DESCRIPTION** The 8X300 system emulates a Microdata 1600 I/O bus. Microdata I/O bus compatible peripherals may then be easily connected to and controlled by a standard 8X300 system. A Microdata I/O bus driver program provides a standard software interface to peripheral devices and requires only 27 words of program storage. Figure 9 illustrates the system. #### **DESIGN APPROACH** Data bytes are transferred to and from the I/O bus in accordance with Microdata I/O bus specifications. Control signal timing and data transfer sequences are generated by programming. A four step procedure is followed to implement the design: - Analyze interface. Analyze Microdata I/O bus relative to: Number of control/data lines, timing and data rates associated with each control/data line, electrical characteristics of each control/data line and determine supplemental circuits needed for electrical compatibility (see Table 9). - Perform functional analysis. The functions to be programmed and any which require supplemental logic are determined. In this case, no supplemental logic is required. The programmed functions are: - a. Transfer bytes in and out - b. Generate control signal timing and data transfer sequences - 3. Define the program to process input and to generate output (see Figure 10). - 4. Determine the 8X300 configuration (see Table 10). | SIGNAL NAME | DATA RATE¹ | SIGNAL<br>DURATION | ELECTRICAL<br>CHARACTERISTICS | # IV<br>BITS | INTERFACE<br>REQUIRED | FUNCTION | |-------------|------------|---------------------|-------------------------------|--------------|-----------------------|----------------------------| | OD00-07 | level | | open collector | 8 | 8D | Data/address from computer | | ID00-07 | level | | TTL | 8 | 8R | Data to computer | | COXX | 4μs | 1.25 <i>µ</i> s | open collector | 1 | D | Control output timing | | DIXX | 4µs | 1.25 <i>u</i> s | open collector | 1 | D | Data input timing | | DOXX | 4μs | .75-1.25 <i>µ</i> s | open collector | 1 | D | Data output timing | D = Open collector driver Table 9 INTERFACE ANALYSIS | ROM/PROM FOR<br>PROGRAM STORAGE | WORKING STORAGE<br>FOR DATA BUFFERS | IV BYES FOR INPUT/OUTPUT INTERFACE | | |---------------------------------|-------------------------------------|----------------------------------------------------------------------------------|--| | I/O Driver 27 words | Depends on peripheral | 11 IV bits for output<br>8 IV bits for input<br>Total: 3 IV bytes per peripheral | | Table 10 8X300 CONFIGURATION R = Resistors # INTERFACE TO EXTERNAL READ/WRITE MEMORY # **DESCRIPTION** The 8X300 controls the storage, retrieval and processing of large blocks of data. Data is stored in a large capacity (up to 64K bytes) read/write RAM external to the 8X300 system. The memory is assembled from widely available n-channel (n-MOS) static or dynamic RAM circuits. Minimal interface circuitry is required to connect the 8X300 Interface Vector bytes to the address, data and control lines of the external memory. Figure 11 illustrates the system. # **DESIGN APPROACH** Data bytes are read from or written into memory through a single IV type. Two additional IV bytes are used as a 16-bit address register to the external memory. 16 bits provide an address range of 65K bytes. The read/write control signals to the memory require two IV bits. Instruction sequences are used for memory read and memory write operations to implement 1 to 2 microsecond memory access times. A four step procedure is followed to implement the design: - Analyze interface. Analyze n-MOS RAM circuits relative to: Number of control/data lines, timing and data rates associated with each control/data line, electrical characteristics of each control/data line and determine any supplemental circuits needed for electrical compatibility (see Table 11). - Perform functional analysis. The functions to be programmed and any which require supplemental logic are determined. The programmed functions are: - Store memory address in IV bytes ADRHI, ADRLO. - b. Set appropriate read/write control bits - c. Wait for memory operation complete - Define the program to process input and to generate output. OFT instruction accuracy to read management. OFT instruction accuracy to read management. - a. GET instruction sequence to read memory location addressed by contents of IV bytes ADRHI, ADRLO (see Figure 12). - PUT instruction sequence to write data into the memory location addressed by the contents of IV bytes ADRHI, ADRLO (see Figure 13) - Determine the 8X300 configuration (see Table 12). | SIGNAL NAME | DATA RATE-1 | SIGNAL<br>DURATION | ELECTRICAL<br>CHARACTERISTICS | # IV<br>BITS | INTERFACE<br>REQUIRED | FUNCTION | |-------------|-------------|--------------------|-------------------------------|--------------|-----------------------|-----------------------------------------------------------------------| | ADRHI | Level | | TTL | 8 | *<br>none | Most significant<br>byte. Memory<br>address, and chip<br>select input | | ADRLO | Level | | TTL | 8 | *<br>none | Least significant<br>byte memory<br>address | | DATA | Level | | TTL | 8 | *<br>none | Memory data | | R/W | 500ns (min) | >250ns | TTL | 1 | *<br>none | Memory read/write control | | R/W DELAY | 500ns (min) | >500ns | TTL | 1 | *<br>none | Data enable delay<br>during memory<br>write | Table 11 INTERFACE ANALYSIS | ROM/PROM FOR<br>PROGRAM STORAGE | WORKING STORAGE | IV BYTES FOR INPUT/OUTPUT INTERFACE 18 IV bits for output 8 IV bits for input and output Total: 4 IV bytes | | | |---------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------|--|--| | GET sequence | None | | | | Table 12 8X300 CONFIGURATION # **256 WAY BRANCH** # **DESCRIPTION** Many data communication applications require conversion of one code structure to another. The 8X300's Execute instruction provides a fast and efficient method of performing this conversion. A single Execute instruction can provide up to a 255 way branch based on a byte stored in a register. This assumes one of the 256 values does not occur during operation of the Execute table. This is easily prevented by testing for one of the values before entering the table, thereby completing the 256 way branch. The example in Figure 14 details how the test for R1 equal to zero is performed first (NZT). If zero, the appropriate conversion value is loaded into R3 (XMIT). If not zero, then the Execute table determines which of the other 255 combinations is in R1 and loads the appropriate conversion value in R3. The 256 way branch requires 260 words of program storage and 1.0 microseconds maximum to execute. The Execute table and the Execute instruction must all be located with one 256 byte page where the first instruction address contains zeros in the 8 least significant bits. The other four instructions may be placed anywhere within the 8X300's address space. # FAST IV SELECT #### **DESCRIPTION** The fast IV select is implemented by adding bits to the instruction word, in increments of 4 or 8 bits. This technique allows IV bytes and working storage to be selected within the same instruction where it is used. This can save important processor time by saving one instruction cycle for each select instruction. It eliminates the need for the IV select instruction. It trades fewer instruction cycle times for hardware. It also trades 16bit select instructions for 4 to 8-bit select fields, thus saving 8 to 12 bits of program storage for every select instruction saved. To some extent, this reduces the cost impact of a larger instruction word. The technique can be used on both IV and buffer storage (including working storage). When used on IV, a decoder is used following an address hold latch to select one IV per address combination. Buffer storage does not require the decoder, instead it utilizes the address directly. The fact select IV can be used on the same system with normal select IV since all the fast select IV contains the same address. The Master Enable (ME) input of each fast select IV is enabled by the AND of Bank Select (LB, RB) and the single line decode. Due to memory access delays, the clock used to latch the fast select address is delayed with a couple of inverter delays to assure address validity. On large systems, there are extra delays which may require the address to be programmed in the instruction prior to its usage. Then a double set of address hold latches are used so the address will appear sufficiently early. #### **DESCRIPTION** The 8X300 has a repertoire of 8 instruction classes which allow the user to test input status lines, set or reset output control lines, and perform high speed input/output data transfers. All instructions are 16 bits in length. Each instruction is fetched, decoded and executed completely in 250ns. Data is represented as an 8-bit byte; bit positions are numbered from left to right, with the least significant bit in position 7. Within the Interpreter, all operations are performed on 8-bit bytes. The Interpreter performs 8-bit, unsigned 2's complement complement arithmetic. #### **INSTRUCTION FORMATS** The general 8X300 instruction format is: | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |---|------------|---|----|------------|---|---|---|---|---|---|----|----|----|----|----|----| | - | Op<br>Code | | le | Operand(s) | | | | | | | | | | | | | Table 1 contains a summary of the 8X300 instruction set and description of the operand fields. All instructions are specified by a 3-bit Operation (Op) Code field. The operand may consist of the following fields: Source (S) field, Destination (D) field, Rotate/Length (R/L) field, Immediate (I) Operand field, and (Program Storage) Address (A) field. The instructions are divided into 5 format types based on the Op Code and the form of the Operand(s) as shown in Figure 1. | OPERATION | FORMAT | RESULT | NOTES | | | |-----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | MOVE | | Content of data field addressed by S, R/L replaces data in field specified by D, R/L. | | | | | ADD | | Sum of AUX and data specified by S, R/L replaces data in field specified by D, R/L. | If S and D both are register addresses then R L specifies a right rotate of R/L | | | | AND | | Logical AND of AUX and data specified by S, R/L replaces data in field specified by D, R/L. | places applied to the register specified by \$ | | | | XOR | | Logical exclusive OR of AUX and data specified by S, R/L replaces data in field specified by D, R/L. | | | | | XMIT | | The literal value I replaces the data in the field specified by S, L. | If S is IV or WS address<br>then I limited to range | | | | NZT | | If the data in the field specified by S, L equals zero, perform the next instruction in sequence. If the data specified by S,L is not equal to zero, execute the instruction at address determined by using the literal I as an offset to the Program Counter. | 00-37. Otherwise I limited to range 000-377. If S specifies an IV or WS address then I is limited to the range 00-37. I is limited to the range 000-377 otherwise. | | | | XEC | | Perform the instruction at address determined by applying the sum of the literal I and the data specified by S,L as an offset to the Program Counter. If that instruction does not transfer control, the program sequence will continue from the XEC instruction location. | The offset operation is performed by reducing the value of PC to the nearest multiple of 32 (if 1:00-377) and adding the offset. | | | | JMP | | The literal value I replaces contents of the Program Counter. | I limited to the range 00000-07777. | | | Table 1 8X300 INSTRUCTION SUMMARY #### **INSTRUCTION FIELDS** # Op Code Field (3-Bit Field) The Op Code field is used to specify 1 of 8 8X300 instructions. # S,D Fields (5-Bit Fields) The S and D fields specify the source and destination of data for the operation defined by the Op Code field. The Auxiliary Register is the implied source for the instructions ADD, AND and XOR which require two source fields. That is, instructions of the form: #### ADD X, Y imply a third operand, say Z, located in the Auxiliary Register so that the operation which takes place is actually X + Z, with the result stored in Y. This powerful capability means that 3 operands are referenced in 250ns. The S and/or D fields may specify a register, or a 1 to 8-bit I/O field, or a 1 to 8-bit Working Storage field. S and D field value assignments in octal are shown in Table 2. # R/L Field (3-Bit Field) The R/L field performs one of two functions, specifying either a field length (L) or a right rotation (R). The function it specifies for a given instruction depends upon the contents of the S and D fields: - A. When both S and D specify registers, the R/L field is used to specify a right rotation of the data specified by the S field. (Rotation occurs on the bus and not in the source register.) The register source data is right rotated within one instruction cycle time independent of the number (0 to 7) of bit positions specified in the R/L field. - B. When either or both the S and D fields specify an IV or Working Storage data field, the R/L field is used to specify the length of the data field (within the byte) accessed, as shown in Figure 2. # I Field (5/8-Bit Field) The I field is used to load a literal value (a binary value contained in the instruction into a register, IV or Working Storage data field or to modify the low order bits of the Program Counter. The length of the I field is based on the S field in XEC, NZT, and XMIT instructions. - A. When S specifies a register, the literal I is an 8-bit field (Type III format). - B. When S specifies an IV or Working Storage data field, the literal I is a 5-bit field (Type IV format). # A Field (13-Bit Field) The A field is a 13-bit Program Storage address field. This allows the 8X300 to directly address 8192 instructions. #### **REGISTER OPERATIONS** When a register is specified as the source, and an IV or Working Storage field as the destination, the least significant bits of the operations (MOVE, ADD, AND, XOR) are merged with the original destination data. The least significant bits of the result are stored in the IV or Working Storage data field specified by the D and R/L fields in the instruction. | OP CODE<br>OCTAL<br>VALUE | ins | STRUCTION | RESULT | |---------------------------|------|----------------|-----------------------------------------------------| | 0 | MOVE | S,R/L,D | (S) → D | | 1 | ADD | S,R/L,D | (S) plus (AUX) → D | | 2 | AND | S,R/L,D | (S) ∧ (AUX) → D | | 3 | XOR | S,R/L,D | (S) ⊕ (AUX) → D | | 4 | XEC | I,R/L,S or I,S | Execute instruction at current PC offset by I + (S) | | 5 | NZT | I,R/L,S or I,S | Jump to current PC offset by I if (S) ≠ 0 | | 6 | XMIT | I,R/L,D or I,D | Transmit literal I → D | | 7 | JMP | Α | Jump to program location A | | | | | | Table 2 S AND D FIELD VALUE ASSIGNMENTS IN OCTAL When an IV or Working Storage field of 1 to 8 bits is specified as the source, and a register as the destination, the 8-bit result of the operations (MOVE, ADD, AND, XOR) is stored in the register. The operations ADD, AND, XOR actually use the IV or Working Storage data field (1 to 8 bits) with leading zeros to obtain 8-bit source data for use with the 8-bit AUX data during the operation. Because IVL and IVR are write-only pseudo registers, they can be specified as destination fields only (see Table 3). Operations involving IVL and IVR as sources are not possible. For example, it is not possible to increment IVR or IVL in a single instruction, and the contents of IVL or IVR cannot be transferred to a working register, IV byte, or Working Storage location. The OVF (Overflow) Register can only be used as a source field; it is set or reset only by the ADD instruction. #### **INSTRUCTION DESCRIPTIONS** The following instruction descriptions employ MCCAP (the 8X300 Cross Assembly Program) programming notation. This notation varies somewhat from the instruction descriptions provided in Tables 1 and 3. Thus, for example, explicit L field definition, as shown in Table 1 and Table 3, is not required by MCCAP instructions; MCCAP creates appropriate variable field addresses from the information contained in the Data Declaration statements provided by the programmer at the beginning of his program. The 8X300 instruction set is described below with examples shown in Figures 3 through 10. $0_8$ -17 $_8$ is used to specify 1 of 7 working registers (R1-R6, R11), Auxiliary Register, Overflow Register, IVL and IVR write-only registers. | OCTAL<br>VALUE | | OCTAL<br>VALUE | | |----------------|------------------------------------|----------------|-----------------------------------------------| | 00 | Auxiliary Register (AUX) | 10 | OVF-Overflow register-Used as | | 01 | R1 | | an S (source) field only. | | 02 | R2 | 11 | R11 | | 03 | R3 | 12 | Unassigned | | 04 | R4 | 13 | Unassigned | | 05 | R5 | 14 | Unassigned | | 06 | R6 | 15 | Unassigned | | 07 | IVL Register-IV Byte address | 16 | Unassigned | | | write-only register-Specified only | 17 | IVR Register-Working Storage | | | in D field in all instructions | | address write-only register- | | | | | Specified only in D field in all instructions | #### a. Register Specification 20- $_{8}$ -27 $_{8}$ is used to specify the least significant bit of a variable length field within the IV/WS Byte previously selected by the IVL register. The length of the field is determined by R/L. #### OCTAL VALUE | 20 | Field within previously selected IV/WS Byte; position of LSB = 0 | |----|------------------------------------------------------------------| | 21 | Field within previously selected IV/WS Byte; position of LSB = 1 | | 22 | Field within previously selected IV/WS Byte; position of LSB = 2 | | 23 | Field within previously selected IV/WS Byte; position of LSB = 3 | | 24 | Field within previously selected IV/WS Byte; position of LSB = 4 | | 25 | Field within previously selected IV/WS Byte; position of LSB = 5 | | 26 | Field within previously selected IV/WS Byte; position of LSB = 6 | | 27 | Field within previously selected IV/WS Byte; position of LSB = 7 | #### b. Left Bank Field Specification $30_8$ - $37_8$ is used to specify the least significant bit of a variable length field within the IV/WS Byte previously selected by the IVR Register. The length of the field is determined by R/L. #### OCTAL VALUE | 30 | Field within previously selected IV/WS Byte; position of LSB = 0 | |----|------------------------------------------------------------------| | 31 | Field within previously selected IV/WS Byte; position of LSB = 1 | | 32 | Field within previously selected IV/WS Byte; position of LSB = 2 | | 33 | Field within previously selected IV/WS Byte; position of LSB = 3 | | 34 | Field within previously selected IV/WS Byte; position of LSB = 4 | | 35 | Field within previously selected IV/WS Byte; position of LSB = 5 | | 36 | Field within previously selected IV/WS Byte; position of LSB = 6 | | 37 | Field within previously selected IV/WS Byte; position of LSB = 7 | #### c. Right Bank Field Specification Table 3 S AND D FIELD SPECIFICATIONS # MOVE S,D or MOVE S(R),D Format: Type I, Type II | 0 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----|---|---|---|-----|---|---|---|----|----|----|-----|--------|-----|----| | 0 0 | 0 | | S | our | e | | | R/ | L | | Des | stinat | ion | | # Operation: (S)→(D) Description Move data. The contents of S are transferred to D; the contents of S are unaffected. If both S and D are registers, R/L specifies a right rotate of the source data before the move. Otherwise, R/L is implicit and specifies the length of the source and/or destination IV/WS field. If the MOVE is between an IV byte and a Working Storage byte, an 8-bit field is always moved. #### Example Store the least significant 3 bits of register 5 (R5) in bits 4, 5 and 6 of the IV byte previously addressed by the IVL register. # ADD S,D or ADD S(R),D Format: Type I, Type II | _ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |---|---|---|---|---|---|-----|----|---|---|----|----|----|-----|--------|-----|--------| | I | 0 | 0 | 1 | | S | our | :е | | | R/ | L | | Des | stinat | ion | $\neg$ | #### Operation (S) plus (AUX) D; set OVF if carry from most significant bit occurs. #### **Description** Unsigned 2's complement addition. The contents of S are added to the contents of the Auxiliary Register (which is the implied source). The result is stored in D; OVF is updated. If both S and D are registers, R/L specifies a right rotate of the source (S) data before the operation. Otherwise, R/L is implicit and specifies the length of the source and/or destination IV/WS fields. S and AUX are unaffected unless specified as the destination. #### **Example** Add the contents of R1 (rotated 4 places) to AUX and store the result in R3. #### AND S,D OR AND S(R),D Format: Type I, Type II Operation: (S) ∧ (AUX)→D **Description** Logical AND. The AND of the source field and the Auxiliary Register is stored into the destination. If both S and D are registers, R/L specifies a right rotate of the source (S) data before the AND operation. Otherwise R/L is implicit and specifies the length of the source and/or destination IV/WS fields. S and AUX are unaffected unless specified as a destination. #### **Example** Store the AND of the selected right bank byte and AUX in R4. The right bank data field is called WSBCD and is 4 bits long and located in bits 2, 3, 4 and 5. #### XOR S,D OR XOR S(R),D Format: Type I, Type II Operation: (S) ⊕ (AUX)→D Description Exclusive OR. The exclusive OR of the source field and the Auxiliary Register is stored in the destination. If both S and D are registers, R/L specifies a right rotate of the source (S) data before the XOR operation. Otherwise R/L is implicit and specifies the length of the source and/or destination IV/WS fields. S and AUX are unaffected unless specified as a destination. #### Example Replace the selected IV byte field with the XOR of the field and AUX. The IV byte field is called STATUS and is 5 bits in length and located in bits 3, 4, 5, 6 and 7 of LB. #### XEC I(S) #### **Format** #### Operation Execute instruction at the address specified by the Address Register with lower 5/8 bits replaced by (S) + I. #### **Description** Execute the instruction at the address determined by replacing the low order bits of the Address Register (AR) with the low order bits of the sum of the literal I and the contents of the source field. If S is a register, the low order 8 bits of AR are replaced; if S is an IV or Working Storage field, the low order 5 bits of AR are replaced, resulting in an execute range of 256 and 32 respectively. The Program Counter is not affected unless the instruction executed is a JMP or NZT (whose branch is taken). #### Example Execute one of n JMPs in a table of JMP instructions determined by the value of the selected IV byte field. The table follows immediately after the XEC instruction and the IV field is called INTERPT and is a 3-bit field located in bits 4, 5 and 6. #### XMIT I,D #### **Format** #### Operation: I→(D) #### **Description** Transmit literal. The literal field I is stored in D. If D is a register, an 8-bit field is transferred; if D is an IV or Working Storage field, up to a 5-bit field is transferred. #### Example Store the bit pattern 110 in the selected Working Storage field. The field name is VALUE and is located in bits 3, 4 and 5. #### NZT S,I #### **Format** #### Operation Non-Zero Transfer. If (S) $\neq$ 0, PC offset by I $\rightarrow$ PC; otherwise PC + 1 $\rightarrow$ PC. #### **Description** If the data specified by the S field is non-zero, replace the low order bits of the Program Counter with I. Otherwise, processing continues with the next instruction in sequence. If S is a register, the low order 8 bits of the PC are replaced; if S is an IV or Working Storage field, the low order 5 bits of the PC are replaced, resulting in an NZT range of 256 and 32 respectively. #### **Example** Jump to Program Address ALPHA if the selected IV byte field is non-zero. The field name is OVERFLO and it is a 1-bit field located in bit 3. #### JMP A #### Format: Type V | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |---|---|---|---|---|---|---|---|---|---|---|-------|----|----|----|----|----| | ı | 1 | 1 | 1 | Γ | | | | | | A | Field | | | | | | # Operation: A → PC Description The literal value A is placed in the Program Counter and processing continues at location A. A has a range of 0-17777<sub>8</sub> in current systems (0-8191). #### Example Jump to location ALPHA (0000101110001) #### **DESCRIPTION** The 8X300 Cross Assembly Program, MCCAP, provides a programming language which allows the user to write programs for the 8X300 in symbolic terms. MCCAP translates the user's symbolic instructions into machine-oriented binary instructions. For example, the jump instruction, JMP, to a user defined position, say ALPHA, in program storage is coded as: #### JMP ALPHA and is translated by MCCAP into the following 16-bit word (see Figure 1). MCCAP allocates the 8X300 program storage and assigns Interface Vector and Working Storage address to symbols as declared in the user's program. The ability to define data of the Interface Vector as symbolic variables is a powerful feature of MCCAP. Interface Vector variables may be operated on directly using the same instructions as those for variables in Working Storage and for the working registers. The Assembler Declaration statements of MCCAP allow the programmer to define symbolic variable names for data elements tailored to his application. Individual bits and sequences of bits in Working Storage and on the Interface Vector may be pamed and operated upon directly by 8X300 instructions. In addition to simplifying the language and bookkeeping of the program, MCCAP provides program segmentation and communication between segments; i.e., the main program and any subprograms. If a sequence of code appears more than once in a program, it can be written as a separate program segment, a subprogram, and called into execution whenever that subprogram's function is required. Program segmentation also permits the construction of a program in logically discrete units. These segments need not be written sequentially or even by the same person. The various program segments provide a function description, or block diagram, of the application. Communication between segments means that control and data can be transferred in both directions. MCCAP automati- | | MCCAP SO | URCE PROG | GRAM | |------------------------------------------|------------------|--------------------|---------------------------------------| | M | ICROCONTROLLER S | YMBOLIC ASSEMI | BLER VER 1.0 | | 1680 • | | | • | | 1681 • | | | | | 1682 01544 | PROC | RDCMMD | | | 1683 • | | | | | 1684 01544 6 07003 | SEL | IVRESP | FDC RESPONSE BYTE | | 1685 01545 6 20101 | XMIT | UR, BCTRL | ESTABLISH USER READ ONLY | | 1686 01546 6 07002 | SEL | IVDATA | HOLDS COMMAND BYTE | | 1687 01547 0 27305 | MOVE | FUNC, R5 | FUNCTION CODE | | 1688 01550 0 24306 | MOVE | DADDR, R6 | DISK ADDRESS | | 1689 01551 0 21202<br>1690 01552 6 07003 | MOVE<br>SEL | BUFF, R2<br>IVRESP | BUFFER FUNCTION CODE | | 1691 01553 6 25100 | XMIT | 0. DONE | SHOW COMMAND IN PROGRESS | | 1692 01554 6 20100 | XMIT | UW. BCTRL | RESTORE USER WRITE | | 1693 01555 6 27101 | XMIT | 1, XFR | SIGNAL USER FDC ACCEPTED BYTE | | 1694 01556 6 07001 | SEL | IVCTRL | USER CONTROL BYTE | | 1695 01557 5 26117 | NZT | CMMD.* | WAIT FOR CMMD TO GO LOW | | 1696 01560 6 07003 | SEL | IVRESP | FDC RESPONSE BYTE | | 1697 01561 6 27100 | XMIT | O. XFR | LOWER XFR SIGNAL | | 1698 01562 6 07001 | SEL | IVCTRL | USER CTRL BYTE | | 1699 01563 4 26123 | XEC | *(CMMD), 2 | WAIT FOR NEXT COMMAND SIGNAL | | 1700 01564 6 07003 | SEL | IVRESP | SECOND COMMAND BYTE AVAILABLE | | 1701 01565 6 20101 | XMIT | UR, BCTRL | SET IVDATA TO USER READ ONLY | | 1702 01566 6 07002 | SEL | IVDATA | 2ND COMMAND BYTE | | 1703 01567 0 27704 | MOVE | TRACK, R4 | TRACK ADDRESS | | 1704 01570 0 27503 | MOVE | SECT, R3 | SECTOR ADDRESS | | 1705 01571 6 07003 | SEL | IVRESP | FDC RESPONSE BYTE | | 1706 01572 6 27101 | XMIT | 1, XFR | SIGNAL USER | | 1707 01573 6 20100 | XMIT | UW, BCTRL | RESTORE USER WRITE | | 1708 01574 6 07001 | SEL | IVCTRL | | | 1709 01575 5 26135 | NZT | CMMD,* | WAIT FOR CMMD TO GO LOW | | 1710 01576 6 07003<br>1711 01577 6 27100 | SEL<br>XMIT | IVRESP | FDC RESPONSE BYTE<br>LOWER XFR SIGNAL | | 1711 01577 6 27100 | XIVII | O, XFR | LOWER AFR SIGNAL | | 1713 01600 7 01652 | RTN | | RETURN | | 1714 | END | RDCMMD | IL IONA | | 1715 | 2.10 | | | | | | | | | | Ei. | gure 2 | | cally generates the code for subprogram entry and exit mechanisms when the appropriate CALL and RTN statements are invoked. #### MCCAP OUTPUT The output from a MCCAP compilation includes an assembler listing and an object module. During pass two of the assembly process, a program listing is produced. The listing displays all information pertaining to the assembled program. This includes the assembled octal instructions, the user's original source code and error messages. The listing may be used as a documentation tool through the inclusion of comments and remarks which describe the function of a particular program segment. The main purpose of the listing, however, is to convey all pertinent information about the assembled program, i.e., the memory addresses and their contents. The object module is also produced during pass two. This is a machine-readable computer output produced on paper tape. The output module contains the specifications necessary for loading the memory of the Microcontroller Simulator (MCSIM), for loading the memory of the SMS ROM Simulator, or for producing ROMs or PROMs. The object module can be produced in MCSIM, ROM Simulator or BNPF format. An example of a MCCAP source program is shown in Figure 2. #### **PROGRAM STRUCTURE** #### **Program Segments** A MCCAP program consists of one or more program segments. Program segments are the logically discrete units, such as the main program and subprograms, which comprise a user's complete program. Program segments consist of sequences of program statements. The first program segment must be the main program. The main program names the overall program and is where execution begins. All other segments are subprograms; each subprogram must be named. Control and data can be passed in both directions between segments. No segment may call itself, or one of its callers, or the main program. Program segments take the form as shown in Figure 3. The Assembler Declaration statements define variables and constants. They must precede the use of the declared variables and constants in the Executable Statements in a program. The Executable Statements are those which result in the generation of one or more executable machine instructions. #### Subprograms Subprograms are program segments which perform a specific function. A major reason for using subprograms is that they reduce programming and debugging labor when a specific function is required to be executed at more than one point in a program. By # PROGRAM SEGMENTS PROGRAM STATEMENT DECLARATION STATEMENT(S) EXECUTABLE STATEMENT(S) SUBPROGRAMS END STATEMENT A. Main Program Form PROCEDURE STATEMENT DECLARATION STATEMENT(S) b. Subprogram Form END STATEMENT **EXECUTABLE STATEMENT(S)** #### Figure 3 creating the required function as a subprogram, the statements associated with that function may be coded once and executed at many different points in a program. Figure 3 illustrates an example. The program structure in Figure 3 causes the code associated with PROC WAIT to be executed three times within PROG MANY-WAIT. This is accomplished even though the statements associated with PROC WAIT are coded only once, rather than three times. #### **Subprogram Calls and Returns** For user-provided procedures, a jump to the associated procedure and a return link are created for each procedure reference. The instructions to accomplish this result in subprogram entry time. The instructions to accomplish subprogram exit result in exit time. The user may utilize the MCCAP procedure mechanism for linking calling programs with called programs or he may create his own instructions to do so. The following describes the linkage mechanism and timing for MCCAP user procedures. Linkage between called and calling programs is achieved through the generation of an indexed "return jump" table, the length of which corresponds to the number of different times in the program that the subprograms are called. This table is generated automatically by MCCAP when procedure CALL and RTN statements are invoked. For each procedure reference, MCCAP creates two statements in the calling program. Thus, the time required for the subprogram entry os 0.5 microseconds. The subprogram return mechanism requires the execution of three instructions or 0.75 microseconds. These times do not include saving and restoring of the working registers. The total time to save all working registers is 3.5 microseconds, the same time to restore all registers. Saving of all working registers is normally not necessary, but worst case calculations for entry and exit time below do include this time. Thus, subprogram exit and entry times are: $0.5\mu s \le Entry Time \le 4.0\mu s$ $0.75\mu s \le Exit Time \le 4.25\mu s$ Details of the code required for procedure CALL and RTN are provided in the Programming Examples section. #### **Macros** A macro is a sequence of instructions that can be inserted in the assembly source text by encoding a single instruction. The macro is defined only once and may then be invoked any number of times in the program. This facility simplifies the coding of programs, reduces the chance of errors, and makes programs easier to change. A macro definition consists of a heading, a body and a terminator. This definition must precede any call on the macro. In MCCAP, the heading consists of the MACRO statement which marks the beginning of the macro and names it. The body of the macro is made up of those MCCAP statements which will be inserted into the source code in place of the macro call. The terminator consists of an ENDM statement which marks the physical end of the macro definition. #### **MCCAP Statements** The MCCAP language consists of thirty statements categorized as follows: Assembler Directive Statements Assembler Declaration Statements Communication Statements Macro Statements Machine Statements The following lists the statements in each category, describes their use, and provides examples. Detailed use of the instructions including rules of syntax and parameter restrictions are described in the MCCAP Reference Manual. #### **Assembler Directive Statements** Assembler Directive statements define program structure and control the assembler outputs. They do not result in the generation of 8X300 executable code. There are twelve Assembler Directive statements: PROG Statement PROC Statement ENTRY Statement END Statement ORG Statement OBJ Statement IF Statement ENDIF Statement LIST Statement NLIST Statement SPAC Statement SPAC Statement #### **PROG Statement** Use Defines the names and marks the beginning of a main program. Example: PROG PROCESS #### **PROC Statement** Use Defines the names and marks the beginning of a subprogram. Example: PROC WAIT #### **ENTRY Statement** Use Defines the name and marks the location of a secondary entry point to a subprogram. Example: ENTRY POINT 2 #### **END Statement** Use Terminates a program segment or a complete program. Examples: END SUB1 END MAIN #### **ORG Statement** Use Sets the program counter to the value specified in the operand field. Example: ORG 200 #### **OBJ Statement** Use To specify the format of the object module. Examples: OBJ R OBJ M OBJ N NOTE "R" indicates the ROM Simulator format. "M" indicates the Microcontroller Simulator format. "N" indicates BNPF format. #### **IF Statement** Use To mark the beginning of a sequence of code, which may or may not be assembled depending on the value of an expression. Examples: IF VAL IF X + Y #### 8X300 CROSS ASSEMBLY PROGRAM (MCCAP) #### **8X300 MICROPROCESSOR APPLICATIONS MEMO** #### **ENDIF Statement** Use To mark the end of sequence of code, which is to be conditionally assembled. In the case of nested IF statements, an ENDIF is paired with the most recent IF. Example: ENDIF #### **LIST Statement** Use To select and control output of a MCCAP assembly. Example: LIST S,O,M,I #### **NLIST Statement** Use To suppress elements of the output from a MCCAP assembly. Example: NLIST O,M,I #### **EJCT Statement** Use To cause the output listing to be advanced to the next page. Example: EJCT #### **SPAC Statement** Use To insert blank lines into the output listing. The number of lines inserted is indicated in the operand field. Example: SPAC 3 #### **Assembler Declaration Statement** Assembler Declaration statements define and describe the data, constants and variables, in a program or subprogram. There are four Assembler Declaration statements: > EQU Statement SET Statement LIV Statement RIV Statement #### **EQU Statement** Use To define a fixed constant. Examples: FIVE EQU 5 ON EQU 1 #### **SET Statement** Use To define and assign a value to a constant, which may later be assigned a new value by another SET statement. Example: OFF SET 0 #### LIV Statement Use To define and assign symbolic names to variables, usually IV bytes, located on the left bank of the Interface Vector. Example: LITE LIV 23,2,1 NOTE The effect of the above example is to define a variable whose name is LITE. It is located in a byte whose address is 23. The right-most bit of LITE is bit 2 and its length is 1 bit. #### **RIV Statement** Use To define and assign symbolic names to variables, usually in Working Storage, located on the right bank of the Interface Vector. Example: DATA RIV 200,6,3 NOTE The effect of the above example is to define a variable whose name is DATA. It is located in a byte whose address is 200. The right-most bit DATA is bit 6 of the byte and its length is 3 bits. #### **Communication Statements** Communication statements are executable statements which provide the mechanism for main program to subprogram linkage. They provide the means by which subprograms are called and returned from. There are two kinds of Communication statements: CALL Statement RTN Statement #### **CALL Statement** Use To transfer control from a calling program to the called subprogram. The CALL statement causes the generation of two 8X300 instructions. Examples: CALL WAIT CALL SINE NOTE The above are valid statements to be coded into the program if WAIT and SINE have been defined in PROC statements. The effect of invoking these statements is to transfer execution control to the procedures WAIT and SINE respectively. #### **RTN Statement** Use To transfer control from a called subprogram to a calling program. Example: RTN #### **Macro Statements** Macro statements provide the mechanism for defining macros and for inserting them into the source code. There are three Macro statements: MACRO Statement ENDM Statement MACRO CALL Statement #### **MACRO Statement** Use To mark the beginning of a macro definition. The MACRO statement forms the heading of the macro definition. Examples: MAC1 MACRO MAC2 MACRO A,B,C NOTE The second example would mark the beginning of a macro called MAC2. The "A,B,C" represents a formal parameter list. These parameters, used in writing the macro body, will be replaced by the actual parameters listed in the MACRO CALL statement. #### **ENDM Statement** Use To mark the end of a macro definition. The ENDM statement forms the terminator of the macro definition. Example: ENDM #### **MACRO CALL Statement** Use To indicate where a macro is to be inserted into the source code and to specify any actual parameters needed by the macro. Example: MAC2 DATA, INPUT, RESULT NOTE There is no single macro call statement. Any macro name which has been defined as such may be coded as if it were a valid MCCAP statement. The macro name is coded in the operation field and the actual parameters are placed in the operand field. #### **Machine Statement** Machine statements are the MCCAP symbolic representations of the 8X300 executable statements. Machine statements have a one to one correspondence to 8X300 instructions. Each Machine statement results in the generation of a single 8X300 instruction. There are eight Machine statements: MOVE Statement ADD Statement AND Statement XOR Statement XOR Statement XMIT Statement XEC Statement NZT Statement JMP Statement #### 8X300 CROSS ASSEMBLY PROGRAM (MCCAP) #### **8X300 MICROPROCESSOR APPLICATIONS MEMO** #### **MOVE Statement** Use To copy the contents of a specified register, WS variable or IV variable into a specified register, WS or IV. Defined in Instruction Descriptions. Examples: MOVE R1(6);R6 MOVE X,Y NOTE The first example illustrates a six place right rotate of R1's data before it is moved to R6. The contents of R1 are not affected. The second example may be a Working Storage or Interface Vector variable move, depending on the way X and Y are defined in Declaration Statements. #### **ADD Statement** Use To add the contents of a specified register, WS variable, or IV variable to the contents of the AUX register and place the result in a specified register, WS variable or IV variable Examples: ADD R1(3),R2 ADD DATA,OUTPUT NOTE The first example illustrates a three place right rotate of R1's data before the addition is carried out. Under certain conditions a rotate may be used to multiply the specified operand by a power of 2 before the addition is done. The contents of R1 are not affected. The second example suggests that the contents of WS variable have been added to the contents of the AUX register and the result placed in an IV variable, making the result immediately available to the user's system. #### **AND Statement** Use To compute the logical AND of the contents of a specified register, WS variable or IV variable and the contents of the AUX register. The logical result is placed in a specified register, WS variable or IV variable. In actual practice, the AND statement is often used to mask out undesired bits of a register. Examples: AND R2,R2 AND R3(1),R5 AND X,Y NOTE The first example illustrates the use of an AND statement in what might be a masking operation. If the AUX register contains 00001111 then this statement sets the 4 high order bits of R2 to 0 no matter what they were originally. The 4 low order bits of R2 would be unaffected. The second example illustrates a one place rotate to the right of R3's data before the AND is carried out. The contents of R3 are not affected. In the third example, X and Y may be parts of the same WS or IV byte, or one may be a WS byte and the other an IV byte. #### **XOR Statement** Use To compute the logical exclusive OR of the contents of a specified register, WS variable or IV variable and the contents of the AUX register, and place the result in a specified register, WS variable or IV variable. In practice, the XOR statement is often used to complement a value and to perform comparisons. Examples: XOR R6,R11 XOR R1(7),R4 XOR X,Y NOTE The first example illustrates the use of an XOR statement in what might be a complementing operation. If the AUX register contains all 1's then the execution of this statement results in the complement of the contents of R6 replacing the contents of R11. The second and third examples are of the same form as the second and third examples of the AND statement #### **XMIT Statement** Use To transmit or load literal values into registers, WS variables or IV variables. Examples: XMIT DATA,IVR XMIT OUTPUT,IVL XMIT -11,AUX XMIT -00001011B,AUX XMIT -13H,AUX NOTE The first example selects a previously declared WS variable by transmitting its address to the IVR register. The second example selects a previously declared IV variable by transmitting its address to the IVL register. The last three examples all result in the generation of the same machine code. They all load the AUX register with –11<sub>10</sub>. In the first case, the programmer has written the number in base 10. In the second case, the programmer has written the number in binary and has indicated this by placing a B after the number. In the third case, the number has been written in octal as indicated by an H after the number. #### **XEC Statement** Üse To select and execute one instruction out of a list of instructions in program memory as determined by the value of a data variable, and then continue the sequential execution of the program beginning with the statement immediately following the XEC unless the selected instruction is a JMP or NZT statement Examples: XEC JTABLE(R1),3 JTABLE JMP GR8ERTHAN JMP LESSTHAN JMP EQUALTO XEC SEND(INPUT),4 "NEXT INSTRUCTION" "NEXT INSTRUCTION" XMIT 00000000B,AUX SEND XMIT 11011011B,AUX XMIT 11111111B,AUX XMIT 10101010B,AUX NOTE In the first example, the execution of the program will transferred to one of three labeled instructions on the basis of whether register R1 contains 0, 1 or 2. In the second example, the XEC statement causes the execution of a statement which transmits a special bit pattern to the AUX register in response to an input signal which is either 0, 1, 2 or 3. After the pattern is transmitted, the execution of the program continues with the next instruction after the XEC. #### **NZT Statement** Use To carry out a conditional branch on the basis of whether or not a register, WS variable, or IV variable is zero or non-zero. Examples: NZT R1,\*+2 NZT SIGN,NEG NOTE In the first example, if the contents of R1 are non-zero, then program execution will continue with the instruction, whose address is the sum of the address of the NZT statement and 2. If the contents of R1 are 0, the program execution continues with the next instruction after the NZT statement. In the second example, if the contents of a WS or IV variable called SIGN is non-zero, then program execution will continue beginning with the instruction whose address is NEG. Otherwise execution continues with the next instruction after the NZT statement. #### **JMP Statement** Use To transfer execution of the program to the statement whose address is the operand of the JMP statement. Examples: JMP START JMP \*-2 NOTE In the first example, execution of the program continues sequentially beginning with the instruction labeled START. In the second example, program execution continues beginning with the instruction whose address is the JMP instruction's address minus 2. #### **SEL Statement** Use Select a variable in Working Storage or on the Interface Vector, so that subsequent machine instructions may reference that variable. Examples: SEL DATA SEL OUTPUT NOTE It is the programmer's responsibility to assure that the proper page has been addressed before calling the SEL statement if the variable may be in Working Storage. The SEL statement causes a single instruction, XMIT, to be assembled into the user program. The operand of the XMIT instruction is the byte address of the named variable (argument of the reference) as it has been allocated in Working Storage or on the Interface Vector. #### PROGRAMMING EXAMPLES This section contains programming examples which demonstrate how the 8X300's instructions can be assembled to perform some simple, commonly required functions. These examples are written as program fragments. They are not complete programs as the Data Declaration and Directive statements have been omitted. Otherwise, they follow standard MCCAP conventions. #### Looping Looping is terminated by incrementing a counter and testing for zero. Register R1 is used as counter register and is loaded with a negative number so that the program counts up to zero. Figure 4 illustrates the process. #### Inclusive-OR (8 Bits) Generate inclusive-OR of the contents of R1 and R2. Store the logical result in R3. Although the 8X300 does not have an OR instruction, it can be quickly implemented by making use of the fact that (A + B) + (A + B) is logically equivalent to $A \oplus B$ . | | INCLUSIVE-OR | | | | | | | |----------|--------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | MOVE | R2,AUX | Load one of the operands into AUX register so that it can be used as the implicit operand of XOR and AND instructions. | | | | | | | XOR | R1,R3 | Take exclusive OR of AUX and R1.<br>Store result in R3. | | | | | | | AND | R1,AUX | Take AND of AUX and R1. Place re-<br>sults in AUX. | | | | | | | XOR | R3,R3 | Take exclusive OR of AUX (A + B) and R3 (A + B). Store result in R3. R3 now contains inclusive OR of R1 and R2. | | | | | | | TIME: 1. | 0 microsecon | ds | | | | | | | | F | igure 5 | | | | | | #### Two's Complement (8-Bits) Generate the two's complement of the contents of R2. Store the result in R3. Assume that R2 does not contain $200_8$ . | | TWO'S | COMPLEMENT | |---------|--------------|------------------------------------| | XMIT | -1,AUX | Load AUX in preparation for XOR. | | XOR | R2,R3 | 1's complement of R2 is now in R3. | | XMIT | 1,AUX | Load AUX in preparation for ADD. | | ADD | R3.R3 | 2's complement of R2 is now in R3. | | TIME: 1 | 0 microsecor | | | | | Figure 6 | #### 8-Bit Subtract Subtract the contents of R2 from the contents of R1 by taking the two's complement of R2 and adding R1. Store the difference in R3 # 8-BIT SUBTRACT XMIT -1.AUX Perform 2's complement, R2. XOR R2,R3 XMIT 1.AUX ADD R3,AUX 2's complement of R2 is now in AUX. ADD R1,R3 R1-R2 is now in R3. TIME: 1.25 microseconds Figure 7 # 16-Bit ADD, Register to Register Add a 16-bit value stored in R1 and R2 to a 16-bit value in R3 and R4. Store the result in R1 and R2. | 16-BIT | ADD, RE | GISTER TO REGISTER | | | | | | |----------|-------------------------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | MOVE | R2,AUX | Move low order byte of first operand to AUX in preparation for ADD. | | | | | | | ADD | R4,R2 | Add the low order bytes of the two operands and store the result in R2. R2 contains the low order byte of the result. | | | | | | | MOVE | R1,AUX | Move high order byte of first operand to AUX. | | | | | | | ADD | OVF,AUX | Add in possible carry from addition of low order bytes. | | | | | | | ADD | R3,R1 | Add the high order bytes plus carry<br>and place result in R1. R1 contains the<br>high order byte of the result. | | | | | | | TIME: 1. | TIME: 1.25 microseconds | | | | | | | | | | Figure 8 | | | | | | #### 16-Bit ADD, Memory to Memory Add a 16-bit value in Working Storage, OPERAND1, to a 16-bit value in Working Storage, OPERAND2, and store result in Working Storage OPERAND1. H1 and L1 represent the high and low order of bytes OPERAND1. H2 and L2 represent the high and low order bytes of OPERAND2. | P,AUX<br>I,IVR<br>I,L1<br>VF,AUX | L1. Move possible carry from addition o low order bytes to AUX register. | |----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ,IVR<br>,L1<br>VF,AUX | Transmit address of low order byte of first operand to IVR. Add low order bytes and store result in L1. Move possible carry from addition o low order bytes to AUX register. | | ,L1<br>VF,AUX | first operand to IVR. Add low order bytes and store result in L1. Move possible carry from addition o low order bytes to AUX register. | | VF,AUX | Move possible carry from addition of low order bytes to AUX register. | | | low order bytes to AUX register. | | 2 IVR | | | • | Add high order byte of second oper-<br>and to possible carry. Store result in<br>AUX. | | 2,AUX | | | 1,IVR | | | 1,H1 | High order byte of sum is in H1. Low order byte of sum is in L1. | | icrosecono | ds | | 1 | ,IVR<br>,H1 | ## Byte Assembly From Bit Serial Input This is typical of problems associated with interfacing to serial communications lines. An 8-bit byte is assembled from bit inputs that arrive sequentially at the Interface Vector. A single bit on the Interface Vector Figure 9 named STROBE is used to define bit timing, and a second bit, named INPBIT, is used as the bit data interface. Figure 10 illustrates the byte assembly. | BYTE | ASSEME | BLY PROGRAM | |---------------|---------------|---------------------------------------------------------------------------------------| | XMIT | 0,R1 | R1 will be used as a character buffer. It has been cleared. | | XMIT | 8.R2 | R2 will be used as a bit counter. | | XMIT | INPADR,IVL | Select IV Byte that contains INPBIT and STROBE. | | NEXT BIT NZT | STROBE,*+2 | Test STROBE for data ready.<br>The MOVE instruction is executed only when STROBE = 1. | | JMP | *-1 | Loop until STROBE = 1. | | MOVE | INPBIT, AUX | | | XOR | R1(1),R1 | Rotate R1 one place right. This puts a zero in the least signifi- | | | | cant bit position. Then take the | | | | exclusive OR of this rotated | | | | version of R1 and of AUX. Place | | | | the result in R1. The least sig- | | | | nificant bit of R1 will now equal | | | | the latest value of INPBIT. | | XMIT | -1.AUX | | | ADD | R2.R2 | Decrement R2. | | | , | If R2 is not yet zero, then more | | | | bits must be collected to com- | | | | plete the byte being assembled. | | MOVE | R1(1),R1 | This instruction will only be | | | | executed when 8 bits have been | | | | collected. After this is done, it is | | | | still necessary to rotate one | | | | more time to get the last INP- | | | | BIT into the high order bit posi- | | | | tion of R1. | | TIME: 1.8 mic | roseconds per | bit (minimum) | | | F: | 44 | | | rıg | ure 11 | #### **Rotate Left** The 8X300 has no instructions which explicitly rotate data to the left. Such an instruction would be redundant because of the circular nature of the rotate operation. For example, a rotate of two places to the left is identical to a rotate of six places to the right. The rotate n places to the left in an 8-bit register, rotate 8-n places to the right. This example illustrates a rotate of the contents of R4 three places to the left. MOVE R4(5),R4 TIME: 250 nanoseconds #### **Three Way Compare** The contents of R1 are compared to the contents of R2. A branch is taken to one of three points in the program depending upon whether R1 = R2, R1 < R2, or R1 > R2. | THRE | E WAY COM | PARE PROGRAM | |-----------|----------------|----------------------------------------------------------------------------| | XMIT | RESULT,IVR | Choose a working Storage byte by transmitting its address to IVR register. | | XMIT | -1,AUX | Load AUX with all 1's, in preparation for complementing contents of R2. | | XOR | R2,RESULT | Store complement of R2 in RE-<br>SULT. | | XMIT | 1,AUX | | | ADD | RESULT, AUX | AUX now contains 2's comple<br>ment of R2. | | ADD | R1,RESULT | RESULT now contains R1-R2 | | NZT | RESULT, NEQUAL | If RESULT ≠ 0, then R1 ≠ R2. | | JMP | EQUAL | | | NEQUAL | NZT SIGN,LESS | Sign Bit = 1 only when R1 < R2 | | GREATER | Continue | : | | | | • | | EQUAL | Continue | • | | | | | | LESS | Continue | • | | TIME: 2.0 | microseconds | | | | Figu | re 13 | #### Execute the one struction whose JTABLE and the con tents of CONTROL. The 8 indicates the length of the table. JTABLE JMP ALPHA1 Table of 8 instructions one of which is execut ed as a result of the XEC JMP ALPHA2 JMP ALPHA8 TIME: 750 nanose Figure 15 **Bit Pattern Detection** In An I/O Field Test input field called Input for specific bit CONTROL.IVL JTABLE (CONTROL),8 XEC # **CONTROL SEQUENCE #1** STATUS FROM USER SYSTEM LARM TO USER SYSTEM IV BYTES Figure 18 | CON | TROL SEQU | JENCE #1 PROGRAM | |---------|--------------------|------------------------------------------------------------------------------------------------| | XMIT | STATUS,IVL | Choose input IV byte by trans-<br>mitting its address to IVL. | | NZT | STATUS,*+2 | Test input bit to determine whether it is still zero. Skip next instruction if it is not zero. | | JMP | *-1 | Jump to previous instruction. | | XMIT | ALARM, IVL | Choose output IV byte. | | XMIT | 1,ALARM | Set output bit by loading ALARM with 1. | | TIME: 1 | .0 microseconds (r | ninimum) | | | | | | | Fig | jure 19 | #### Interrupt Polling Three external interrupt signals are connected to three IV bits. The three bits are scanned by the program to determine the presence of an interrupt request. A branch is taken to one of eight program locations depending upon whether any or all of the interrupt request signals are present. The IV bits associated with the interrupt requests are wired to the low order three bits of the IV byte named Control. Figures 14 and 15 illustrate the interrupt polling. pattern, for example: 1 0 1 1. If pattern is not found, branch to NFOUND, otherwise continue sequential execution. Figures 16 and 17 illustrate the procedure. INTERRUPT POLLING PROGRAM by transmitting its address to IVL register. | BIT P | ATTERN DE | TECTION PROGRAM | |-------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | XMITI | INPUT,IVL | Choose proper IV Byte by trans-<br>mitting its address to IVL regis-<br>ter. | | XMIT | 1011B,AUX | Store desired bit pattern in AUX register for use as implicit operand of XOR instruction. | | XOR | INPUT,AUX | Take exclusive OR of the contents of INPUT and AUX. Store the result in AUX. Now the contents of AUX will be zero if the contents of INPUT are 1011. | | NZT • | AUX,NFOUND | Test AUX for zero. Branch to NFOUND if non-zero. | | | | | | | Continue<br>D microseconds <b>Fi</b> | gure 17 | #### Control Sequence #1 Set an output bit when an input bit goes high (is set) (see Figure 18). #### **Control Sequence #2** Output a specific 5-bit pattern in response to a specified 3-bit input field. #### Subprogram Calls and Returns The mechanism for managing subprogram calls and returns is based on assigning a return link value to each subprogram caller; this return link value is then used, on exit from the subprogram, to index into the return jump table which returns control to the callers of the subprogram. Figure 21 is an example of a subprogram called from four different locations in the main program. As seen from Figure 21, each subprogram (or procedure) caller is assigned a "tag" or index values ranging from 0 to 3, or a total of four index values for the four callers. Before jumping to the subprogram, the index value is placed in a previously agreed upon location, register R11 in this case. Upon exit from the subroutine, the index value stored in R11 is used as an offset to the Program Counter in order to execute the proper JMP instruction. The key to returning to the proper caller is the index jump table. Figure 22 gives a detailed description of the return operation. | RETURN OPERATION | | | | |------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Address n | XEC*+1 | This instruction results in the execution of the instruction located at the current value of the Program counter p plus 1 plus the contents of R11, which is the caller index value. | | | Address n+1 | JMP A | | | | Address n+2 | JMP B | The JMP table follows in consecutive<br>Program Storage locations following<br>SEC. | | | Address n+3 | JMP C | | | | Address n+4 | JMP D | | | | l | F | igure 21 | | #### **ABSTRACT** Many possible applications for microprocessors demand a very quick response to requests for action or information. While MOS microprocessors are relatively cheap. they do not generally possess the necessary speed. Although bipolar microprocessors tend to possess greater speed, they are mostly designed as general purpose devices, which means that they are not ideally suited to the requirements of a fast real-time microcomputer system. The Signetics 8X300 microprocessor has been specifically designed to fulfill this role. This article describes the architecture and instruction set of the 8X300 and, by the use of examples, explains the capabilities and applications of the device. Considerably improved data throughout is obtained from the use of separate data and address buses for the program memory, coupled with extremely flexible I/O control. Data may be input, modified and output all in the same instruction by the use of the two independent, parallel I/O ports. #### INTRODUCTION As semiconductor technology improved, allowing greater die area with economically acceptable yield, the amount of logic that could be put on a marketable integrated circuit increased. It naturally followed that rather than provide more individual elementary gates on a single die, these gates would be interconnected to afford the user of these chips more complicated logic functions in a single package. The attractiveness of the more complex integrated circuits compelled semiconductor manufacturers to strive for increasing circuit density. The prospect of putting an entire, although elementary, computer CPU on a single die focused attention on those fabrication processes which allowed the greatest densities. Therefore, the MOS process was the first to yield an entire microprocessor on a chip. Unfortunately, a price was paid in that the MOS processes did not produce as high a speed of logic element as the usual bipolar processes. Because of density limitations, the bipolar process could only produce the less dense parts of chip microprocessors—the bit slices. Now, however, the improvements in bipolar technology permit the construction of single chip microprocessors with all of the performance advantages of bipolar Schottky technology. Such a circuit has been fabricated and is being produced with significantly high yield to allow commercial availability of quantity parts. The product is the 8X300 microprocessor produced by Signetics. It is the purpose of this paper to present the 8X300 by discussing the architecture and some of the key fabrication and technology features of the microprocessor. This paper concludes with a brief review of some of the present as well as potential applications of this device. The 8X300 was optimized for control applications rather than for extensive numerical processing, so before the main presentation begins, it is advisable to describe the basic requirements in the envisaged application field of the 8X300. Control here applies to a wide variety of areas and is not necessarily limited to those specific areas itemized below. The action of control may be the sole purpose of a standalone microprocessor. In such a task, the microprocessor examines statuses at a particular rate and issues command words or bits to the external circuitry to effect the function of the whole machine as it is described in the control program. Thus, the microprocessor selects specific bits defined by the program, tests the bits, and responds or directs by setting or clearing other bits. Although elementary on the surface, this task may be quite complex involving timing, interval measurement, and various forms of decision making, all at potentially high speed. Control may also take the form of bit or word manipulation and data movement such as in data concentrators, communication controllers, disk and tape controllers and similar devices. Here the data destined for storage, transfer or transmission may require alteration (for example bit packing, preamble addition or error detection/correction); consequently the control also involves calculation or data generation. Consider an industrial metal cutter required to form a complex shape as directed by some external data input. Matrix multiplications may be a very necessary part of this controller's process in order to carry out its function. Thus, we see that controllers in this context may perform a wide variety of bit and arithmetic processing depending upon the type of controller one is discussing. The 8X300 is capable of good performance in all of these control areas. #### **ARCHITECTURE** The architecture of a microprocessor is intimately connected to the technology used to produce the device, for one could define architectures which are realizable only with certain fabrication approaches. Also, a microprocessor's architecture is described by its instruction set and its input/output structure. So, in this section, the 8X300 will be examined both from the inside—technology, block diagram, etc., and from the outside—instruction set, I/O bus, timing, etc. The 8X300 is fabricated using standard Schottky technology. Dual layer metallization is used to minimize die area, reduce capacitance and hence maximize the speed of the processor. A microphotograph of the 8X300 die is shown in Figure 1. The die measures 250 mils square and is the largest bipolar microprocessor in existence. The 8X300 is a complete processor on a single chip and, as will be seen later, results in a minimum circuit count processor system. Linear elements are also provided on the die as shown in Figure 2. One functional entity is the clock generator circuit, which oscillates at a frequency determined by an external crystal or timing capacitor. This circuit generates all timing signals required internally by the 8X300 and externally for bus timing. Secondly, a voltage regulator in combination with an externally connected (user-provided) pass transistor, provides a stable low voltage source for the operation of selected internal segments. This voltage is approximately 3 volts and is used in areas where power conservation rather than speed is a prime concern. (The 3 volts does not imply I2-L utilization.) Maximum current used is 450mA (300mA typical) with 150mA used in the 5 volt (VCC) connection and 300mA used in the 3 volt (VCR). With the regulator, the entire processor operates from a single +5 volt supply over the commercial temperature range (0°C to +70°C). The 8X300 is packaged in a 50-pin dual-in-line ceramic package. The block diagram of the 8X300 processor is shown in Figure 3. It does not show the circuitry just described. First, note that full instruction decoding logic is provided to interpret the instruction classes and perform the indicated operation. This will be discussed in more detail later. This decoding and control logic provides all internal signals required as well as certain control lines for data input and output. These lines are RB, LB, WC, SC and MCLK, External control may be applied to hold the 8X300 in a non-processing or wait state (via halt) or force the processor to instruction address zero (reset). The processor also contains its own program counter (PC) which is automatically incremented upon instruction execution or, in certain cases, is not incremented or is loaded with a new value. Current address control, provided by the address register (AR) may be derived all or in part from the program counter, the instruction data (AR0-AR4) or from the output of the ALU (AR5-AR12). Thus, the present and future instruction to be executed may be altered through instructions or the condition of selected data. #### Input/Output Separate buses are provided for instruction address and instruction data. The current contents of the address register (AR) are presented on a 13-bit bus (A0-A12) to the program memory to fetch the 16-bit instruction word. The 8X300 possesses the capability of directly addressing 8K of program storage. The instruction word enters the processor via the instruction bus (I0-I15) and is stored in the instruction register (R). The processing part of the 8X300 is shown in the upper half of Figure 3. The entire processor is oriented about 8-bit data manipulation; therefore interfaces to external circuitry use an 8-bit bus, designated the Interface Vector (IV) bus (IV0-IV7). For internal storage of data, eight 8-bit read/ write registers are provided, designated R1-R6. R11 and AUX (auxiliary). The auxiliary register contains one of the operands that are used in two operand instructions such as ADD, AND and XOR (Exclusive-OR). A 1bit overflow register (OVF) is provided to store the overflow resulting from add operations. The IV latch is not addressable, but stores original data brought in from the IV bus to be used in the merge operation prior to output. At the heart of the processing is the ALU which performs various arithmetic and logic operations on data. The ALU, when combined with the rotate, mask, shift and merge elements, permits unique data operations. Before proceeding, it is essential that the IV bus concept be explained. From this, we shall go back and discuss the architecture and instruction set in greater detail. The IV bus serves both as an address and data bus and is accompanied by the bus control signals shown in Figure 4. Since the bus carries addresses as well as data, I/O ports must be enabled before data transfers may take place. This is usually accomplished by presenting an address on the bus under program control. The control line SC is used to indicate address content of the bus. When presented with an address, an I/O port either enables itself (becomes active on the bus to accept or present data) if the address presented is its own, or disables itself (becomes inactive) if the address presented does not match its own address. Together with this, processor I/O ports have been designed which allow 1 of 512 interface vector bytes to be selected without decoders. Having two ports, one for the user and the other to the microprocessor, these IV bytes are completely bidirectional. The unique feature of these bytes is the way in which they are addressed. Each IV byte has an 8-bit field programmable address, which is used to enable the microprocessor port, allowing data transfer through it. To effect input and output data transfer, the 8X300 IV outputs are three-state drivers. Additionally, to control external devices, the 8X300 issues the write command, WC, which indicates whether data transfers are read (into the 8X300) or write (out of the 8X300). The bus direction is entirely under control of the 8X300. A unique feature of the 8X300 is the partitioning of the bus into two banks, designated left bank (LB) and right bank (RB). Using the LB and RB signals from the processor as master enables for the I/O ports, the processor may dynamically select ports as Figure 5 illustrates. Two I/O ports may be active during one cycle provided that they are on opposite banks. To do this, I/O ports recognize addresses, data or controls only when enabled by the bank signal to which they are connected. Clearly, the bank partitioning may be considered as a ninth address bit which is alterable by the processor within an instruction. (The 8X300, therefore, has 512 direct I/O port address capability.) A general data operation between two I/O ports could follow the following steps. First, an address is presented to one bank enabling a selected I/O port and disabling all others on that bank. Secondly, another address is presented to the opposite bank effecting a similar selection there. Subsequently, in one instruction cycle, the 8X300 may accept data from one port (on one bank), operate on the data and deposit the result in the other port in the second bank. If the working storage of the registers is not sufficient, additional storage can be added using an I/O port address to add another 256X8 words of RAM . See Figure 6. In order to fully appreciate the speed of the last operation, accepting data from one port and depositing it on the other, it is necessary to explore the details of the instruction cycle. Each 8X300 operation is executed in one instruction cycle which is subdivided into four quarter cycles. The quarter cycles are shown in Figure 5. The instruction address for an operation is presented at the output during the third quarter of the previous instruction cycle. With a memory of sufficient speed, the instruction is returned and accepted by the processor during the first quarter of the cycle in which that instruction is to be executed. The instruction is decoded and used to direct the operation of the processor throughout the cycle. For data processing, the instruction cycle may be viewed as having two halves. During the first half of the cycle, data to be processed is brought into the processor and stored in the IV latch. This is accomplished during the first quarter cycle. The next quarter cycle of this first half is used to bring the data through the ALU, thereby processing the data as required by the instruction. The second half cycle is the output phase during which the data is presented to the IV bus and finally clocked into the appropriate I/O port after bus stabilization. The processor issues MCLK for this purpose. Bank selection during input and output phases is independent, thus data may be input from the right bank and deposited in the left bank or vice-versa, or to and from the same bank if the same IV is used. Bank selection during instruction cycle phases is specified by the instruction. Therefore, the processor may input data from one port, operate on the data and return it to a second port in one instruction cycle time. Remember that instruction fetching is concurrent with data operations. The cycle time is 250ns, making the 8X300 comparable in speed on a microcycle basis, to bipolar slice systems. #### Instruction Set The power of the 8X300 architecture is embodied in the instruction set which controls the ALU, rotate, mask, shift and merge functions to provide for various data operations. Each 16-bit instruction word is subdivided into several fields. The arithmetic and logical instructions follow the format shown in Figure 7. There are eight instruction classes each with variations depending upon the operand specifications. These instructions provide for: Arithmetic and logic operations— Add, And and XOR Data movement— Move and XMIT (transmit) Context alteration— JMP (unconditional jump), NZT (test and branch on non-zero) and XEC (execute the instruction at the address specified without program counter alteration) The operand fields specify the source of the data as one of the internal registers or from the IV bus as left bank or right bank, and the destination of the data as one of the internal registers, left bank or right bank or as left bank or right bank or as left bank or right bank addresses. Additionally, these fields specify the length and position of the data which is to be processed. As an example, see Figure 8. Before going through an example, some features of this instruction should be explained. The first 3 bits are used for the op-code. The 5 source bits contain two separate information groups: The first 2 bits (3 and 4) define the actual source while the next 3 bits (5, 6 and 7) define the least significant bit of the variable length field of the source. These are represented in the diagram by two digits—the first modulo 4 and the second modulo 8. In the example the first digit being 2 selects left bank I/O (right bank = 3). The length of the source data field is specified by the length (bits 8, 9 and 10). The 5 destination bits are represented by two digits—the first modulo 4 and the second modulo 8, as the source. In Figure 8, the destination is an internal register, specified by the first digit being 0 or 1. The actual register is specified by the value of the second digit. These operand fields control the rotate, mask and shift operations as data proceeds through the microprocessor. Rather than go through the details of the complete instruction set, it is more instructive to proceed with an example which will serve to illustrate what may be done with a single instruction. What shall be done in this example is to select two I/O ports, add the contents of the AUX register to a specified segment of the source, merge the result with the original data and deposit the result at the destination. Suppose the source of the data is in IV port, address 5 on the left bank, and the destination address is contained in internal register R3. Further suppose that the AUX register already contains the required value to be added. First, the I/O ports are selected: XMIT 5, IVL (transmit the number 5 to the bus as left bank address). MOVE R3,IVR (move contents of R3 to the bus as a right bank address). The I/O ports have now been enabled using two instructions—500ns total thus far. Now perform ADD LB, RB (add left bank to AUX and deposit in right bank port). The add instruction is shown in Figure 9 where the add operand fields specify the selection of bits throughout rotate and length (mask), and after addition specify the position of merge (shift) in the original data. Although the source, length and destination fields shown here are unique to the MOVE, ADD, AND and XOR instructions, the comments made about these fields also apply to the fields of all the other instructions. Port 5 on the left bank is assumed to contain a<sub>0</sub>-a<sub>7</sub> (Figure 10) and the AUX register is assumed to contain b<sub>0</sub>-b<sub>7</sub>. The source field specifies selecting bits starting with a5 and the length field specifies taking 3 bits to the left. Thus, a<sub>5</sub>, a<sub>4</sub> and a<sub>3</sub> are masked off and right justified. Note that this requires that only contiguous bits be selected for operation. Next, the selected bits are added to the same length of bits (beginning at the right) from the AUX register. Thus, the sum $(a_3, a_4, a_5) + (b_5, b_6, b_7)$ is computed producing a 3-bit sum, S<sub>1</sub>, S<sub>2</sub>, S<sub>3</sub> (and a possible overflow). The destination field of the add instruction then specifies a shift of 1 bit to the left. The shift is made and the 3 bits of the sum are merged with the original source data. Note that the same length specification (3 in the example) applies in source selection, operation and merge functions and is not alterable within one instruction cycle. The destination contains the set of bits shown in Figure 10 after the add operation. Note that the entire set of rotate, mask, add, shift and merge functions took place in one instruction cycle time. The content of each field can be represented by a set of digits. These digits have a direct relation to the specific operations which the data undergoes as it is directed along the 8X300 internal data paths. The op code for add is 1. This is followed by a two digit source field. The source field is in fact two fields (in this particular case) in which the first digit, 2, specifies left bank, while the second digit specifies the rotate operation which is to be performed on the incoming data. The L or length field specifies the number of bits to be accepted for ALU operation. This is the mask function specification and selects a quantity of bits counting from the right. The masking operation takes place after the rotate. The destination field, like the source field, specifies the bank or internal register (right bank in this case), and for the bank destination, also specifies the shift operation. There is one important point to note about the instruction format. Since the fields are easily represented by octal digits and since these digits have a direct relation to the function specified by the field, programming the 8X300 is very easy. Simple mnemonic representation of each of the field specifications, such as ADD for the add function, LB and RB for left bank and right bank and so forth, are easily translated into the octal representation. With this convenience, several hundred lines of program code can be easily generated by hand from the mnemonic representation. Consequently, for small tasks (i.e., less than 500 instructions), an assembler is not essential for efficient programming. A simple conversion is required to generate the actual program memory content. The above example is typical of what can be done with the MOVE, ADD, AND and XOR instructions. However, the control functions perform differently and are worthy of further attention. Specifically, the XEC (execute) instruction is powerful in that it may be register or I/O vectored. The XEC instruction temporarily changes the contents of the address register for the one instruction cycle following the XEC while allowing sub- sequent control to be resumed through the program counter. In this light, XEC may be viewed as calling a single instruction subroutine. The XEC instruction performs the vectoring by concatenating the higher order program counter contents with a number determined, in part, by the contents of one of the internal registers or by the content of an I/O port. Thus, the XEC instruction may be used to sequence through a list where the list counter is an internal register, or it may be used to branch to a specific service routine based on some external status reflected in a selected I/O port. #### **APPLICATIONS** The 8X300 may be exploited in a variety of applications where high speed is required and where the architecture fits the particular requirement. The 8X300 may serve in disk controllers, communications data concentrators and demultiplexers, tape controllers, industrial process controllers, video controllers including entertainment and games, as well as CRT/keyboard terminals, plus a variety of other applications. Principally, the 8X300 affords its greatest service to the user in high speed, relatively sophisticated systems. For example, a low speed MOS processor might be used to control a CRT display and do so economically. However, add the requirement to do data processing for, say, graphics or color display, then the 8X300 becomes increasingly attractive. With 8-bit parallel to serial conversion, the 8X300 may easily process data and directly produce video for alphanumeric display. Generally, one may conclude that the 8X300 serves well where the control processor is required to be in the data path. In controlling computer peripherals, one alternative is to use a single 8X300 processor to control a number of peripherals, as opposed to having one lower speed, less costly processor with separate memory and auxiliary circuits in each peripheral. Economically, the 8X300 is certainly competitive with the bit slice approach. For those who need the performance, the 8X300 affords a complete, single chip processor at a power consumption of only 1.5 watts in contrast to three to four chips for a bit slice equivalent using nearly 5 watts. The typical system configuration for the 8X300 is shown in Figure 4. The 8X300 interfaces to the external world through a convenient number of I/O ports connected to the IV bus. Program storage is provided by a suitable ROM or PROM, but RAM could be used here also depending upon the user's application. However, in the more common control applications, the function of the processor is dedicated and, consequently, there is no need to have alterable program storage. This reasoning is also evident in the 8X300 architecture, as exem- plified in Figure 4. It is clear that there is no direct connection between the program store and the I/O system, as opposed to other microprocessors (the MOS microprocessor in particular) in which instructions are fetched over the same bus on which data and I/O transfers take place. Figure 4 also emphasizes the compact nature of the processor system. Note that the CPU and program store are realized in as few as three packages (e.g. 8X300 with two 82S115 chips). I/O ports are added as required for the particular system configuration Connections to the IV bus are not restricted to the 8T32 type of addressable bidirectional I/O port. Depending upon requirements, a number of devices may be employed. Working storage in the form of RAM may be interfaced directly to the IV bus with an 8T31 or other suitable device used as an address latch. This affords the user temporary storage for data and status information. ROM may also be provided in order to access fixed constants for use by the processor. Examples of such ROM include sine function look-up tables, coordinate translation constants, sensor linearization curves. etc. Some users have objected to the overhead cost in addressing I/O ports prior to an operation. As in the example used in this paper, 500ns (two instructions) were taken up in selecting I/O ports prior to the major data operation. This is acceptable if ports continue to be accessed for a number of times and thereby reduce the addressing overhead. However, for those who see this as a limitation, there is a convenient alternative. The instruction memory may be extended such that an extra field appears as an additional bus which is applied to each I/O port. Port selection (addressing) would then be done upon instruction fetch. No latch addressable I/O ports would be used, but the normal active-on-address-decode scheme would be employed. The address field may be as wide as required to serve all system I/O ports and if necessary memory. Bus left bank and right bank partitioning would still be used, so the address field would contain two addresses, one for each bank. With this scheme, an entire operation such as described earlier, including the selection of I/O ports, could be accomplished in 250ns. # SMS 3000 MICROCONTROLLER SIMULATOR #### **FEATURES** - Totally self-contained with keyboard alphanumeric display, tape reader, TTY output - Dual MicroControllers: one to run instrument, one dedicated to execute user's program - · Real time instruction execution - Control of program execution-Halt Single Step and Run Modes #### **DESCRIPTION** The SMS MicroController Simulator, MCSIM, is a hardware development instrument designed to perform in the user's system exactly as an SMS MicroController. It directly supports the SMS 300 (8X300) as well as MicroController prototyping systems. MCSIM gives the user an Interpreter system with a modifiable Program Storage and a Control Panel which together provide a means of entering, running, monitoring, debugging and changing a program. It features ease of use due to its high level interactive display/keyboard and simple operating system. MCSIM allows the user to run his program on-line - Direct program/register/IV examination and modification through keyboard - Three breakpoint types—Normal, Halt and Insert Instruction - Up to 4K words of high speed read/write program storage - Format compatible with papertape output of MicroController Cross Assembly Program in real time. Through the Control Panel, data stored in internal registers, Working Storage and IV Bytes can be examined and modified. An extensive breakpoint capability permits the user to quickly locate program faults. MCSIM contains two MicroControllers: one for running the instrument and a second totally dedicated to the user's program and prototyping system. This insures that when program development is complete and the design specifications have been met, production systems will perform identically with the prototype. #### Operation MCSIM operation is separated into six modes, each mode consisting of a related set of functions and status displays. Access to a mode is made using one of the six mode selection keys. The currently selected mode is displayed at the extreme left part of the display; the currently selected function is displayed at the extreme right of the display. Selection among the available functions is made using the ▲ and ▼ keys, incrementing and decrementing to the next function. The function selected at last exit is automatically re-selected when the mode is re-entered except for the Breakpoint Mode which selects the Current display. An operation is generally performed using the following four steps: - Select a mode by depressing one of the six Mode Select Keys. - Select a function in that mode by positioning the function roll with one of the two Function Select Keys. - Set up any necessary conditions, such as entering data or readying papertape in the reader. - Activate the function by depressing the Function Acknowledge Key (FCN/ACK). #### **MCSIM Operator Controlled Functions** | Mode | Functions | |------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------| | Manual Examination and alteration of Program Storage | Change Address<br>Store Instruction | | Tape<br>Load or dump all or part of<br>Program Storage | Load<br>Verify -<br>Begin Punch Address<br>End Punch Address<br>Punch<br>Program Identification | | Register Examination and alteration of the Interpreter's internal registers | Change Address<br>Store Octal Data<br>Store Binary Data<br>Complement Overflow | | Interface Vector Examination and alteration of the locations on the IV Bus | Display Current Enabled Bytes<br>Change IV Address<br>Store Binary Data in IV<br>Location | | Breakpoint Set one of three types of breakpoint for program debugging | Display Currently Active Breakpoint Set Normal (Sync) Break- point Set Stop Breakpoint Replace Instruction at Breakpoint | | Execute Control and monitor execution of a program | Halt<br>Run Program<br>Insert Instruction<br>Single Step | #### **Specifications** #### **Control Panel** The Mode Select Keys and the Function Select Keys used in combination give the user 26 possible functions to accomplish complete loading and testing of the program. Each Mode Select Key accesses a set of functions, one of which is chosen using the Function Select Keys. #### **Status Messages** Message displays are used to indicate special conditions which may result from the operation of MCSIM: POWER ON, MCSIM SYSTEM START ???MORE THAN ONE KEY PRESSED UNABLE TO READ TAPE. RESTART UNDEFINED MEMORY ADDRESS (octal address) INVALID INSTRUCTION (instruction code) LOADING INTERRUPTED, RESTART V'FYING INTERRUPTED, RESTART P'CHING INTERRUPTED, RESTART NO VERIFY (octal address, tape data, memory data) CLEAR RESET LINE TO START RUNNING CLEAR HALT LINE TO START RUNNING INVALID 8-BIT OCTAL VALUE (octal value) UNDEFINED IV BYTE ADDRESS (octal address) #### Data Input/Output Panel 36 character self scan display for messages and data readout 12 key numeric keyboard for data entry/modification 120 character/second tape reader for high speed data Tape Reader 120 character/second entry (ASCII format) 20 ma current loop output for listing of program code on Teletype® terminal #### Sync Output TTY Output pulse whenever address breakpoint is reached. #### System Interface MCSIM is connected to the user's prototyping system via a single ribbon cable. This cable terminates in either a MicroController Simulation Module or a dual in-line plug which is pin for pin compatible with the SMS 300 Interpreter. There are two different simulation modules to exactly match presently available MicroController systems. Selection of the proper input/output connector makes a MCSIM appear to be physically and electrically equivalent to a production MicroController or Interpreter. #### **MCCAP** The MicroController Cross Assembly Program (MCCAP) is designed to translate symbolic instructions into object code that can be executed by the SMS 300. This program will run on most computers that have a FORTRAN compiler with a computer word length of at least 16 bits and a random access capability. MCCAP features: - Symbolic address assignment and references - 'Automatic Procedure Handling - Predefined System Procedures - Forward References - Expression Evaluation - Flexibility to handle MicroController component configurations as well as standard systems - Generation of object code for MCSIM, the SMS ROM Simulator, or most PROM programmers. #### **Physical Characteristics** Power 115 V or 230 V ± 10% 50 or 60 Hz ± 10% 350 watts/min. to 750 watts/max. (Power dissipation dependent on the number of Simu- lation Modules configured in the system) Dimensions 7 inches high x 17 inches wide x 19 inches deep Installation May be used on table or may be installed in standard 19 inch rack with mount adapters Weight 65 lbs. net, 75 lbs shipping Ventilation Air Flow 120 CFM Environmental 0° to 55°C, Relative Humidity to 90%. #### **FEATURES** - Real time monitoring instrument for SMS 300 - Totally self contained - Displays IV address and data - Displays current program address - Displays current instruction - Control of RESET and HALT - Single step capability - Real time instruction insertion - Two real time breakpoints - Breakpoint output signal #### **DESCRIPTION** The MicroController Monitor is a self contained debug and maintenance tool for use with all systems containing the SMS 300 (8X300). It provides a control panel allowing an operator to observe, modify, and control program execution in real time permitting system faults to be rapidly traced. The Monitor displays the status of the Address, Instruction, and IV Bus of an Interpreter. Switch registers associated with each display can be used to set breakpoint addresses and enter instructions or data from the Monitor. Program execution can be halted, single stepped, or altered from Monitor controls. The Monitor can be used to insert instructions thereby examining or modifying the contents of internal registers, Working Store, and IV Bytes. In addition, it can be used to start program execution from any address and enable the operator to set program loops allowing a program segment to be checked independently of normal program flow. Breakpoints on IV data and program address allow the operator to halt program execution or insert instructions in real time. As shown in the diagram below, the Monitor connects to the system under test through flat ribbon cables (provided) or an adaptor (optional) which plugs into an Interpreter socket. These connections are buffered and present a negligible load to the system. Other features include a Sync output which provides pulses at a selectable program address or Interface Vector event. #### Operation The MicroController Monitor provides the user with two basic modes of system operation, RUN and STEP. When in the RUN mode, indicator LED's provide a continuous real time display of the three major system busses: Address, Instruction, and Data. Program execution can be halted by one of two actions: depressing the Halt switch or selecting the Halt on Breakpoint function. When halted, it is possible to execute one instruction at a time by pressing the RUN/STEP control to the STEP position. The readout shows the current (static) bus information and the next instruction to be executed. For checkout purposes it is useful to be able to set a program loop or modify the normal program flow in some other manner. This is accomplished by inserting in real time the instruction set up on the Instruction Switch Register whenever the Program Address Breakpoint is reached. To check for system noise or similar malfunction a separate Insert Instruction switch can be set to the Multiple position, forcing one instruction repetitively. When halted, a single instruction can be inserted by toggling the Insert Instruction switch to the Single position. When an instruction is being inserted, system ROM is temporarily disabled. To aid in the diagnosis of a malfunction an advanced breakpoint capability is provided. In addition to the Halt and Insert functions when a Program Address Breakpoint is reached, a breakpoint can be generated on the Interface Vector (IV) Bus data or address. This permits program execution to be halted or a Sync pulse generated in response to external data or the contents of RAM. Three modes of IV Breakpoint generation are selectable: Breakpoint on IV Address: Breakpoint on IV Address and IV Write Data; and Breakpoint on IV Address and IV Read Data. The IV Breakpoint Data switches have a "don't care" position to permit generation of a breakpoint on a data subfield. A Sync pulse output is provided on either the IV Breakpoint or Program Address Breakpoint (switch selectable). #### **Specifications** | Controls | |----------| |----------| **RUN/STEP** Sets operation mode, continuous execution (RUN) or single step (STEP). **INSERT INST** Unconditionally causes execution of the instruction in the Instruction Switch Register. RESET/HALT Three position switch used to uncondition- ally HALT program execution or RESET Interpreter's Program Counter to zero. PGM ADR BKPT Selects appropriate function to be performed when Program Address Breakpoint is reached: HALT - halt on breakpoint, INSERT - replace normal instruction with instruction set into Instruction Switch Register, OFF - program execution un- changed by breakpoint. Selects appropriate function to be performed IV BKPT when IV Breakpoint is reached: HALT halt on breakpoint, OFF - program execu- tion unchanged by breakpoint. Selects IV Breakpoint on one of three **BKPT UPON** conditions: specified IV address, specified write data at IV address, specified read data at the IV address. SYNC SOURCE Selects source for output Sync pulse, IV Breakpoint or Program Address Breakpoint. Sync pulse always available at breakpoint regardless of function selected by breakpoint controls. Switch Registers INSTRUCTION Sixteen two position switches for entering instruction to be inserted (during breakpoint or insert instruction control). **BREAKPOINT** Thirteen two position switches to select **ADDRESS** program breakpoint address. Eight two position switches to select IV byte BREAKPOINT breakpoint address or Working Store **ADDRESS** breakpoint address. Selects display of LB (Left Bank) or RB BANK > (Right Bank) IV address information. Also selects either LB or RB for IV breakpoint. ١V Eight three position switches, 0, 1, X (don't **BREAKPOINT** care), to select IV Data Breakpoint. DATA Displays RUN LED display Indicating when Interpreter not halted. **CURRENT** LED display of the binary value of next INSTRUCTION instruction to be executed. CURRENT LED display of the binary address of the next instruction to be performed. **PROGRAM ADDRESS** IN XEC LED display indicating that the value of the RANGE Interpreter's program counter and address register may not match because the previous instruction command was "Execute". BANK Displays bank addressed by the current instruction (left bank or right bank). **CURRENT IV** Shows the binary address of the currently **ADDRESS** enabled IV Byte or Working Store location. **CURRENT IV** Binary display of the data on the IV bus. DATA Outputs SYNC Pulse output whenever the switch selected breakpoint occurs. PGM EN(L) A low true signal used to enable or disable system program ROM (required only when Interpreter adaptor is used). Cycle Time The Monitor can be adjusted to work with any MicroControllerbased system with a cycle time of 200 ns to 2µs. #### Physical Characteristics 115 VAC ± 10% @ 0.75 amp max. Power 230 VAC ± 10% @ 0.38 amp max. (optional) 47-63 Hz Dimensions 7" H x 17.5" W x 3" D Installation May be used on table or may be installed in standard 19 inch rack (using optional adaptors). Weight 10 lbs. net, 13 lbs. shipping Forced air, 120 CFM. Ventilation Environmental 0° to 50°C, relative humidity to 90% Cables 2 provided, 3 feet long #### SIGNETICS **HEADQUARTERS** 811 East Arques Avenue Sunnyvale, California 94086 Phone: (408) 739-7700 ARIZONA Phoenix Phone: (602) 971-2517 CALIFORNIA Inglewood Phone: (213) 670-1101 Irvine Phone: (714) 833-8980 (213) 924-1668 San Diego Phone: (714) 560-0242 Sunnyvale Phone: (408) 736-7565 COLORADO Parker Phone: (303) 841-3274 FLORIDA Pompano Beach Phone: (305) 782-8225 ILLINOIS Rolling Meadows Phone: (312) 259-8300 INDIANA Noblesville Phone: (317) 773-6770 KANSAS Wichita Phone: (316) 683-6035 MASSACHUSETTS Woburn Phone: (617) 933-8450 MICHIGAN Southfield Phone: (313) 645-1232 MINNESOTA Edina Phone: (612) 835-7455 **NEW JERSEY** Cherry Hill Phone: (609) 665-5071 Piscataway Phone: (201) 981-0123 NEW YORK Wappingers Falls Phone: (914) 297-4074 Woodbury, L.I. Phone: (516) 364-9100 OHIO Worthington Phone: (614) 888-7143 TEXAS Dallas Phone: (214) 661-1296 #### REPRESENTATIVES **ARIZONA** Phoenix Chaparral-Dorton Phone: (602) 263-0414 CALIFORNIA San Diego Mesa Engineering Phone: (714) 278-8021 Sherman Oaks Astralonics Phone: (213) 990-5903 CANADA Calgary. Alberta Philips Electronics Industires Ltd. Phone: (403) 243-7737 Montreal, Quebec Philips Electronics Industries Ltd. Phone: (514) 342-9180 Ottawa, Ontario Philips Electronics Industries Ltd. Phone. (613) 237-3131 Scarborough. Ontario Philips Electronics Industries Ltd. Phone. (416) 292-5161 Vancouver, B.C. Philips Electronics Industries Ltd. Phone: (604) 435-4411 COLORADO Denver Barnhill Five, Inc. Phone: (303) 426-0222 CONNECTICUT Newtown Kanan Associates Phone: (203) 426-8157 FI ORIDA Altamonte Springs Semtronic Associates Phone: (305) 831-8233 Largo Semtronic Associates Phone: (813) 586-1404 ILLINDIS Chicago L-Tec Inc. Phone: (312) 286-1500 KANSAS Lелеха Buckman & Associates Phone: (913) 492-8470 MARYLAND Glen Burni Microcomp. Inc. Phone: (301) 761-4600 MASSACHUSETTS Reading Kanan Associates Phone: (617) 944-8484 MICHIGAN Bloomfield Hills Enco Marketing Phone: (313) 642-0203 MINNESOTA Edina Mel Foster Tech. Assoc Phone: (612) 835-2254 MISSOURI St. Charles Buckman & Associates Phone: (314) 724-6690 NEW JERSEY Haddonfield Thomas Assoc.. Inc. Phone: (609) 854-3011 **NEW MEXICO** Albuquerque The Staley Company. Inc. Phone: (505) 821-4310/11 NEW YORK Ithaca Bob Dean, Inc. Phone: (607) 272-2187 NORTH CAROLINA Cary Montgomery Marketing Phone: (919) 467-6319 OHIO Centerville Norm Case Associates Phone: (513) 433-0966 Fairview Park Norm Case Associates Phone: (216) 333-4120 OREGON Portland Western Technical Sales Phone: (503) 297-1711 Dallas TEYAS Cunningham Company Phone: (214) 233-4303 Houston Cunningham Company Phone: (713) 461-4197 HATH West Bountiful Barnhill Five, Inc. Phone: (801) 292-8991 WASHINGTON Bellevue Western Technical Sales Phone: (206) 641-3900 WISCONSIN Greentield L-Tec. Inc. Phone: (414) 545-8900 #### DISTRIBUTORS ALABAMA Huntsville Hamilton/Avnet Electronics Phone (205) 533-1170 ARIZONA Phoenix Hamilton/Avnet Electronics Phone: (602) 275-7851 Liberty Electronics Phone: (602) 257-1272 CALIFORNIA Costa Mesa Schweber Electronics Phone: (714) 556-3880 Culver City Hamilton Electro Sales Phone: (213) 558-2173 El Segundo Liberty Electronics Phone: (213) 322-8100 Mountain View Elmar Electronics Phone: (415) 961-3611 Hamilton/Avnet Electronics Phone: (415) 961-7000 San Diego Hamilton/Avnet Electronics Phone: (714) 279-2421 Liberty Electronics Phone: (714) 565-9171 Sunnyvale Intermark Electronics Phone: (408) 738-1111 CANADA Downsview, Ontario Cesco Electronics Phone: (416) 661-0220 Mississauga. Ontario Hamilton/Avnet Electronics Phone: (416) 677-7432 Montreal. Quebec Cesco Electronics Phone: (514) 735-5511 Zentronics Ltd. Phone: (514) 735-5361 Ottawa Ontario Hamilton/Avnet Electronics Phone: (613) 226-1700 Zentronics Ltd. Phone: (613) 238-6411 Toronto. Ontario Zentronics Ltd. Phone: (416) 789-5111 Vancouver, B.C. Bowtek Electronics Co Ltd Phone: (604) 736-1141 Ville St. Laurent, Quebec Hamilton/Avnet Electronics Phone: (514) 331-6443 COLORADO Commerce City Elmar Electronics Phone: (303) 287-9611 Nenver uenver Hamilton/Avnet Electronics Phone: (303) 534-1212 Lakewood Acacia Sales, Inc Phone: (303) 232-2882 CONNECTICUT Danbury Schweber Electronics Phone: (203) 792-3500 Georgetown Hamilton/Avnet Electronics Phone: (203) 762-0361 Hamden Arrow Electronics Phone: (203) 248-3801 FLORIDA Ft. Lauderdale Arrow Electronics Phone: (305) 776-7790 Hamilton/Avnet Electronics Phone: (305) 971-2900 Hollywood Schweber Electronics Phone: (305) 922-4506 Orlando Hammond Electronics Phone: (305) 241-6601 GEORGIA Atlanta Schweber Electronics Phone: (404) 449-9170 Norcross Hamilton/Avnet Electronics Phone: (404) 448-0800 ILLINOIS Elk Grove Schweber Electronics Phone: (312) 593-2740 Elmhurst Semiconductor Specialists Phone: (312) 279-1000 Schieler Park Hamilton/Avnet Electronics Phone: (312) 671-6082 INDIANA Indianapolis Semiconductor Specialists Phone: (317) 243-8271 KANSAS Lenexa Hamilton/Avnet Electronics Phone: (913) 888-8900 MARYLAND Baltimore Arrow Electronics Phone: (301) 247-5200 Gaithersburg Pioneer Washington Electronics Phone: (301) 948-0710 Hanover Hamilton/Avnet Electronics Phone: (301) 796-5000 Rockville Schweber Electronics Phone: (301) 881-2970 MASSACHUSETTS Waltham Schweber Electronics Phone: (617) 890-8484 Woburn Arrow Electronics Phone: (617) 933-8130 Hamilton/Avnet Electronics Phone: (617) 933-8000 MICHIGAN Farmington Semiconductor Specialists Phone: (313) 478-2700 Livonia Hamilton/Avnet Electronics Phone: (313) 522-4700 Trey Schweber Electronics Phone: (313) 583-9242 MINNESOTA Eden Prairie Schweber Electronics Phone: (612) 941-5280 Edina Hamilton/Avnet Electronics Phone: (612) 941-3801 Minneapolis Semiconductor Specialists Phone: (612) 854-8841 MISSOURI Hazelwood Hamilton/Avnet Electronics Phone: (314) 731-1144 NEW MEXICO Albuquerque Hamilton/Avnet Electronics Phone: (505) 765-1500 NEW YORK Buffalo Summit Distributors Phone: (716) 884-3450 East Syracuse Hamilton/Avnet Electronics Phone: (315) 437-2642 Farmingdale, L.I. Arrow Electronics Phone: (516) 694-6800 Johnson City Wilshire Electronics Phone: (607) 797-1236 Rochester Hamilton/Avnet Electronics Phone: (716) 442-7820 Schweber Electronics Phone: (716) 461-4000 Westbury, L.I. Hamilton/Avnet Electronics Phone: (516) 333-5800 Schweber Electronics Pmne: (516) 334-7474 NORTHERN NEW JERSEY Cedar Grove Hamilton/Avnet Electronics Phone: (201) 239-0800 Saddlebrook Arrow Electronics Phone: (201) 797-5800 SOUTHERN NEW JERSEY AND PENNSYLVANIA Cherry Hill. N.J. Milgray-Delaware Valley Phone: (609) 424-1300 Moorestown, N.J. Arrow/Angus Electronics Phone: (609) 235-1900 Mt. Laurel. N.J. Hamilton/Avnet Electronics Phone: (609) 234-2133 CENTRAL NEW JERSEY AND PENNSYLVANIA Somerest, N.J. Schweber Electronics Phone: (201) 469-6008 Horsham, PA Schweber Electronics Phone: (215) 441-0600 NORTH CAROLINA Greensboro Hammond Electronics Phone: (919) 275-6391 OHIO Beechwood Schweber Electronics Phone: (216) 464-2970 Cleveland Arrow Electronics Phone: (216) 464-2000 Hamilton/Avnet Electronics Phone: (216) 461-1400 Pioneer Standard Electronics Phone: (216) 587-3600 Dayton Arrow Electronics Phone: (513) 253-9176 Hamilton/Avnet Electronics Phone: (513) 433-0610 Pioneer Standard Electronics Phone: (513) 236-9900 TEXAS Dallas Component Specialists Phone: (214) 357-6511 Hamilton/Aynet Electronics Phone: (214) 661-8204 Schweber Electronics Phone: (214) 661-5010 Houston Component Specialists Phone. (713) 771-7237 Hamilton/Avnet Electronics Phone: (713) 780-1771 Schweber Electronics Pone: (713) 784-3600 HATH Salt Lake City Alta Electronics Phone: (801) 486-7227 Hamilton/Avnet Electronics Phone: (801) 262-8451 WASHINGTON Bellevue Hamilton/Avnet Electronics Phone: (206) 746-8750 Seattle Intermark Electronics Phone: (206) 767-3160 Liberty Electronics Phone: (206) 763-8200 FOR SIGNETICS PRODUCTS WORLDWIDE ARGENTINA Fapesa I.y.C. Buenos-Aires Phone: 652-7438/7478 AUSTRIA Osterreichische Philips Wien Phone: 93 26 11 AUSTRALIA Philips Industries-ELCOMA Lane-Cove N.S.W. Phone: 421261 BELGIUM M.B.L.E. Bruselles Phone: 523 00 00 BRAZIL Ibrape, S.A. Sao Paulo Phone: 287-7144 CANADA Philips Electron Devices Toronto Phone: 425-5161 CHILE Philips Chilena S.A. Phone: 39-400 DENMARK Miniwatt A/S Kobenhavn Phone: (01) 69 16 22 FINLAND Oy Philips Ab Helsinki Phone: 1 72 71 FRANCE R.T.C. Paris Phone: 355-44-99 Valvo Hamburg Phone: (040) 3296-1 HONG KONG Philips Hong Kong, Ltd Kwuntong Phone: 3-427232 Semiconductors, Ltd. (REPRESENTATIVE ONLY) Bombay Phone: 293-667 GERMANY INDIA INDONESIA P.T. Philips-Ralin Electronics Jakarta Phone: 581058 IRAN Berkeh Company, Ltd. Tehran Phone: 831564 ISRAFI Rapac Electronics, Ltd. Tel Aviv Phone: 477115-6-7 ITALY Philips S.p.A. Milano Phone: 2-6994 IAPAN Signetics Japan. Ltd. Tokyo Phone: (03) 230-1521 KOREA Philips Electronics Korea. Ltd. Seoul Phone: 44-4202 MEXICO Electronica S.A. de C.V. Mexico D.F. Phone: 533-1180 NETHERLANDS Philips Nederland B.V Eindhoven Phone: (040) 79 33 33 NEW ZEALAND E.D.A.C. Ltd. Wellington Phone: 873-159 NORWAY Electronica A.S. Oslo Phone: (02) 15 05 90 PHILIPPINES Philips Industrial Dev., Inc. Makata-Rizal Phone: 868951-9 SINGAPORE/MALAYSIA Philips Singapore Pte., Ltd. Toa Payoh Phone: 538811 SOUTH AFRICA E.D.A.C. (PTY). Ltd. Johannesburg Phone: 24-6701-3 SPAIN Copresa S.A Barcelona Phone: 329 63 12 SWEDEN Elcoma A.B. Stockholm Phone: 08/67 97 80 SWITZERLAND Philips A.G. Zurich Phone: 01/44 22 11 TAIWAN Philips Taiwan. Ltd. Taipei Phone: (02) 551-3101-5 THAILAND/LAOS Saeng Thong Radio, Ltd. Bangkok Phone: 527195, 519763 UNITED KINGDOM Mullard. Ltd. London Phone: 01-580 6633 UNITED STATES Signetics international Corp. Sunnyvale. California Phone: (408) 739-7700 VENEZUELA. PANAMA. Aruba, trinidad Instrulab C.A. Caracas Phone: 614138 **NOTES** Signetics Corporation 811 East Arques Avenue Sunnyvale, California 94086 Telephone 408/739-7700