Skip to content

Latest commit

 

History

History
112 lines (66 loc) · 5.43 KB

README.md

File metadata and controls

112 lines (66 loc) · 5.43 KB

ND-120 CPU

Content

This repo contains:

  • Original Norsk Data ND-120 CPU Design Documents from 1988. Scanned in 2023
  • Modern Logisim and HDL implementation from 2023.

You can read more about this CPU and much more in NDWiki and the official website for Norsk Data

The goal of this repo is to re-create the schematics and create the HDL files so we can program an FPGA to run as the original ND-120 CPU Card.

On the way to the FPGA code, there will be testable Logisim Circuits and Logisim code that can be converted and tested in C++ using Verilator.

History

Compressed history of the work progress:

Date Description
11. March 2023 Received Design Documentation from Lasse Bockelie
21. August 2023 Logisim Drawings completed for DGA and DELILAH/CGA
03. December 2023 Using Logisim drawings to start generate Verilog files for DGA and CGA
12. December 2023 Starting to consolidate all information about PAL chips (PNG for PALASM code, OCR to TXT and write Verilog version of PAL code)
26. December 2023 Logisim drawings of CPU Board 3202D completed
27. December 2023 Using Logisim drawings to start generate Verilog files for CPU Board 3202D
11. January 2024 Most PALASM code has been ported to Verilog
January-June 2024 Adding support chips, refactoring and bugfixing. Adding tests and test results
June-November 2024 No work done
9. November 2024 Starting up again after a long break. Cleaning up code, refactoring and testing. Connecting everything together.
20. November 2024 Verilator - Microcode is loaded from ROM to DRAM. MACL microcode starts but fail on STACK operations, and fails on COND operations.
13. December 2024 Verilator - Microcode MACL starts, CPU test code runs. OPCOM is initialized and communication over UART works.

Requirements

The minimum requirements to make the CPU work is:

Component Schematic HDL Status
DELILAH CPU Gate Array (CGA) Completed Logisim generated Verilog QA on schematic/Verilog ongoing
NEC Decoder Gate Array (DGA) Completed Logisim generated Verilog QA on schematic/Verilog ongoing
ND 3202 CPU Board revision D Completed Logisim generated Verilog QA on schematic/Verilog ongoing
PAL Chips All PALASM code has been validated Verilog and testcode created QA on Verilog ongoing

In the CPU Board we will plug in the DELILAH CPU and the Decoder, all PAL chips and several other support chips (74-series, RAM and UART,++)

Stretch goals

Design and implement I/O devices for reading and writing files from FLASH memory simulating the device.

  • Floppy
  • Hard Drive

Design documents

All the design documents are in the Design Documents folder.

Norsk Data documents

Functional Description, Instruction set, Microprogramming guide and more are in the NorskData-Doc folder.

Microcode

The Microcode dump is from a ND-120 3202 CPU Board is Version 14/L The source code is also for the L version.

Panel Controller - 6805 CPU CHIP

ROM dump

The ND-120/CX CPU Board has an on-board MC68705-U3 CPU.

The physical front panel also has an MC68705 CPU, however this chip is not identical to the on on the 3202D CPU Board - its an MC68705-P3 with fewer I/O pins.

The MC68705 is an MC 6805 8-bit CPU with on-chip RAM, I/O and Timer. Motorola 68HC05

  • P3 version = 28 pins, 2x 8 bits I/O ports, 1x 4 bit I/O port
  • U3 version = 40 pins, 4x 8 bits I/O ports

We have a ROM dumps from both the MC68705-U3 chip (from the 3202D CPU Board) and the MC68705-P3 (from an ND-5000C panel controller).

Big thanks to Matthieu Benoit for reading the data out of the chips

Reverse engineering has been done using the free SRE tool GHIDRA from NSA.

Schematic drawings

Logisim

All the Logisim files are stored in the Logisim folder

Logisim Requirements

You need to install the Logisim-Evolution design tool from Logisim Evolution Repository

The Logisim diagrams has been drawn with Version 3.8.0

FPGA

Verilog

Most Verilog files are generated from the Logisim drawings, using Logisim-Evolution FPGA tools.

All the Verilog files are stored in the Verilog folder

Verilator

To test the Verilog code using Verilator you need to install the Verilator tool