๐Ÿ’พ Archived View for bbs.geminispace.org โ€บ s โ€บ FPGA โ€บ 18912 captured on 2024-12-17 at 15:06:34. Gemini links have been rewritten to link to archived content

View Raw

More Information

โฌ…๏ธ Previous capture (2024-08-31)

๐Ÿšง View Differences

-=-=-=-=-=-=-

A 6502 on a $20 Tang Nano 9K

Ah, after some fiddling, got a minimal 6502 system flashing an LED. Running at stock 27MHz, with 2K RAM and 2K ROM.

The FPGA has 48K of block RAM and an HDMI interface, so I could build, say, a credible Apple 2, or an Atari -- the CPU consumes just over 10โ„… of resources.

There is also an SD card interface and an 64mbit SDRAM, and a bunch of Flash, and an LCD interface... Not bad for $20.

Posted in: s/FPGA

๐Ÿš€ stack [mod]

Jul 30 ยท 5 months ago ยท ๐Ÿ‘ norayr, dozens

11 Comments โ†“

๐Ÿ™ norayr ยท Jul 30 at 14:23:

amazing. i wish i would understand in fpga and build an oric atmos which would be able to understand modern keyboard and vga display.

i wonder if project oberon would work on such a system you have.

๐Ÿš€ stack [OP/mod] ยท Jul 30 at 15:10:

@norayr - you can do it! Around 2008 I decided to figure it out after years of wanting to do some hardware. In many ways FPGAs are more satisfying than software, although hardware description languages are a bit of a mess.

My approach to FPGAs is somewhat unorthodox punk rock - I generally instantiate circuits (memories, muxes, etc) and wire them together instead of describing logic and letting the toolchain 'infer' what I mean. I also don't simulate, but build bottom-up, writing and testing components then wiring them together.

Anyway, FPGAs are much less complicated than any modern programming language, especially if you know anything about digital logic.

๐Ÿš€ stack [OP/mod] ยท Jul 30 at 15:15:

@norayr: re Oberon -- yes, it would fit, but you'd have to rewrite the video to use HDMI (or wire up a few resistors and a VGA connector). And replace the PS/2 keyboard code with the built-in USB interface. The microSD slot is there, so it can be self-contained, unless you want VGA or the wireless network.

I built a few Project Oberon boards a few years back, only to find out that I really don't like the language!

๐Ÿ™ norayr ยท Jul 30 at 15:52:

okay, very inspiring. so this fpga board costs $20? unbelievable. and do you need some windows/macos software to program it (or compile verilog) or is it possible to do everything on linux, and is it possible to have the open source toolchain?

omg, you even built it. yeah, i am a fan, i need to do this. i need to learn how to do this.

๐Ÿš€ stack [OP/mod] ยท Jul 30 at 19:46:

@norayr: Yes, there is the manufacturer's (Gowin's) own IDE/toolchain, which is not too bad, for WIndows and Linux, and there is a free yosys/apycula toolchain for Linux which is actually much better than Gowin's (you can use Makefiles and vim instead of the idiotic IDE)

The opensource toolchain builds my 6502 project in 30 seconds, Gowin's in 1 minute.

And the opensource loader (openFPGALoader) works really great.

As for Oberon, a decade ago, this was my little project:

โ€” https://web.archive.org/web/20160505143509/http://oberonstation.x10.mx/

๐Ÿš€ Remy ยท Jul 31 at 19:03:

My friend used python to make his commodore 64 for the analog pocket

๐Ÿš€ stack [OP/mod] ยท Jul 31 at 20:22:

@remy do you mean this project?

โ€” https://github.com/markus-zzz/myc64-pocket

Analogue Pocket is a cool FPGA handheld (2 FPGAs I think). I don't think there is much Python involved, however. At least I hope not, for I am not a fan of Python.

๐Ÿš€ Remy ยท Aug 01 at 14:29:

yes, this project. There is a tool that converts python to verilog and then compiles.

๐Ÿš€ stack [OP/mod] ยท Aug 01 at 16:18:

@remy I can't imagine why anyone would ever want to do that, but the world is full of strange and sometimes interesting things

๐Ÿš€ Remy ยท Aug 01 at 19:10:

It is simpler to write python than verilog for people who like python. It is possible to have a design with both verilog and python. The entire design doesn't have to be written in python

๐Ÿš€ stack [OP/mod] ยท Aug 01 at 20:50:

I know people do this, but aside from my objections to Python as an abomination of a language in general, and its lack of stability when some library 10 layers down gets updated...

Verilog is already pretty far from the hardware -- and you have to cross your fingers and hope it infers the circuitry you want... To add another layer adds yet more uncertainty about what will come out, and you would still need to know verilog to make sure your translator is not generating something similar but different from what you want.

But there is no accounting for taste or poor judgement. I am sure your friend knows what they are doing.