### CPU-Z USER'S MANUAL IEEE S-100 4-6 MHz CPU with onboard RAM/ROM & interrupt control Congratulations on your decision to purchase the CPU Z board, specifically designed for electrical and mechanical compatibility with the IEEE S-100 bus standard. The S-100 bus is the professional level choice for commercial, industrial, and scientific applications. This bus provides for ready expansion and modification as the state of the computing art improves. We believe this board, along with the rest of the S-100 portion of the CompuPro family, is one of the best boards available for that bus. As amateur radio operators have contributed greatly to communication technology, so too the computer hobbyist has provided the microcomputer industry with many significant developments. In recognition of this fact, we also make this board available in "UNKIT" form for those who enjoy the challenge of assembling and testing a fine computer board. As the first company to nationally offer memory kits to computer hobbyists, we again thank you for choosing a CompuPro CPU Z board...welcome to the club! ### TECHNICAL OVERVIEW The CPU Z was specifically designed to give the user one of the best Z80 CPU boards for the S-100 bus. The board features on-board PROM sockets, a power-on-jump circuit to any 256 byte boundary, a Memory Manager to extend the addressing range of the system from 64K-bytes to a maximum of 16M-bytes of system RAM, fully maskable vectored interrupts to speed up system throughput by eliminating polling loops, and wait state generation circuitry for all machine cycles. Other features standard to all CompuPro boards include thorough bypassing of all supply lines to suppress transients, on board regulators, and low power Schottky TTL and MOS technology integrated circuits for reliable, cool operation. All this and sockets for all IC's go into a double sided, solder masked printed circuit board with a complete component legend. ### **USING THE VECTORED INTERRUPTS** The CPU chip recognizes 8 instructions as Restart0 - Restart7. These instructions will cause the program counter to jump to one of eight locations depending on the Restart instruction. | RESTART | Program Counter (HEX) | |---------|-----------------------| | 0 | 0 | | 1, | 8 | | 2 | 10 | | 3 | 18 | | 4 . | 20 | | 5 · | 28 | | 6 | 30 | | 7 | 38 | At these locations, jumps to interrupt driver routines can be placed into either RAM or PROM. Then when one of the VIO - VI7 lines goes low, the specific routine can instantly be started to service the interrupting device. Upon Poweron-Clear or reset (RESET\*) the interrupt mask is cleared, enabling all eight interrupt lines (NOTE: This does NOT mean that the Z80 has interrupts enabled.). Then (with the VI switch (SW3-8) turned ON) when any of the VI inputs goes low the Restart will be generated if the CPU has previously received an Enable Interrupts (FB(H)) command. To disable an individual interrupt line, or a group of lines, the mask must be set up by an output to Port FE(H) with the desired mask in the Accumulator. A "1" in the mask will disable the interrupt line, and a "O" will enable the interrupt line. If it is desired to use this CPU Z board with the Z80 mode 2 interrupts, the on-board vector generation circuitry must be disabled. To do this switch SW3-8 should be turned OFF, and all I's should be output to the interrupt mask port (Port FE(H)). This will prevent the CPU Z from responding to the V.I. lines, but it will still respond to the bus interrupt signal (bus pin 73). | EXAMPLE | (HEX) | (BINARY) | |--------------------|-------|------------| | to disable V15-V17 | 07 | (00000111) | | to disable VI2 | 20 | (00100000) | | to disable all | FF | (11111111) | Note that the VI lines are all open collector and more than one device can be connected to each VI line by using open collector gates. It is recommended to put a "DEAD MEMORY" error recovery routine at location 38 (H), since this location will be jumped to in case the CPU encounters an FF (H) instruction, which corresponds to a restart 7. This is the instruction that will be read from a memory location for which there is no system memory. Location 38 is the most common launching pad for CPU flights into never-never land. ### USING THE NONMASKABLE INTERRUPT The S-100 BUS has a NMI\* pin (bus pin 12) which is implemented on the CPU card for any function that the user desires. NMI\* is primarily used for a catastrophic system failure, such as loss of primary power. This interrupt enables the processor to execute a short program to save current system parameters on either a disc or some other nonvolatile memory before total power is lost (which usually takes milliseconds, lots of time for a computer). The NMI\* causes the CPU to jump to address 66(H), which should be initialized with a routine to control the interrupt. ### **EXTENDED ADDRESSING** Address lines A16-A23 are driven through output port FD(H) and can be changed with a simple output instruction. Upon Power-on-Clear or reset (RESET\*) the extended address lines will be reset to 0, bringing the system up in base page. To access memory in other than base page requires an output to Port FD(H) with the desired page address in the Accumulator in order to set the extended address lines A16-A23. These address lines are pin numbers 16, 17,15, 59, 61, 62, 63, & 64, for address lines A16-A23 respectively. Example shown below: | ACCUMULATOR DATA | TO ACCESS PAGE | | | | | | | | | |------------------|----------------|-------|--|--|--|--|--|--|--| | (HEX) | (BINARY) | (HEX) | | | | | | | | | 40 | 01000000 | 40 | | | | | | | | | 2 | 00000010 | 2 | | | | | | | | | FΩ | 11110000 | F0 | | | | | | | | Of course, to take advantage of this extended addressing feature requires memory boards which respond to extended address lines. If a board does not monitor the S-100 extended address lines, then only the normal 16 address lines will be decoded. ### **WAIT STATES** A single wait state may be added to any processor cycle by closing the corresponding dip switch on SWL. A wait may be added to: | CYCLE | SWITCH | POSITION | |-------------|--------|----------| | PROM | | 1 | | I/O | | 2 | | MEMORY | | 3 | | INSTRUCTION | | 4 | Due to critical timing requirements of the 280 during an instruction fetch (M1), extra time may be required for marginally slow memory chips. When running at 4 MBZ some RAM chips may also need more time for each memory operation than is normally allowed. The on board PROM sockets may be used for many different speed PROM's, and when running at 4 MHZ a wait state may be needed for a fetch there also. The I/O wait should rarely be needed because of the fact that few I/O boards run slow and the 280 automatically generates one I/O wait state, but the provision is made to the user. ### ON-BOARD-MEMORY SOCKETS The MEMORY sockets on this board are set up to take INTEL 2716, T.I. 2516 2Kx8 EPROMS, or any of the new 2Kx8 RAM chips which are pin compatible (Hitachi HM6116 or equivalent). By cutting J2(A-B) on the solder side above Ul7, J4 on the solder side to the left of U29, an J5(A-C) on the solder side beside U29 and installing jumpers J2(A-C) and J5(A-B) the sockets can now be used for 2732 4Kx8 EPROMS. (NOTE: Extreme care must be used when soldering in the jumpers so as not to damage the board or any of the traces. A soldering iron of no more than 25 watts should be used.) With 2732's SW3-4 is no longer used to address the sockets. The on-board sockets will be totally disabled when switch SW3-5 is ON. With SW3-6 ON, the sockets are addressable anywhere in base page (A16-A23 are all 0) on a 4K boundry (8K for the 2732's). This feature allows the user to have MEMORY in base page only. With SW3-6 OFF, the sockets ignores address lines A16 - A23 and occupies every page of memory. A prime example of how to use the sockets in this "shadow" mode would be to use them with SW3-6 turned ON and the Power-on-jump set to the start of the PROM address, then when the system is initially turned on the program in the PROM will start and either initialize the system by booting in a disk program, or some other type of routine. Then the last thing the PROM will do is jump to the RAM address where the initialization routine was loaded. The first thing that program will do is an output to port FD(H) of anything except 0. This will set the extended page address to the page that was in the Accumulator, and the sockets will be disabled. RAM which was overlapped with the PROM can now be used and a complete memory map is available to the user. SW3 positions 1-4 are used for address lines A15-A12. The socket closest to the Z80 chip is the low address half PROM and the right socket the high half. ### Example: | SI | VITC | H \$3 | | DESIRED START AD | ORESS (HEX) | |----|------|-------|-------|------------------|--------------------| | 1 | 2 | 3 | 4 | 2716 | 2732 | | 0 | 0 | 0 | | 0000-0FFF | 0 <b>00</b> 0-1FFF | | 0 | 0 | 0 | 1 | 1000-1FFF | | | 0 | 0 | 1 | O. | 2000-2FFF | 2000-3FFF | | 0 | 0 | 1 | 1 | 3000-3FFF | | | : | : | : | : | : : | : : | | : | : | : | ; | : : | : : | | 1 | 0 | 1 | 0 | A000-AFFF | A000-BFFF | | : | : | : | : | : : | - | | 1 | 1 | 1 | 1 | F000-FFFF | | | | | ON | = "0" | OFF = "1" | | To disable ROM completely, turn ON SW3-5 ### CLOCK The clock for this system can be set to allow the CPU to run at either 2MHZ or 4MHZ. SW1-5 is used to select between these two speeds. When SW1-5 is ON the CPU will run at 2MHZ and bus pin 24 (Φ) will have a 2MHZ square wave on it. When SW1-5 is OFF, the system will run at 4MHZ and bus pin 24 will have a 4MHZ square wave on it. With a 24MHZ crystal used for X1 the speed switch SW1-5 will select between processor speeds of 6MHZ (when ON) and 3MHZ (when OFF). Bus pin 49 (CLK) will always have a 2MHZ signal on it. ### POWER-ON-JUMP/JUMP-ON-RESET Provisions have been made on this board to allow the processor to jump to any memory location on a 256 byte boundary on either a power-on only, or every reset also. To enable this feature, JMP ENABLE (SW1-8) should be turned CN and the jump address should be set on switch S2 according to the table below. To enable the jump on every reset also, SW3-7 should also be turned CN. | SWITCH<br>POSITION | FUNCTI | ON | | |--------------------|--------|-----|-----------| | 1 | . " | A15 | | | 2 | | A14 | | | 3 | . * | A13 | | | 4 | . * | A12 | ON = "1" | | 5 | . " | All | OFF = "0" | | 6 | . " | Al0 | | | 7 | . * | A9 | | | 8 | . " | A8 | | EXAMPLE: To jump to E900 for a North Star floppy disc system, S2 positions 1-3,5, and 8 should be ON and S2 positions 4,6,and 7 should be OFF. JMP ENABLE (SW1-8) should be ON to enable this feature. NOTE: Since the jump circuitry disables the input buffer, it is unnecessary to use the phantom line (S-100 pin 67) for proper operation. ### **MWRITE GENERATION** The CPU Z has circuitry on board for generating the MWRITE signal (bus pin 68) and a positive going strobe will be generated for each memory write operation. This circuitry looks at the bus and whenever the sOUT signal is low, and the pWR\* signal strobes low, a MWRITE strobe will be generated. This signal must be generated at only one source in each system. If there is a front panel in your system it also may be generating the MWRITE signal, and the signal from the CPU Z must be disabled. There are two ways to disable this signal: A) Cut jumper J7 on the solder side below U36 and R26; or B) Remove pin 9 of U36 from its socket and let the pin hang out, this makes it easier to reconnect the pin should you ever want MWRITE to be generated from the CPU 2 board in the future. If MWRITE is generated in more than one place, memory boards that rely on MWRITE as their write strobe may not work properly. ### IMSAI FRONT PANEL USAGE Although we will soon be manufacturing a front panel that will be fully compatible with the IEEE standard, if you have an IMSAI type front panel this CPU will require minor modifications to work properly. The problems arise from the fact that the IMSAI front panel (which does not conform to the IEEE standard) requires some signals that are not on the S-100 bus. Jumper pads are provided to allow these lines to be used. J6, and J8 should be installed to connect bus pins 53, and 71 respectively to control the CPU from the front panel. When the system is set to run at 4MHZ. the front panel will force the CPU to run at 2MHZ when the RUN/STOP signal is in the STOP This will allow for proper front panel operation which is speed dependent. Socket J3 in the upper right corner is for the front panel connector. The CPU MWRITE circuitry will also have to be disabled if the front panel is going to generate MWRITE (bus pin 68). Jumper J9 can be installed to have the CPU drive bus pin 27 (which was the WAIT line), but this is not necessary for proper system operation. ### **VECTORED INTERRUPTS AND MASK** Upon reset (RESET\*) U23 is cleared, and will output all lows to the Or-gates (U33 & U34). The VIO - VI7 inputs normally sit at a high level, and hence all inputs on U22 are high. This resting state makes the GS output high. Upon receiving a vectored interrupt when one of the VIO - VI7 inputs goes low, U22 will output a value corresponding to the highest priority interrupt on the lines. This value will go to U44 and when the CPU acknowledges the interrupt, the proper Restart command will go to the CPU. When a 1 has been written into the mask port FE(H), U23 will output a high to the associated Or-gate (U33 & U34). Then when an interrupt pulls the input low, U22 will still have a high input and will never detect interrupts that are being masked out. ### **EXTENDED ADDRESSING** When an OUT FD(H) instruction is executed, the data bits in the Accumulator are latched into U24 and output on bus lines A16-A23. These address lines will be tri-stated along with the other 16 address lines when ADDR-DSABL (Bus pin 22) is driven low by an external device requesting control of the bus. ### **CPU STATUS LINES** The S-100 bus has eight status signals that all bus masters must provide, these signals come from U45. During either a read cycle or a write cycle these status signals are latched on the bus. A short time after the read or write signal goes away the status signals are allowed to toggle. The S-100 status signals are shown below, along with their associated bus pins. (A \* suffix means active low signal.) | SIGNAL | BUS PIN | |--------|---------| | sWO* | 97 | | SMEMR | 47 | | SINTA | 96 | | sMl | 44 | | sINP | 46 | | SOUT | 45 | | SHLTA | 48 | | sXTRQ* | 58 | These status bits are decoded from the seven control signals coming from the Z80 as shown below: ### STATUS SIGNALS | CONTROL SIGNAL | sW | 0* | sMEMR | ATMIR | sM1 | sinp | #OUT | sHLTA | |----------------|-------|---------|-------|-------|-----|------|------|-------| | | (a) a | er (le) | | | | | | | | RF\$H* | t | x | x | X | X | X | X | x | | MRQ* | 0 | x | 0 | X | x | X | X | x | | RD* | 1 | x | 0 | X | x | 0 | x | x | | WR* | X | 0 | x | X | X | x | O O | x | | IORQ* | X | x | x | 0 | х | 6 | 8 | X | | M1* | х | х | x | 0 | 0 | X | X | x | | HALT* | x | x | x | x | x | x | x | 0 | (A\* suffix means active low signal) An X means a don't care condition. The SXTRQ\* signal is permanently high since this is an 8 bit processor. ### SYSTEM CLOCK The system clock circuitry consists mainly of Ul, U3, and U4. The 16 MHZ square wave is fed into U4 which divides it down to the desired system clock speed. The multiplexer U3 will feed either 16 MHZ or 8 MHZ to the pSYNC and pSTVAL\* generation circuitry and 2MHZ or 4MHZ to the 280 and bus for the system clock. The Z80 clock has inverters from U30 along with some discrete devices for providing the required clock rise and fall time. If jumper J8 is used, then when the RUN LINE (bus pin 71) is low the input to U5 will be low and cause the system to run at 2 MHZ. This is the same circuitry that switch SW1-5 uses to determine the system speed. The 2MHZ clock for bus pin 49 is generated with crystal X2, inverters in U27, and a flip-flop in U2 which is then fed through a buffer to bus pin 49. ### POWER-ON-JUMP(POJ)/JUMP-ON-RESET(JOR) The jump circuitry consists of octal inverter U21 (81LS96), DIP switch SW2, SIP resistor R23, hex o.c. inverter U32 (74LS05), a "D" flip flop U2, the POJ enable switch SW1-8, and JOR enable switch SW3-7. With the POJ enable switch ON. upon receiving a power-on-clear, the "D" flip flop is cleared which disables input buffer U43, and enables jump buffer U21. This action starts a three byte sequence which will cause the CPU to jump to the proper starting location. The CPU is reset to address 0, and from the jump buffer a jump (C3H) instruction is put on the data bus. At address 1 the low order address of zero is then put on the data bus, then at address 2 the high order address coming from the jump switch setting is placed on the data bus. When address 2 is in the address buffer the "D" flip flop will then be clocked to the set state and disable the jump buffer while enabling the data input buffer. The "D" flip flop will not get cleared again until the next POC. This complete sequence also occurs for every RESET\*, if switch SW3-7 is turned ON. This option will allow the CPU to come up with a known jump on power-on and then later when a reset is recognized the CPU can either start again at O(H) or jump to the address in switch SW2. ### **WAIT STATES** The CPU wait line (280 pin 24) is driven by three main sources, causing the processor to give more time for certain devices or system states. The three sources are; a) The RDY (pin 72) bus signal, which will be driven by an external device which must have more time to respond to the CPU, b) The XRDY (pin 3) bus signal which is driven by the front panel (if the system has one), and c) On board selector to generate a wait state for four different states. The on-board wait state will come from the settings of SW1 positions 1-4. M1 (SW1-4) will generate a wait state for every instruction cycle. The MRQ (SW1~3) will generate a wait state for every memory fetch cycle. The IORQ (SW1-2) will generate a wait state during every I/O operation. Finally, the ROM switch (SWI-1) will generate a wait state for every access of the on-board MEMORY. U8 will remain in the clear mode with Q\* high unless one of these switches (SWI positions 1-4) is turned ON. Then when one of the selected inputs go low, U8 will be set and cause the wait input (on the CPU) to go low. These wait states can only start when pSYNC is high. When pSYNC goes low U8 will be clocked low with the next negative edge of the system clock. ### SWITCH SUMMARY | S1<br>POSITION | FUNCTION | |----------------|------------------------------------------| | 1<br>2 | WAIT STATE FOR ROM WAIT STATE FOR I/O | | | WAIT STATE FOR MEMORY FETCH | | 3<br>4 | WAIT STATE FOR INSTRUCTION FETCH | | 5 | SPEED SWITCH (OFF = 4 MHZ.) | | 6 | NOT USED | | 7 | NOT USED | | 8 | POWER-ON-JUMP ENABLE | | \$2 | | | POSITION | FUNCTION | | ı | JUMP ADDRESS BIT A15 | | 2 | JUMP ADDRESS BIT A14 | | 3 | JUMP ADDRESS BIT A13 ON = "1" | | 4 | JUMP ADDRESS BIT A12 OFF = "O" | | 5 | JUMP ADDRESS BIT All | | 6 | JUMP ADDRESS BIT A10 | | ž | JUMP ADDRESS BIT A9 | | 8 | JUMP ADDRESS BIT A8 | | <b>S</b> 3 | | | POSITION | FUNCTION | | 1 | SOCKET ADDRESS BIT A15 \ | | 2 | SOCKET ADDRESS BIT A14 \ ON = "0" | | 3 | SOCKET ADDRESS BIT A13 / OFF = "1" | | 4 | SOCKET ADDRESS BIT Al2 / | | 5 | SOCKET DISABLE (WHEN ON) | | 6 | SOCKET BASE PAGE ONLY (WHEN ON) | | 7 | JUMP-ON-RESET ENABLE | | 8 | INTERRUPT ENABLE FOR VECTORED INTERRUPTS | ### **JUMPER SUMMARY** J2 - Used with J4, J5, to convert memory sockets for 2732 use J3 - Front panel data socket J4 - See J2 J5 - See J2 J6 - SSDSBL for IMSAI type systems J7 - MWRITE brought to Bus pin 68 J8 - Run or single step for IMSAI type systems WAIT brought to Bus pin 27 J9 - ## Parts List\_ ## (1) CPU Z circuit board INTERGRATED CIRCUITS (NOTE: the following parts may have letters, suffixes and prefixes along with the key numbers given below.) OTHER ELECTRONIC COMPONENTS | (SR7, SR12, SR13, | 9: | *(5) | | rs All OTHER* | | (R3)* | (R6) * | (R29)* | (R10)* | (R1, R2, R4, | | | | R19, R27, R28)* | (XI) | (XX) | (DI, DZ)* | | | | | | (87-83) * | | | | | | the board | |-----------------------|--------------------------|------------------------|------------------|-------------------|-------------|-------------------|------------------|---------------------|--------------------|-----------------------|--------------|------------------------|------------------------|--------------------|--------------|-------------------------------------|-----------------------|---------------|----------------------|-----------------------|------------------------------|----------------------|-------------------------|----------------|--------------------|--------------------|--------------------|---------------------------------|-----------------------------------------| | SIP resistor packs | 39uf Tantalum capacitors | 390 - 430 pF capacitor | | Ceramic Bypass ca | | 120 ohm resistor | 150 ohm resistor | 390 ohm resistor | 910 ohm resistor | 1K ohm resistors c.f. | | L.SK onm resistors c.f | 4./K onm resistors c.f | Code action | AMIL CLYSCAL | Arms orystal<br>Glass signal attach | sanoto terifite esero | | CHICALOCHOO TACTINA | PROCESSION COMPONENTS | Total profit of acceleration | Din Suitch o Section | TOTAL SWITCH O POSICION | Cott C 20 Test | Sers 0-32 nardware | Caid extractors | | المرادة المرادة المرادة المرادة | Surprise directly soldered on the board | | (5) | <u>(S</u> | Œ; | Ð | (Z) | 9; | (T) | € | æ. | € | (2) | Ş | 96 | S | 3 | 33 | 36 | (7) | | | | (46) | (F) | 3 | 96 | 96 | (7) | | * | ₹ | | | | U10) | , U27) | (Ul, Ul4, Ul6, | , U30, U31) | _ | , U46) | U12) | | (iii) | | , U34) | | ( <del>8</del> ) | | | | | | , U39-41) | | . 024) | . U37) | 045) | 042, 043) | | | U48) | | | | | (Ne, | (015 | (E) | 026, | (0.32) | (038 | (35, | <u>(</u> 8) | (II) | | | (U13) | | _ | (022) | (33) | 3 | <u>3</u> | (035, | (0.73) | (023, | (036, | (U44, | (019, | (021) | (020) | (047, | (6) | | below.) | | guad 2 input NAND | guad 2 input NOR | hex inverter | | hex inverter o.c. | quad 2 input AND | triple 3 input NAND | triple 3 input AND | dual 4 input AND | 8 input NAND | quad 2 input OR | quad 2 input NOR o.c. | dual "D" flip flop | quad buffers | octal encoder | quad 2-to-1 mux. | 4 bit counter | 8 bit shift register | octal bus driver | quad 2 input XNOR | octal latches | hex bus driver | octal latches | octal bus driver | octal bus inverter | Z80 microprocessor | 5 volt regulator | DND transistor | | numbers given below.) | | 741.500 | 741.502 | 74LS04 | | 74LS05 | 741.508 | 741.510 | 741511 | 74LS21 | 74LS30 | 741.532 | 741.533 | 741.574 | 741.5125 | 741.5148 | 741.5158 | 74LS161/3 | 74LS165 | 74LS244 | 74LS266 | 74LS273 | 74LS367 | 74LS373 | 811.595 | 811.596/98 | Z80A | 7805 | ANGONG | | Ŋ | | | • | - | | | | | | | | | | | | | | | | | | | | | | | | | | # Component Layout