This is an old revision of the document!


ECB Zilog Peripherals

Introduction

The Zilog Peripherals board adds Zilog Z80 family serial and counter timer peripherals I/O chips to an existing ECB Z80 SBC or N8 computer.

Pictures

Specifications

  • Two serial ports using Z80-DART or Z80-SIO
  • Baud rates can be jumper selected or use Z80-CTC channels for software programmable
  • Four parallel ports with handshaking using two Z80-PIO
  • Four counter / timers using Z80-CTC
  • Daisy chained priority interrupts for Z80 mode 2 operation

Acknowledgments

The ECB ZILOG Peripherals board is based on a design presented in c't magazine in 1985 “Datenverkehr - Die I/O-Karte fur den ECB-Bus” by Georg Umback. The original documentation for this project can be seen here: development

Andrew Lynch designed the Retrobrew version with David Giles and Douglas Goodall assisting with testing on the SBC V1 & V2 respectively.

Version

The following documentation and files describe version 2 which has not been manufactured and tested as at 29/11/2019. Version 2 adds a jumper to bridge CTC counter 2 and 3 so that CTC counter 2 can be used as a prescaler. The serial headers connectors have been reconfigured to the IBM PC standard. A reset configuration jumper has been added to allow selection of either KONTRON or Legacy (N8VEM) reset method.

Details on prior versions can be can be found here.

Hardware Documentation

Schematics

Board Layout

KiCad Files

PCB Gerber files

Connectors

  • X1 - PIO1
  • X2 - PIO2
  • X3 - DART/SIO channel B (RS-232 levels)
  • X4 - CTC, DART/SIO channel A (TTL levels)
  • X5 - oscillator divider selection
  • X6 - DART/SIO baud rate clock source selection
  • X7 - DART/SIO channel A (RS-232 levels)

Hardware Documentation

Board address

The board occupies 16 I/O addresses. The base address is selected by the jumpers labeled SW1 to SW4 near the ECB connector. All jumpers need shorting headers to select the desired address range. If used with an N8 computer it is generally safe to use address ranges A0h and above. Not all possible conflicts are shown as many of the ECB boards have flexible address selection. The photo shows the board set for 10h to 1Fh.


Base

Address

SW1

(A7)

SW2

(A6)

SW3

(A5)

SW4

(A4)

Conflicts

00h

2-3

2-3

2-3

2-3

I/O on N8 CPU after reset

10h

2-3

2-3

2-3

1-2

20h

2-3

2-3

1-2

2-3

Used for Disk I/O IDE

30h

2-3

2-3

1-2

1-2

Used for Disk I/O Floppy

40h

2-3

1-2

2-3

2-3

N8 CPU registers

50h

2-3

1-2

2-3

1-2

N8 CPU registers

60h

2-3

1-2

1-2

2-3

Used by Z80 SBC I/O

70h

2-3

1-2

1-2

1-2

Used by Z80 SBC I/O

80h

1-2

2-3

2-3

2-3

N8 I/O default

90h

1-2

2-3

2-3

1-2

N8 I/O default

A0h

1-2

2-3

1-2

2-3

B0h

1-2

2-3

1-2

1-2

C0h

1-2

1-2

2-3

2-3

D0h

1-2

1-2

2-3

1-2

E0h

1-2

1-2

1-2

2-3

F0h

1-2

1-2

1-2

1-2

ECB VDU I/O

Visual guide for I/O address setting:

Chip address

Each of the four I/O chips uses four I/O addresses. In this table 'n' is the board base address.


n0h

CTC channel 0

Can be used for DART/SIO channel A baud rate

n1h

CTC channel 1

Can be used for DART/SIO channel B baud rate

n2h

CTC channel 2

n3h

CTC channel 3

n4h

DART/SIO channel A data

on connector X7

n5h

DART/SIO channel B data

on connector X3

n6h

DART/SIO channel A command

n7h

DART/SIO channel B command

n8h

PIO1 port A data

on connector X1

n9h

PIO1 port B data

on connector X1

nAh

PIO1 port A command

nBh

PIO1 port B command

nCh

PIO2 port A data

on connector X2

nDh

PIO2 port B data

on connector X2

nEh

PIO2 port A command

nFh

PIO2 port B command

Z80-DART/SIO

The Z80-DART/SIO provides two serial ports with handshaking. The DART provides asynchronous serial protocols (the type normally used) and the SIO provides asynchronous and synchronous serial protocols. Zilog produced a number of variations to cater for different functions and pinouts. Any type can be used with this board if you allow for the slight pin differences outlined below. The Z80-SIO/9 only has one channel and the pins marked n/c should not be connected.


Pin 11

Pin 25

Pin 26

Pin 27

Pin 28

Pin 29

Z80-DART

RIA

/DTRB

TxDB

/RxTxCB

RxDB

RIB

Z80-SIO/0 (Z8440)

/SYNCA

/DTRB

TxDB

/RxTxCB

RxDB

/SYNCB

Z80-SIO/1

/SYNCA

TxDB

/TxCB

/RxCB

RxDB

/SYNCB

Z80-SIO/2

/SYNCA

/DTRB

TxDB

/TxCB

/RxCB

RxDB

Z80-SIO/9

/SYNCA

n/c

n/c

n/c

n/c

n/c

Where

  • /DTRB - Data Terminal Ready channel B (modem signal)
  • TxDB - Transmit data out channel B
  • RxDB - Receive data in channel B
  • /RxTxCB - baud rate clock input for both channels
  • /RxCB - baud rate clock input for channel B receive
  • /TxCB - baud rate clock input for channel B transmit
  • RIA, RIB - ring indicator input for channel A, B
  • /SYNCA, /SYNCB - synchronisation I/O channel A, B (synchronous modes only)

The ring indicator signals are not on connectors X3 and X7 at RS-232 levels.

The Z80-DART and Z80-SIO/0 can be used without extra board modification.

The Z80-SIO/1 needs pins 26 and 27 joined at the chip for the same baud rate on transmit and receive, chip pin 25 routed to board pin 26, no DTR or RI signals.

The Z80-SIO/2 needs pins 27 and 28 joined at the chip for the same baud rate on transmit and receive, chip pin 29 routed to board pin 28, no RI signal

The Z80-SIO/9 needs all channel B pins left disconnected.

One recommended modification is to bridge pins 13 and 14 of the Z80-DART/SIO. This joins /RxCA to /TxCA so channel A has the same baud rate clock source on receive and transmit.

Baud rate selection

There are two ways of providing the baud rate clock to the Z80-DART/SIO. For a fixed baud rate it uses the divider selection on header X5. Programmable baud rates can use the CTC channels (detailed later).

The source of the baud rate divider can be either the system clock (PHI) or an oscillator module at position U8. Recommended oscillator modules are 4.9152MHz or 2.4576MHz. This clock source is fed to a 74LS393 which divides it by 2 to 256 depending on a jumper at header X5. This divided source (PHI_X) is routed to the Z80-DART/SIO and/or Z80-CTC. From this it can be seen as very flexible (or confusing) so a simple example will be given. The source for the divider will be a 4.9152MHz oscillator module. This will be divided by the 74LS393 to give a fixed baud rate to both channels of the Z80-DART/SIO from 300 to 38400 baud (76800 and 153600 baud rates are also possible, for 115200 a 1.8432MHz oscillator is used in U8 and no divider).

First jumper pins 15-16 of X5 to select the oscillator module. A second jumper on X5 selects the divider output for PHI_X. The /16 or /64 option is programmed into the Z80-DART/SIO registers. The photo shows the jumpers for 9600 baud.


BAUD

PHI_X (Hz)

/16 or /64

X5 Jumper

300

19200

/64

3-4

600

38400

/64

3-5

1200

19200

/16

3-4

2400

38400

/16

3-5

4800

76800

/16

6-8

9600

153600

/16

7-8

19200

614400

/16

8-10

38400

1228800

/16

9-11

More information on baud rate selection and limitations can be found here.

Next the Z80-DART/SIO's clock pins need to be connected to PHI_X using header X6. For the fixed baud rate jumper pins 3-5 or 5-7 for channel A and 8-10 for channel B of header X6 (as in the photo). This assumes the above recommended modification has been made.

  \
 ==== Serial leads ====

X3 / X7 pin

Signal

DB-9M

DB-9F

Note

1
DCD in

2
DSR

3

/Rx in

4

RST out

5

/Tx out

6

CST int

7

DTR out

8

RI

9

GND

10

n/c

n/c

n/c

Z80-CTC

The Z80-CTC provides four counter / timer channels. Channel 0 can be used as the baud rate clock source for the Z80-DART/SIO channel A. Channel 1 can be used for the Z80-DART/SIO channel B baud rate clock source. All four channels are available on header X4.

The channels can also be used to provide mode 2 vectored interrupts for non-Zilog I/O (e.g. the UART on the Z80 SBC V2). To do this put the channel into counter mode with a preset value of 1. When the trigger input is activated by the interrupt source, the counter will decrement to zero and cause an interrupt to the CPU with the vector provided by the Z80-CTC.

Channel 2 & 3 can be configured to provide a 50Hz interrupt which can facilitate implementing multi-tasking system. This required setting appropriate clock dividers, configuration jumpers and software modes.

  • Assuming 4.9152Mhz crystal
  • Jumper X5 pins 15-16 and pins 9-11
  • Jumper X5 pin 3 (PHI_X) to X4 pin 7 (CTC_TG2)
  • Jumper P1 (on v1 board jumper X4 pin 8 (CTC_ZC2) to X4 pin 9 (CTC_TG3)
  • Configure the interrupt vector.
  • Configure channel 3 to divide by 256
  • Configure channel 4 to divide by 48 and interrupt.
  • Refer to ROMWBW ctc.asm driver for example.

To enable the CTC, ROMWBW must be rebuilt with the following custom configuration added:

SBC_std_cust.asm

CTCENABLE     .SET     TRUE    ; ENABLE ZILOG CTC SUPPORT
CTCBASE       .SET     $B0     ; CTC BASE I/O ADDRESS

Correct operation of the 50Hz interrupt timer can be confirmed with the TIMER.COM:

TIMER /C

Z80-PIO

The Z80-PIOs provide two 8-bit parallel ports each. Each Z80-PIO has its own header with 5v and GND lines for connecting to the outside world. Note these connectors have a totally different layout to the PPI connectors on other boards. No jumpers need to be set to use these Z80-PIOs.

Interrupts

The /INT pins from the Z80-DART/SIO, Z80-CTC and Z80-PIOs are connected together as a 'wired-OR' gate and buffered for a common interrupt to the CPU. These pins are open-drain outputs so they can be connected together. The board is setup for Mode 1 or Mode 2 interrupts. The four chips are also daisy chained to give priority to the interrupts. The Z80-CTC has the highest priority, followed by the Z80-DART/SIO, Z80-PIO1 and lowest is Z80-PIO2. Z80-CTC channel 3 is ideal for use as a 'general' mode 2 interrupt as it doesn't have an output pin.

For example, to use the UART on the Z80-SBC MK-II board with mode 2 interrupts requires a jumper setting and a hardware modification. On the N8VEM Z80-SBC MK-II jumper pins 2-3 on k12. This connects the UART interrupt to A23 on the ECB connector. On the Zilog peripherals board solder a bridge between A23 on the ECB connector and pin 20 of the Z80-CTC. Alternatively solder to pin 11 of header X4 and jumper pins 9-11 to connect to the Z80-CTC. The N8VEM Z80-SBC MK-I requires more modifications and is not covered here.

Initial Testing

For this section I will assume the base address of the board is B0h, the oscillator module at U8 is 4.9152MHz. On X5 there are jumpers between 7-8 and 15-16 to give a baud rate of 9600. On X6 jumper pins 3-5 and 8-10 to put the baud rate clock to the Z80-DART/SIO. If available use a frequency counter to measure 153600Hz at pins 13, 14 and 27 of the Z80-DART/SIO.

Testing the Z80-CTC

On X6 put a jumper on pins 2-4 to put the 153600Hz signal to channel 0. Using DBGMON send the following to the Z80-CTC. (Text in blue is what you type)

>O B0 47
>O B0 00
>O B1 27
>O B1 00

The first command sets channel 0 as a counter, the second sets the count value to 256. The output on pin 7 of the Z80-CTC should be 600Hz (153600 / 256). The third and fourth commands set channel 1 as a timer which divides the system clock by 65536. Given my setup has the CPU running at 4MHz the output on pin 8 of the Z80-CTC should be a bit over 61Hz (4000000/65536). The outputs are not a square wave but a series of pulses and were too short to be picked up by my ancient logic probe. However they measured correctly on my frequency counter. An oscilloscope would be handy as well.

Testing the Z80-DART/SIO

I am using a SIO/0 on my board. The DART uses the same register layout except the synchronous stuff is missing.
Loopback test. Install a jumper between pins 3 and 5 of X7 to connect TxD with RxD of channel A. Using DBGMON send the following:


>O B6 04 select write register 4
>O B6 46 x16 clock, 1 stop, no parity
>O B6 01 select write register 1
>O B6 04 disable interrupts
>O B6 03 select write register 3
>O B6 C1 8 bits, no auto enables, receiver enable
>O B6 05 select write register 5
>O B6 EA DTR on, RTS on, enable transmit


Next check the status by

>I B6

Bit 6 is set after a chip reset and is cleared with

>O B6 C0

If bit 2 (Tx pending) is set then we're ready to transmit, so

>O B4 40

will send the character 40 (@) to the transmit buffer. Then read status and bit 0 should be set to indicate a character has been received. Read it with

>I B4

and the result should be 40. If not then try again as it could be leftover crud in the receive buffer.
Once the loopback test is successful then take out the jumper in X7, put in your carefully constructed serial lead and try it with a terminal.

Testing the Z80-PIOs

After reset the Z80-PIOs will have their ports set to mode 1 (all inputs). Using the monitor to read the four ports at 0xB8, 0xB9, 0xBC and 0xBD (i.e.I B8) will read the values on the pins. With nothing connected to headers X1 and X2 my Z80-PIOs read all zeros. A clip lead from the 5 to any I/O pin will show up as a different value when the port is read.

A simple register test program is available (base address 0xB0): :boards:ecb:zilog-peripherals:2piotst.zip


At this stage you should have a functioning Zilog Peripheral Board. Combined with the SBC V2 you now have enough serial ports, timers and parallel ports to create a working MP/M system. Any takers?

Using the Z80-PIO with a Centronics printer.

The Z80-PIO has four modes of operation - input, output, bi-directional and bit. The input and output modes have handshaking pins for each port, the bi-directional mode (port A only) uses handshaking pins from both ports and bit mode uses no handshaking pins. For a printer the output mode is used with the port's RDY pin used as a strobe output and the /STB pin used as an ACK input. However the RDY signal is too short (and the wrong polarity) for the printer. This signal is used to trigger a monostable (say a 74LS123) with an active low output pulse about 0.5mS long. The BUSY signal and other control lines go to/from the other port in bit mode.
Buffering the data and control lines are needed for long cables. Use a 74LS245 or similar for the data lines, a 74LS07 or similar for the control lines.

The above idea has been prototyped and may become a future mini-board.

Resources

Datasheets

FilenameFilesizeLast modified
2piotst.zip3.4 KiB2018/09/24 10:21
ctctimer.gif99.4 KiB2020/01/29 05:57
zilog-peripherals-jumpers.png13.2 KiB2018/07/16 09:56
zp_zilog-peripherals.zip5.4 KiB2018/04/22 12:30
zp_zilog_peripherals_init.txt1.6 KiB2018/04/22 12:50


boards/ecb/zilog-peripherals/start.1624965989.txt.gz · Last modified: 2021/06/29 07:26 by b1ackmai1er
Driven by DokuWiki Recent changes RSS feed Valid CSS Valid XHTML 1.0