

Based on original ZX81 design



## MICRO COUNTER

The MICRO COUNTER, is a four bit counter that starts to count at the beginning of each /M1 cycles and reset to zero on the rising edge of the 4th t state just in time to start counting again. Using the 6.5Mhz clock signal as the lowest bit its possible to split the 4 t states into 16 time zones. It was found that I only needed to split it into 8 zones corresponding to each half cycle of the CPU clock during the M1 cycle. This counter is used to trigger the various events during the Forced NOP cycle. When /M1 goes low the inverter clocks the positive edge triggered D flip flop which then outputs a low on it Q output this releases the active high clr input on the counter which is clocked at double the CPU clock by the /6.5Mhz signal when the count reaches 8 it presets the Q output via the other inverter, clearing the count back to zero ready to be triggered again by the next M1 cycle by resetting at 8 it ensures that our circuit will not interfere with any instruction that has a longer M1 cycle. The signal L\_PRE is used to preset the NOP THIS CYCLE Flip flop at the end of each cycle.



## /ROMCS & /RAMCS

Takes A14 and OR's it with /MREQ to generate the /ROMCS signal (both A14 and /MREQ low).

Takes an inverted A14 and OR's it with /MREQ to generate the /RAMCS signal (A14 high and /MREQ low).

## NOP THIS CYCLE

Sets the output of the 7474 Low when a videl cycle is detected

The next Flip flop in the video circuit detects whether this M1 cycle is a video cycle or not, by using D6, A15, /HALT and /M1. The latched output will remain in the low state until the rising edge if the next CPU M1 cycle, it is preset to 1 when my micro counter reaches 8.





# IO READ-WRITE

Gives a low on /IORD or /IOWR depending if its a read or write IO instruction used in the VSYNC & NMI Control circuit.



### FORCE NOP CYCLE

This is the bit that actually forces all logic lows (B inputs tied to ground) when the outputs (the A bus) are enabled the CPU data lines are forced low, forcing the NOP cycle.



#### ZX81 Project

Augusto Baffa © Feb/2021

Based on original design by Andy Rea

## **VIDEO INVERTER**

The video inverter circuit consist of a flip flop that latches the state of the invert bit of the character code from the char code latch but only if this cycle was is a forced NOP, if it is not a forced NOP then the top or gate allows the invert bit7 through to the D input ready to be latched every time when the micro counter reaches 7 falling edge of T4, if it is a forced NOP cycle also via the bottom or gate the shift register is allowed to load the new character pattern, otherwise it will continue to load in white video via its serial input below.





All that remains now is to get the VSync, Hsync and Video all together to produce a useable composite video signal

This is done with the following. Δ U24:B R3 560 /HSYNC CSYNC VSYNC D 大 74LS86 D2 Q1 R2 1N4148 NPN BF199 or Equivalent RV1 CVID OUT Which combines the Hsync and Sync to give a low output which turns off Q making the output 0V Whilst the live video signal drives the emitter 1k follower to give the final composite video. -

ZX81 Project

Augusto Baffa © Feb/2021

Based on original design by Andy Rea



### ZX81 Project

Augusto Baffa © Feb/2021

Based on original ZX81 design





If the VSync pulse is started the OR gate on the left holds the pair of counters in there reset state (all outputs low) otherwise the counters will count each of the clock pulses from the 3.25Mhz signal the lower counter been clocked at 1/16 of the main clock signal when the count reaches 192 the sync becomes active via the 2 input AND gate (connected to Qc an Qd of the second counter) and will remain so for the next 15 clock pulses until the count reaches 207 at which point the pair of 3 input and gates in conjunction with inverters (I didn't have a 7411 which would negate the need for the extra inverters) almost instantly resets both counters back to zero. So left free running you get a 15 cycles long pulse every 207 cycles (4.61uS long, every 63.69uS, we are aiming for 4.7uS and 64uS respectively) due to the way the Zeddy generates the video it is a requirement that the hsync pulses are slightly short so they remain synchronized with the video from the zeddy.

The hsync pulses are also used for the /NMI pulses if the NMI is turned on.



This circuit is quite simple as long as you understand how a nand gate RS latch works.

There are 2 latches used in the zeddies one for the VSYNC pulse (the top latch) and one for the NMI on or off control the (bottom latch)

So a read on port \$FE [ IN A.(\$FE) ] will always read the keyboard and if the NMI generator if off will also toggle the RS latch starting the VSync pulse and stopping the hsync generator.

Any port write will stop the VSync pulse and restart the hsync generator.

The NMI control is done of two separate ports, a write to port \$FE will turn on the NMI generator, and a write to port \$FD will turn off the NMI generator.

**ZX81 Project** 

Augusto Baffa © Feb/2021

Based on original design by Andy Rea

