Capricorn CPU microcode


I started to look more precisely to the Capricorn CPU with the HP patent # 4424563.
With this patent I started to look at the microcode of the CPU, but it appears that the given microcode is not the final one. It can be seen with the LDM R4,=xxyy instruction.
In a real HP85/86 this code jump to xxyy+1 address and with the microcode from the patent this jump to xxyy+3 or +4 (if DRP R4 code before).

Does anyone have more informations about that ?

Thanks in advance.


Edited: 4 Mar 2010, 11:16 a.m.


Interesting. The patent application was submitted at a late enough date that the PLA contents (microcode) should have been long since finalized. I haven't yet studied it in enough detail to confirm your finding, so perhaps you could explain in a bit more detail how the patent microcode gets to +3/+4 rather than +1.

Aside from finding someone who worked on it, the only way I know to determine the exact microcode in a production Capricorn chip would be to decap and photomicrograph the chip, and thereby extract the PLA pattern.


Here is a link to an excel file with the microcode executed for each opcode:

The first page is the PLA decoded with some comments.

The second is about the outputs of the control logic.

The third is the microcode for each opcode (the Byte and Multibyte opcode are grouped). This was done with a python script interpreting the PLA for each opcode.

The fourth is the opcodes in octal, the fifth in hexadecimal.

The comments are mainly in french, sorry.

It was used to make a simulation with tkGate software. Actually it's operational (based on the patent and some other documentations) but this bug is a serious one ...

To see the bug, look at 'Ajustement PC' : adjust the PC (R4-5), code done after the most opcodes (and particularly NOT done after ARP and DRP opcodes see 'ARP R#' witch jump back to state 16d (read a new opcode)).

It can be seen that after 'LDM D,=a' opcode the jump is made to state 7d (Adjust PC)

Adjust PC (state 7d for PCL:R4 and 17d for PCH:R5) is adding N register + 1 to PC.
N is an internal register counting the bytes read from the last 'real' opcode, and in this case the =a loop (state 1, near excel line 148, is done 2 times and stopped due to RPTE input) increments N by 1 at each loop (NCDM column, INN output).
If a DRP R4 opcode was just before the LDM, N was already incremented by one (state 25d excel line 41).

So the total adjustment is 3 or 4.

It is consistent with the tkGate simulation where the PLA is computed with a Verilog script to drive the rest of the CPU (done with the schemes from the patent).

Edited: 5 Mar 2010, 5:38 a.m.


I was having trouble visualizing the flow of the microcode, so I used graphviz to plot a graph of the state machine:

It only has the state numbers (in octal), without any annotations to explain the meanings of the states or transitions.


Thanks for the graph, I found a mistake in the excel file given previously.
After state 37O (31d) it's state 4O (4d), not 8O as I used ...
I'll look at it more precisely.

It's only in the excel file not on the microcode I used, so not a real mistake.

Anyway, I just wired a small hack to the simulation (CLN when WRAM and CDRP==5 for those who might understand ;) ) and it's enough to continue

Edited: 5 Mar 2010, 11:19 a.m.


Anyway, I just wired a small hack to the simulation (CLN when WRAM and CDRP==5 for those who might understand ;) ) and it's enough to continue

Could this 'hack' exist already in the real HP-85, either as a few gates inside the Capricorn processor chip or as external logic?




Yes it could be. It's a simple one only 10 gates or so and all the signals are already in the function block 'COUNTERS' (on patent fig 1)

Possibly Related Threads…
Thread Author Replies Views Last Post
  HP-71B CPU frequency? Christoph Giesselink 18 4,771 03-02-2013, 09:35 AM
Last Post: Gerson W. Barbosa
  OT: Mechanical CPU clock Ethan Conner 1 1,120 04-19-2012, 01:23 AM
Last Post: Mike Morrow
  HP 15C LE programming, does CPU run fast? designnut 1 1,095 02-12-2012, 05:13 PM
Last Post: Jeff O.
  Emulator CPU usage Martin Pinckney 6 2,030 10-13-2010, 01:43 AM
Last Post: HrastProgrammer
  HP-35 Microcode-level Emulator (in JavaScript!) Ashley Nathan Feniello 4 1,468 10-02-2010, 03:23 PM
Last Post: Frank Boehm (Germany)
  HP-35 Microcode-level Emulator (in JavaScript!) Ashley Nathan Feniello 1 963 09-02-2010, 01:39 AM
Last Post: Pal G.
  HP nut CPU and illegal instruction sequences HÃ¥kan Thörngren 9 2,604 01-05-2010, 12:50 PM
Last Post: Eric Smith
  Lab-Volt (348?) cpu trainer peter a walker (papwalker) 0 778 09-02-2009, 08:48 AM
Last Post: peter a walker (papwalker)
  P41CX, Palm TX, and CPU Speed setting Les Wright 8 2,090 04-27-2006, 07:29 AM
Last Post: Thomas Okken
  HP 35 CPU Tom Bagdas 6 1,814 09-02-2005, 07:45 PM
Last Post: don wallace

Forum Jump: