| ... | ... |
@@ -24,5 +24,5 @@ rm -f ./bin/emulator |
| 24 | 24 |
cc -std=c89 -DDEBUG -Wall -Wno-unknown-pragmas -Wpedantic -Wshadow -Wextra -Werror=implicit-int -Werror=incompatible-pointer-types -Werror=int-conversion -Wvla -g -Og -fsanitize=address -fsanitize=undefined uxn.c emulator.c -L/usr/local/lib -lSDL2 -o bin/emulator |
| 25 | 25 |
|
| 26 | 26 |
# run |
| 27 |
-./bin/assembler examples/line.usm bin/boot.rom |
|
| 27 |
+./bin/assembler examples/draw.usm bin/boot.rom |
|
| 28 | 28 |
./bin/emulator bin/boot.rom |
| ... | ... |
@@ -4,6 +4,7 @@ |
| 4 | 4 |
:dev/w fff9 ( std write port ) |
| 5 | 5 |
|
| 6 | 6 |
;x_ 2 ;y_ 2 ;x 2 ;y 2 ;w 2 ;h 2 ;color 1 |
| 7 |
+;x0 2 ;y0 2 ;x1 2 ;y1 2 ;dx 2 ;dy 2 ;err1 2 ;err2 2 ( line ) |
|
| 7 | 8 |
|
| 8 | 9 |
|0100 @RESET |
| 9 | 10 |
|
| ... | ... |
@@ -38,6 +39,23 @@ |
| 38 | 39 |
( fill rect x y w h ) |
| 39 | 40 |
,0028 ,0038 ,0050 ,0030 ,linerect JSR |
| 40 | 41 |
|
| 42 |
+ |
|
| 43 |
+ ( positive ) |
|
| 44 |
+ ,01 ,color STR |
|
| 45 |
+ +0030 ,x0 STR^ +0040 ,y0 STR^ |
|
| 46 |
+ +0100 ,x1 STR^ +0060 ,y1 STR^ |
|
| 47 |
+ ,line JSR |
|
| 48 |
+ |
|
| 49 |
+ ,02 ,color STR |
|
| 50 |
+ +0020 ,x0 STR^ +0010 ,y0 STR^ |
|
| 51 |
+ +0090 ,x1 STR^ +0070 ,y1 STR^ |
|
| 52 |
+ ,line JSR |
|
| 53 |
+ |
|
| 54 |
+ ,03 ,color STR |
|
| 55 |
+ +0010 ,x0 STR^ +0040 ,y0 STR^ |
|
| 56 |
+ +0070 ,x1 STR^ +0060 ,y1 STR^ |
|
| 57 |
+ ,line JSR |
|
| 58 |
+ |
|
| 41 | 59 |
,redraw JSR |
| 42 | 60 |
|
| 43 | 61 |
BRK |
| ... | ... |
@@ -70,6 +88,31 @@ BRK |
| 70 | 88 |
,x_ LDR^ ,w LDR^ ,x LDR^ ADD^ ,0001 ADD^ LTH^ ,linerectrow ROT JMP? POP^ |
| 71 | 89 |
RTS |
| 72 | 90 |
|
| 91 |
+@line |
|
| 92 |
+ ,x0 LDR^ ,x_ STR^ ,y0 LDR^ ,y_ STR^ ( start at x0,y0 ) |
|
| 93 |
+ ,x1 LDR^ ,x0 LDR^ ,diff16sub JSR ,dx STR^ ( int dx = abs[x1 - x0] ) |
|
| 94 |
+ ,y1 LDR^ ,y0 LDR^ ,diff16sub JSR -0001 MUL!^ ,dy STR^ ( int dy = -abs[y1 - y0] ) |
|
| 95 |
+ ,dx LDR^ ,dy LDR^ ADD!^ ,err1 STR^ ( int err1 = dx + dy, e2; ) |
|
| 96 |
+ @lineloop |
|
| 97 |
+ ,x_ LDR^ ,y_ LDR^ ,putpixel JSR ( draw ) |
|
| 98 |
+ @line-x |
|
| 99 |
+ ,err1 LDR^ +0002 MUL!^ ,err2 STR^ ( e2 = 2 * err; ) |
|
| 100 |
+ ,err2 LDR^ ,dy LDR^ LTH!^ ,line-y ROT JMP? POP^ ( e2 >= dy ) |
|
| 101 |
+ ,err1 LDR^ ,dy LDR^ ADD!^ ,err1 STR^ ( err1 += dy; ) |
|
| 102 |
+ ,x_ LDR^ +0001 ADD!^ ,x_ STR^ ( y0 += y0 < y1 ? 1 : -1; ) |
|
| 103 |
+ @line-y |
|
| 104 |
+ ,err2 LDR^ ,dx LDR^ GTH!^ ,line-end ROT JMP? POP^ ( e2 <= dx ) |
|
| 105 |
+ ,err1 LDR^ ,dx LDR^ ADD!^ ,err1 STR^ ( err1 += dx; ) |
|
| 106 |
+ ,y_ LDR^ +0001 ADD!^ ,y_ STR^ ( y0 += y0 < y1 ? 1 : -1; ) |
|
| 107 |
+ @line-end |
|
| 108 |
+ ,x_ LDR^ ,x1 LDR^ NEQ!^ ,lineloop ROT JMP? POP^ ( loop ) |
|
| 109 |
+ RTS |
|
| 110 |
+ |
|
| 111 |
+@diff16 |
|
| 112 |
+ OVR^ OVR^ GTH^ ,diff16sub ROT JMP? POP^ |
|
| 113 |
+ SWP^ @diff16sub SUB^ |
|
| 114 |
+RTS |
|
| 115 |
+ |
|
| 73 | 116 |
@redraw |
| 74 | 117 |
,0000 IOW^ |
| 75 | 118 |
,0000 IOW^ |
| ... | ... |
@@ -3,27 +3,28 @@ |
| 3 | 3 |
:dev/r fff8 ( std read port ) |
| 4 | 4 |
:dev/w fff9 ( std write port ) |
| 5 | 5 |
|
| 6 |
-;x_ 2 ;y_ 2 ;x0 2 ;y0 2 ;x1 2 ;y1 2 ;color 1 |
|
| 7 |
-;dx 2 ;dy 2 ;err 2 ;err2 2 |
|
| 6 |
+;x_ 2 ;y_ 2 ;color 1 |
|
| 7 |
+;x0 2 ;y0 2 ;x1 2 ;y1 2 ;dx 2 ;dy 2 ;err1 2 ;err2 2 |
|
| 8 | 8 |
|
| 9 | 9 |
|0100 @RESET |
| 10 | 10 |
|
| 11 | 11 |
( set dev/write to screen ) |
| 12 | 12 |
,01 ,dev/w STR |
| 13 | 13 |
|
| 14 |
+ ( positive ) |
|
| 14 | 15 |
,01 ,color STR |
| 15 | 16 |
+0030 ,x0 STR^ +0040 ,y0 STR^ |
| 16 |
- +0050 ,x1 STR^ +0060 ,y1 STR^ |
|
| 17 |
+ +0100 ,x1 STR^ +0060 ,y1 STR^ |
|
| 17 | 18 |
,line JSR |
| 18 | 19 |
|
| 19 | 20 |
,02 ,color STR |
| 20 | 21 |
+0020 ,x0 STR^ +0010 ,y0 STR^ |
| 21 |
- +0060 ,x1 STR^ +0070 ,y1 STR^ |
|
| 22 |
+ +0090 ,x1 STR^ +0070 ,y1 STR^ |
|
| 22 | 23 |
,line JSR |
| 23 | 24 |
|
| 24 | 25 |
,03 ,color STR |
| 25 | 26 |
+0010 ,x0 STR^ +0040 ,y0 STR^ |
| 26 |
- +0080 ,x1 STR^ +0060 ,y1 STR^ |
|
| 27 |
+ +0070 ,x1 STR^ +0060 ,y1 STR^ |
|
| 27 | 28 |
,line JSR |
| 28 | 29 |
|
| 29 | 30 |
( draw control points ) |
| ... | ... |
@@ -39,19 +40,20 @@ BRK |
| 39 | 40 |
,x0 LDR^ ,x_ STR^ ,y0 LDR^ ,y_ STR^ ( start at x0,y0 ) |
| 40 | 41 |
,x1 LDR^ ,x0 LDR^ ,diff16sub JSR ,dx STR^ ( int dx = abs[x1 - x0] ) |
| 41 | 42 |
,y1 LDR^ ,y0 LDR^ ,diff16sub JSR -0001 MUL!^ ,dy STR^ ( int dy = -abs[y1 - y0] ) |
| 42 |
- ,dx LDR^ ,dy LDR^ ADD!^ ,err STR^ ( int err = dx + dy, e2; ) |
|
| 43 |
- @loop |
|
| 43 |
+ ,dx LDR^ ,dy LDR^ ADD!^ ,err1 STR^ ( int err1 = dx + dy, e2; ) |
|
| 44 |
+ @lineloop |
|
| 44 | 45 |
,x_ LDR^ ,y_ LDR^ ,putpixel JSR ( draw ) |
| 45 |
- ,err LDR^ +0002 MUL!^ ,err2 STR^ ( e2 = 2 * err; ) |
|
| 46 |
- ,err2 LDR^ ,dy LDR^ LTH!^ ,continue1 ROT JMP? POP^ ( e2 >= dy ) |
|
| 47 |
- ,err LDR^ ,dy LDR^ ADD!^ ,err STR^ ( err += dy; ) |
|
| 46 |
+ @line-x |
|
| 47 |
+ ,err1 LDR^ +0002 MUL!^ ,err2 STR^ ( e2 = 2 * err; ) |
|
| 48 |
+ ,err2 LDR^ ,dy LDR^ LTH!^ ,line-y ROT JMP? POP^ ( e2 >= dy ) |
|
| 49 |
+ ,err1 LDR^ ,dy LDR^ ADD!^ ,err1 STR^ ( err1 += dy; ) |
|
| 48 | 50 |
,x_ LDR^ +0001 ADD!^ ,x_ STR^ ( y0 += y0 < y1 ? 1 : -1; ) |
| 49 |
- @continue1 |
|
| 50 |
- ,err2 LDR^ ,dx LDR^ GTH!^ ,continue2 ROT JMP? POP^ ( e2 <= dx ) |
|
| 51 |
- ,err LDR^ ,dx LDR^ ADD!^ ,err STR^ ( err += dx; ) |
|
| 51 |
+ @line-y |
|
| 52 |
+ ,err2 LDR^ ,dx LDR^ GTH!^ ,line-end ROT JMP? POP^ ( e2 <= dx ) |
|
| 53 |
+ ,err1 LDR^ ,dx LDR^ ADD!^ ,err1 STR^ ( err1 += dx; ) |
|
| 52 | 54 |
,y_ LDR^ +0001 ADD!^ ,y_ STR^ ( y0 += y0 < y1 ? 1 : -1; ) |
| 53 |
- @continue2 |
|
| 54 |
- ,x_ LDR^ ,x1 LDR^ LTH!^ ,loop ROT JMP? POP^ ( loop ) |
|
| 55 |
+ @line-end |
|
| 56 |
+ ,x_ LDR^ ,x1 LDR^ NEQ!^ ,lineloop ROT JMP? POP^ ( loop ) |
|
| 55 | 57 |
RTS |
| 56 | 58 |
|
| 57 | 59 |
@redraw |