top left Image    Igor

In my original sketch for the Megaprocessor I was guessing that there would be a frame for controlling the processor. I had a dream of big levers, dials, knife switches etc., and one or two of those big sparky things. I called this frame Igor after the professors loyal assistant. And there would also be a frame for some peripherals such as I/O, timers and interrupts.
artist impression

When it later came to actually designing them my ideas changed somewhat...
Firstly whilst the design of the peripherals is much much simpler than that of the processor it turns out that its size, if built in discrete transistors, is not proportionately smaller. It could well take two or three frames rather than just one. And I was running out of space. So I decided that I couldn't/wouldn't build them from discrete components but use some more sensible technology. And if you use an FPGA then it takes no space at all.
Secondly my vision for Igor faded away. It turned out there really wasn't very much for him to do. One lever (for clock speed) and just one big switch for reset. I think I originally thought there would be a lot of status information coming out of the processor which would need to be displayed. But there wasn't.
I had also decided by about this time that as well as the 256B of RAM I'd build from discrete components it would also be nice to have  a larger chunk so I could run some more interesting programs. And if I had this it would also make life a lot nicer if I could download programs into it from the outside world.

The Igor board was born to mop up all of these functions :
  • clock speed control and generation
  • reset
  • peripherals : I/O, counter, timer, interrupts, UART
  • 32K RAM: dual ported between the Megaprocessor and something that could be talked to over a serial interface

picture of Igor

This was built around an FPGA development board from Lattice. The chips around the edge of the board provide voltage level translation (the FPGA is a 3V device, whilst the Megaprocessor is 5V). IC8 is a PIC  processor which I use to provide a bit of intelligence (e.g. working out dividers and decimal display values for the clock) and a UART. It talks to the FPGA over SPI.

I was originally intending to have just the one built and have it do everything. However when it came to designing the frame and working out how to draw what was happening a single board with "magic happens here" didn't seem very satisfactory. Also as the minimum order for PCBs is 3 I had three of the boards (actually 4, they sent me a bonus one) to hand so I decided to split out the functions to : control, RAM, peripherals.

When starting to write the code for the Igor which would look after just the clock and reset I had a further idea. If the board was not acting as a peripheral for the processor then it could monitor it instead. In particular it could sniff the address bus and halt the clock when it saw a specified value. i.e. it gave me breakpoints. It meant I had to change the direction of some of the interfaces so that they all pointed in. You can see one of the little blue wires changing control signals on IC1 at top left.

As a further development  I wrote a VHDL version of the Megaprocessor which could run in the FPGA.
I put one instance running in the control Igor. This was fed the data sniffed from processor read data bus and given the same control signals as the megaprocessor itself. It should therefore behave in exactly the same way generating the same address and write data requests. Checking these meant that I had two different versions of the Megaprocessor that should run in lockstep with each other and so gives me a powerful test and debug tool. If ever the two versions diverge the clock is instantly stopped and I can examine the processor(s) frozen at the point of error.

During integration I was able to take advantage of that bonus fourth Igor. By completely reversing the direction of all the interfaces (that was a bit ugly) and running just the VHDL version of the Megaprocessor in the FPGA it emulate a Megaprocessor and use that for testing the control frame.
Igor used as emulator

Igor's been an invaluable assistant.

Would still have liked one of those spark ladders though. Something like this one.




© 2014-2016 James Newman.