# IMSAI/ALTAIR S-100 COMPATIBLE

ASSEMBLY MANUAL AND

OPERATING INSTRUCTIONS

Revised 5/77

.

-- On board 2708 EPROM addressable to any 4K boundary above 32K

-- Power-on-jump to any 4K boundary above 32K, or the on-board 2708

-- A wait state may be added to any:

1) Ml cycle

2) Memory Request cycle

3) On-board ROM cycle (for use at 4 MHz)

4) Input cycle

5) Output cycle

-- On-board run-stop flip<sub>t</sub> flop and optional generation of MEMORY WRITE allow front panel-less operation

-- Selectable IO addressing mode:

- 8080 mode where peripheral address byte is duplicated on high and low order address bytes
- Z-80 mode where the peripheral byte appears on the low order address, and the contents of the accumulator appears on the high order byte, allowing simultancous I/0

-- DMA Grant tri-states all signals from the processor board

-- 8224 clock generator provides 8080 look-alike  $\phi l$  and  $\phi 2$  for the S-100 bus

-- Status signals SINP, SOUT, SMEMR, & SWO are latched per S-100 bus specs.

-1-

#### Board Assembly

1) Install sockets for IC 1 thru IC 4, IC 6 thru IC 27, and IC 29 thru IC 40.

- 2) Install 8 position dip switches (SPST) at locations IC 5 and IC 28.
- 3) Install .1 uf capacitors at locations C4, C5, and C11 to C24.
- 4) Install a 50 to 100 uf electrolytic capacitor at locations Cl and C6. Note the polarity orientation on the silkscreen.
- 5) Install a 10 pf capacitor at location C9.
  - 6) Install a 100 pf mica capacitor at location ClO.
  - 7) Install the following resistors:
    - R1 4.7K
    - R2 1K

#### R6 330 ohms

8) Install 7805 regulator and heat sink at location Ql. It is advisable to use heat sink grease between the regulator and the heat sink.

9) If you plan to use the 2708 PROM install:

C2 & C3 50 to 100 uf electrolytic capacitors

- R3 51 ohm resistor
- R4 240 ohm resistor
- D1 12 volt zener diode

D2 5.1 volt zener diode

#### 2 MHz Operation

- Install an 18 MHz XTAL at location Y1. If the crystal is an overtone type crystal, then install L1, C7 , and C8 . If the crystal is a fundamental type, then these components are not necessary.
- 2) Install resistor R5 at 3300 ohms.
- 3) Open all dip switches (off position).

4) Install jumper J2 (adjacent to IC 23) in the 8080 mode by connecting the middle to the lower pads.

| Z-80 | 8080 |
|------|------|
| mode | mode |

## 4 MHz Operation

- Install a 36 MHz crystal at location Y1. If the crystal is a third overtone type, then install L1, C7, and C8.
- 2) Install R5 at 1.8K ohms.
- 3) Open all dip switches except IC 5 position 5. This inserts a wait state into every memory cycle, so that you may test the processor with 500 ns memory.
- 4) If you are using a 2708  $\grave{\text{EPROM}}$  , close IC 5 position 6.
- 5) Install jumper J2 (adjacent to IC 23) in the 8080 IO mode by connecting the middle to the lower pads.

# Front Panel-less Operation

On the reverse side of the printed circuit card (not the component side) in the upper left hand corner there are four sets of pads marked A, B, C, and D. Connect each set of pads by carefully soldering a small piece of wire to the two pads of each set.

2) Mount your front panel control switches and attach their terminals to a length of ribbon cable. Attach the other end of the ribbon to a dip header plug, pins 13, 14, 15, and 16 as shown in the schematic. Attach the ground to the ground plane

on the S-100 bus.



3) Close the dip switch at location IC 5 position 1. This allows the processor card to generate its own Memory Write signal (MWRT), normally a front panel function.

## Options

1) On-board 2708 EPROM

To use the provision for the on-board 2708, install the components for the plus 12-volt and minus 5-volt power supplies as per step 9 of the board assembly instructions. Connect pad J to pad H of the ROM enable jumper (near IC20).

2) No on-board 2708

Connect pad J to pad K of the ROM enable jumper.

3) Power-on Reset jump

The reset jump feature may be enabled in a number of ways. If you are running front panel-less, the jumpenable line is available at the front panel connector by connecting the pads across letter D. When this line is grounded the reset jump is enabled. If you are using a front panel, two options exist:

a) The Reset jump may be permanently enabled by connecting pad F to pad G. This grounds the jump enable line.
b) Tie pad F to any unused S-100 bus pin. When this bus pin is grounded, the reset jump will be enabled. Note that when the jump is enabled the data bus will be blanked during a reset operation. The processor will not be able to read the contents of memory until the jump address is reached. If the processor

-4-

is stopped and you hit reset and the jump is enabled, the processor will reset to location 0000, remain stopped, and the data bus will read all zeros, regardless of what is stored at this location. Hitting the run switch will allow the processor to step through memory until the jump address is reached, at which time normal memory operations are resumed, with all memory locations being visible to the processor.

4) PROM and Jump Addressing

The on-board 2708 PROM and the reset jump are addressed by clsoing the appropriate dip switch at IC 28. They may be addressed at any 4K boundary above 32K. Note that only one dip switch may be closed at a time.

| Address | (hex) | Close switch a | t position |
|---------|-------|----------------|------------|
| 8000    |       | 8              |            |
| 9000    |       | 7              |            |
| 000A    |       | 6              |            |
| B000    |       | <sup>;</sup> 5 |            |
| C000    |       | 4              |            |
| D000    |       | 3              |            |
| E000    |       | 1              |            |
| F000    |       | 2              | ખ          |

5) Wait State Selection

A wait state may be added to any of the following processor cycles by closing the appropriate dip switch at IC 5.

| Wait Added on Cycle    | Close switch at position |
|------------------------|--------------------------|
| Ml (instruction fetch) | 4                        |
| all Memory             | 5                        |
| on-board 2708          | 6                        |
| Input                  | 7                        |
| Output                 | 8                        |

6) Address Multiplexing

Jumper J2 has been provided so that you may choose between

8080 and Z-80 IO addressing modes. Unless you have a specific need for using the Z-80 mode, it is recommended that you use the 8080 mode, thereby maintaining S-100 bus compatibility. See step 4 of the section on 2 MHz operation for the proper installation of this jumper.

#### Checkout Procedure

It is highly recommended that you use static memories during the initial checkout of your processor board. The timing signals necessary to interface dynamic memory are highly critical and checkout is greatly simplified if static memory is used. When handling MOS devices such as the Z-80, be careful to ground your body to both the processor board and the conductive foam in which the devices are stored before handling the chips. Avoid touching the pins of the chips if possible. Do not proceed from any step until the proper results are obtained.

- If you have installed the jump enable jumper (pad F to pad G), temporarily disconnect it. If you have a jump enable switch, open the switch (jump not enabled).
- 2) Install the board in the computer, power-up and check the output of of the five-volt regulator (right-most pin). If it is not 5 volts, either the regulator is defective, or a short circuit exists on the board. Power-down and check the board for solder bridges.
- 3) Power down and install the 8224 clock generator (8224-4 at 4 MHz). Power up and check pin 6 for a 2 MHz (4 MHz) square wave.
- 4) Power-down and install the remaining TTL and the Z-80. Power up and repeat steps 2 and 3. If a front panel is used, plug in the connector.

5) Stop the processor if it is running. Press the reset button and hold down. Examine the following pins of the Z-80 chip:

| PIN | NAME  | CONDITION | EXPECTED |
|-----|-------|-----------|----------|
| 26  | RESET | low       |          |

-6-

| PIN            | NAME               | CONDITION EXPECTED |
|----------------|--------------------|--------------------|
| 30-4-*<br>1-5  | A <b>Ø-</b><br>A15 | high               |
| 7-10*<br>12-15 | D <b>Ø-</b><br>D7  | high               |

\*These pins may be examined by checking the front panel lights: AO-A15 and DO-D7 should all be on while reset is held down.

6) Release the RESET button. Examine the following pins on the Z-80 chip;

| PIN           | NAME   | CONDITION EXPECTED |
|---------------|--------|--------------------|
| 26            | RESET  | high               |
| 25            | BUSRQ  | high               |
| 24            | WAIT   | low                |
| 18            | HLTA   | high               |
| 27            | MI     | low                |
| 16            | INT    | high               |
| 17            | NMI    | high               |
| 23            | BUSAK  | high               |
| 30-40*<br>1-5 | A0-A15 | low                |

\*may be examined via front panel lights. AO-A15 should be off.

If there is a front panel, proceed with the following tests:

7) Hit the EXAMINE NEXT switch 3 or 4 times and see if the address lights count up in binary.

8) With all the address switches off, hit EXAMINE The processor should return to location zero, with all address lights off.

9) Power-down and install a memory board at location zero. Power-up and hit STOP and RESET. With all data switches off, hit DEPOSIT. All data lights should go out.

10) Change data switch  $\emptyset$  to a one and hit DEPOSIT NEXT. Check that data light  $\emptyset$  is now on.

11) Change each of the remaining data switches, one at a time, to a one.

Hit DEPOSIT NEXT after each change and check that the corresponding data light is now on.

12) When all of the switches are on and all of the data lights are on, hit RESET. Step through memory hitting EXAMINE NEXT. The data lights should come on one by one until they are all on.

13) Enter the following program at location  $\emptyset$ .

| Address | Data     | Instruction |
|---------|----------|-------------|
| 0000    | D3 18    | Out 18(Hex) |
| 0002    | C3 00 00 | Jmp 0000    |

Hit RESET. The data lights should contain D3, the MEMR light, the  $\overline{SWO}$  light, and the M1 light should be on, INP and OUT should be off. Hit SINGLE STEP. Nothing should change except the address and the data lights. Hit SINGLE STEP. The MEMR and M1 +  $\overline{SWO}$  lights should now go off and the OUT light go on. Check to see that both the high and low address bytes contain 18(Hex). This is the 8080 IO mode. After hitting SINGLE STEP 4 times, the processor should return to address zero.

14) Hit RUN. Check to see that the OUT light is partially on. Close the dip switch at location IC 5 position 8, the wait light should come on very dimly. When the dip switch at position 4 is closed, the wait light should come on more strongly. Open position 4 and close position 5; the wait light should come on. Open the switches.

15) Change the contents of location  $\emptyset$  to DB. Hit RESET and RUN. The INP light should now come partially on. Close the dip switch at location IC 5 position 7. The wait light should come on very dimly.

16) Connect a temporary jumper between pads J and K, disconnecting pads J and H if they are connected. Connect a temporary jumper between pads F and G. Deposit 76 (hex) at location COOO. Close the dip switch at location IC 28 position 4. Hit RESET. The data bus at location zero should contain all zeros. Hit RUN. After a fraction of a second the HLTA light should go on. This completes the checkout procedure.

#### Processor Status

The five primary status lines from the Z-80 chip are Memory Request  $(\overline{\text{MREQ}})$ , Instruction Fetch  $(\overline{\text{MT}})$ , Input-Output Request  $(\overline{\text{IORQ}})$ , Read  $(\overline{\text{RD}})$ , and Write  $(\overline{\text{WR}})$ . They are defined as follows:

- MREQ when active (low), indicates that the address bus contains a valid address for a Memory Read or Memory Write.
- IORQ indicates that the address bus contains a valid address for an input or an output device.
- RD indicates that the CPU wants to read data from memory or an I/O device. The addressed emmory or device uses this signal to gate data onto the data bus.
- $\overline{WR}$  indicates the data bus holds valid information to be stored in the addressed memory or I/O device.
- M) indicates that the current machine cycle is the opcode "fetch" of an instruction cycle.

These signals are inverted and gated together by IC 18 and IC 19 to form the status signals SOUT (output), SINP (input), SMEMR (memory read), and SWO (write operation in progress) as follows:

> SOUT = IORQ • WR (IC 18 pin 6) SINP = IORQ • RD (IC 18 pin 8) SMEMR = MREQ • RD (IC 18 pin 11)  $SWO = \overline{RD} • \overline{INTA}$  (IC 18 pin 3)

The Z-80 does not have an interrupt acknowledge (INTA) pin. Rather, INTA is defined on the Z-80 chip as

 $INTA = M1 \cdot IORQ$ 

This signal is generated by IC 15 at pin 11 and is inverted at IC 17 pin 2 for use in the generation of SWO.

These four status signals are then latched by the quad latch IC 13 and SWO is inverted by using the  $\overline{Q}$  output from the latch to form  $\overline{SWO}$ . The latched status signals provide status information for the S-100 bus after gating through the tri-state bus drivers in IC 3.

The Status latch IC 13 is clocked by the PSYNC signal from one-shot IC 8. The Psync signal is true for the first 400 nsec (200 nsec at 4 Mhz) of every IO or memory cycle (except Refresh) and is used by many peripherals to indicate the earliest moment when status and address information may be sampled from the bus. It may also be used by some peripheral cards to sample status information o: the DATA OUT bus. A full description of this signal is given in the section on 8080 PSYNC. The length of the Sync signal is determined by the resistor R5. The one-shot IC 8 is triggered by the SYNCENABLE signal (IC 14 pin 8) which is defined as:

# SYNCEN = $(MRQ \cdot \overline{RFSH}) + IORQ$

The Memory Write signal MWRT may optionally be generated on the processor card by closing the dip switch at IC 5 position 1. MWRT is defined as; MWRT = MRQ • WR. This signal need only be generated in a front panel-less machine. In a machine with a front panel, the MWRT is generated by the front panel circuitry and defined as processor Memory Write OR Deposit.

## Processor Control Bus

The processor write strobe  $\overline{PWR}$  is simply the write strobe of the Z-80 chip delayed slightly by two sections of IC 12 and optionally delayed until the end of the PSYNC signal via jumper Jl. This jumper need only be installed if status information is to be steed onto the data bus. See the section on 8080 PSYNC for a complete explanation.

The processor data bus in signal PDBIN is created at IC 10 pin 10 and is defined as:

#### PDBIN = RD + INTA

This is inverted at IC 17 pin 8 and gated to the bus by tri-state driver IC 4. PDBIN is also AND-ed with the sense switch disable sig-

nal (SSWDSB)from the front panel at IC 14 pin 3. When SSWDSB is active, data is not gated in from the Data-In-bus so that the processor may accept data from the front panel circuitry via the ribbon cable connected to IC 34.

#### Wait State Generation

A wait state may be added to any processor cycle by closing the appropriate dip switch at location IC 5.

| Wait added to cycle | Switch position |  |
|---------------------|-----------------|--|
| MI                  | 4               |  |
| all Memory          | 5               |  |
| on-board 2708       | 6               |  |
| Input               | 7               |  |
| Output              | 8               |  |

When using marginally slow memory, it may be necessary to add a wait state to the M1 (instruction fetch) cycle since the Z-80 chip makes its most critical timing demands upon the memory during this cycle. If you are using memory with an access time of greater than 500 nsec and a processor clock of 2 MHz <u>or</u> memory with access time greater than 250 nsec and a clock rate of 4 MHz, then you must add a wait state to every memory cycle. The on-board 2708 EPROM will run without wait states at 2 MHz, but a wait state must be added at 4 MHz. If you wish to add a wait state to an input or an output cycle, provision has been made, though this should only be necessary in extreme cases.

Wait states are generated in the following way: The SYNCEN from IC 14 pin 8 is successively clocked through the two flip flop sections of IC 9 by the processor clock  $\emptyset$ . The output of this circuit is a positive-going pulse at pin 8 of IC 15 with a duration of one clock period every time a new processor cycle begins. The wait request signals from the dip switch IC 5 are OR-ed together by IC 6 and inverted at pin 8 of IC 7. This signal may be considered a wait enable signal. If the wait enable signal is active (high) then the pulse from IC 15 pin 8 is gated through to the NOR gate, IC 6, and then into the Z-80 chip, generating a wait state for one clock period.

## <u>Clock</u> Generation

An 8224 clock generator has been used to generate the  $\emptyset$ l and  $\emptyset$ 2 signals for the S-100 bus and the clock for the Z-80 chip. The Z-80 is clocked by the  $\emptyset$ 2 signal. This brings the internal timing structure of the Z-80 chip into close emulation of 8080 timing signals, a necessity for interfacing to the S-100 bus. Note that the tank circuit connected to pin 13 of the 8224 need only be installed with a third overtone type crystal. Resistor R1 and capacitor C6 determine the duration of the power-on reset pulse.

## Address Multiplexing

The 8080 processor chip provides the peripheral address byte on both the high order and the low order address bytes during an I/O instruction. The Z-80 chip, however, provides the peripheral byte only on the low order address byte. This is done so that the contents of the accumulator may be transferred to the high order address byte during an input instruction, allowing simultaneous input and ouput. Many peripheral cards designed for the S-100 bus decode the high order address byte during an IO instruction, which will cause errors if the Z-80 IO mode is used. Multiplexors IC 24 and IC 25 have been provided so that you may select between 8080 and Z-80 IO modes via jumper J2. It is adviseable to connect the jumper to the ADDMUX line thereby operating the board in 8080 mode unless you specifically need the simultaneous IO feature. If you choose Z-80 mode you may have to extensively modify your existing IO boards to operate correctly in this mode.

## ROM Addressing and Power on Jump

Addressing for the on-board 2708 (IC 36) is done via address decoder IC 29 and dip switch IC 28. The ROM and the power-on/reset

jump are addressed together, and may be located at an 4K boundary above 32K. Note that only one switch of the dip switch IC 28 may be closed at a time in order to avoid addressing the ROM at two places in memory. The power-on jump operates in the following way: The processor reset line (RESCLK) clocks the flip flop IC 21 at pin 3. If the jump enable line (JUMPEN) is low at this moment, either by connecting points F and G on the circuit board, or by connection to a front panel switch, (the JUMPEN line is available on the front panel connector IC 34 at pin 16) then flip flop IC 21 is set and the first set of inverting data receivers are tri-stated. This allows the pullup resistors in IC 32 and IC 38 to force the data lines high. The second set of inverting data receivers change all these highs to lows and the processor sees an instruction word of all zeros, which it decodes as a NOP. This had the effect of incrementing the program counter with no other operation being performed. The Program countersteps through memory until the address selected with IC 28 and IC 29 is reached. The ROM select signal is then generated which resets flip flop IC 21 and the processor resumes normal operation.

If you are not using the on-board ROM, but do wish to use the reset jump to go to your own monitor, this may be done by connecting a jumper between pad J and pad K on the circuit board. If the ROM is used, connect the jumper between pad J and pad H. If the jumper is connected between pads J and H, then the data input drivers will be tri-stated when the ROM is being addressed, preventing conflict between the data input drivers and the ROM data lines. If you do not use the ROM, however, and the jumper is connected between J and H, the 1K block of memory beginning at the reset jump address will be "blanked out" by the tri-stating of the input drivers. This is a-voided if pad J is tied permanently high by connecting it to pad K. In this configuration, the chip select on the ROM will never tri-state the input drivers and the system memory at the selected jump address is again "visible" to the Z-80.

-13-

## Direct Memory Access

A Direct Memory Access cycle is initiated by bringing the  $\overline{PHOLD}$ line low (bus pin 74). This is buffered by IC 11 and connected directly to the bus request ( $\overline{BUSRQ}$ ) pin of the Z-80. The Z-80 samples this line with the rising edge of the last clock period of any processor cycle and if it is active all processor operation is suspended during the next clock cycle and the bus acknowledge pin ( $\overline{BUSAK}$ ) goes active. This pin is inverted by IC 19 and buffered by IC 20 to drive the DMA grant (DMAG) line on the bus (pin 26).  $\overline{BUS'K}$  is also buffered by IC 20 and drives three sections of IC 22 and one section of IC 7. This has the effect of Tri-stating all data, address, and control signals from the processor card, thereby relinquishing all control to the DMA device. The DMA operation is terminated when the  $\overline{PHOLD}$  line is returned to its inactive (high) state.

## Interrupt Handling

Interrupts are handled internally in the Z-80 chip with very little external circuitry required. When the Interrupt line on the S-100 bus is active (low), this low is gated to the processor chip by buffer IC 20. The Z-80 samples its  $\overline{INT}$  pin during the last clock period of each instruction cycle and if it is active AND the internal interrupts enabled flip-flop is set (interrupts are enabled) AND the BUSRQ line is not active, then an interrupt is generated. The processor generates a special M1 cycle (instruction fetch) at this point. During this special cycle the **IORQ** signal becomes active concurrently with the MI signal (normally M1 and MREQ are active during an instruction fetch). This special MI cycle is defined as the interrupt acknowledge signal and an active high signal is generated at IC 15 pin 11 and gated onto the S-100 bus by buffer IC 4. When this signal is active, the interrupting device can place an 8-bit vector on the processor data bus. Refer to the Z-80 technical manual as to how this interrupt vector is utilized by the Z-80 in each of the three interrupt response modes.

On the 8080 processor chip one of the status lines was assigned to the interrupt enable flip-flop, so that its status could be read by external devices. The pin proved to be of extremely limited usefulness, and was not included on the Z-80 chip. The S-100 bus, however, being essentially a copy of the 8080 pin-out, does include this signal. While it is possible to build circuitry to emulate the function of this pin, its limited usefulness suggests not doing so. Note that the internal interrupt flip-flop operates in the usual way, being set by an EI instruction (ENABLE INTERRUPTS) and reset by a DI instruction (DISABLE INTERRUPTS) OR by a processor reset operation. If you are using any periferal cards that perform interrupts to the processor, check to see if they examine the INTE signal (bus pin 28). If they do, this bus pin may be tied permanently high and the peripheral cards will operate correctly. Note also that if you have a front panel light that indicates interrupts enabled, it will not operate and may be reassigned to another functior.

The Non-maskable Interrupt (NML) line operates in much the same way as the interrupt line, but this line has priority over the normal interrupt line and cannot be disabled under software control. It is extremely useful to provide response to important signals such as impending power failure. CPU response to an NMI signal is similar to a normal interrupt response except that the contents of the data bus is ignored while the processor stores the program counter on the stack and jumps to location 0066H. The PSYNC signal indicates three things on the 8080 processor chip:

- 1) PSYNC identifies the first time state in every machine cycle
- 2) PSYNC And-ed with  $\emptyset$ 1 or  $\overline{\emptyset}2$  indicates the earliest moment that address information is stable on the address bus.
- 3) PSYNC indicates that status information is available on the Data bus. The normal operation of an 8630 processor card is to latch the system status information off the data bus into an on-board 8212, using PSYNC as a strobe. This latched status information is then available to the S-100 bus.

The Z-80 chip, however, does not generate a PSYNC signal, and does not require that status information be latched at the beginning of each machine cycle.

These differences in processor chip architecture have caused some problems in interfacing the Z-80 to the S-100 bus. The PSYNC signal has been created and satisfies the first two conditions of 8080 PSYNC. The third condition, that status information be available on the data bus during the PSYNC signal, has been intentionally ignored. To satisfy the third condition of the 8080 PSYNC signal, status information would have to be gated onto the data-out bus during the PSYNC signal. This is both unnecessary and drastically reduces the time that data is available on the DATA OUT bus during a memory write or output cycle.

If you have peripheral cards that examine the data-out bus during PSYNC, the simple solution is to cut the data line examined at the chip input and to tie the input to the apprpriate status line on the bus.

| Data Line Examined | Symbol | Available at bus pin |
|--------------------|--------|----------------------|
| DO                 | INTA   | 96                   |
| D1                 | WO     | 97                   |
| D3                 | HLTA   | 48                   |
| D4                 | OUT    | 45                   |
|                    |        |                      |

| Data Line Examined | Symbol | Available at bus pin |
|--------------------|--------|----------------------|
| D5                 | м      | 44                   |
| D6 .               | INP    | 46                   |
| D7                 | MEMR   | 47                   |

# An Example: IMSAI Front Panel Fix

The IMSAI front panel, for example, examines data line D05 during the PSYNC interval, in order to stop the processor at an M1 cycle. The Z-80 will not necessarily stop on an M1 cycle unless this data line is cut and the line tied to SM1 (pin 44) on the S-100 bus. When using the Z-80 board, the following differences exist in the assignment of S-100 bus pins:

INTE Interrupt Enable (bus pin 28) is not generated by the CPU as explained in the section on Interrupt handling.

NMI Non-maskable Interrupt is not accepted by 8080 processors but is accepted by Z-80 CPUs. This function has been assigned to the previously unassigned bus pin 12 adjacent to the vectored interrupt lines VIO to VI7.

- STACK Stack operation (bus pin 98) is an 80SD status line that indicates that a stack operation is in progress. This line is not generated by the Z-80 and is not available on the bus. Front panel lights connected to this pin will not operate correctly.
- RFSH Refresh is a signal generated by the Z-80 for interfacing the processor to dynamic memories. It has been assigned to previously undefined bus pin 67.
- MRQ Memory request is also generated by the Z-80 and is useful in interfacing dynamic memory without slowing the processor. It has been assigned to undefined bus pin 65.

# S-100 Bus Definition

|     | SYMBOLS: | "P" prefix indicates a p<br>signal | rocessor command/control                                                                                                                                                           |
|-----|----------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          | "S" prefix indicates a p           | rocessor status signal                                                                                                                                                             |
|     | LEVELS:  | All bus signals except t           | he power supply are TTL                                                                                                                                                            |
| No. | SYMBOL   | NAME                               | FUNCTION                                                                                                                                                                           |
| 1   | +8V      | +8 volts                           | Unregulated input to 5v<br>regulators                                                                                                                                              |
| 2   | +16V     | +16 volts                          | Positive unregulated voltage                                                                                                                                                       |
| 3   | XRDY     | External Ready                     | For special applications:<br>Pulling this line low will<br>cause the processor to enter a<br>WAIT state and allows the status<br>of the normal Ready line (PRDY)<br>to be examined |
| 4   | VIO      | Vectored Interrupt                 |                                                                                                                                                                                    |
| 5   | VII      | Vectored Interrupt<br>Line #1      |                                                                                                                                                                                    |
| 6   | VI2      | Vectored Interrupt<br>Line #2      |                                                                                                                                                                                    |
| 7   | VI3      | Vectored Interrupt<br>Line #3      |                                                                                                                                                                                    |
| 8   | VI4      | Vectored Interrupt<br>Line #4      |                                                                                                                                                                                    |
| 9   | V15      | Vectored Interrupt<br>Line #5      |                                                                                                                                                                                    |
| 10  | VI6      | Vectored Interrupt<br>Line #6      |                                                                                                                                                                                    |
| 11  | V17      | Vectored Interrupt<br>Line #7      |                                                                                                                                                                                    |
| 12  | NMI      | Non masable Interrupt              |                                                                                                                                                                                    |

|     | <u>No.</u> | SYMBOL  | NAME                       | FUNCTION                                                                                                                                                                  |
|-----|------------|---------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | 18         | STA DSB | STATUS DISABLE             | Allows the buffers for the 5 status lines to be tri-stated                                                                                                                |
|     | 19         | C/C DSB | COMMAND/CONTROL<br>DISABLE | Allows the buffers for the 4<br>output command/control lines to<br>be tri-stated                                                                                          |
|     | 20         | UNPROT  | UNPROTECT                  | Input to the memory protect flip-<br>flop on a given memory board                                                                                                         |
|     | 21         | SS      | SINGLE STEP                | Front panel signal that indicates<br>that the machine is in the process<br>of performing a single step                                                                    |
|     | 22         | ADD DSB | ADDRESS DISABLE            | Allovs the buffers for the 16<br>address lines to be tri-stated                                                                                                           |
| 5   | 23         | DO DSB  | DATA OUT DISABLE           | Allows the buffers for the 8<br>data output lines to be tri-stated                                                                                                        |
| ÷., | 24         | φ2      | Phase 2 Clock              |                                                                                                                                                                           |
|     | 25         | φl      | Phase 1 Clock              |                                                                                                                                                                           |
|     | 26         | PHLDA   | Hold Ackňowledge           | e Processor ; control output<br>signal which appears in response<br>to the HOLD signal; indicates that<br>the data and address bus will go to<br>the high impedance state |
|     | 27         | PWAIT   | WAIT                       | Processor command/control output<br>signal which acknowledges that<br>the processor is in a WAIT state                                                                    |
|     | 28         | PINTE   | INTERRUPT<br>ENABLE        | This signal not generated by Z-80                                                                                                                                         |
|     | 29         | A5      | Address Line #5            |                                                                                                                                                                           |
|     | 30         | A4      | Address Line #4            |                                                                                                                                                                           |
|     | 31         | A3      | Address Line #3            |                                                                                                                                                                           |
|     | 32         | A15     | Address Line #15           |                                                                                                                                                                           |
|     | 33         | A12     | Address Line #12           | :                                                                                                                                                                         |
|     | 34         | A9      | Address Line #9            |                                                                                                                                                                           |
|     | 35         | D01     | Data Out Line #1           |                                                                                                                                                                           |
|     |            |         |                            |                                                                                                                                                                           |
|     |            |         | -20-                       |                                                                                                                                                                           |

|   |            |        |                  | ``                                                                                                                                                                                            |
|---|------------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | <u>No.</u> | SYMBOL | NAME             | FUNCTION                                                                                                                                                                                      |
|   | 36         | DOO    | Data Out Line #0 |                                                                                                                                                                                               |
|   | 37         | A10    | Address Line #10 |                                                                                                                                                                                               |
|   | 38         | D04    | Data Out Line #4 |                                                                                                                                                                                               |
|   | 39         | D05    | Data Out Line #5 |                                                                                                                                                                                               |
|   | 40         | D06    | Data Out Line #6 |                                                                                                                                                                                               |
|   | 41         | DI2    | Data In Line #2  |                                                                                                                                                                                               |
|   | 42         | DI3    | Data In Line #3  |                                                                                                                                                                                               |
|   | 43         | DI7    | Data In Line #7  |                                                                                                                                                                                               |
|   | 44         | SMI    | MI               | Status output signal that in-<br>dicates that the processor is<br>in the fetch cycle for the first<br>byte of an instruction                                                                  |
|   | 45         | SOUT   | OUT              | Status output signal which indi-<br>cates that the address bus contains<br>the address of an output device<br>and the data bus will contain the<br>output data when PWR is active             |
|   | 46         | SINP   | INP              | Status output signal which indi-<br>cates that the address bus con-<br>tains the address of an input<br>device and the input data should<br>be placed on the data bus when<br>PDBIN is active |
|   | 47         | SMEMR  | MEMR             | Status output signal which indi-<br>cates that the data bus will be<br>used for memory read data                                                                                              |
|   | 48         | SHLTA  | HLTA             | Status output signal which acknowledges a HALT instruction                                                                                                                                    |
|   | 49         | GLOCK  | CLOCK            | Inverted output of the oscillator that generates the 2 phase clock                                                                                                                            |
| , | 50         | GND    | GROUND           |                                                                                                                                                                                               |
|   | 51         | +8V    | +8 volts         | Unregulated input to 5v regulators                                                                                                                                                            |
|   | 52         | -16V   | -l6 volts        | Negative unregulated voltage                                                                                                                                                                  |
|   |            |        |                  |                                                                                                                                                                                               |

|             | No. | SYMBOL  | NAME                       | FUNCTION                                                                                                                                                              |
|-------------|-----|---------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 18  | STA DSB | STATUS DISABLE             | Allows the buffers for the 5 status lines to be tri-stated                                                                                                            |
|             | 19  | C/C DSB | COMMAND/CONTROL<br>DISABLE | Allows the buffers for the 4<br>output command/control lines to<br>be tri-stated                                                                                      |
|             | 20  | UNPROT  | UNPROTECT                  | Input to the memory protect flip-<br>flop on a given memory board                                                                                                     |
|             | 21  | SS      | SINGLE STEP                | Front panel signal that indicates<br>that the machine is in the process<br>of performing a single step                                                                |
|             | 22  | ADD DSB | ADDRESS DISABLE            | Allovs the buffers for the 16<br>address lines to be tri-stated                                                                                                       |
|             | 23  | DO DSB  | DATA OUT DISABLE           | Ē Allows the buffers for the 8<br>data output lines to be tri-stated                                                                                                  |
|             | 24  | φ2      | Phase 2 Clock              |                                                                                                                                                                       |
| s. s. €<br> | 25  | φl      | Phase 1 Clock              |                                                                                                                                                                       |
|             | 26  | PHLDA   | Hold Acknowledge           | Processor control output<br>signal which appears in response<br>to the HOLD signal; indicates that<br>the data and address bus will go to<br>the high impedance state |
|             | 27  | PWAIT   | WAIT                       | Processor command/control output<br>signal which acknowledges that<br>the processor is in a WAIT state                                                                |
|             | 28  | PINTE   | INTERRUPT<br>ENABLE        | This signal not generated by Z-80                                                                                                                                     |
|             | 29  | A5      | Address Line #5            |                                                                                                                                                                       |
|             | 30  | A4      | Address Line #4            |                                                                                                                                                                       |
|             | 31  | A3      | Address Line #3            |                                                                                                                                                                       |
|             | 32  | A15     | Address Line #15           |                                                                                                                                                                       |
|             | 33  | A12     | Address Line #12           | ·<br>·                                                                                                                                                                |
|             | 34  | A9      | Address Line #9            |                                                                                                                                                                       |
|             | 35  | D01     | Data Out Line #1           |                                                                                                                                                                       |
|             |     |         |                            |                                                                                                                                                                       |
|             |     |         |                            |                                                                                                                                                                       |

|   | <u>No.</u> | SYMBOL       | NAME             | FUNCTION                                                                                                                                                                                      |
|---|------------|--------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | 36         | DOO          | Data Out Line #0 |                                                                                                                                                                                               |
|   | 37         | A10          | Address Line #10 |                                                                                                                                                                                               |
|   | 38         | D04          | Data Out Line #4 |                                                                                                                                                                                               |
|   | 39         | D05          | Data Out Line #5 |                                                                                                                                                                                               |
|   | 40         | D06          | Data Out Line #6 |                                                                                                                                                                                               |
|   | 41         | DI2          | Data In Line #2  |                                                                                                                                                                                               |
|   | 42         | DI3          | Data In Line #3  |                                                                                                                                                                                               |
|   | 43         | DI7          | Data In Line #7  |                                                                                                                                                                                               |
|   | 44         | <b>SM1</b> . | M]               | Status output signal that in-<br>dicates that the processor is<br>in the fetch cycle for the first<br>byte of an instruction                                                                  |
|   | 45         | SOUT         | OUT              | Status output signal which indi-<br>cates that the address bus contains<br>the address of an output device<br>and the data bus will contain the<br>output data when PWR is active             |
|   | 46         | SINP         | INP              | Status output signal which indi-<br>cates that the address bus con-<br>tains the address of an input<br>device and the input data should<br>be placed on the data bus when<br>PDBIN is active |
|   | 47         | SMEMR        | MEMR             | Status output signal which indi-<br>cates that the data bus will be<br>used for memory read data                                                                                              |
|   | 48         | SHLTA        | HLTA             | Status output signal which acknowledges a HALT instruction                                                                                                                                    |
|   | 49         | GLOCK        | CLOCK            | Inverted output of the oscillator that generates the 2 phase clock                                                                                                                            |
| , | 50         | GND          | GROUND           |                                                                                                                                                                                               |
|   | 51         | +8V          | +8 volts         | Unregulated input to 5v regulators                                                                                                                                                            |
|   | 52         | -16V         | -l6 volts        | Negative unregulated voltage                                                                                                                                                                  |
|   |            |              |                  |                                                                                                                                                                                               |

.

| <u>No.</u> | SYMBOL  | NAME                    | FUNCTION                                                                                                                                            |
|------------|---------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 53         | SSW DSB | SENSE SWITCH<br>DISABLE | Disables the data input buffers<br>so the input from the sense switches<br>may be strobed onto the bidirectional<br>data bus right at the processor |
| 54         | EXT CLR | EXTERNAL CLEAR          | Clear signal for I/O devices (front panel switch closure to ground)                                                                                 |

•

| 68 | MWRT . | MEMORY WRITE         | Indicates that the current data<br>on the Data Out Bus is to be<br>written into the memory location<br>currently on the address bus                                                                                                                                                   |
|----|--------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 69 | PS     | PROJECT STATUS       | Indicates the status of the memory<br>protect flip-flop on the memory<br>board currently addressed                                                                                                                                                                                    |
| 70 | PROT   | PROTECT              | Input to the memory protect flip-<br>flop on the memory board currently<br>addressed                                                                                                                                                                                                  |
| 71 | RUN    | RUN                  | Front panel signal that indicates that the RUN/STOP flip-flop is Reset                                                                                                                                                                                                                |
| 72 | PRDY   | READY                | Processor command/control input<br>that controls the run state of the<br>processor; if the line is pulled low<br>the processor will enter a wait<br>state until the line is released                                                                                                  |
| 73 | PINT   | INTERRUPT<br>REQUEST | The processor recognizes an inter-<br>rupt request on this line at the<br>end of the current instruction or<br>while halted. If the processor<br>is in the HOLD state or the Inter-<br>rupt Enable flip-flop is reset, it will<br>not honor the request                               |
| 74 | PHOLD  | HULD                 | Processor command/control input<br>signal which requests the pro-<br>cessor to enter the HOLD state;<br>allows an external device to gain<br>control of address and data buses<br>as soon as the processor has com-<br>pleted its use of these buses for<br>the current machine cycle |

| <u>No.</u> | SYMBOL     | NAME             | FUNCTION                                                                                                                                             |
|------------|------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 75         | PRESET     | RESET            | Processor command/control input;<br>while activated the content of the<br>program counter is cleared and the<br>instruction register is set to O     |
| 76         | PSYNC      | SYNC             | Processor command/control output<br>provides a signal to indicate the<br>beginning of each machine cycle                                             |
| 77         | PWR        | WRITE            | Processor command/control output<br>used for memory write or I/O output<br>control: data on <u>the</u> data bus is<br>stable while the PWR is active |
| 78         | PDBIN      | DATA BUS IN      | Processor command/control output<br>signal indicates to external ci <del>r</del> cuits<br>that the data bus is in the input<br>mode                  |
| 79         | AO         | Address Line #0  | · · · ·                                                                                                                                              |
| 80         | Al         | Address Line #1  |                                                                                                                                                      |
| 81         | A2         | Address line #2  |                                                                                                                                                      |
| 82         | A6         | Address Line #6  |                                                                                                                                                      |
| 83         | A7         | Address Line #7- |                                                                                                                                                      |
| 84         | <b>A</b> 8 | Address Line #8  |                                                                                                                                                      |
| 85         | A13        | Address Line #13 |                                                                                                                                                      |
| 86         | A14        | Address Line #14 |                                                                                                                                                      |
| 87         | A11        | Address Line #11 |                                                                                                                                                      |
| 88         | D02        | Data Out Line #2 |                                                                                                                                                      |
| 89         | D03        | Data Out Line #3 |                                                                                                                                                      |
| 90         | D07        | Data Out Line #7 |                                                                                                                                                      |
| 91         | DI4        | Data In Line #4  |                                                                                                                                                      |
| 92         | D15        | Data In line #5  |                                                                                                                                                      |
| 93         | DI6        | Data In Line #6  |                                                                                                                                                      |
| 94         | DII        | Data In Line #1  |                                                                                                                                                      |
| 95         | DIO        | Data In Line #0  |                                                                                                                                                      |

Ŷ

•

| <u>No.</u> | SYMBOL | NAME           | FUNCTION                                                                                                                                         |
|------------|--------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 96         | SINTA  | INTA           | Status output signal to acknow-<br>ledge signal for INTERRUPT request                                                                            |
| 97         | SWO    | WO             | Status output signal indicates<br>that the operation in the current<br>machine cycle will be a WRITE memory or<br>output function                |
| 98         | SSTACK | STACK          | Status output signal indicates<br>that the address bus holds the<br>pushdown stack address from the<br>Stack Pointer; not available with<br>Z-80 |
| 99         | POC    | Power-On Clear |                                                                                                                                                  |
| 100        | GND    | Ground         |                                                                                                                                                  |

· · · ·

#### Parts List

IC 1 -  $8224^{10}$  (8224- $4^{20}$  at 4 MHz) will 34 - This is the Front Panel connector IC 2 - Resistor Pak IC 35 - Resistor Pak IC 3 - 8T97 IC 36 - 2708 EPROM (optional) IC 4 - 8T97 IC 37 - 8T98 or 8098 IC 5 - 8 position spst Dip Switch IC 38 - Resistor Pak IC 6 - 74LS21 IC 39 - 8T98 or 8098 IC 7 - 74LS00 IC 40 - 8T97 IC 8 - 74]2] (Texas Instruments Note: Resistor packs supplied with Recommended) this kit are 16 pin, 15 resis-tor, with pin 16 common. Values IC 9 - 74LS74 IC 10 - 74LS02 between 1K and 4.7K may be used. IC 11 - 8T97 R1 - 4.7KIC 12 - 74LS04 R2 - 1K R3 - 5] ohms IC 13 - 74LS75 R4 - 240 ohms IC 14 - 74LS00 R5 - 3.3 k(1.8 K at 4 MHz)IC 15 - 74LS08 IC 16 - Resistor Pak R6 - 330 .ohms IC 17 - 74LS04 01 - 7805 5 volt regulator ļ - Heatsink -IC 18 - 74LS08 IC 19 - 74LSO4 Y1 - 18.000 MHz crystal (36.000 at 4 MHz) IC 20 - 8T97 L] - ] uhy (needed only with overtone XTAL) IC 21 - 74LS74 D1 - 12 volt zener diode D2 - 5.1 volt zener diode IC 22 - 74LS00 IC 23 - 74LS02 Cl - C3 50-100 uf electrolytic capacitors 25 volt IC 24 - 74LS157 C4, C5, C7, C11 - C24 - .1 uf ceramic IC 25 - 74LS157 capacitors IC 26 - 8T97 C6 - 50 to 100 uf electrolytic IC 27 - 8T97 C8 - 56 pf @ 2 MHz 20 pf @ 4 MHz IC 28 - 8 position C9 - 10 pf SPST Dip Switch C10 - 200pf IC 29 - 74LS138 IC 30 - Z-80 (Z-80A at 4 MHz) IC 31 - 8T98 or 8098 Intel or AND IC 32 - Resistor Pak IC 33 - 8T97

## ITHACA AUDIO Z-80 CPU BOARD

Revisions schedule

- Rev. 0 initial release
- Rev. 1 edge connectors lines 18 and 19 interchanged. Line 18 corrected to chip 22-9; line 19 to chip 7-1.



• .



LAYOUT DIAGRAM 280 BOARD

مريد المع

## ITHACA AUDIO Z-80 CPU BOARD

Revisions schedule

- Rev. 0 Initial release
- Rev. 1 Edge connectors lines 18 and 19 interchanged. Line 18 corrected to chip 22-9; line 19 to chip 7-1.
- Rev. 1.1 RClk changed to RClk U17-10 used instead of u17-11. This improves reset jump operation.
- Rev. 1.2 Data received on the data in bus is no longer placed on the data out bus. This prevents the possibility of ringing on the data busses caused by crosstalk.
- Rev. 1.3 The pins and polarity of refresh have been changed from line 67 to line 66 to correspond with Bus standards.



