ceving 31 minutes ago

I had to upvote right after this sentence: "I wanted to be able to play the EGA version of Monkey Island 1 on it"

haxxorfreak 20 hours ago

I love the hard drive sound emulation! I find that modern restorations of vintage hardware using SD cards to emulate drives are missing an important part of the nostalgic experience when they just start up completely silently.

  • tverbeure 17 hours ago

    I was about the comment the same. It adds a lot of authenticity to the whole game loading process!

    • Natsu 10 hours ago

      I actually still have an original 8088 sitting in a closet. I need to figure out something to do with it some day.

  • ForOldHack 18 hours ago

    The floppy disk usually made this straight up honking noise . I had a V20, but at 10Mhz. Never had a problem, except for formatting floppies. The V20 has a few tricks up it's sleeve, with a few less clock cycles on some instructions, and a Z80 mode to run cpm.

    But,the real trick was to put real IBM roms in a clone board and run Xenix. When the clone roms are back in it still booted. Helped a lot to have a 2:1 Rll controller. Xenix was just pollute and delute - system V with some BSD thrown in and a slightly altered portable C complier that was later admitted to be wrong endian.

    Did this Board have a FPU socket? Made turbo pascal run much faster. ( The 8087 version we got from the physics lab...) Especially the Hilbert matrix. And FFTs.

    • iberator 17 hours ago

      Why original IBM BIOS was requried for Xenix?!

      • ForOldHack 13 hours ago

        The Roms it came with did not work, also the disks had to have perfect media. Everything bad to be formatted beforehand. So, I got IBM ROMS and it worked, then got some other roms so the keyboard speed switch would work, while the IBM ROMS were installed there was a simple program that would kick up the speed, and turn wait states off. It was slightly faster than a 6mhz AT for DOS and we did not have Xenix 286. Got me through K&R and passed the class, but do useful work? No.

      • ForOldHack 13 hours ago

        We found out after the third try, that both the IBM and one of the clone BIOSes would run the install, and all of them would boot. ( And an OMTI Rll controller, supported... Dual hard disks too. ) I needed an assembly language program to much the speed up to 10mhz, and it still ran fine, right up to the 'make nethack' then 4 hours later...beeeep beeeep beep. OS not found. We never figured out weather it was a out of memory error or a temp file error ... But the OS was gone.

dlcarrier 20 hours ago

The title is a bit misleading; it's running on an 8088-compatible CPU, and a 1 megabyte SRAM, with the FPGA containing the display adapter and drive controller, as well as the glue logic.

  • II2II 20 hours ago

    A bit misleading, albeit in an impressive way. I nearly skipped the article thinking that it would be an all FPGA solution. Instead, they interfaced somewhat period correct chips: the V20 was used in XT compatibles of the era, the DAC was authentic (even if it is only a small part of the sound card), and the 1 MB RAM chip is the sort of cost cutting measure they would have used back in the day if it was available (though it would likely have been DRAM rather than SRAM). The rest being on an FPGA is certainly understandable since it was listed as an FPGA based project!

    • ssrc 19 hours ago

      And the FPGA is a modern day equivalent to an ULA. If they could have put all of the chips in a single programmable one, they would.

  • nsxwolf 18 hours ago

    This build demonstrate what’s actually interesting about FPGA to me. A pure implementation might as well be a software emulator. Being able to interface real chips makes this really neat.

    • gblargg 8 hours ago

      Good point. I was thinking why he didn't just do the V20 etc. on the FPGA, but then a software emulator would be more flexible. Having a real hardware interface that has the right timing is something software would have to work very hard to do. Using an FPGA also forces the designer to more or less really understand the original hardware design, not just the software-visible effects as an emulator author can get away with.

mk_stjames 15 hours ago

There is 32MB of SDRAM on the FPGA board.... I wonder exactly what using 1MB of that as the system memory would have entailed instead of the separate 1MB SRAM chip that had to be soldered. Was using the extra SRAM chip just done just to do it, or is there a specific reason there that I'm not seeing/understanding...

  • bit-hack 14 hours ago

    The main reason is just due to me knowing my own limitations. SRAM is really simple to interface with and i've not yet tried to write a DRAM controller since its much more complex. Putting SRAM on the board made me more confident about the project. I did have it in mind that I could try to use the DRAM in place of the SRAM at a later stage (as you suggest) as a good way to focus on learning how to use it.

    • mk_stjames 11 hours ago

      Really cool, I figured that was the case and I'd be in the same boat.

      I have an ice40UP5k board but I quickly ran out of block ram and LUTS whenever trying to use it for anything substantial, but seeing this project has me itching to start something around one of these icesugar pro boards. yosys & nextpnr support made things really damn easy when I was working with the ice40.

plantinthebok 18 hours ago

What was the most surprising timing constraint you had to meet for the V20 bus controller? The 8088's multiclock cycles were always under specified in original datasheets and I'm curious what reality looked like.

  • bit-hack 16 hours ago

    The bus controller was fairly straight forward. I found the timing diagrams in the V20 datasheet to be pretty easy to follow. The clock for the CPU is generated by the FPGA which I derived from a clock running at twice the speed, that made it easy to pick which clock edges I wanted to sample from or assert data for the CPU on. I did have a bug or two in there early on which meant that memory writes would not store the data I was expecting as I sampled the data bus at the wrong time. That was a tricky one as the bug would only become visible when that location was loaded from again. The CPU i'm using is rated for 16Mhz, but i've only tried to push it up to 10Mhz so far so I have a bit of margin. Some more issues might pop up if I push the speed higher I suspect. Its very stable as it is now and i've not seen any issues I could attribute to the bus handling.

    • rasz an hour ago

      >I derived from a clock running at twice the speed

      aah, so CFG_ENABLE_20MHZ runs cpu at 10. I was surprised you could run the bus at 20MHz with this FPGA devboard, 10 makes more sense.

      As I touched on that in HaD comment this is not a good devboard :( It has terrible pinout https://github.com/wuxx/icesugar-pro/tree/master/schematic all 100 signals huddling together in the middle with only 9 ground pins among them. Very bad for signal integrity. Whats worse someone in China actually decided to sell it commercially :( Luckily you made it work.

asdefghyk 17 hours ago

A bit offtopic for this article , but I'm waiting for some FPGA's based "..device PC emulator?..." that can connect to my old hard drives from the mid 80s ... and boot them ....

inglor_cz 21 hours ago

Wow. A lot of memories unlocked instantly. My first PC in 1995 was a very old IBM PC XT.

  • keyle 8 hours ago

    I bought a brand new 386 dx 33 back in the day, I felt like a kid at the chocolate factory in that smokey computer shop; price lists everywhere, floppy drives and floppies stacked in a complete mad-scientist looking shop. It was a mess. I thought "these are my people".

    One of the best days of my life.

  • Lio 21 hours ago

    Yeah I had a little Carry-I PC XT clone with CGA/Hercules graphics, V20 8088 and an amber screen that I really regret selling.

    I guess it couldn’t really do that much at the time compared to Amigas, STs and Acorns but there was something magic about my experiences with the PC.

  • hintbits 18 hours ago

    Same. I had a used Amstrad PC 1640, which had V20 @ 8Mhz and EGA graphics. The author's desire really hit home here.

    • hintbits 18 hours ago

      correction: it had v30, which was 8086 rather than 8088 clone (16bit bus)

ForOldHack 13 hours ago

I would like to have a xt and at and 386 in this tiny form factor, to play Rogue on the X T and try to compile nethack on the 286 version of Xenix and the 386 version of Xenix. I know from experience it will never compile on the 8088 version of Xenix. It will wreck your OS and filesystem.

ForOldHack 18 hours ago

Well, we have a dos clone and FFTs I. The news... Can this run the DOS clone and do FFTs?

snvzz 20 hours ago

Looks nice, but there's no license. Can't do a thing with this.

  • bit-hack 16 hours ago

    Thats an oversight on my part, I should put a license on it. I would love for anyone to be able to build one or tinker with the code as they want to. After all I was only able to make this because others shared their projects that I could learn from.

    • Brian_K_White 8 hours ago

      I would suggest CC-BY-SA

      You can do this by doing as little as making a single file named LICENSE in the top level directory, with a single line:

          This work is licensed under CC BY-SA 4.0. To view a copy of this license, visit https://creativecommons.org/licenses/by-sa/4.0
      
      That's it.

      It is the hardware/artwork spritual equivalent of GPL2. It means the user must not remove your name, must make source/plans available, and commercial activity is ok.

      Just a suggestion if you don't know where to begin or what to do, hadn't really thought about it or read up on all the infinite options etc.

      • bit-hack 4 hours ago

        Thanks for the suggestion, I've added this license to the project.

  • smokel 19 hours ago

    Marvel and enjoy.

  • fortyseven 19 hours ago

    Jesus christ, must everything be transactional?

    • Brian_K_White 9 hours ago

      If you like this kind of thing and might ever possibly make something even remotely or partly similar of your own (because you like this kind of thing remember, meaning, a lot of the same people as the ones who would be interested in reading the blog in the first place, such as yourself and myself), technically you have to be careful that you never even looked at this without a license that declares explicitly what the terms are.

      Without any declared license the default is full restrictive rights to the author/artist/creator.

      That is how literally true it is to say "can't do anything with this" they can't even view it.

      Let alone actually download a copy, let alone build it, let alone modify it, let alone redistribute their modified version...

      I don't know what this "transactional" accusation is supposed to even mean, but the need for a license is completely reasonable and not asking for anything.

      My own "jesus" question: Jesus do you do any sort of work in either software or hardware without knowing this?