Difference between revisions of "Port"
Line 71: | Line 71: | ||
<br> | <br> | ||
− | == | + | == 3853 port $0F == |
− | == VC-18 port | + | |
+ | The 3853 Static Memory Interface uses port $0F as a local timer port. | ||
+ | |||
+ | == 3853 port $0E == | ||
+ | |||
+ | The 3853 Static Memory Interface uses port $0E as interrupt control port. | ||
+ | |||
+ | == VC-18 port $20 and $21 == | ||
Used to save data in a 1kx1 2012 RAM in Videocart 18 | Used to save data in a 1kx1 2012 RAM in Videocart 18 | ||
− | == VC-10 port | + | == VC-10 port $24 and $25 == |
− | |||
Used to save data in 1kx1 2102 RAM in Videocart 10 | Used to save data in 1kx1 2102 RAM in Videocart 10 | ||
+ | |||
+ | == 3854 port $F0 to $FF == | ||
+ | The 3854 DMA device each has three internal registers adressed as four separate I/O-ports. | ||
+ | Registers are called BUFA, BUFB, BUFC and BUFD where BUFA and BUFB represents address, BUFC represents byte count that also uses four bits from BUFD. Last four bits are used for function code. |
Revision as of 17:27, 25 August 2024
The VES has four usable 8-bit data ports in the console, port 0 and 1 that are in the 3850 CPU and port 4 and 5 on one of the 3851 Program Storage Units. These I/O:s are hooked to specific functions as shown in the table below.
When looking at the opcodes we'll see that using the two ports on the CPU requires half the CPU time compared to using Port 4 and 5 on the PSU, this means that you can fetch right hand controller data two cycles faster than from left one which is worth noting if you need to maximize speed.
Contents
CPU port 0
0 TIME console button
1 MODE console button
2 HOLD console button
3 START console button
4 - not connected -
5 RAM WRT - A pulse here executes a write to Video RAM.
6 Enable data from controllers, set to 1 while write to Video RAM.
7 - not connected -
CPU port 1
0 Right controller right
1 Right controller left
2 Right controller back
3 Right controller forward
4 Right controller counter clockwise
5 Right controller clockwise
6 Right controller pull
7 Right controller push
Two bits have a second function, they decide the color of a plotted pixel:
6 Write Data0, Indicates that valid data is present for both VRAM ODD0 and EVEN0
7 Write Data1, Indicates that valid data is present for both VRAM ODD1 and EVEN1
PSU port 4
Port 4 has double duties and serve left controller
as well as horizontal video position (X-coordinate).
0 Left controller right
1 Left controller left
2 Left controller back
3 Left controller forward
4 Left controller counter clockwise
5 Left controller clockwise
6 Left controller pull
7 Left controller push
Also:
0 Video Select
1 Video Horizontal A
2 Video Horizontal B
3 Video Horizontal C
4 Video Horizontal D
5 Video Horizontal E
6 Video Horizontal F
7
PSU port 5
Port 5 serves the vertical video position (Y-coordinate) and also sound.
0 Video Vertical A
1 Video Vertical B
2 Video Vertical C
3 Video Vertical D
4 Video Vertical E
5 Video Vertical F
6 Tone AN (beep sound)
7 Tone BN (beep sound)
3853 port $0F
The 3853 Static Memory Interface uses port $0F as a local timer port.
3853 port $0E
The 3853 Static Memory Interface uses port $0E as interrupt control port.
VC-18 port $20 and $21
Used to save data in a 1kx1 2012 RAM in Videocart 18
VC-10 port $24 and $25
Used to save data in 1kx1 2102 RAM in Videocart 10
3854 port $F0 to $FF
The 3854 DMA device each has three internal registers adressed as four separate I/O-ports. Registers are called BUFA, BUFB, BUFC and BUFD where BUFA and BUFB represents address, BUFC represents byte count that also uses four bits from BUFD. Last four bits are used for function code.