Links to raw panoramic photos (CAUTION: files are VERY LARGE, a browser might hang):
- 1801BM1А Top metal, 19Kx19K, 524M
- 1801BM1А Diffusion, 12Kx12K, 202M
- 1801BM1Г Top metal, 19Kx19K, 525M
- 1801BM1Г Diffusion, 18Kx18K, 472M
The 1801BM1 is the single-chip processor designed in early 1980th with PDP-11 compatible architecture. Notable, it is not an exact clone of one of the DEC processors but has its own original architecture and PLM-based state machine.
It supports PDP-11 basic instruction set and extra instructions SOB and XOR from Extended Instruction Set (EIS). No MMU is implemented. There were designed and produced two versions of 1801BM1 - K1801BM1A and K1801BM1Г (Cyrillic letter "Г"), they had the same architecture but completely different PLM content, implementing different state machines. The goal of this microprogram refactoring was to add MUL instruction support into K1801BM1Г.
The processor was produced in the 5-micron NMOS process with depletion-mode loads, one metal and one polycrystalline silicon layer, and self-aligned gates. The 1801BM1A contains 16632 gates, 1801BM1Г - 16646 gates, operates at 5MHz/5V, and provides 625K register-register instructions per second. The front-end bus is Qbus compatible, the multicore configuration is supported with up to 4 processors one the same bus. Also there is the built-in timer, 1801BM1Г supported timer interrupts.
There is no internal ODT implemented, the in-system test and debug are supported with special HALT mode and external ROM.
- the very detailed processor description (in Russian), including internal structure and microcode execution, the built-in timer details unveiled, all actual bus diagrams described. The document has been written on the base of reverse engineering
- the directory contains HDL-related materials, sources, and sample projects for Quartus and ISE. There are three models: original asynchronous, refactored synchronous and Wishbone compatible
- asynchronous Verilog HDL model is as close as possible to the original gate-level schematics. In practice can be used for modeling purposes only, because processor contains latches (note, it differs from flip-flop), those work in non-reliable fashion on synchronous FPGAs. Also model does not contain gate and line delays, in some simulating environment it can be very critical. Nonetheless, this model is included in the package as a demo of the closest possible approximation to the original die. Maybe not synthesizable with some tools, simulation only.
- synchronous Verilog HDL model, the frontend bus is Q-Bus, does not contain latches, and can be synthesized for synchronous FPGAs. All internal and external timings are precisely the same as in an asynchronous original model with precision to half period of high-frequency clock. This model can be used to build the in-socket replacement of real 1801BM1 chip
- synchronous Wishbone compatible version of 1801BM1 synchronous core uses a single clock, is FPGA-optimized, and follows the original command execution timings, is intended for SoC building
\cad\vm1 (moved to dedicated repo)
- topology in Sprint Layout format
- topology in PCD-2004 pcb format
- schematics in PCD-2004 pcb format
- schematics in pdf (gate level)
- test software, including restored factory test sources and ROM images. Build batch should be run before building FPGA bitstream to include test software image
- run "tst\build.bat t401" to prebuild desired test software image (t401 is a sample)
- run ModelSim simulator
- set "vm1/hdl/org/sim/de0" as working directory in ModelSim (File->Change Directory)
- execute "do run.do" console command
- wait, simulation may take some time till complete
- see the results in waveform and console output
- RAM 8Kx16bit at 0000008 with initialized content from test.mif file
- TTY at 1775608, 608/648 vector interrupts, tx/rx with cts/rts handshake, 115200/8/N/1, RS-232 levels (board dependent).
- 50Hz system timer interrupt (IRQ2, edge sensitive, vector 1008), enabled by board switch[0], if timer is enabled the board led[0] lights
- 4x7-segment display, segments attached to output registers at 1777148/1777158, see the test software source for the details
- switches and buttons can be read from input register at 1777148
- board button[0] is reset, short press less than 1 sec causes system reset, long press over 1 second simulates power reset (excluding RAM content)
- Wishbone compatible 1801BM1A core
- register file and constant generator in RAM block
- balanced area/speed optimization chosen
- slow model, worst corner
All results are just approximate estimations by synthesis tools (Quartus/XST/Vivado) on sample projects.
Board | FPGA | Family | Fmax | LUTs | FFs | MEM |
---|---|---|---|---|---|---|
DE0 | EP3C16F484C7N | Cyclone III | 111 MHz | 1420 | 427 | 1 M9K |
DE1 | EP2C20F484C7N | Cyclone II | 94 MHz | 1410 | 464 | 1 M4K |
DE2-115 | EP4CE115F29C7N | Cyclone IV | 111 MHz | 1370 | 425 | 1 M9K |
AX309 | XC6SLX9FTG256-2 | Spartan 6 | 72 MHz | n/a | 387 | 1 BR8 |
DE10-LT | 10M50DAF484C7G | Max 10 | 82 MHz | 1373 | 469 | 1 M9K |
QC5 | 5CEFA2F23I7N | Cyclone V | 131 MHz | 693 | 384 | 1 M10K |
QC10 | 10CL006U256CN8 | Cyclone 10 | 108 MHz | 1349 | 694 | 1 M9K |
EG4 | EG4S20BG256 | Eagle EG4S20 | 95 MHz | 1810 | 621 | 1 M9K |
QA7 | XC7A35TFTG256-1 | Artix 7 | 124 MHz | 1298 | 669 | 0.5 BR |
QK7 | XC7K325TFFG676-1 | Kintex 7 | 181 MHz | 1301 | 633 | 4.5 BR |