Skip to content

Latest commit

 

History

History

vm3

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 

Die photo

Die photo

Links to raw panoramic photos (CAUTION: files are VERY LARGE, browser might hang):

1801BM3

The 1801BM3 is a single-chip microprocessor, was designed in the second half of 1980-th and had PDP-11 compatible architecture. Notable, it was not an exact clone of one of the original DEC processors but had its own internal architecture.

The 1801BM3 is the further development of 1801BM1/1801BM2 and is the most performance microprocessor in the 1801 series, encompasses MMU, and provides an integrating option for external FPP (dedicated 1801BM4 chip). Its ALU takes 3 clocks per micro-operation, there is the dedicated PC adder (i.e ALU is not used to update PC), and 1801BM3 is capable to execute a register-register command only in 3 clocks. The 1801BM3 is not based on the static design, there is presumably a lower limit of operating frequency about 100kHz.

Compatibility

The closest DEC model 1801BM3 matches is PDP-11/34, it supports:

  • odd address trap
  • PSW mapping to 177777768
  • mtps and mfps instructions
  • ash, ashc, mul, div instructions
  • MMU SR0 diagnostics M-bit
  • exception on 012 and 102 CPU mode
  • non advancing (Rx)+, @(Rx)+ in case of exception
  • fully compatible 11/34 MMU in 18-bit mode
  • 22-bit MMU extension (absent in original 11/34)

Known 1801BM3 incompatible issues

  • all reserved SR3 register bits are readonly and read out as ones
  • if instuction runs into bus timeout and on exception handling the MMU exception occurs, the SR2 contains the address of the next instruction
  • special HALT mode is implemented to handle halt instruction and double error exceptions in kernel mode, provides ODT functionality with external ROM program

Models passed the factory tests

The factory tests passed by the asynchronous model in simulation:

  • fkaac0 - 11/34, basic instructions test
  • fkabd0 - 11/34, traps and exceptions test
  • fkaca0 - 11/34, extended instruction set test (EIS)
  • fkthb0 - memory management unit test (11/34, 18-bit MMU)
  • jkdad0 - memory management unit test (F11, 22-bit MMU)
  • haltm - halt mode test, 1801BM3 specific

Directory structure

\hdl

  • 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

\hdl\org

  • 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-flops), ones work in non-reliable fashion on synchronous FPGAs. Also model does not contain 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. May not be synthesizable with some tools, presented for simulation purposes only.

\hdl\syn

  • synchronous Verilog HDL model, the frontend bus is Q-Bus, uses single clock to operate, does not contain latches, and whole model can be synthesized for synchronous FPGAs. This model is intermedate step for final Wishbone-compatible version.

\cad\vm3 (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)

Work in Progress