Skip to main content

Building the TD4 4-Bit CPU

The TD4 is a famous 4-bit CPU featured in the book How to Build a CPU by Kaoru Tonami. The book focuses on constructing a functional processor entirely from basic 74-series TTL logic ICs. While the book is unfortunately only available in Japanese, a friend from Japan sent me a copy along with a TD4 PCB. I believe the PCB is based on the open-source design files available on BG5DIW's GitHub repository.

"How to Build CPU" book and the PCB.

Recently, I finally found the time to build and experiment with it. The project took a few months, as I had to translate the book myself to grasp the core concepts. The overall design is simple and elegant, offering a set of 12 instructions and a 16-byte ROM (implemented via DIP switches) for programming. The board operates on 5V and can be powered via USB. Most components were sourced from local shops, though I had to order a few 74HC-series ICs online. Later, I tested the circuit by replacing some 74HC components with 74LS series chips, and it worked without any issues.

The PCB is straightforward to solder. The only SMD components are four LEDs and a Micro-USB socket. If you haven't done SMD soldering before, the USB socket might look intimidating, but you only need to solder pins 1 and 5 (the remaining pins are not used in this design). 

Assembled TD4 CPU.

The most time-consuming part of the assembly was soldering the 1N4148 diodes. The book suggests using a 1S1588 or a D8-1A diode network, but these are difficult to source locally or online. Therefore, I opted for individual 1N4148 diodes. In the TD4 architecture, these diodes function as a Diode Matrix ROM. Since the "program" is stored via physical DIP switches, the diodes act as one-way gates. They prevent current from back-feeding into other parts of the circuit when multiple switches are flipped, effectively creating the logic gates necessary to decode the 16-byte memory addresses into specific 4-bit instructions for the CPU to execute.

Once assembly is complete, the TD4 is ready for immediate use; it requires no firmware or calibration. The PCB offers two power options: the easiest is via the Micro-USB port, while the second is a 2.54mm pin header. I used the pin header to attach the power leads for my logic probe, which was essential while I studied the circuit's operation alongside the book.

Functional TD4 CPU.

The TD4 is a hard-wired logic CPU, meaning it doesn't use a microprogram; every instruction is executed by direct electrical paths through the logic gates. The chipset typically consists of:

  • 74HC161: Used for the A and B registers and the Output port.
  • 74HC161: Another 4-bit counter used for the Program Counter (PC).
  • 74HC153: Multiplexers that act as the selector for the ALU inputs.
  • 74HC283: Configured as 4-bit ALU.
  • 74HC10 and 74HC32: NAND/AND gates used for the instruction decoder.

The clock is generated by a simple 74HC14 oscillator circuit, allowing you to step through instructions manually or run them at a very low frequency to watch the LEDs toggle as data moves between registers.

System clock can monitor from pin 2 of any 74HC161 counter.

The most interesting part of this project is programming the system. Due to the limited address space, the tasks you can perform are modest. I experimented with various counter systems, and all worked as expected. I initially wrote the code on paper and calculated the DIP switch positions manually based on the book's instruction set.

To simplify this process, I developed a small web-based utility using JavaScript that converts assembler source code directly into DIP switch positions. This allowed me to iterate quickly and try out more complex logic. You can find this TD4 Assembler utility here: github.com/dilshan/td4-assembler.

The logic levels of this system can easily monitor using logic probe.

This is one of the counter programs I tested with the CPU. This specific routine reads the input from the DIP switches and increments the value with every clock cycle. Once the counter reaches 0xF, it resets back to the user-specified starting value and resumes counting.:

in b
out b
add b, 1
jnc 1
jmp 0
Address bus and C-flag states of above code listing when input = 0x8.

The TD4 is the perfect "Hello World" for computer architecture because it strips away the complexity of modern processors. There are no hidden layers-no microcode, no complex cache, and no operating system. By building it, you see exactly how a bit moves from a switch, through a multiplexer, and into a register. It demystifies the relationship between physical hardware and software logic, making it an invaluable educational tool for anyone interested in embedded systems or electronic engineering.

Details for How to Build a CPU can be found at the publisher's support site. A TD4 emulator (Windows only) is also available for download at the same link.

Comments

Popular posts from this blog

CD2003 - yet another simple FM radio receiver

In the last few days, we are looking for some simple FM radio receiver to integrate into one of our ongoing projects. For that, we try several FM radio receiver ICs including TDA7000, CD2003/TA2003/TA8164, CXA1019, and KA22429. Out of all those chips we select CD2003 (or TA2003/TA8164) based receiver for our project because of its simplicity and outstanding performance. Except to CD2003, Sony CXA1019 also perform well but we drop it because of its higher component count. We design our receiver based on Toshiba TA2003 datasheet and later we try TA8164 and CD2003 with the same circuit. Either CD2003 or TA8164 can directly replace TA2003 IC, and as per our observations, TA8164 gives excellent results out of those 3 chips. A prototype version of CD2003 FM radio receiver The PCB design and schematic which we used in our prototype project are available to download at google drive (including pin-outs of crystal filters and inductors ). Except for CD2003 IC, this receiver consist...

Arduino superheterodyne receiver

In this project, we extend the shortwave superheterodyne receiver we developed a few years ago . Like the previous design, this receiver operates on the traditional superheterodyne principle.  In this upgrade, we enhanced the local oscillator with Si5351 clock generator module and Arduino control circuit. Compared to the old design, this new receiver uses an improved version of an intermediate frequency amplifier with 3 I.F transformers. In this new design, we divide this receiver into several blocks, which include, mixer with a detector, a local oscillator, and an I.F amplifier. The I.F amplifier builds into one PCB. The filter stage, mixer, and detector stages place in another PCB. Prototype version of 455kHz I.F amplifier. In this prototype build, the Si5351 clock generator drives using an Arduino Uno board. With the given sketch, the user can tune and switch the shortwave meter bands using a rotary encoder. The supplied sketch support clock generation from 5205kHz (tuner f...

Experimental narrowband FM receiver for 2-meter band

This project is about MC3362 and ADF4351 based modularized, 2-meter narrow band FM receiver. In this design, the receiver splits into three modules as RF preamplifier, MC3362 tuner, and ADF4351 oscillator. The RF preamplifier builts around BF900 dual-gate MOSFET. The tuner stage builts using the popular MC3362 , low power narrowband FM receiver IC. For the oscillator, we use the ADF4351 DDS RF signal generator module. The core component of this receiver is MC3362 IC. This IC was designed by Motorola and is no longer in production, but this IC is still available to purchase in many online stores . The chip we used in this receiver was purchased from a local electronic component store for LKR 75 (USD 0.2). The RF preamplifier used in this receiver extracts from the N.Ganesan's (VU3GEK) LRR200, 2-meter band FM receiver project . Prototype version of the RF preamplifier. In this prototype, the above preamplifier was built as a module using a Manhattan construction technique. Th...