6502.org Forum  Projects  Code  Documents  Tools  Forum
It is currently Sat Nov 23, 2024 5:54 pm

All times are UTC




Post new topic Reply to topic  [ 42 posts ]  Go to page 1, 2, 3  Next
Author Message
 Post subject: PICO vga/uart/ps/2
PostPosted: Wed Jun 26, 2024 7:12 pm 
Offline

Joined: Mon Jan 19, 2004 12:49 pm
Posts: 986
Location: Potsdam, DE
I'm following Troy's graphics controller chip series with interest and have been persuaded by the PIO module to move from the STM32 and Nucleo to the Pi Pico - specifically because it has a lot if internal memory and can generate 640 x 480 VGA in 4-bits per pixel without too much trouble.

Immediate requirements were to find a tool-chain that worked. Because the official getting started approach didn't/doesn't work with my Linux Mint setup (it couldn't download MS Visual Code, and apparently couldn't work with a pre-installed flatpak version of same) I looked at other approaches. The CLI approach appears to work, but one needs to keep a careful eye on one's working directory, or the damn thing compiles everything in your directories - which took half an hour.

Also, I wanted to work with C, not Python. I'm not fond of a language which can return '1', "1", or "Tuesday" and still be syntactically correct, and nor do I appreciate the effects of invisible white space...

So as a hopefully temporary approach I ended up with Arduino. I don't particularly like the UI, and the way it handles included files is truly appalling, but I can live with it.
Attachment:
1719427074102.jpg
1719427074102.jpg [ 1.34 MiB | Viewed 1601 times ]


This is a dot display just being used as a character display for now. But I have a number of further steps/issues to resolve:
  • The arduino ide does not include the pio assembler. I have located one online here which appears to work: https://wokwi.com/tools/pioasm from which assembled .h files can be included. But...
  • I have as yet no idea how to implement the interface between the 6502 bus and the rp2040. I am planning some small number of registers, but some of them may require multiple writes to fill a buffer which in turn is written to the screen.
  • On the other hand I can copy my existing ps/2 translate() routine and the ps/2 input is just a shift register, so should be easy.

I started with a build here: https://github.com/Pancra85/VGA_graphics which is itself a rewrite of Hunter-Adams' college course. It took a little work, in particular to uncouple the second buffer and get the full 480 line output (for some reason, I don't appear to be outputting line 479 so still investigating).

However, I have the immediate task working - though I need to find a better font file than the two I have, I have some video working (unfortunately after taking this pic I pushed the auto button on the monitor and it has irretrievably moved everything six inches left... I'll sort it later.)

More to follow when it happens...

Neil


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Wed Jun 26, 2024 9:12 pm 
Offline
User avatar

Joined: Thu May 28, 2009 9:46 pm
Posts: 8509
Location: Midwestern USA
barnacle wrote:
This is a dot display just being used as a character display for now...

Well, we all now know what you like to slurp while working with your computer toys.  :D

_________________
x86?  We ain't got no x86.  We don't NEED no stinking x86!


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Thu Jun 27, 2024 2:55 am 
Offline
User avatar

Joined: Tue Feb 28, 2023 11:39 pm
Posts: 257
Location: Texas
barnacle wrote:
I'm following Troy's graphics controller chip series with interest and have been persuaded by the PIO module to move from the STM32 and Nucleo to the Pi Pico - specifically because it has a lot if internal memory and can generate 640 x 480 VGA in 4-bits per pixel without too much trouble.


Looking at the specs of the demo board from AdaFruit it looks like it can handle 15-bpp.
https://www.adafruit.com/product/5675

I'm hopeful I can get 15-bpp at 320x240 but we'll see.

Quote:
Immediate requirements were to find a tool-chain that worked. Because the official getting started approach didn't/doesn't work with my Linux Mint setup (it couldn't download MS Visual Code, and apparently couldn't work with a pre-installed flatpak version of same) I looked at other approaches. The CLI approach appears to work, but one needs to keep a careful eye on one's working directory, or the damn thing compiles everything in your directories - which took half an hour.


Not sure how you have it setup, my structure looks like so:
Code:
/home/kfiresun/src/pipico/
|- pico-skd
`- hello
    |- CMakeList.txt
    |- pico_sdk_import.cmake
    `- hello.c


The CMakeList.txt only has the hello.c listed in it. You can get cmake to recursively read all files in a directory, but if you have a complex project structure that might not be the best idea.

Anyhow, my commands look like so:
Code:
cmake . -DPICO_SDK_PATH=../pico-sdk -DPICO_BOARD=pico_w
make -j22


(Adjust -j22 to the number of threads your CPU can handle)

Attachment:
Screenshot 2024-06-26 215008.png
Screenshot 2024-06-26 215008.png [ 36.04 KiB | Viewed 1577 times ]


Quote:
Also, I wanted to work with C, not Python. I'm not fond of a language which can return '1', "1", or "Tuesday" and still be syntactically correct, and nor do I appreciate the effects of invisible white space...


I'm glad I'm not the only one who finds that "feature" of Python horrible. >_<

Quote:

This is a dot display just being used as a character display for now. But I have a number of further steps/issues to resolve:

Quote:
I have as yet no idea how to implement the interface between the 6502 bus and the rp2040. I am planning some small number of registers, but some of them may require multiple writes to fill a buffer which in turn is written to the screen.


Not entirely sure yet, I'm still trying to figure out what I can and can't do with the PIO state machines. I think they'll read multiple pins in one clock cycle though, at which point you should be able to shift the bits into the FIFO.

The RP2040 docs say that the PIOs are capable of doing read and writes to 8080 and 6800 buses.

The one thing I'm running into is that if I do 15-bpp then that's 17 of the 26 available GPIO pins, leaving me all of 9 pins for talking to the 6502 (not enough to do read/write, chip select, and 8 data bits)

I'm contemplating the idea of multiplexing the output of the VGA signals through 7 or so pins. 5-bits (one channel) and 2-bits indicating which channel, with the "fourth" channel being the sync bits.

Edit:

Visual Studio Code is a nice to have, but I would guess you could just as easily use what ever editor you wish. I tend to use nano for quick and dirty edits, and Visual Studio (not Code) for larger projects.

I've seen some people do some pretty amazing things with vi, emacs, and Atom though.


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Thu Jun 27, 2024 6:03 am 
Offline

Joined: Mon Jan 19, 2004 12:49 pm
Posts: 986
Location: Potsdam, DE
Yeah, my desired resolution is limited by the internal ram to 640 x 480 at four bits per (I'm using three at the moment but that's an easy change). It may be possible to go to 600 x 800 (which would take 240,000 bytes of video buffer) but I think that's going to be very tight on ram to do everything else, so that's a long way down the road - e.g. if rpi deliver another version with more internal ram.

What I'm interested in is a standalone system that can be used both as a simple 6502 machine at monitor level, and as something with compact flash and the video controller in the 6502 address space. Using the rp2040 as the controller solves the issue of the 6502 having to swap in 150k of ram, but adds the complication of having to simulate access to 'registers'. I saw that the chip is able to interface to intel and motorola busses so that should be fine, but I have not yet found any examples (though I think Troy might have some hints).

I'm not interested in video games so there's no tiles or sprites or build it on the fly, which simplifies things, but I am considering using four pins as video output either driving rgb (or rggb) directly and through an r-2r DAC to drive all three pins with a sixteen level gray scale. Ideally under software control, but again, we'll see. However with that in mind I also want to use the rp2040 to provide the ps/2 interface - at least a receiver-only - and a bidirectional UART. A drop-in, on the bus generalised IO part that can handle at least those three things simplifies a lot of the rest of the design. And the fact that it's dirt cheap - four bucks for the pi pico, or a buck for the chip alone - doesn't hurt at all. (I think it's possible that the UART may actually work across the USB socket, which is a big bonus for me.)

I'm no fan of VSC: I've used it, but I don't really like its habit of getting in the way with hints and suggestions which invariably seem to obscure the bit of code I'm trying to look at :grr: and generally I use Geany and a command line to compile, even large code bases. I use the STM32Cube IDE for STM arm code, and also IAR for work stuff (an infinitely superior IDE) but one issue I find with many IDEs is that their idea of 'projects' and 'solutions' doesn't really fit with my stone age ideas. In particular, simply cloning a project is often a serious head bender... (try telling STM32Cube that you'd like to do the same project again but you've changed your mind on the actual processor...)

Neil


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Thu Jun 27, 2024 6:18 am 
Offline
User avatar

Joined: Thu Dec 11, 2008 1:28 pm
Posts: 10986
Location: England
barnacle wrote:
I saw that the chip is able to interface to intel and motorola busses so that should be fine, but I have not yet found any examples

I collected some links recently which might be helpful
https://github.com/oliverschmidt/a2pico
https://github.com/dp111/PicoTube
https://github.com/hoglet67/pico-swram
https://github.com/hoglet67/pico_bus6502


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Thu Jun 27, 2024 8:02 am 
Offline

Joined: Mon Jan 19, 2004 12:49 pm
Posts: 986
Location: Potsdam, DE
Thanks Ed, I shall give them a look over. Appreciated.

Meanwhile, this morning's efforts:
- changed the font for one a bit more elegant (https://github.com/viler-int10h/vga-tex ... ADABL7.F16 - though given the way the display spreads the pixels it might be worth looking for a skinnier font)
- got rid of some naughty utf-8 characters in my Sherlock Holmes extract
- zoomed in past the beer

Attachment:
1719474956270.jpg
1719474956270.jpg [ 1.3 MiB | Viewed 1557 times ]


Neil


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Thu Jun 27, 2024 7:51 pm 
Offline

Joined: Mon Jan 19, 2004 12:49 pm
Posts: 986
Location: Potsdam, DE
Ed, the A2pico stuff has definite possibilities. Not sure I understand it yet (= bloody sure I don't understand it yet) but looks hopeful. Depends on the timing though; still need to investigate further.

Neil


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Thu Jun 27, 2024 8:04 pm 
Offline
User avatar

Joined: Thu Dec 11, 2008 1:28 pm
Posts: 10986
Location: England
Glad I could help - look forward to seeing what you do...


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Thu Jun 27, 2024 8:35 pm 
Offline

Joined: Mon Jan 19, 2004 12:49 pm
Posts: 986
Location: Potsdam, DE
Currently deciding whether a text scroll - which requires about 150k memory moves - is fast enough to avoid the need to maintain a separate virtual tty screen and copy each character from that. Which of course still requires a lot of memory access...

Phase one is to make a basic 'any char to screen' tty (from the serial port for now). Phase two is to handle things like BS and TAB; phase three is to implement some subset of ANSI to allow colour selection and cursor positioning. Somewhere in there, probably, a flashing cursor (or maybe a vertical bar tied to the gaps between characters).

Only then do I get onto actually joining it to a bus; from there I can handle ps/2 and serial...

Before hauling one's self up by one's boot straps, it is first necessary to knit the boot laces. :mrgreen:

Neil


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Fri Jun 28, 2024 3:12 am 
Offline
User avatar

Joined: Wed Aug 18, 2021 1:35 am
Posts: 72
Location: South Australia
Hey. Nice work!

I would definitely consider a tile map for text mode. You could then even support a circular buffer for storing the tile ids. That way, scrolling the screen is as simple as updating the start address to render tiles from. Or you could do a basic tile map, then you only need to move all of the tile ids. Much less than 150k.

_________________
Cheers
Troy

[My introduction]


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Fri Jun 28, 2024 5:50 am 
Offline

Joined: Mon Jan 19, 2004 12:49 pm
Posts: 986
Location: Potsdam, DE
True, but it requires a continuous process of building the display based on the tile map, whereas at the moment a character need only be rendered once, until it needs moving. I also want to keep the option open to generate some sort of graphical display, which again would be difficult to render on the fly (the processors inside are going to be doing other things too :) )

I have considered - but not implemented - a half-way house where text-as-ascii is stored in an 80 x 30 array, and rendered from there to the video buffer only when something changes, but only those parts that change (i.e. I don't need to redraw all 2,400 characters -> 150k pixels every time I hit a letter, only if I do a scroll). Scroll will definitely be faster than a redraw, with memmove().

Swings, roundabouts... I might know later today whether the scroll speed is adequate.

Neil


Last edited by barnacle on Sun Jun 30, 2024 8:19 am, edited 1 time in total.

Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Fri Jun 28, 2024 6:22 am 
Offline
User avatar

Joined: Wed Aug 18, 2021 1:35 am
Posts: 72
Location: South Australia
Fair enough.

You'll find generating the VGA frame on the fly (one scanline at a time) isn't too intensive. Even if it keeps one of your CPU cores 100% busy (it won't), you still have another whole CPU core to play with :)

_________________
Cheers
Troy

[My introduction]


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Fri Jun 28, 2024 8:12 am 
Offline
User avatar

Joined: Wed Feb 14, 2018 2:33 pm
Posts: 1488
Location: Scotland
barnacle wrote:
Currently deciding whether a text scroll - which requires about 150k memory moves - is fast enough to avoid the need to maintain a separate virtual tty screen and copy each character from that. Which of course still requires a lot of memory access...


I understand there's a DMA engine on the RP2040, so use that for the memory move?

I use DMA on my Ruby Pi project to do screen clear, scrolling (1D moves) and character printing to the screen (1D to 2D move).

Quote:
Phase one is to make a basic 'any char to screen' tty (from the serial port for now). Phase two is to handle things like BS and TAB; phase three is to implement some subset of ANSI to allow colour selection and cursor positioning. Somewhere in there, probably, a flashing cursor (or maybe a vertical bar tied to the gaps between characters).


My Ruby 6502/816/Pi projects use the Acorn VDU character codes for basics like cursor move/home/XY and graphics (plot, line, triangle, etc.) which then allowed BBC Basic programs to "just work" using the built in keywords. The codes are somewhat simpler than ANSI.

-Gordon

_________________
--
Gordon Henderson.
See my Ruby 6502 and 65816 SBC projects here: https://projects.drogon.net/ruby/


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Fri Jun 28, 2024 9:18 am 
Offline

Joined: Mon Jan 19, 2004 12:49 pm
Posts: 986
Location: Potsdam, DE
I'm unclear whether the VDU codes are in-band signalling or separate basic commands. For this use case I need something in-band, hence the (possibly simplified) ansi.

Neil


Top
 Profile  
Reply with quote  
 Post subject: Re: PICO vga/uart/ps/2
PostPosted: Fri Jun 28, 2024 9:31 am 
Offline
User avatar

Joined: Thu Dec 11, 2008 1:28 pm
Posts: 10986
Location: England
rather than tiles, which are good for games, perhaps use a linked list of lines - one-pixel lines. Then you can scroll by updating the list. There's a per-line overhead of dereferencing the line address for each line output to the screen, but there's always time in hsync to do stuff so that shouldn't be too bad.

I have the vaguest idea there was a system like this back in the day. It's a little like the Amiga's Copper, but it's not that I'm thinking of.

It's a sort of display list processor - those were used for vector displays.


Top
 Profile  
Reply with quote  
Display posts from previous:  Sort by  
Post new topic Reply to topic  [ 42 posts ]  Go to page 1, 2, 3  Next

All times are UTC


Who is online

Users browsing this forum: No registered users and 7 guests


You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot post attachments in this forum

Search for:
Jump to: