General Category > Lisa Project Ideas
LisaHDMI (or VGA)
rayarachelian:
Idea: use an RPI Zero W (should have multiple cores, doesn't need much RAM) to collect the VSYNC, HSYNC, and video Data lines that are output to the Lisa's video analog board, and render output off the HDMI port. You'll need level converters since these are 5V on the Lisa, but the RPi wants 3.3V. You might be able to go cheap and use 3 resistors, but that might be noisy, etc.
Can be done with something other than an RPI, but the board must have multiple cores, be relatively fast, and have video output and GPIO.
Preferably all 3 lines coming from the Lisa should be readable by the SBC (Single Board Computer) in one read and not multiple. i.e. a single read byte or word.
To make it easier to detect, perhaps VSYNC should be put on a high bit so that you can test the "N" flag (negative) with a simple branch. Or perhaps it might be better to put the HSYNC line there instead as that will be tested more often.
The board should launch two processes at high priority (assuming we're using Linux) and leave any remaining cores for the OS running on it.
One process will collect data from the input lines, the second will render them onto the display (frame buffer). No other connectivity, such as ethernet, or USB is needed for this project.
The first phase of the first project will count the number of lines on a frame (or more) to figure out if we're running on a 3A system ROM, or standard (D-H) ROM.
--- Code: ---
while (read_gpio_bits && count<3) {
if (gpio & HSYNC) linecount++;
if (gpio & VSYNC) count++;
}
lines= linecount/count; // do some averaging here and decide which system type we're on.
--- End code ---
To do this count the number of HSYNC pulses between each pair of VSYNC pulses. You'll also need to carefully clock the rate of the data bits coming in.
Once we know how many lines to render, we'll start collecting and plotting the Data bit onto a shared memory 32KB area that's also accessible by the second process.It may be advantageous to use multiple 32KB areas as well.
VSYNC is used to signal the end of a frame, and HSYNC is used to end a line.
--- Code: ---
while (read_gpio_bits) {
if (gpio & VSYNC) {x=0; y=0;}
if (gpio & HSYNC) {x=0; y++;}
plot(x,y,gpio & DATA); }
--- End code ---
The second process could then use one of many algorithms to render video on the frame buffer (we don't want X11 here), perhaps using SDL or some other library.You could steal the HQ3X, or AA, or AA with Gray Replacement algos from LisaEm for this.
This board could also be hooked up to the VSROM and some other point on the CPU board where the video Data bit could be read from in order to display output on an HDMI or VGA/etc LCD monitor.
It could also be used to replace a dead video system by removing the analog board and CRT with a properly sized 12" monitor that accepts HDMI signals.
(You could then use a USB HDMI capture card to capture the output of the Lisa and put it on a video projector, or for use with a video podcast, etc.)
Edit: forgot to mention, for this project you should either compile in the RTOS Linux patches, and/or pin these two processes to a specific core and set it to the realtime class.
sigma7:
From time to time the issue of replacing the CRT with an LCD has come up. Until recently, the available resolutions of LCDs weren't sufficient to render an accurate representation of the rectangular pixels of the stock Lisa video.
Various online references to the Lisa rectangular pixels say they are 50% higher than wide. ie. a H:W ratio of 3:2. If that were the case, then using an array of 3x2 LCD pixels per Lisa pixel would require 1092 x 1440.
I wondered what this would look like on a 1200x1920 monitor so I made a graphic rectangle that size. Seems like a reasonable size to look at in spite of the big border, but surprise, it doesn't look right!
The actual size of the physical image the Lisa is supposed to have on screen is defined by an Apple service part #077-8043-A, which is a graticule overlay. I've never seen one and I haven't been able to find any documents as to its measurements.
Next best I can do is to measure the opening in the front panel, and to me it looks like an image of 6" x 9" would fit nicely. (Hmmm... 2:3 ratio)
720 pixels in 9" is 0.01250" per pixel
364 pixels in 6" is 0.01648" per pixel
and 0.01648 : 0.01250 is a ratio of 1.318, not 1.5
If the specification of a Lisa pixel is actually a ratio of 4:3 then given
720 pixels in 9" is 0.01250" per pixel (width)
364 pixels at 4:3 would be 0.01667" per pixel (height) and that would result in the raster being 6.0667" high.
So I believe the correct description of the Lisa video is a H:W ratio of 2:3 for the entire raster, with each pixel being a rectangle of 4:3 H:W
It does make an LCD more challenging as it would require a HxW resolution of 1456 x 2160, but this will fit in now available 4K monitors.
To facilitate making an adapter for this, the Sapient motherboards have a header position beside the CPU board that has video signals and power.
James
edit1: fixed pixel's aspect ratio -- it is taller than it is wide
edit2: fixed math and rewrote to be consistently H:W
Lisa2:
--- Quote from: sigma7 on October 26, 2022, 05:54:52 pm ---To facilitate making an adapter for this, the Sapient motherboards have a header position beside the CPU board that has video signals and power.
--- End quote ---
I just happen to have Sapient motherboard next to me, here is photo of the connector (J18) that was added to the design for this very purpose.
Rick
rayarachelian:
--- Quote from: Lisa2 on October 26, 2022, 09:58:14 pm ---
--- Quote from: sigma7 on October 26, 2022, 05:54:52 pm ---To facilitate making an adapter for this, the Sapient motherboards have a header position beside the CPU board that has video signals and power.
--- End quote ---
I just happen to have Sapient motherboard next to me, here is photo of the connector (J18) that was added to the design for this very purpose.
Rick
--- End quote ---
That's most excellent, can you share the pinouts to that connector so that someone who wants to make use of it knows which pins do what?
sigma7:
I think this is the pinout for J18...
1 DOTCLK (pin 106 of CPU board)
2 Ground
3 /HSYNC (pin 111 of CPU board)
4 Ground
5 /CSYNC (pin 67 of CPU board)
6 +5
7 VID (pin 115 of CPU board)
8 +5
9 /VSYNC (pin 113 of CPU board)
10 +12
If you are going to attach to it, it would be wise to verify for yourself of course.
Navigation
[0] Message Index
[#] Next page
Go to full version