VideoMacPacHack/documentation/hardware.md
2020-04-06 01:45:52 +01:00

136 lines
7.3 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# Video Mac Pac hardware
The following document is based on an analysis and reverse engineering of the Video Mac Pac board. To date we have not found any original documentation on this design.
## Operation overview
The Video Mac Pac, designed in 1991 by Computer Care Inc., is a PDS expansion card for the Macintosh Portable (M5120 and M5126) that provides a second video output in addition to the Portables built-in screen. It supports 1-bit video at several resolutions:
* 640x872 (Apple Portait Display)
* 640x872 (Sunkyung FPD)
* 640x872 (Samsung FPD)
* 640x480 (Apple Monochrome Display)
* 640x480 (VGA)
* 800x600 (Super VGA)
* 528x348 (Mono TTL)
* 272x208 (TV/VCR)
These resolutions are selectable through the Video Mac Pac control panel which must be installed for the card to work.
The hardware design and software drivers appear to be closely related to the Lapis DisplayServer-SE video card. The card is based on a Xilinx CPLD whose firmware is loaded at boot by the control panel, along with VRAM and some glue logic for interfacing to the PDS slot and to the display.
## CPLD
The Video Mac Pac is based on the Xilinx `XC2018-100PC84` CPLD, which has the following specifications:
* 84-pin PLCC package
* 5V logic
* 1800 gates
* 74 I/Os
* 100ns toggle rate
The size of a program configuration on the XC2018 is 17878 bits. There is no non-volatile storage either on the XC2018 or elsewhere on the Video Mac Pac, meaning that the CPLD configuration is downloaded by the Macintosh on power-up.
On the VMP, the XC2018 mode pins `M0, M1, M2` are configured as `101`, corresponding to Peripheral mode. In this mode, the program is clocked in 1 bit at a time on the `DIN` and `WRT` pins.
For comparison, the Lapis DisplayServer-SE is also based on the XC2018. The SE-DPD (capable of driving dual page displays) instead uses the `XC3020-70-PC84`.
## VRAM
The VMP uses four Micron `MT42C4064Z-12` 64kx4 VRAM ICs. These are in a 24-pin ZIP package (i.e. SIP with staggered leads). Each VRAM chip handles 4 bits of a 16-bit data word.
The CPLD maps the VRAM to the memory address space from `$720000` to `$73FFFF` (128k bytes in total).
## GAL
The CPLD must be programmed by the Macintosh using the Video Mac Pac control panel. A `GAL16V8-25LNC` IC on the board implements an address decoder for address `$740200` (binary `0111 010x xxxx xx1x xxxx xxxx`).
The GAL also takes as input a sense line (active high) from the external video dongle. When the dongle is connected, address `$740200` is matched and `AS/` is low, the output (tied to the `WRT` pin on the CPLD) goes low. This feature is used to program the CPLD after power-on, after which point further communication takes place directly to the CPLD via the bus on the PDS slot.
If the dongle is not connected when the control panel loads, the CPLD will not be programmed and the video card will not operate until a restart takes place.
## PDS slot
See Apple's *Designing Cards and Drivers for the Macintosh Family* for the pinout of the Macintosh Portable PDS slot. The following pins of the PDS slot connect to the CPLD:
* Clock signal `16M`
* All address lines `A23-A0`
* Data line `D0` (connected to `DIN` to program the CPLD)
* Address strobe `/AS`
* Data strobes `/UDS` and `/LDS`
* Read/write signal `R/W`
* Acknowledge signals `/DTACK` and `/EXT.DTACK`
* Reset signal `/SYS.RST`
The following parts of the PDS slot connect directly to the VRAM:
* Data lines `D15-D0`, 4 bits per IC
All other VRAM pins are connected via the CPLD.
## Relay
The VMP contains a miniature 5V relay which is switched by way of the PDS signal `5/0V`. This powers down the card when the Portable goes to sleep.
When the Portable wakes from sleep, the CPLD program will be lost and it appears that a power cycle is required to enable the external screen.
## Oscillators
The VMP has 3 oscillator cans: 36MHz, 50.35MHz, 57.2832MHz. The 36MHz oscillator is socketed, while the other two are soldered. One of the three oscillator signals is chosen by the CPLD depending on the screen resolution. These provide the pixel clock for the video output.
The oscillators are not powered directly on the board. Rather, power to the oscillators is routed to a pin on the external video dongle connector, and the dongle routes the power back to the oscillators. This appears to be a power saving measure when the dongle is not connected.
In addition to the three oscillators, the card receives a 16MHz clock from the PDS slot.
## Outputs
The CPLD generates eight output logic signals which are buffered through a `74F244` octal buffer. These signals include:
* Three video signals. Our testing showed that these three always generate the same signal, as the card is 1-bit monochrome, but perhaps keeping separate signals was intended for a future design which would be full colour.
* Horizontal and vertical sync
* Three other signals which measure as constant high or low depending on the chosen resolution. These may have performed control functions for an external dongle (now lost).
The signals appear on a 20-pin header with the following pinout:
| pin | description | pin | description |
| --- | -------------- | --- | ----------- |
| 1 | oscillator +5V | 2 | +5V out |
| 3 | ground | 4 | sense input |
| 5 | ground | 6 | HSYNC |
| 7 | ground | 8 | VSYNC |
| 9 | ground | 10 | unknown 1 |
| 11 | ground | 12 | video 1 |
| 13 | ground | 14 | video 2 |
| 15 | ground | 16 | video 3 |
| 17 | ground | 18 | unknown 2 |
| 19 | ground | 20 | unknown 3 |
## Video Adapter Dongle
The VMP has a 20-pin IDC header, which connects by a ribbon cable to a DB25 male connector mounted in the rear cover of the Portable. This presumably connects to a dongle which provides the last step of signal conditioning and the correct pinout for the monitor in question.
We do not have the original dongle, however based on experimentation we have worked out its probable functions:
* The dongle provides a loopback between the +5V power supply and the power input to the oscillators. This is presumably to reduce power consumption when the dongle isnt connected and the card is not in use.
* The DB25 contains a sense line to the GAL which is responsible for programming the CPLD. On the dongle, this line is pulled up to +5V, allowing the GAL to be programmed and the card to become operational only when the dongle is connected at boot.
* The dongle may provide level-shifting for driving analog monitors (e.g. VGA, Apple 13”). For TTL monitors a different dongle might have been used which passed through the video signal directly.
The pinout of the DB25 male is as follows:
| pin | description | pin | description |
| --- | -------------- | --- | ----------- |
| 1 | oscillator +5V | 14 | +5V out |
| 2 | ground | 15 | sense input |
| 3 | ground | 16 | HSYNC |
| 4 | ground | 17 | VSYNC |
| 5 | ground | 18 | unknown 1 |
| 6 | ground | 19 | video 1 |
| 7 | ground | 20 | video 2 |
| 8 | ground | 21 | video 3 |
| 9 | ground | 22 | unknown 2 |
| 10 | ground | 23 | unknown 3 |
| 11 | n/c | 24 | n/c |
| 12 | n/c | 25 | n/c |
| 13 | n/c | | |