Difference between revisions of "Accessing VRAM"

From veswiki
Jump to: navigation, search
 
(4 intermediate revisions by the same user not shown)
Line 1: Line 1:
 
... which means drawing graphics ...
 
... which means drawing graphics ...
  
To write data to video ram you have to load the x coordinate to port 4, y coordinate to port 5 and color to port 1 and then execute the transfer by writing to port 0. For compatibility with the first generation of Fairchild Video Entertainment System, especially the 2MHz PAL model, there needs to be a delay after sending the data through before the next pixel is loaded and sent.
+
To write data to video ram you have to load the x coordinate to port 4, y coordinate to port 5 and color to port 1 and then execute the transfer by writing to port 0. For compatibility with the first generation of Fairchild Video Entertainment System, especially the 2MHz PAL model, there needs to be a delay after sending the data through before the next pixel is loaded and sent. [http://mess.org MESS] will work fine without the delay but it's important for a real console or you'll get holes or gaps in what is drawn.
  
 
Here's an example of plot code used to to plot one pixel, coordinate (0,0) is top left corner, note that the first few horizontal and vertical lines are usually not visible on screen.
 
Here's an example of plot code used to to plot one pixel, coordinate (0,0) is top left corner, note that the first few horizontal and vertical lines are usually not visible on screen.
Line 9: Line 9:
 
;---------------;
 
;---------------;
  
; plot out a single point on the screen
+
; plot a single pixel on the screen
 
; uses three registers as "arguments", load correct data  
 
; uses three registers as "arguments", load correct data  
 
; in these registers before making a subroutine call (pi).
 
; in these registers before making a subroutine call (pi).
Line 16: Line 16:
 
; Valid colors
 
; Valid colors
 
;------------------------
 
;------------------------
 +
; green = $00 (%00000000)
 
; red = $40 (%01000000)
 
; red = $40 (%01000000)
 
; blue = $80 (%10000000)
 
; blue = $80 (%10000000)
; green = $00 (%00000000)
 
 
; bkg = $C0 (%11000000)
 
; bkg = $C0 (%11000000)
 
;------------------------
 
;------------------------
Line 25: Line 25:
  
 
plot:
 
plot:
; set the color using r1
+
; set the color on port 1 using r1
 
lr A, 1
 
lr A, 1
 
outs 1
 
outs 1
Line 37: Line 37:
 
lr A, 3
 
lr A, 3
 
com ; y-coordinate needs to be inverted before it's stored
 
com ; y-coordinate needs to be inverted before it's stored
 +
; ni %00111111 ; optional code to mute soundbits
 
outs 5 ; loaded to port 5
 
outs 5 ; loaded to port 5
  
 
; transfer data to the screen memory
 
; transfer data to the screen memory
; done by sending $60 and then $50 to port 0.
+
lis 6
li $60 ;%01100000
+
sl 4
 
outs 0
 
outs 0
li $50 ;%01010000
+
sl 1
 
outs 0
 
outs 0
  
Line 56: Line 57:
 
</pre>
 
</pre>
  
Code is taken from original cart/bios disassembly. It's however surprising that the value %01010000 is used for the second screen transfer as bit 4 isn't hooked up on that port. %01000000 ($40) should have the same effect. <br>
+
Comments about the code: This code is taken from the original cart/bios disassembly with minor changes.<br>
As seen in the [[Opcode|opcode table]] the instruction '''LI''' uses 2 bytes and takes 2.5 cycle to complete, a slightly better option could be the instruction '''LIS''' and '''SL 4''' that takes the same space but 0.5 cycle less. When drawing a lot of graphics this adds up after a while. ;-)
+
As seen in the [[Opcode|opcode table]] the instruction '''COM''' an extra cycle, a slightly better option <br>
 +
would be to skip the complement instruction and use the inverted value for the plot. <br>
 +
When drawing a lot of graphics this adds up after a while. ;-)

Latest revision as of 12:49, 16 August 2020

... which means drawing graphics ...

To write data to video ram you have to load the x coordinate to port 4, y coordinate to port 5 and color to port 1 and then execute the transfer by writing to port 0. For compatibility with the first generation of Fairchild Video Entertainment System, especially the 2MHz PAL model, there needs to be a delay after sending the data through before the next pixel is loaded and sent. MESS will work fine without the delay but it's important for a real console or you'll get holes or gaps in what is drawn.

Here's an example of plot code used to to plot one pixel, coordinate (0,0) is top left corner, note that the first few horizontal and vertical lines are usually not visible on screen.

;---------------;
; Plot Function ;
;---------------;

; plot a single pixel on the screen
; uses three registers as "arguments", load correct data 
; in these registers before making a subroutine call (pi).
; r1 = color
;------------------------
; Valid colors
;------------------------
; green	= $00 (%00000000)
; red	= $40 (%01000000)
; blue	= $80 (%10000000)
; bkg	= $C0 (%11000000)
;------------------------
; r2 = x (0-127)
; r3 = y (0-63)

plot:
	; set the color on port 1 using r1
	lr	A, 1
	outs	1

	; set the column using r2
	lr	A, 2
	com				; x-coordinate needs to be inverted before it's stored
	outs	4			; loaded to port 4

	; set the row using r3
	lr	A, 3
	com				; y-coordinate needs to be inverted before it's stored
;	ni	%00111111		; optional code to mute soundbits
	outs	5			; loaded to port 5

	; transfer data to the screen memory
	lis	6
	sl	4
	outs	0
	sl	1
	outs	0

	; delay until it's fully updated
	lis	6
plot.delay:	
	ai	$ff
	bnz	plot.delay

	pop							; return from the subroutine

Comments about the code: This code is taken from the original cart/bios disassembly with minor changes.
As seen in the opcode table the instruction COM an extra cycle, a slightly better option
would be to skip the complement instruction and use the inverted value for the plot.
When drawing a lot of graphics this adds up after a while. ;-)