Home » Archimedes archive » Acorn User » AU 1994-04.adf » !StarInfo_StarInfo » Turnbull/!Tubes/!RunImage
Turnbull/!Tubes/!RunImage
This website contains an archive of files for the Acorn Electron, BBC Micro, Acorn Archimedes, Commodore 16 and Commodore 64 computers, which Dominic Ford has rescued from his private collection of floppy disks and cassettes.
Some of these files were originally commercial releases in the 1980s and 1990s, but they are now widely available online. I assume that copyright over them is no longer being asserted. If you own the copyright and would like files to be removed, please contact me.
Tape/disk: | Home » Archimedes archive » Acorn User » AU 1994-04.adf » !StarInfo_StarInfo |
Filename: | Turnbull/!Tubes/!RunImage |
Read OK: | ✔ |
File size: | 3E3F bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
10REM >!RunImage 20REM by Alistair Turnbull 30REM (c) AU April 1994 40: 50MODE12:MODE9:OFF 60PROCconstants 70spacelen%=&80000:DIMspace%spacelen% 80code%=space%:space%+=&4000:endcode%=code%+&4000 90pos%=space%:space%+=16*nopos%+4 100lines%=space%:space%+=4*nolines%+4 110slist%=space%:space%+=4*nolines% 120sin%=space%:cos%=sin%+(64<<2):space%=cos%+(256<<2) 130spr%=space%:space%+=nospr%*1024:endspr%=space% 140back%=space%:space%+=&A000 150IFspace%>space%+spacelen%THENERROR255,"Not enough memory" 160PROCassemble 170PROCsetuppos 180FORT%=0TO319:sin%!(T%<<2)=(1<<SC%)*SIN(2*PI*T%/256):NEXT 190PROCcolours(0,0,0,0,0,0):OSCLI("FX112,2"):OSCLI("FX113,2") 200CLS:PROCfancyprint("Please wait a moment",640,512) 210PROCfadein(85,0,0,0,85,85) 220OSCLI("LOAD <Tubes$dir>.Sprites "+STR$~spr%) 230OSCLI("FX112,1"):PROCbackground 240PROCfadeout(85,0,0,0,85,85) 250FORT%=0TO&9FFFSTEP4:back%!T%=scr%!T%:scr2%!T%=scr%!T%:NEXT 260REPEAT 270CALLframe% 280UNTIL0 290END 300: 310: 320DEFPROCconstants 330nospr%=256 340nopos%=32:nolines%=32 350TR%=44 360AC%=16:VC%=12:SC%=12 370ENDPROC 380: 390DEFPROCsetuppos 400READNP%,NL% 410FORT%=0TONP%-1:READX%,Y%,Z% 420pos%!(T%*16)=(X%+128<<24)+(Y%+128<<16)+(Z%+128<<8) 430NEXT:pos%!(NP%*16)=-1 440READcheck%:IFcheck%<>-1THENERROR255,"Data error" 450FORT%=0TONL%-1:READF%,G%,N% 460lines%!(T%*4)=(F%<<24)+(G%<<16)+(N%<<8) 470NEXT:lines%!(NL%*4)=-1 480READcheck%:IFcheck%<>-1THENERROR255,"Data error" 490ENDPROC 500: 510DATA4,6 520DATA60,60,-60 530DATA-60,-60,-60 540DATA60,-60,60 550DATA-60,60,60 560DATA-1 570DATA0,1,8, 0,2,8, 0,3,8, 1,2,8, 1,3,8, 2,3,8 580DATA-1 590: 600DEFPROCbackground 610LX=-1:LY=1:LZ=-2:F=1/SQR(LX*LX+LY*LY+LZ*LZ):LX=LX*F:LY=LY*F:LZ=LZ*F 620MX=1:MY=1:MZ=-2:F=1/SQR(MX*MX+MY*MY+MZ*MZ):MX=MX*F:MY=MY*F:MZ=MZ*F 630OSCLI("FX112,2"):!back%=148:back%!4=-1:SYS"OS_ReadVduVariables",back%,back%:scr2%=!back% 640OSCLI("FX112,1"):!back%=148:back%!4=-1:SYS"OS_ReadVduVariables",back%,back%:scr%=!back% 650FORX%=-30TO30STEP4:FORY%=-30TO30STEP4 660X=X%/32:Y=Y%/32:Z2=1-X*X-Y*Y:IFZ2>0THEN 670Z=-SQR(Z2) 680PROClight(X,Y,Z):POINTX%+32,Y%+32 690PROClight(-X,-Y,Z):POINTX%+96,Y%+32 700ELSEPROClight(0,0,-1):POINTX%+32,Y%+32:POINTX%+96,Y%+32 710ENDIF:NEXT, 720MOVE0,0:MOVEBY63,63:VDU23,27,1,0| 730MOVE64,0:MOVEBY63,63:VDU23,27,1,1| 740FORX%=0TO20:FORY%=0TO15:VDU23,27,0,RND(2)-1|:PLOT&ED,(X%<<6)-((Y%AND1)<<5),Y%<<6:NEXT, 750ENDPROC 760: 770DEFPROClight(X,Y,Z) 780LB=LX*X+LY*Y+LZ*Z:IFLB<0THENLB=0ELSELB=3*LB+RND(1) 790MB=MX*X+MY*Y+MZ*Z:IFMB<0THENMB=0ELSEMB=3*MB+RND(1) 800GCOL0,(LB<<2)+MB 810ENDPROC 820: 830DEFPROCcolours(A%,B%,C%,D%,E%,F%) 840LOCALT%,U% 850FORT%=0TO3:FORU%=0TO3:COLOURT%+(U%<<2),T%*A%+U%*D%,T%*B%+U%*E%,T%*C%+U%*F%:NEXT, 860ENDPROC 870: 880DEFPROCfadein(A%,B%,C%,D%,E%,F%) 890NT%=TIME:REPEAT:H%=TIME-NT%:IFH%>128THENH%=128 900PROCcolours(A%*H%>>7,B%*H%>>7,C%*H%>>7,D%*H%>>7,E%*H%>>7,F%*H%>>7) 910UNTILH%>=128 920ENDPROC 930: 940DEFPROCfadeout(A%,B%,C%,D%,E%,F%) 950NT%=TIME:REPEAT:H%=128-TIME+NT%:IFH%<0THENH%=0 960PROCcolours(A%*H%>>7,B%*H%>>7,C%*H%>>7,D%*H%>>7,E%*H%>>7,F%*H%>>7) 970UNTILH%<=0 980ENDPROC 990: 1000DEFPROCfancyprint(T$,X%,Y%) 1010Y%+=15:X%-=LEN(T$)<<4:VDU5 1020GCOL0,(3<<0)+(1<<2):MOVEX%-4,Y%+4:PRINTT$ 1030GCOL0,(1<<0)+(3<<2):MOVEX%+4,Y%+4:PRINTT$ 1040GCOL0,(1<<0)+(0<<2):MOVEX%-4,Y%-4:PRINTT$ 1050GCOL0,(0<<0)+(1<<2):MOVEX%+4,Y%-4:PRINTT$ 1060GCOL0,(2<<0)+(2<<2):MOVEX%,Y%+4:PRINTT$ 1070GCOL0,(2<<0)+(0<<2):MOVEX%-4,Y%:PRINTT$ 1080GCOL0,(0<<0)+(2<<2):MOVEX%-4,Y%:PRINTT$ 1090GCOL0,(0<<0)+(2<<2):MOVEX%,Y%-4:PRINTT$ 1100GCOL0,(1<<1)+(1<<2):MOVEX%,Y%:PRINTT$ 1110VDU4:OFF 1120ENDPROC 1130: 1140DEFFNadr(R%,A%,I%) 1150IF(P%AND3)<>0THENPRINT"Code isn't word aligned!":END 1160LOCALN%,O%,H%,U%:H%=A%-(P%+8):N%=0:O%=15 1170FORU%=1TOI%:IFH%=0THEN 1180[OPT T%:MOV R%,O%:] 1190ELSEWHILE(H%AND3)=0:H%=H%>>2:N%+=2:ENDWHILE 1200IF(H%AND256)=0THEN 1210[OPT T%:ADD R%,O%,#(H%AND255)<<N%:]:H%-=H%AND255 1220ELSE[OPT T%:SUB R%,O%,#(256-H%AND255)<<N%:]:H%+=256-H%AND255 1230ENDIF 1240ENDIF:O%=R%:NEXT 1250IFH%<>0THENPRINT"Could not ADR to ";A%;" in ";I%;" instructions (R%=";R%;")":END 1260=T% 1270: 1280DEFPROCassemble 1290FORT%=0TO2STEP2:P%=code% 1300[OPT T% 1310.link% 1320EQUD -1:EQUD -1:EQUD -1:EQUD -1 1330.sp%:EQUD -1 1340: 1350.vduvars%:EQUD 148:EQUD -1 1360.scraddr%:EQUD -1 1370.bank%:EQUD -1 1380: 1390.frame% 1400STR R13,sp% 1410STR R14,link%+0 1420LDR R1,bank% 1430AND R1,R1,#1 1440ADD R1,R1,#1 1450STR R1,bank% 1460MOV R0,#112 1470SWI "OS_Byte" 1480ADR R0,vduvars% 1490ADR R1,scraddr% 1500SWI "OS_ReadVduVariables" 1510; Draw the frame 1520BL drawback% 1530BL animation% 1540BL rotate% 1550BL transform% 1560BL sort% 1570BL plotshape% 1580; Display the new screen 1590MOV R0,#19 1600SWI "OS_Byte" 1610LDR R1,bank% 1620MOV R0,#113 1630SWI "OS_Byte" 1640LDR R14,link%+0 1650LDR R13,sp% 1660MOV PC,R14 1670: 1680.tempstoreft% 1690EQUD -1:EQUD -1:EQUD -1:EQUD -1 1700EQUD -1:EQUD -1:EQUD -1:EQUD -1 1710: 1720.findtube% 1730ADR R13,tempstoreft% 1740STMIA R13,{R0-R3,R14} 1750OPT FNadr(13,spr%,2) 1760CMP R2,#0 1770RSBLT R0,R0,#0 1780RSBLT R1,R1,#0 1790RSBLT R2,R2,#0 1800CMP R1,#0 1810ADDGE R13,R13,#6<<10 1820RSBLT R1,R1,#0 1830CMP R0,#0 1840ADDLT R13,R13,#3<<10 1850RSBLT R0,R0,#0 1860CMP R1,R0 1870CMPGT R1,R2 1880BGT ybigft% 1890CMP R2,R0 1900BGT zbigft% 1910.xbigft% 1920ADD R13,R13,#1<<10 1930.endbigft% 1940CMP R1,R0,ASR#1 1950SUBGE R1,R1,R0,ASR#1 1960ADDGE R13,R13,#96<<10 1970CMP R1,R0,ASR#2 1980ADDGE R13,R13,#48<<10 1990CMP R2,R0,ASR#1 2000SUBGE R2,R2,R0,ASR#1 2010ADDGE R13,R13,#24<<10 2020CMP R2,R0,ASR#2 2030ADDGE R13,R13,#12<<10 2040.endfindtube% 2050ADR R3,tempstoreft% 2060LDMIA R3,{R0-R3,R14} 2070MOV PC,R14 2080: 2090.ybigft% 2100ADD R13,R13,#2<<10 2110MOV R3,R0 2120MOV R0,R1 2130MOV R1,R2 2140MOV R2,R3 2150B endbigft% 2160: 2170.zbigft% 2180MOV R3,R2 2190MOV R2,R1 2200MOV R1,R0 2210MOV R0,R3 2220B endbigft% 2230: 2240.tempstoreds% 2250EQUD -1:EQUD -1:EQUD -1:EQUD -1 2260EQUD -1:EQUD -1:EQUD -1:EQUD -1 2270EQUD -1:EQUD -1:EQUD -1:EQUD -1 2280EQUD -1:EQUD -1:EQUD -1:EQUD -1 2290: 2300.drawsprite% 2310; Corrupts R2 2320ADR R2,tempstoreds% 2330STMIA R2,{R0-R1,R3-R9,R11,R13-R14} 2340SUB R0,R0,#15.5*(1<<AC%):; TL corner 2350SUB R1,R1,#15.5*(1<<AC%) 2360MOV R0,R0,LSR#AC% 2370MOV R1,R1,LSR#AC% 2380CMP R0,#288 2390CMPLE R1,#224 2400BGT enddrawsprite%:; (Partially) off screen 2410BIC R13,R13,#1 2420LDR R14,scraddr% 2430ADD R14,R14,R1,ASL#5 2440ADD R14,R14,R1,ASL#7 2450AND R2,R0,#7:; Word alignment 2460MOV R0,R0,LSR#3 2470ADD R14,R14,R0,ASL#2:; Screen address 2480MOV R11,#32 2490ADR R1,routineds% 2500LDR R0,[R1,R2,ASL#2] 2510ADD PC,R1,R0 2520MOV R0,R0 2530: 2540.enddrawsprite% 2550ADR R2,tempstoreds% 2560LDMIA R2,{R0-R1,R3-R9,R11,R13-R14} 2570MOV PC,R14 2580: 2590.routineds% 2600]:FORU%=0TO7:[OPT T% 2610EQUD enddrawsprite%-routineds% 2620]:NEXT:[OPT T% 2630: 2640]:routineds%!(0<<2)=P%-routineds%:[OPT T% 2650.yloop% 2660LDMIA R14,{R0-R3} 2670LDMIA R13!,{R5-R8} 2680BIC R0,R0,R6:ORR R0,R0,R5 2690BIC R1,R1,R8:ORR R1,R1,R7 2700LDMIA R13!,{R5-R8} 2710BIC R2,R2,R6:ORR R2,R2,R5 2720BIC R3,R3,R8:ORR R3,R3,R7 2730STMIA R14,{R0-R3} 2740ADD R14,R14,#160 2750SUBS R11,R11,#1 2760BGT yloop% 2770B enddrawsprite% 2780: 2790]:FORU%=1TO7:routineds%!(U%<<2)=P%-routineds%:[OPT T% 2800.yloop% 2810LDMIA R14,{R0-R4} 2820LDMIA R13!,{R5-R8} 2830BIC R0,R0,R6,LSL#U%<<2:ORR R0,R0,R5,LSL#U%<<2:BIC R1,R1,R6,LSR#8-U%<<2:ORR R1,R1,R5,LSR#8-U%<<2 2840BIC R1,R1,R8,LSL#U%<<2:ORR R1,R1,R7,LSL#U%<<2:BIC R2,R2,R8,LSR#8-U%<<2:ORR R2,R2,R7,LSR#8-U%<<2 2850LDMIA R13!,{R5-R8} 2860BIC R2,R2,R6,LSL#U%<<2:ORR R2,R2,R5,LSL#U%<<2:BIC R3,R3,R6,LSR#8-U%<<2:ORR R3,R3,R5,LSR#8-U%<<2 2870BIC R3,R3,R8,LSL#U%<<2:ORR R3,R3,R7,LSL#U%<<2:BIC R4,R4,R8,LSR#8-U%<<2:ORR R4,R4,R7,LSR#8-U%<<2 2880STMIA R14,{R0-R4} 2890ADD R14,R14,#160 2900SUBS R11,R11,#1 2910BGT yloop% 2920B enddrawsprite% 2930]:NEXT:[OPT T% 2940: 2950.tempstoredt% 2960EQUD -1:EQUD -1:EQUD -1:EQUD -1 2970EQUD -1:EQUD -1:EQUD -1:EQUD -1 2980EQUD -1:EQUD -1:EQUD -1:EQUD -1 2990EQUD -1:EQUD -1:EQUD -1:EQUD -1 3000: 3010.drawtube% 3020; Corrupts R13 3030; Expects R0-R1 to be the direction vector 3040; Expects R3-R4(,R5) to be start position 3050; Expects R6 to be the number of steps 3060ADR R13,tempstoredt% 3070STMIA R13,{R0-R12,R14} 3080CMP R2,#0 3090ADDGT R3,R3,R0:; Must start at the far end 3100ADDGT R4,R4,R1 3110ADDGT R5,R5,R2 3120RSBGT R0,R0,#0:; Must have vector facing towards viewer 3130RSBGT R1,R1,#0 3140RSBGT R2,R2,#0 3150BL findtube% 3160; Divide 1<<8 by 3 3170MOV R7,#1<<8 3180MOV R8,#0 3190]:FORU%=7TO1STEP-1:[OPT T% 3200CMP R6,R7,ASR#U% 3210SUBLE R7,R7,R6,ASL#U% 3220ADDLE R8,R8,#1<<U% 3230]:NEXT:[OPT T% 3240CMP R6,R7 3250ADDLE R8,R8,#1 3260MOV R5,R1,ASR#8 3270MOV R1,R4 3280MOV R4,R0,ASR#8 3290MOV R0,R3 3300MUL R4,R8,R4:; Vector per step 3310MUL R5,R8,R5 3320ADD R0,R0,R4,ASR#1:; Half way along first step 3330ADD R1,R1,R5,ASR#1 3340.steploop% 3350BL drawsprite% 3360ADD R0,R0,R4 3370ADD R1,R1,R5 3380SUBS R6,R6,#1 3390BGT steploop% 3400ADR R13,tempstoredt% 3410LDMIA R13,{R0-R12,R14} 3420MOV PC,R14 3430: 3440.tempstoretrans% 3450EQUD -1:EQUD -1:EQUD -1:EQUD -1 3460EQUD -1:EQUD -1:EQUD -1:EQUD -1 3470EQUD -1:EQUD -1:EQUD -1:EQUD -1 3480: 3490.view% 3500EQUD 1<<VC%:EQUD 0:EQUD 0:; X-vector 3510EQUD 0:EQUD 1<<VC%:EQUD 0:; Y-vector 3520EQUD 0:EQUD 0:EQUD 1<<VC%:; Z-vector 3530: 3540.transform% 3550; Corrupts R0 3560ADR R0,tempstoretrans% 3570STMIA R0,{R1-R9,R14} 3580OPT FNadr(14,pos%,2) 3590.posloop% 3600LDR R9,[R14] 3610CMN R9,#1:; Pos list terminator 3620BEQ endtransform% 3630BIC R0,R9,#1:; Clear the "already drawn" flag 3640ADR R7,view% 3650; X*X-vector 3660MOV R8,R9,LSR#24 3670MOV R9,R9,LSL#8 3680LDMIA R7!,{R4-R6} 3690MUL R1,R8,R4 3700SUB R1,R1,R4,ASL#7 3710MUL R2,R8,R5 3720SUB R2,R2,R5,ASL#7 3730MUL R3,R8,R6 3740SUB R3,R3,R6,ASL#7 3750; Y*Y-vector 3760MOV R8,R9,LSR#24 3770MOV R9,R9,LSL#8 3780LDMIA R7!,{R4-R6} 3790MLA R1,R8,R4,R1 3800SUB R1,R1,R4,ASL#7 3810MLA R2,R8,R5,R2 3820SUB R2,R2,R5,ASL#7 3830MLA R3,R8,R6,R3 3840SUB R3,R3,R6,ASL#7 3850; Z*Z-vector 3860MOV R8,R9,LSR#24 3870MOV R9,R9,LSL#8 3880LDMIA R7!,{R4-R6} 3890MLA R1,R8,R4,R1 3900SUB R1,R1,R4,ASL#7 3910MLA R2,R8,R5,R2 3920SUB R2,R2,R5,ASL#7 3930MLA R3,R8,R6,R3 3940SUB R3,R3,R6,ASL#7 3950MOV R1,R1,ASL#AC%-VC% 3960MOV R2,R2,ASL#AC%-VC% 3970MOV R3,R3,ASL#AC%-VC% 3980ADD R1,R1,#160<<AC% 3990ADD R2,R2,#128<<AC% 4000STMIA R14!,{R0,R1-R3} 4010B posloop% 4020: 4030.endtransform% 4040ADR R0,tempstoretrans% 4050LDMIA R0,{R1-R9,R14} 4060MOV PC,R14 4070: 4080.tempstoresort% 4090EQUD -1:EQUD -1:EQUD -1:EQUD -1 4100EQUD -1:EQUD -1:EQUD -1:EQUD -1 4110: 4120.sort% 4130; Corrupts R0 4140ADR R0,tempstoresort% 4150STMIA R0,{R0-R1,R11-R14} 4160; Compile a list of lines, with distances attached 4170OPT FNadr(14,pos%+12,2):; Z-coordinates 4180OPT FNadr(13,lines%,2) 4190OPT FNadr(12,slist%,2) 4200MOV R11,#0 4210.lineloop% 4220LDR R0,[R13],#4 4230CMN R0,#1 4240BEQ endsort1% 4250AND R1,R0,#255<<16 4260AND R0,R0,#255<<24 4270LDR R0,[R14,R0,LSR#24-4] 4280LDR R1,[R14,R1,LSR#16-4] 4290ADD R0,R0,R1 4300MOV R0,R0,ASR#1 4310BIC R0,R0,#255 4320ORR R0,R0,R11 4330STR R0,[R12],#4 4340ADD R11,R11,#1 4350B lineloop% 4360: 4370.endsort1% 4380STR R0,[R12],#-4 4390; Sort them 4400OPT FNadr(14,slist%,2) 4410; R12 is last one 4420CMP R12,R14 4430BLE endsort2%:; 0 or 1 of them 4440.outloop% 4450LDMIA R14,{R0-R1} 4460MOV R13,R14 4470.inloop% 4480CMP R0,R1 4490STRGT R0,[R13],#4 4500MOVGT R0,R1 4510STRLE R1,[R13],#4 4520LDR R1,[R13,#4] 4530CMP R13,R12 4540BLT inloop% 4550STR R0,[R13] 4560SUB R12,R12,#4 4570CMP R12,R14 4580BGT outloop% 4590.endsort2% 4600ADR R0,tempstoresort% 4610LDMIA R0,{R0-R1,R11-R14} 4620MOV PC,R14 4630: 4640.tempstoreps% 4650EQUD -1:EQUD -1:EQUD -1:EQUD -1 4660EQUD -1:EQUD -1:EQUD -1:EQUD -1 4670EQUD -1:EQUD -1:EQUD -1:EQUD -1 4680EQUD -1:EQUD -1:EQUD -1:EQUD -1 4690: 4700.plotshape% 4710; R0 corrupted 4720ADR R0,tempstoreps% 4730STMIA R0,{R1-R14} 4740OPT FNadr(10,pos%,2) 4750OPT FNadr(11,lines%,2) 4760OPT FNadr(12,slist%,2) 4770.plotloop% 4780LDR R0,[R12],#4 4790CMN R0,#1 4800BEQ endplotshape% 4810AND R0,R0,#255 4820LDR R0,[R11,R0,ASL#2] 4830AND R6,R0,#255<<8 4840MOV R6,R6,LSR#8 4850AND R3,R0,#255<<24 4860AND R4,R0,#255<<16 4870ADD R3,R10,R3,LSR#24-4 4880ADD R4,R10,R4,LSR#16-4 4890OPT FNadr(13,spr%+(192<<10),2):; Sphere 4900LDR R0,[R3] 4910TST R0,#1 4920BNE alreadyplotted1% 4930ORR R0,R0,#1 4940STR R0,[R3] 4950LDMIB R3,{R0-R1} 4960BL drawsprite% 4970.alreadyplotted1% 4980LDR R0,[R4] 4990TST R0,#1 5000BNE alreadyplotted2% 5010ORR R0,R0,#1 5020STR R0,[R4] 5030LDMIB R4,{R0-R1} 5040BL drawsprite% 5050.alreadyplotted2% 5060LDMIB R3,{R0-R2} 5070LDMIB R4,{R3-R5} 5080SUB R0,R0,R3 5090SUB R1,R1,R4 5100SUB R2,R2,R5 5110BL drawtube% 5120B plotloop% 5130: 5140.endplotshape% 5150ADR R0,tempstoreps% 5160LDMIA R0,{R1-R14} 5170MOV PC,R14 5180: 5190.tempstorerot% 5200EQUD -1:EQUD -1:EQUD -1:EQUD -1 5210EQUD -1:EQUD -1:EQUD -1:EQUD -1 5220EQUD -1:EQUD -1:EQUD -1:EQUD -1 5230EQUD -1:EQUD -1:EQUD -1:EQUD -1 5240: 5250.rotate% 5260; Corrupts R0 5270ADR R0,tempstorerot% 5280STMIA R0,{R1-R14} 5290; The rotations 5300OPT FNadr(14,sin%,2) 5310MOV R0,#1<<VC%:MOV R1,#0:MOV R2,#0:; Identity matrix 5320MOV R3,#0:MOV R4,#1<<VC%:MOV R5,#0 5330MOV R6,#0:MOV R7,#0:MOV R8,#1<<VC% 5340; X-axis rotation 5350LDR R12,angles%+0 5360AND R12,R12,#255 5370ADD R12,R14,R12,ASL#2 5380LDR R13,[R12,#cos%-sin%] 5390LDR R12,[R12] 5400]:FORU%=0TO8STEP3:[OPT T% 5410MOV R9,(U%+2) 5420MUL (U%+2),R13,R9 5430MLA (U%+2),R12,(U%+1),(U%+2) 5440MUL (U%+1),R13,(U%+1) 5450MUL R9,R12,R9 5460SUB (U%+1),(U%+1),R9 5470MOV (U%+1),(U%+1),ASR#SC% 5480MOV (U%+2),(U%+2),ASR#SC% 5490]:NEXT:[OPT T% 5500; Y-axis rotation 5510LDR R12,angles%+4 5520AND R12,R12,#255 5530ADD R12,R14,R12,ASL#2 5540LDR R13,[R12,#cos%-sin%] 5550LDR R12,[R12] 5560]:FORU%=0TO8STEP3:[OPT T% 5570MOV R9,U% 5580MUL U%,R13,R9 5590MLA U%,R12,(U%+2),U% 5600MUL (U%+2),R13,(U%+2) 5610MUL R9,R12,R9 5620SUB (U%+2),(U%+2),R9 5630MOV (U%+2),(U%+2),ASR#SC% 5640MOV U%,U%,ASR#SC% 5650]:NEXT:[OPT T% 5660; Z-axis rotation 5670LDR R12,angles%+8 5680AND R12,R12,#255 5690ADD R12,R14,R12,ASL#2 5700LDR R13,[R12,#cos%-sin%] 5710LDR R12,[R12] 5720]:FORU%=0TO8STEP3:[OPT T% 5730MOV R9,(U%+1) 5740MUL (U%+1),R13,R9 5750MLA (U%+1),R12,U%,(U%+1) 5760MUL U%,R13,U% 5770MUL R9,R12,R9 5780SUB U%,U%,R9 5790MOV U%,U%,ASR#SC% 5800MOV (U%+1),(U%+1),ASR#SC% 5810]:NEXT:[OPT T% 5820OPT FNadr(12,view%,2) 5830STMIA R12,{R0-R8} 5840ADR R0,tempstorerot% 5850LDMIA R0,{R1-R14} 5860MOV PC,R14 5870: 5880.tempstoreanim% 5890EQUD -1:EQUD -1:EQUD -1:EQUD -1 5900EQUD -1:EQUD -1:EQUD -1:EQUD -1 5910EQUD -1:EQUD -1:EQUD -1:EQUD -1 5920EQUD -1:EQUD -1:EQUD -1:EQUD -1 5930: 5940.random%:EQUD 1 5950.colno%:EQUD 15 5960: 5970.angles% 5980EQUD 0:EQUD 0:EQUD 0 5990EQUD 1:EQUD 2:EQUD 3 6000.colours% 6010EQUD 0:EQUD 85:EQUD 85 6020EQUD 85:EQUD 0:EQUD 0 6030EQUD 0:EQUD 0:EQUD 0 6040EQUD 0:EQUD 0:EQUD 0 6050: 6060.animation% 6070; Corrupts R0 6080ADR R0,tempstoreanim% 6090STMIA R0,{R1-R14} 6100LDR R14,random% 6110; Increment angles 6120ADR R13,angles% 6130LDMIA R13,{R0-R5} 6140ADD R14,R14,R14,ASL#8 6150TST R14,#&FF000000 6160BNE dontchangespeed% 6170ADD R14,R14,R14,ASL#8 6180MOV R3,R14,ASR#31-1 6190ADD R14,R14,R14,ASL#8 6200MOV R4,R14,ASR#31-1 6210ADD R14,R14,R14,ASL#8 6220MOV R5,R14,ASR#31-1 6230.dontchangespeed% 6240ADD R0,R0,R3 6250ADD R1,R1,R4 6260ADD R2,R2,R5 6270STMIA R13,{R0-R5} 6280; Increment colours 6290ADR R13,colours% 6300LDMIA R13,{R0-R11} 6310ADD R14,R14,R14,ASL#7 6320TST R14,#&FE000000 6330BNE dontchangecolour1 6340TST R14,#1<<24 6350MOVEQ R0,#0 6360MOVNE R0,#85 6370TST R14,#1<<23 6380MOVEQ R1,#0 6390MOVNE R1,#85 6400TST R14,#1<<22 6410MOVEQ R2,#0 6420MOVNE R2,#85 6430.dontchangecolour1 6440ADD R14,R14,R14,ASL#7 6450TST R14,#&FE000000 6460BNE dontchangecolour2 6470TST R14,#1<<24 6480MOVEQ R3,#0 6490MOVNE R3,#85 6500TST R14,#1<<23 6510MOVEQ R4,#0 6520MOVNE R4,#85 6530TST R14,#1<<22 6540MOVEQ R5,#0 6550MOVNE R5,#85 6560.dontchangecolour2 6570]:FORU%=6TO11:[OPT T% 6580CMP U%,(U%-6) 6590ADDLT U%,U%,#1 6600SUBGT U%,U%,#1 6610]:NEXT:[OPT T% 6620STMIA R13,{R0-R11} 6630; Redefine colours 6640LDR R12,colno% 6650ADD R12,R12,#5 6660AND R12,R12,#15 6670STR R12,colno% 6680.colloop% 6690SWI &113:; VDU19, 6700MOV R0,R12 6710SWI "OS_WriteC":; colour, 6720SWI &110:; 16, 6730AND R1,R12,#3 6740MOV R2,R12,LSR#2 6750MUL R0,R1,R6 6760MLA R0,R2,R9,R0 6770CMP R0,#255 6780MOVGT R0,#255 6790SWI "OS_WriteC":; Red, 6800MUL R0,R1,R7 6810MLA R0,R2,R10,R0 6820CMP R0,#255 6830MOVGT R0,#255 6840SWI "OS_WriteC":; Green, 6850MUL R0,R1,R8 6860MLA R0,R2,R11,R0 6870CMP R0,#255 6880MOVGT R0,#255 6890SWI "OS_WriteC":; Blue 6900ADD R14,R14,#1 6910STR R14,random% 6920ADR R0,tempstoreanim% 6930LDMIA R0,{R1-R14} 6940MOV PC,R14 6950: 6960.tempstoredb% 6970EQUD -1:EQUD -1:EQUD -1:EQUD -1 6980EQUD -1:EQUD -1:EQUD -1:EQUD -1 6990EQUD -1:EQUD -1:EQUD -1:EQUD -1 7000EQUD -1:EQUD -1:EQUD -1:EQUD -1 7010: 7020.drawback% 7030; Corrupts R0 7040ADR R0,tempstoredb% 7050STMIA R0,{R1-R14} 7060LDR R14,scraddr% 7070ADD R14,R14,#32>>1 7080OPT FNadr(13,back%+(32>>1),3) 7090MOV R12,#256 7100.yloop% 7110]:FORU%=0TO255STEP8*8:[OPT T% 7120LDMIA R13!,{R0-R7} 7130STMIA R14!,{R0-R7} 7140]:NEXT:[OPT T% 7150ADD R13,R13,#320-256>>1 7160ADD R14,R14,#320-256>>1 7170SUBS R12,R12,#1 7180BGT yloop% 7190ADR R0,tempstoredb% 7200LDMIA R0,{R1-R14} 7210MOV PC,R14 7220: 7230]:IFP%>endcode%THENERROR255,"Not enough code memory" 7240NEXT 7250ENDPROC
� >!RunImage � by Alistair Turnbull � (c) AU April 1994 (: 2�12:�9:� <�constants F%spacelen%=&80000:�space%spacelen% P3code%=space%:space%+=&4000:endcode%=code%+&4000 Z#pos%=space%:space%+=16*nopos%+4 d&lines%=space%:space%+=4*nolines%+4 n$slist%=space%:space%+=4*nolines% x6sin%=space%:cos%=sin%+(64<<2):space%=cos%+(256<<2) �2spr%=space%:space%+=nospr%*1024:endspr%=space% �back%=space%:space%+=&A000 �5�space%>space%+spacelen%��255,"Not enough memory" � �assemble � �setuppos �3�T%=0�319:sin%!(T%<<2)=(1<<SC%)*�(2*�*T%/256):� �3�colours(0,0,0,0,0,0):�("FX112,2"):�("FX113,2") �1�:�fancyprint("Please wait a moment",640,512) ��fadein(85,0,0,0,85,85) �)�("LOAD <Tubes$dir>.Sprites "+�~spr%) ��("FX112,1"):�background ��fadeout(85,0,0,0,85,85) �5�T%=0�&9FFF�4:back%!T%=scr%!T%:scr2%!T%=scr%!T%:� � �frame% �0 "� ,: 6: @��constants Jnospr%=256 Tnopos%=32:nolines%=32 ^ TR%=44 hAC%=16:VC%=12:SC%=12 r� |: ���setuppos ��NP%,NL% ��T%=0�NP%-1:�X%,Y%,Z% �6pos%!(T%*16)=(X%+128<<24)+(Y%+128<<16)+(Z%+128<<8) ��:pos%!(NP%*16)=-1 �)�check%:�check%<>-1��255,"Data error" ��T%=0�NL%-1:�F%,G%,N% �+lines%!(T%*4)=(F%<<24)+(G%<<16)+(N%<<8) ��:lines%!(NL%*4)=-1 �)�check%:�check%<>-1��255,"Data error" �� �: ��4,6 �60,60,-60 �-60,-60,-60 �60,-60,60 &�-60,60,60 0�-1 :-�0,1,8, 0,2,8, 0,3,8, 1,2,8, 1,3,8, 2,3,8 D�-1 N: X��background bELX=-1:LY=1:LZ=-2:F=1/�(LX*LX+LY*LY+LZ*LZ):LX=LX*F:LY=LY*F:LZ=LZ*F lDMX=1:MY=1:MZ=-2:F=1/�(MX*MX+MY*MY+MZ*MZ):MX=MX*F:MY=MY*F:MZ=MZ*F vW�("FX112,2"):!back%=148:back%!4=-1:ș"OS_ReadVduVariables",back%,back%:scr2%=!back% �V�("FX112,1"):!back%=148:back%!4=-1:ș"OS_ReadVduVariables",back%,back%:scr%=!back% ��X%=-30�30�4:�Y%=-30�30�4 �'X=X%/32:Y=Y%/32:Z2=1-X*X-Y*Y:�Z2>0� �Z=-�(Z2) ��light(X,Y,Z):ȒX%+32,Y%+32 �!�light(-X,-Y,Z):ȒX%+96,Y%+32 �/��light(0,0,-1):ȒX%+32,Y%+32:ȒX%+96,Y%+32 ��:�, ��0,0:�BY63,63:�23,27,1,0| ��64,0:�BY63,63:�23,27,1,1| �H�X%=0�20:�Y%=0�15:�23,27,0,�(2)-1|:�&ED,(X%<<6)-((Y%�1)<<5),Y%<<6:�, �� �: ��light(X,Y,Z) -LB=LX*X+LY*Y+LZ*Z:�LB<0�LB=0�LB=3*LB+�(1) -MB=MX*X+MY*Y+MZ*Z:�MB<0�MB=0�MB=3*MB+�(1) �0,(LB<<2)+MB *� 4: > ��colours(A%,B%,C%,D%,E%,F%) H �T%,U% RF�T%=0�3:�U%=0�3:�T%+(U%<<2),T%*A%+U%*D%,T%*B%+U%*E%,T%*C%+U%*F%:�, \� f: p��fadein(A%,B%,C%,D%,E%,F%) z#NT%=�:�:H%=�-NT%:�H%>128�H%=128 �C�colours(A%*H%>>7,B%*H%>>7,C%*H%>>7,D%*H%>>7,E%*H%>>7,F%*H%>>7) ��H%>=128 �� �: � ��fadeout(A%,B%,C%,D%,E%,F%) �#NT%=�:�:H%=128-�+NT%:�H%<0�H%=0 �C�colours(A%*H%>>7,B%*H%>>7,C%*H%>>7,D%*H%>>7,E%*H%>>7,F%*H%>>7) � �H%<=0 �� �: ���fancyprint(T$,X%,Y%) �Y%+=15:X%-=�(T$)<<4:�5 �#�0,(3<<0)+(1<<2):�X%-4,Y%+4:�T$ #�0,(1<<0)+(3<<2):�X%+4,Y%+4:�T$ #�0,(1<<0)+(0<<2):�X%-4,Y%-4:�T$ #�0,(0<<0)+(1<<2):�X%+4,Y%-4:�T$ $!�0,(2<<0)+(2<<2):�X%,Y%+4:�T$ .!�0,(2<<0)+(0<<2):�X%-4,Y%:�T$ 8!�0,(0<<0)+(2<<2):�X%-4,Y%:�T$ B!�0,(0<<0)+(2<<2):�X%,Y%-4:�T$ L�0,(1<<1)+(1<<2):�X%,Y%:�T$ V�4:� `� j: tݤadr(R%,A%,I%) ~,�(P%�3)<>0��"Code isn't word aligned!":� �(�N%,O%,H%,U%:H%=A%-(P%+8):N%=0:O%=15 ��U%=1�I%:�H%=0� �[OPT T%:MOV R%,O%:] � �ȕ(H%�3)=0:H%=H%>>2:N%+=2:� ��(H%�256)=0� �0[OPT T%:ADD R%,O%,#(H%�255)<<N%:]:H%-=H%�255 �9�[OPT T%:SUB R%,O%,#(256-H%�255)<<N%:]:H%+=256-H%�255 �� � �:O%=R%:� �J�H%<>0��"Could not ADR to ";A%;" in ";I%;" instructions (R%=";R%;")":� �=T% �: ��assemble �T%=0�2�2:P%=code% [OPT T% .link% (#EQUD -1:EQUD -1:EQUD -1:EQUD -1 2.sp%:EQUD -1 <: F.vduvars%:EQUD 148:EQUD -1 P.scraddr%:EQUD -1 Z.bank%:EQUD -1 d: n.frame% xSTR R13,sp% �STR R14,link%+0 �LDR R1,bank% �� R1,R1,#1 �ADD R1,R1,#1 �STR R1,bank% �MOV R0,#112 �SWI "OS_Byte" �ADR R0,vduvars% �ADR R1,scraddr% �SWI "OS_ReadVduVariables" �; Draw the frame �BL drawback% �BL animation% BL rotate% BL transform% BL sort% "BL plotshape% ,; Display the new screen 6MOV R0,#19 @SWI "OS_Byte" JLDR R1,bank% TMOV R0,#113 ^SWI "OS_Byte" hLDR R14,link%+0 rLDR R13,sp% |MOV PC,R14 �: �.tempstoreft% �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �: �.findtube% �ADR R13,tempstoreft% �STMIA R13,{R0-R3,R14} �OPT �adr(13,spr%,2) � CMP R2,#0 �RSBLT R0,R0,#0 �RSBLT R1,R1,#0 �RSBLT R2,R2,#0 CMP R1,#0 ADDGE R13,R13,#6<<10 RSBLT R1,R1,#0 & CMP R0,#0 0ADDLT R13,R13,#3<<10 :RSBLT R0,R0,#0 D CMP R1,R0 NCMPGT R1,R2 XBGT ybigft% b CMP R2,R0 lBGT zbigft% v.xbigft% �ADD R13,R13,#1<<10 �.endbigft% �CMP R1,R0,ASR#1 �SUBGE R1,R1,R0,ASR#1 �ADDGE R13,R13,#96<<10 �CMP R1,R0,ASR#2 �ADDGE R13,R13,#48<<10 �CMP R2,R0,ASR#1 �SUBGE R2,R2,R0,ASR#1 �ADDGE R13,R13,#24<<10 �CMP R2,R0,ASR#2 �ADDGE R13,R13,#12<<10 �.endfindtube% ADR R3,tempstoreft% LDMIA R3,{R0-R3,R14} MOV PC,R14 : *.ybigft% 4ADD R13,R13,#2<<10 > MOV R3,R0 H MOV R0,R1 R MOV R1,R2 \ MOV R2,R3 fB endbigft% p: z.zbigft% � MOV R3,R2 � MOV R2,R1 � MOV R1,R0 � MOV R0,R3 �B endbigft% �: �.tempstoreds% �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �: �.drawsprite% ; Corrupts R2 ADR R2,tempstoreds% &STMIA R2,{R0-R1,R3-R9,R11,R13-R14} $(SUB R0,R0,#15.5*(1<<AC%):; TL corner .SUB R1,R1,#15.5*(1<<AC%) 8MOV R0,R0,LSR#AC% BMOV R1,R1,LSR#AC% LCMP R0,#288 VCMPLE R1,#224 `/BGT enddrawsprite%:; (Partially) off screen jBIC R13,R13,#1 tLDR R14,scraddr% ~ADD R14,R14,R1,ASL#5 �ADD R14,R14,R1,ASL#7 �� R2,R0,#7:; Word alignment �MOV R0,R0,LSR#3 �)ADD R14,R14,R0,ASL#2:; Screen address �MOV R11,#32 �ADR R1,routineds% �LDR R0,[R1,R2,ASL#2] �ADD PC,R1,R0 � MOV R0,R0 �: �.enddrawsprite% �ADR R2,tempstoreds% &LDMIA R2,{R0-R1,R3-R9,R11,R13-R14} MOV PC,R14 : .routineds% (]:�U%=0�7:[OPT T% 2"EQUD enddrawsprite%-routineds% <]:�:[OPT T% F: P-]:routineds%!(0<<2)=P%-routineds%:[OPT T% Z.yloop% dLDMIA R14,{R0-R3} nLDMIA R13!,{R5-R8} xBIC R0,R0,R6:�R R0,R0,R5 �BIC R1,R1,R8:�R R1,R1,R7 �LDMIA R13!,{R5-R8} �BIC R2,R2,R6:�R R2,R2,R5 �BIC R3,R3,R8:�R R3,R3,R7 �STMIA R14,{R0-R3} �ADD R14,R14,#160 �SUBS R11,R11,#1 �BGT yloop% �B enddrawsprite% �: �6]:�U%=1�7:routineds%!(U%<<2)=P%-routineds%:[OPT T% �.yloop% �LDMIA R14,{R0-R4} LDMIA R13!,{R5-R8} aBIC R0,R0,R6,LSL#U%<<2:�R R0,R0,R5,LSL#U%<<2:BIC R1,R1,R6,LSR#8-U%<<2:�R R1,R1,R5,LSR#8-U%<<2 aBIC R1,R1,R8,LSL#U%<<2:�R R1,R1,R7,LSL#U%<<2:BIC R2,R2,R8,LSR#8-U%<<2:�R R2,R2,R7,LSR#8-U%<<2 "LDMIA R13!,{R5-R8} ,aBIC R2,R2,R6,LSL#U%<<2:�R R2,R2,R5,LSL#U%<<2:BIC R3,R3,R6,LSR#8-U%<<2:�R R3,R3,R5,LSR#8-U%<<2 6aBIC R3,R3,R8,LSL#U%<<2:�R R3,R3,R7,LSL#U%<<2:BIC R4,R4,R8,LSR#8-U%<<2:�R R4,R4,R7,LSR#8-U%<<2 @STMIA R14,{R0-R4} JADD R14,R14,#160 TSUBS R11,R11,#1 ^BGT yloop% hB enddrawsprite% r]:�:[OPT T% |: �.tempstoredt% �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �: �.drawtube% �; Corrupts R13 �.; Expects R0-R1 to be the direction vector �-; Expects R3-R4(,R5) to be start position �*; Expects R6 to be the number of steps �ADR R13,tempstoredt% �STMIA R13,{R0-R12,R14} CMP R2,#0 .ADDGT R3,R3,R0:; Must start at the far end ADDGT R4,R4,R1 &ADDGT R5,R5,R2 0;RSBGT R0,R0,#0:; Must have vector facing towards viewer :RSBGT R1,R1,#0 DRSBGT R2,R2,#0 NBL findtube% X; Divide 1<<8 by 3 bMOV R7,#1<<8 l MOV R8,#0 v]:�U%=7�1�-1:[OPT T% �CMP R6,R7,ASR#U% �SUBLE R7,R7,R6,ASL#U% �ADDLE R8,R8,#1<<U% �]:�:[OPT T% � CMP R6,R7 �ADDLE R8,R8,#1 �MOV R5,R1,ASR#8 � MOV R1,R4 �MOV R4,R0,ASR#8 � MOV R0,R3 �"MUL R4,R8,R4:; Vector per step �MUL R5,R8,R5 �2ADD R0,R0,R4,ASR#1:; Half way along first step ADD R1,R1,R5,ASR#1 .steploop% BL drawsprite% ADD R0,R0,R4 *ADD R1,R1,R5 4SUBS R6,R6,#1 >BGT steploop% HADR R13,tempstoredt% RLDMIA R13,{R0-R12,R14} \MOV PC,R14 f: p.tempstoretrans% z#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 �: � .view% �(EQUD 1<<VC%:EQUD 0:EQUD 0:; X-vector �(EQUD 0:EQUD 1<<VC%:EQUD 0:; Y-vector �(EQUD 0:EQUD 0:EQUD 1<<VC%:; Z-vector �: �.transform% �; Corrupts R0 �ADR R0,tempstoretrans% �STMIA R0,{R1-R9,R14} �OPT �adr(14,pos%,2) .posloop% LDR R9,[R14] #CMN R9,#1:; Pos list terminator $BEQ endtransform% .1BIC R0,R9,#1:; Clear the "already drawn" flag 8ADR R7,view% B; X*X-vector LMOV R8,R9,LSR#24 VMOV R9,R9,LSL#8 `LDMIA R7!,{R4-R6} jMUL R1,R8,R4 tSUB R1,R1,R4,ASL#7 ~MUL R2,R8,R5 �SUB R2,R2,R5,ASL#7 �MUL R3,R8,R6 �SUB R3,R3,R6,ASL#7 �; Y*Y-vector �MOV R8,R9,LSR#24 �MOV R9,R9,LSL#8 �LDMIA R7!,{R4-R6} �MLA R1,R8,R4,R1 �SUB R1,R1,R4,ASL#7 �MLA R2,R8,R5,R2 �SUB R2,R2,R5,ASL#7 �MLA R3,R8,R6,R3 SUB R3,R3,R6,ASL#7 ; Z*Z-vector MOV R8,R9,LSR#24 MOV R9,R9,LSL#8 (LDMIA R7!,{R4-R6} 2MLA R1,R8,R4,R1 <SUB R1,R1,R4,ASL#7 FMLA R2,R8,R5,R2 PSUB R2,R2,R5,ASL#7 ZMLA R3,R8,R6,R3 dSUB R3,R3,R6,ASL#7 nMOV R1,R1,ASL#AC%-VC% xMOV R2,R2,ASL#AC%-VC% �MOV R3,R3,ASL#AC%-VC% �ADD R1,R1,#160<<AC% �ADD R2,R2,#128<<AC% �STMIA R14!,{R0,R1-R3} �B posloop% �: �.endtransform% �ADR R0,tempstoretrans% �LDMIA R0,{R1-R9,R14} �MOV PC,R14 �: �.tempstoresort% �#EQUD -1:EQUD -1:EQUD -1:EQUD -1 #EQUD -1:EQUD -1:EQUD -1:EQUD -1 : .sort% "; Corrupts R0 ,ADR R0,tempstoresort% 6STMIA R0,{R0-R1,R11-R14} @6; Compile a list of lines, with distances attached J*OPT �adr(14,pos%+12,2):; Z-coordinates TOPT �adr(13,lines%,2) ^OPT �adr(12,slist%,2) hMOV R11,#0 r.lineloop% |LDR R0,[R13],#4 � CMN R0,#1 �BEQ endsort1% �� R1,R0,#255<<16 �� R0,R0,#255<<24 �LDR R0,[R14,R0,LSR#24-4] �LDR R1,[R14,R1,LSR#16-4] �ADD R0,R0,R1 �MOV R0,R0,ASR#1 �BIC R0,R0,#255 ��R R0,R0,R11 �STR R0,[R12],#4 �ADD R11,R11,#1 �B lineloop% : .endsort1% STR R0,[R12],#-4 &; Sort them 0OPT �adr(14,slist%,2) :; R12 is last one DCMP R12,R14 N"BLE endsort2%:; 0 or 1 of them X .outloop% bLDMIA R14,{R0-R1} lMOV R13,R14 v.inloop% � CMP R0,R1 �STRGT R0,[R13],#4 �MOVGT R0,R1 �STRLE R1,[R13],#4 �LDR R1,[R13,#4] �CMP R13,R12 �BLT inloop% �STR R0,[R13] �SUB R12,R12,#4 �CMP R12,R14 �BGT outloop% �.endsort2% �ADR R0,tempstoresort% LDMIA R0,{R0-R1,R11-R14} MOV PC,R14 : .tempstoreps% *#EQUD -1:EQUD -1:EQUD -1:EQUD -1 4#EQUD -1:EQUD -1:EQUD -1:EQUD -1 >#EQUD -1:EQUD -1:EQUD -1:EQUD -1 H#EQUD -1:EQUD -1:EQUD -1:EQUD -1 R: \.plotshape% f; R0 corrupted pADR R0,tempstoreps% zSTMIA R0,{R1-R14} �OPT �adr(10,pos%,2) �OPT �adr(11,lines%,2) �OPT �adr(12,slist%,2) �.plotloop% �LDR R0,[R12],#4 � CMN R0,#1 �BEQ endplotshape% �� R0,R0,#255 �LDR R0,[R11,R0,ASL#2] �� R6,R0,#255<<8 �MOV R6,R6,LSR#8 �� R3,R0,#255<<24 �� R4,R0,#255<<16 ADD R3,R10,R3,LSR#24-4 ADD R4,R10,R4,LSR#16-4 *OPT �adr(13,spr%+(192<<10),2):; Sphere $LDR R0,[R3] . TST R0,#1 8BNE alreadyplotted1% B�R R0,R0,#1 LSTR R0,[R3] VLDMIB R3,{R0-R1} `BL drawsprite% j.alreadyplotted1% tLDR R0,[R4] ~ TST R0,#1 �BNE alreadyplotted2% ��R R0,R0,#1 �STR R0,[R4] �LDMIB R4,{R0-R1} �BL drawsprite% �.alreadyplotted2% �LDMIB R3,{R0-R2} �LDMIB R4,{R3-R5} �SUB R0,R0,R3 �SUB R1,R1,R4 �SUB R2,R2,R5 �BL drawtube% B plotloop% : .endplotshape% ADR R0,tempstoreps% (LDMIA R0,{R1-R14} 2MOV PC,R14 <: F.tempstorerot% P#EQUD -1:EQUD -1:EQUD -1:EQUD -1 Z#EQUD -1:EQUD -1:EQUD -1:EQUD -1 d#EQUD -1:EQUD -1:EQUD -1:EQUD -1 n#EQUD -1:EQUD -1:EQUD -1:EQUD -1 x: �.rotate% �; Corrupts R0 �ADR R0,tempstorerot% �STMIA R0,{R1-R14} �; The rotations �OPT �adr(14,sin%,2) �8MOV R0,#1<<VC%:MOV R1,#0:MOV R2,#0:; Identity matrix �&MOV R3,#0:MOV R4,#1<<VC%:MOV R5,#0 �&MOV R6,#0:MOV R7,#0:MOV R8,#1<<VC% �; X-axis rotation �LDR R12,angles%+0 �� R12,R12,#255 �ADD R12,R14,R12,ASL#2 LDR R13,[R12,#cos%-sin%] LDR R12,[R12] ]:�U%=0�8�3:[OPT T% "MOV R9,(U%+2) ,MUL (U%+2),R13,R9 6 MLA (U%+2),R12,(U%+1),(U%+2) @MUL (U%+1),R13,(U%+1) JMUL R9,R12,R9 TSUB (U%+1),(U%+1),R9 ^MOV (U%+1),(U%+1),ASR#SC% hMOV (U%+2),(U%+2),ASR#SC% r]:�:[OPT T% |; Y-axis rotation �LDR R12,angles%+4 �� R12,R12,#255 �ADD R12,R14,R12,ASL#2 �LDR R13,[R12,#cos%-sin%] �LDR R12,[R12] �]:�U%=0�8�3:[OPT T% � MOV R9,U% �MUL U%,R13,R9 �MLA U%,R12,(U%+2),U% �MUL (U%+2),R13,(U%+2) �MUL R9,R12,R9 �SUB (U%+2),(U%+2),R9 �MOV (U%+2),(U%+2),ASR#SC% MOV U%,U%,ASR#SC% ]:�:[OPT T% ; Z-axis rotation &LDR R12,angles%+8 0� R12,R12,#255 :ADD R12,R14,R12,ASL#2 DLDR R13,[R12,#cos%-sin%] NLDR R12,[R12] X]:�U%=0�8�3:[OPT T% bMOV R9,(U%+1) lMUL (U%+1),R13,R9 vMLA (U%+1),R12,U%,(U%+1) �MUL U%,R13,U% �MUL R9,R12,R9 �SUB U%,U%,R9 �MOV U%,U%,ASR#SC% �MOV (U%+1),(U%+1),ASR#SC% �]:�:[OPT T% �OPT �adr(12,view%,2) �STMIA R12,{R0-R8} �ADR R0,tempstorerot% �LDMIA R0,{R1-R14} �MOV PC,R14 �: �.tempstoreanim% #EQUD -1:EQUD -1:EQUD -1:EQUD -1 #EQUD -1:EQUD -1:EQUD -1:EQUD -1 #EQUD -1:EQUD -1:EQUD -1:EQUD -1 #EQUD -1:EQUD -1:EQUD -1:EQUD -1 *: 4.random%:EQUD 1 >.colno%:EQUD 15 H: R.angles% \EQUD 0:EQUD 0:EQUD 0 fEQUD 1:EQUD 2:EQUD 3 p .colours% zEQUD 0:EQUD 85:EQUD 85 �EQUD 85:EQUD 0:EQUD 0 �EQUD 0:EQUD 0:EQUD 0 �EQUD 0:EQUD 0:EQUD 0 �: �.animation% �; Corrupts R0 �ADR R0,tempstoreanim% �STMIA R0,{R1-R14} �LDR R14,random% �; Increment angles �ADR R13,angles% �LDMIA R13,{R0-R5} �ADD R14,R14,R14,ASL#8 TST R14,#&FF000000 BNE dontchangespeed% ADD R14,R14,R14,ASL#8 $MOV R3,R14,ASR#31-1 .ADD R14,R14,R14,ASL#8 8MOV R4,R14,ASR#31-1 BADD R14,R14,R14,ASL#8 LMOV R5,R14,ASR#31-1 V.dontchangespeed% `ADD R0,R0,R3 jADD R1,R1,R4 tADD R2,R2,R5 ~STMIA R13,{R0-R5} �; Increment colours �ADR R13,colours% �LDMIA R13,{R0-R11} �ADD R14,R14,R14,ASL#7 �TST R14,#&FE000000 �BNE dontchangecolour1 �TST R14,#1<<24 ��Q R0,#0 �MOVNE R0,#85 �TST R14,#1<<23 ��Q R1,#0 �MOVNE R1,#85 TST R14,#1<<22 �Q R2,#0 MOVNE R2,#85 .dontchangecolour1 (ADD R14,R14,R14,ASL#7 2TST R14,#&FE000000 <BNE dontchangecolour2 FTST R14,#1<<24 P�Q R3,#0 ZMOVNE R3,#85 dTST R14,#1<<23 n�Q R4,#0 xMOVNE R4,#85 �TST R14,#1<<22 ��Q R5,#0 �MOVNE R5,#85 �.dontchangecolour2 �]:�U%=6�11:[OPT T% �CMP U%,(U%-6) �ADDLT U%,U%,#1 �SUBGT U%,U%,#1 �]:�:[OPT T% �STMIA R13,{R0-R11} �; Redefine colours �LDR R12,colno% �ADD R12,R12,#5 � R12,R12,#15 STR R12,colno% .colloop% "SWI &113:; �19, ,MOV R0,R12 6SWI "OS_WriteC":; colour, @!SWI &110:; 16, J� R1,R12,#3 TMOV R2,R12,LSR#2 ^MUL R0,R1,R6 hMLA R0,R2,R9,R0 rCMP R0,#255 |MOVGT R0,#255 �&SWI "OS_WriteC":; Red, �MUL R0,R1,R7 �MLA R0,R2,R10,R0 �CMP R0,#255 �MOVGT R0,#255 �-SWI "OS_WriteC":; Green, �MUL R0,R1,R8 �MLA R0,R2,R11,R0 �CMP R0,#255 �MOVGT R0,#255 �2SWI "OS_WriteC":; Blue �ADD R14,R14,#1 �STR R14,random% ADR R0,tempstoreanim% LDMIA R0,{R1-R14} MOV PC,R14 &: 0.tempstoredb% :#EQUD -1:EQUD -1:EQUD -1:EQUD -1 D#EQUD -1:EQUD -1:EQUD -1:EQUD -1 N#EQUD -1:EQUD -1:EQUD -1:EQUD -1 X#EQUD -1:EQUD -1:EQUD -1:EQUD -1 b: l.drawback% v; Corrupts R0 �ADR R0,tempstoredb% �STMIA R0,{R1-R14} �LDR R14,scraddr% �ADD R14,R14,#32>>1 � OPT �adr(13,back%+(32>>1),3) �MOV R12,#256 �.yloop% �]:�U%=0�255�8*8:[OPT T% �LDMIA R13!,{R0-R7} �STMIA R14!,{R0-R7} �]:�:[OPT T% �ADD R13,R13,#320-256>>1 �ADD R14,R14,#320-256>>1 SUBS R12,R12,#1 BGT yloop% ADR R0,tempstoredb% LDMIA R0,{R1-R14} *MOV PC,R14 4: >0]:�P%>endcode%��255,"Not enough code memory" H� R� �
00000000 0d 00 0a 14 f4 20 20 20 20 20 3e 21 52 75 6e 49 |..... >!RunI| 00000010 6d 61 67 65 0d 00 14 1b f4 20 62 79 20 20 41 6c |mage..... by Al| 00000020 69 73 74 61 69 72 20 54 75 72 6e 62 75 6c 6c 0d |istair Turnbull.| 00000030 00 1e 17 f4 20 28 63 29 20 41 55 20 41 70 72 69 |.... (c) AU Apri| 00000040 6c 20 31 39 39 34 0d 00 28 05 3a 0d 00 32 0c eb |l 1994..(.:..2..| 00000050 31 32 3a eb 39 3a 87 0d 00 3c 0e f2 63 6f 6e 73 |12:.9:...<..cons| 00000060 74 61 6e 74 73 0d 00 46 25 73 70 61 63 65 6c 65 |tants..F%spacele| 00000070 6e 25 3d 26 38 30 30 30 30 3a de 73 70 61 63 65 |n%=&80000:.space| 00000080 25 73 70 61 63 65 6c 65 6e 25 0d 00 50 33 63 6f |%spacelen%..P3co| 00000090 64 65 25 3d 73 70 61 63 65 25 3a 73 70 61 63 65 |de%=space%:space| 000000a0 25 2b 3d 26 34 30 30 30 3a 65 6e 64 63 6f 64 65 |%+=&4000:endcode| 000000b0 25 3d 63 6f 64 65 25 2b 26 34 30 30 30 0d 00 5a |%=code%+&4000..Z| 000000c0 23 70 6f 73 25 3d 73 70 61 63 65 25 3a 73 70 61 |#pos%=space%:spa| 000000d0 63 65 25 2b 3d 31 36 2a 6e 6f 70 6f 73 25 2b 34 |ce%+=16*nopos%+4| 000000e0 0d 00 64 26 6c 69 6e 65 73 25 3d 73 70 61 63 65 |..d&lines%=space| 000000f0 25 3a 73 70 61 63 65 25 2b 3d 34 2a 6e 6f 6c 69 |%:space%+=4*noli| 00000100 6e 65 73 25 2b 34 0d 00 6e 24 73 6c 69 73 74 25 |nes%+4..n$slist%| 00000110 3d 73 70 61 63 65 25 3a 73 70 61 63 65 25 2b 3d |=space%:space%+=| 00000120 34 2a 6e 6f 6c 69 6e 65 73 25 0d 00 78 36 73 69 |4*nolines%..x6si| 00000130 6e 25 3d 73 70 61 63 65 25 3a 63 6f 73 25 3d 73 |n%=space%:cos%=s| 00000140 69 6e 25 2b 28 36 34 3c 3c 32 29 3a 73 70 61 63 |in%+(64<<2):spac| 00000150 65 25 3d 63 6f 73 25 2b 28 32 35 36 3c 3c 32 29 |e%=cos%+(256<<2)| 00000160 0d 00 82 32 73 70 72 25 3d 73 70 61 63 65 25 3a |...2spr%=space%:| 00000170 73 70 61 63 65 25 2b 3d 6e 6f 73 70 72 25 2a 31 |space%+=nospr%*1| 00000180 30 32 34 3a 65 6e 64 73 70 72 25 3d 73 70 61 63 |024:endspr%=spac| 00000190 65 25 0d 00 8c 1e 62 61 63 6b 25 3d 73 70 61 63 |e%....back%=spac| 000001a0 65 25 3a 73 70 61 63 65 25 2b 3d 26 41 30 30 30 |e%:space%+=&A000| 000001b0 0d 00 96 35 e7 73 70 61 63 65 25 3e 73 70 61 63 |...5.space%>spac| 000001c0 65 25 2b 73 70 61 63 65 6c 65 6e 25 8c 85 32 35 |e%+spacelen%..25| 000001d0 35 2c 22 4e 6f 74 20 65 6e 6f 75 67 68 20 6d 65 |5,"Not enough me| 000001e0 6d 6f 72 79 22 0d 00 a0 0d f2 61 73 73 65 6d 62 |mory".....assemb| 000001f0 6c 65 0d 00 aa 0d f2 73 65 74 75 70 70 6f 73 0d |le.....setuppos.| 00000200 00 b4 33 e3 54 25 3d 30 b8 33 31 39 3a 73 69 6e |..3.T%=0.319:sin| 00000210 25 21 28 54 25 3c 3c 32 29 3d 28 31 3c 3c 53 43 |%!(T%<<2)=(1<<SC| 00000220 25 29 2a b5 28 32 2a af 2a 54 25 2f 32 35 36 29 |%)*.(2*.*T%/256)| 00000230 3a ed 0d 00 be 33 f2 63 6f 6c 6f 75 72 73 28 30 |:....3.colours(0| 00000240 2c 30 2c 30 2c 30 2c 30 2c 30 29 3a ff 28 22 46 |,0,0,0,0,0):.("F| 00000250 58 31 31 32 2c 32 22 29 3a ff 28 22 46 58 31 31 |X112,2"):.("FX11| 00000260 33 2c 32 22 29 0d 00 c8 31 db 3a f2 66 61 6e 63 |3,2")...1.:.fanc| 00000270 79 70 72 69 6e 74 28 22 50 6c 65 61 73 65 20 77 |yprint("Please w| 00000280 61 69 74 20 61 20 6d 6f 6d 65 6e 74 22 2c 36 34 |ait a moment",64| 00000290 30 2c 35 31 32 29 0d 00 d2 1b f2 66 61 64 65 69 |0,512).....fadei| 000002a0 6e 28 38 35 2c 30 2c 30 2c 30 2c 38 35 2c 38 35 |n(85,0,0,0,85,85| 000002b0 29 0d 00 dc 29 ff 28 22 4c 4f 41 44 20 3c 54 75 |)...).("LOAD <Tu| 000002c0 62 65 73 24 64 69 72 3e 2e 53 70 72 69 74 65 73 |bes$dir>.Sprites| 000002d0 20 22 2b c3 7e 73 70 72 25 29 0d 00 e6 1c ff 28 | "+.~spr%).....(| 000002e0 22 46 58 31 31 32 2c 31 22 29 3a f2 62 61 63 6b |"FX112,1"):.back| 000002f0 67 72 6f 75 6e 64 0d 00 f0 1c f2 66 61 64 65 6f |ground.....fadeo| 00000300 75 74 28 38 35 2c 30 2c 30 2c 30 2c 38 35 2c 38 |ut(85,0,0,0,85,8| 00000310 35 29 0d 00 fa 35 e3 54 25 3d 30 b8 26 39 46 46 |5)...5.T%=0.&9FF| 00000320 46 88 34 3a 62 61 63 6b 25 21 54 25 3d 73 63 72 |F.4:back%!T%=scr| 00000330 25 21 54 25 3a 73 63 72 32 25 21 54 25 3d 73 63 |%!T%:scr2%!T%=sc| 00000340 72 25 21 54 25 3a ed 0d 01 04 05 f5 0d 01 0e 0b |r%!T%:..........| 00000350 d6 66 72 61 6d 65 25 0d 01 18 06 fd 30 0d 01 22 |.frame%.....0.."| 00000360 05 e0 0d 01 2c 05 3a 0d 01 36 05 3a 0d 01 40 0f |....,.:..6.:..@.| 00000370 dd f2 63 6f 6e 73 74 61 6e 74 73 0d 01 4a 0e 6e |..constants..J.n| 00000380 6f 73 70 72 25 3d 32 35 36 0d 01 54 19 6e 6f 70 |ospr%=256..T.nop| 00000390 6f 73 25 3d 33 32 3a 6e 6f 6c 69 6e 65 73 25 3d |os%=32:nolines%=| 000003a0 33 32 0d 01 5e 0a 54 52 25 3d 34 34 0d 01 68 18 |32..^.TR%=44..h.| 000003b0 41 43 25 3d 31 36 3a 56 43 25 3d 31 32 3a 53 43 |AC%=16:VC%=12:SC| 000003c0 25 3d 31 32 0d 01 72 05 e1 0d 01 7c 05 3a 0d 01 |%=12..r....|.:..| 000003d0 86 0e dd f2 73 65 74 75 70 70 6f 73 0d 01 90 0c |....setuppos....| 000003e0 f3 4e 50 25 2c 4e 4c 25 0d 01 9a 19 e3 54 25 3d |.NP%,NL%.....T%=| 000003f0 30 b8 4e 50 25 2d 31 3a f3 58 25 2c 59 25 2c 5a |0.NP%-1:.X%,Y%,Z| 00000400 25 0d 01 a4 36 70 6f 73 25 21 28 54 25 2a 31 36 |%...6pos%!(T%*16| 00000410 29 3d 28 58 25 2b 31 32 38 3c 3c 32 34 29 2b 28 |)=(X%+128<<24)+(| 00000420 59 25 2b 31 32 38 3c 3c 31 36 29 2b 28 5a 25 2b |Y%+128<<16)+(Z%+| 00000430 31 32 38 3c 3c 38 29 0d 01 ae 16 ed 3a 70 6f 73 |128<<8).....:pos| 00000440 25 21 28 4e 50 25 2a 31 36 29 3d 2d 31 0d 01 b8 |%!(NP%*16)=-1...| 00000450 29 f3 63 68 65 63 6b 25 3a e7 63 68 65 63 6b 25 |).check%:.check%| 00000460 3c 3e 2d 31 8c 85 32 35 35 2c 22 44 61 74 61 20 |<>-1..255,"Data | 00000470 65 72 72 6f 72 22 0d 01 c2 19 e3 54 25 3d 30 b8 |error".....T%=0.| 00000480 4e 4c 25 2d 31 3a f3 46 25 2c 47 25 2c 4e 25 0d |NL%-1:.F%,G%,N%.| 00000490 01 cc 2b 6c 69 6e 65 73 25 21 28 54 25 2a 34 29 |..+lines%!(T%*4)| 000004a0 3d 28 46 25 3c 3c 32 34 29 2b 28 47 25 3c 3c 31 |=(F%<<24)+(G%<<1| 000004b0 36 29 2b 28 4e 25 3c 3c 38 29 0d 01 d6 17 ed 3a |6)+(N%<<8).....:| 000004c0 6c 69 6e 65 73 25 21 28 4e 4c 25 2a 34 29 3d 2d |lines%!(NL%*4)=-| 000004d0 31 0d 01 e0 29 f3 63 68 65 63 6b 25 3a e7 63 68 |1...).check%:.ch| 000004e0 65 63 6b 25 3c 3e 2d 31 8c 85 32 35 35 2c 22 44 |eck%<>-1..255,"D| 000004f0 61 74 61 20 65 72 72 6f 72 22 0d 01 ea 05 e1 0d |ata error"......| 00000500 01 f4 05 3a 0d 01 fe 08 dc 34 2c 36 0d 02 08 0e |...:.....4,6....| 00000510 dc 36 30 2c 36 30 2c 2d 36 30 0d 02 12 10 dc 2d |.60,60,-60.....-| 00000520 36 30 2c 2d 36 30 2c 2d 36 30 0d 02 1c 0e dc 36 |60,-60,-60.....6| 00000530 30 2c 2d 36 30 2c 36 30 0d 02 26 0e dc 2d 36 30 |0,-60,60..&..-60| 00000540 2c 36 30 2c 36 30 0d 02 30 07 dc 2d 31 0d 02 3a |,60,60..0..-1..:| 00000550 2d dc 30 2c 31 2c 38 2c 20 30 2c 32 2c 38 2c 20 |-.0,1,8, 0,2,8, | 00000560 30 2c 33 2c 38 2c 20 31 2c 32 2c 38 2c 20 31 2c |0,3,8, 1,2,8, 1,| 00000570 33 2c 38 2c 20 32 2c 33 2c 38 0d 02 44 07 dc 2d |3,8, 2,3,8..D..-| 00000580 31 0d 02 4e 05 3a 0d 02 58 10 dd f2 62 61 63 6b |1..N.:..X...back| 00000590 67 72 6f 75 6e 64 0d 02 62 45 4c 58 3d 2d 31 3a |ground..bELX=-1:| 000005a0 4c 59 3d 31 3a 4c 5a 3d 2d 32 3a 46 3d 31 2f b6 |LY=1:LZ=-2:F=1/.| 000005b0 28 4c 58 2a 4c 58 2b 4c 59 2a 4c 59 2b 4c 5a 2a |(LX*LX+LY*LY+LZ*| 000005c0 4c 5a 29 3a 4c 58 3d 4c 58 2a 46 3a 4c 59 3d 4c |LZ):LX=LX*F:LY=L| 000005d0 59 2a 46 3a 4c 5a 3d 4c 5a 2a 46 0d 02 6c 44 4d |Y*F:LZ=LZ*F..lDM| 000005e0 58 3d 31 3a 4d 59 3d 31 3a 4d 5a 3d 2d 32 3a 46 |X=1:MY=1:MZ=-2:F| 000005f0 3d 31 2f b6 28 4d 58 2a 4d 58 2b 4d 59 2a 4d 59 |=1/.(MX*MX+MY*MY| 00000600 2b 4d 5a 2a 4d 5a 29 3a 4d 58 3d 4d 58 2a 46 3a |+MZ*MZ):MX=MX*F:| 00000610 4d 59 3d 4d 59 2a 46 3a 4d 5a 3d 4d 5a 2a 46 0d |MY=MY*F:MZ=MZ*F.| 00000620 02 76 57 ff 28 22 46 58 31 31 32 2c 32 22 29 3a |.vW.("FX112,2"):| 00000630 21 62 61 63 6b 25 3d 31 34 38 3a 62 61 63 6b 25 |!back%=148:back%| 00000640 21 34 3d 2d 31 3a c8 99 22 4f 53 5f 52 65 61 64 |!4=-1:.."OS_Read| 00000650 56 64 75 56 61 72 69 61 62 6c 65 73 22 2c 62 61 |VduVariables",ba| 00000660 63 6b 25 2c 62 61 63 6b 25 3a 73 63 72 32 25 3d |ck%,back%:scr2%=| 00000670 21 62 61 63 6b 25 0d 02 80 56 ff 28 22 46 58 31 |!back%...V.("FX1| 00000680 31 32 2c 31 22 29 3a 21 62 61 63 6b 25 3d 31 34 |12,1"):!back%=14| 00000690 38 3a 62 61 63 6b 25 21 34 3d 2d 31 3a c8 99 22 |8:back%!4=-1:.."| 000006a0 4f 53 5f 52 65 61 64 56 64 75 56 61 72 69 61 62 |OS_ReadVduVariab| 000006b0 6c 65 73 22 2c 62 61 63 6b 25 2c 62 61 63 6b 25 |les",back%,back%| 000006c0 3a 73 63 72 25 3d 21 62 61 63 6b 25 0d 02 8a 1d |:scr%=!back%....| 000006d0 e3 58 25 3d 2d 33 30 b8 33 30 88 34 3a e3 59 25 |.X%=-30.30.4:.Y%| 000006e0 3d 2d 33 30 b8 33 30 88 34 0d 02 94 27 58 3d 58 |=-30.30.4...'X=X| 000006f0 25 2f 33 32 3a 59 3d 59 25 2f 33 32 3a 5a 32 3d |%/32:Y=Y%/32:Z2=| 00000700 31 2d 58 2a 58 2d 59 2a 59 3a e7 5a 32 3e 30 8c |1-X*X-Y*Y:.Z2>0.| 00000710 0d 02 9e 0c 5a 3d 2d b6 28 5a 32 29 0d 02 a8 1f |....Z=-.(Z2)....| 00000720 f2 6c 69 67 68 74 28 58 2c 59 2c 5a 29 3a c8 92 |.light(X,Y,Z):..| 00000730 58 25 2b 33 32 2c 59 25 2b 33 32 0d 02 b2 21 f2 |X%+32,Y%+32...!.| 00000740 6c 69 67 68 74 28 2d 58 2c 2d 59 2c 5a 29 3a c8 |light(-X,-Y,Z):.| 00000750 92 58 25 2b 39 36 2c 59 25 2b 33 32 0d 02 bc 2f |.X%+96,Y%+32.../| 00000760 cc f2 6c 69 67 68 74 28 30 2c 30 2c 2d 31 29 3a |..light(0,0,-1):| 00000770 c8 92 58 25 2b 33 32 2c 59 25 2b 33 32 3a c8 92 |..X%+32,Y%+32:..| 00000780 58 25 2b 39 36 2c 59 25 2b 33 32 0d 02 c6 08 cd |X%+96,Y%+32.....| 00000790 3a ed 2c 0d 02 d0 1d ec 30 2c 30 3a ec 42 59 36 |:.,.....0,0:.BY6| 000007a0 33 2c 36 33 3a ef 32 33 2c 32 37 2c 31 2c 30 7c |3,63:.23,27,1,0|| 000007b0 0d 02 da 1e ec 36 34 2c 30 3a ec 42 59 36 33 2c |.....64,0:.BY63,| 000007c0 36 33 3a ef 32 33 2c 32 37 2c 31 2c 31 7c 0d 02 |63:.23,27,1,1|..| 000007d0 e4 48 e3 58 25 3d 30 b8 32 30 3a e3 59 25 3d 30 |.H.X%=0.20:.Y%=0| 000007e0 b8 31 35 3a ef 32 33 2c 32 37 2c 30 2c b3 28 32 |.15:.23,27,0,.(2| 000007f0 29 2d 31 7c 3a f0 26 45 44 2c 28 58 25 3c 3c 36 |)-1|:.&ED,(X%<<6| 00000800 29 2d 28 28 59 25 80 31 29 3c 3c 35 29 2c 59 25 |)-((Y%.1)<<5),Y%| 00000810 3c 3c 36 3a ed 2c 0d 02 ee 05 e1 0d 02 f8 05 3a |<<6:.,.........:| 00000820 0d 03 02 12 dd f2 6c 69 67 68 74 28 58 2c 59 2c |......light(X,Y,| 00000830 5a 29 0d 03 0c 2d 4c 42 3d 4c 58 2a 58 2b 4c 59 |Z)...-LB=LX*X+LY| 00000840 2a 59 2b 4c 5a 2a 5a 3a e7 4c 42 3c 30 8c 4c 42 |*Y+LZ*Z:.LB<0.LB| 00000850 3d 30 8b 4c 42 3d 33 2a 4c 42 2b b3 28 31 29 0d |=0.LB=3*LB+.(1).| 00000860 03 16 2d 4d 42 3d 4d 58 2a 58 2b 4d 59 2a 59 2b |..-MB=MX*X+MY*Y+| 00000870 4d 5a 2a 5a 3a e7 4d 42 3c 30 8c 4d 42 3d 30 8b |MZ*Z:.MB<0.MB=0.| 00000880 4d 42 3d 33 2a 4d 42 2b b3 28 31 29 0d 03 20 11 |MB=3*MB+.(1).. .| 00000890 e6 30 2c 28 4c 42 3c 3c 32 29 2b 4d 42 0d 03 2a |.0,(LB<<2)+MB..*| 000008a0 05 e1 0d 03 34 05 3a 0d 03 3e 20 dd f2 63 6f 6c |....4.:..> ..col| 000008b0 6f 75 72 73 28 41 25 2c 42 25 2c 43 25 2c 44 25 |ours(A%,B%,C%,D%| 000008c0 2c 45 25 2c 46 25 29 0d 03 48 0a ea 54 25 2c 55 |,E%,F%)..H..T%,U| 000008d0 25 0d 03 52 46 e3 54 25 3d 30 b8 33 3a e3 55 25 |%..RF.T%=0.3:.U%| 000008e0 3d 30 b8 33 3a fb 54 25 2b 28 55 25 3c 3c 32 29 |=0.3:.T%+(U%<<2)| 000008f0 2c 54 25 2a 41 25 2b 55 25 2a 44 25 2c 54 25 2a |,T%*A%+U%*D%,T%*| 00000900 42 25 2b 55 25 2a 45 25 2c 54 25 2a 43 25 2b 55 |B%+U%*E%,T%*C%+U| 00000910 25 2a 46 25 3a ed 2c 0d 03 5c 05 e1 0d 03 66 05 |%*F%:.,..\....f.| 00000920 3a 0d 03 70 1f dd f2 66 61 64 65 69 6e 28 41 25 |:..p...fadein(A%| 00000930 2c 42 25 2c 43 25 2c 44 25 2c 45 25 2c 46 25 29 |,B%,C%,D%,E%,F%)| 00000940 0d 03 7a 23 4e 54 25 3d 91 3a f5 3a 48 25 3d 91 |..z#NT%=.:.:H%=.| 00000950 2d 4e 54 25 3a e7 48 25 3e 31 32 38 8c 48 25 3d |-NT%:.H%>128.H%=| 00000960 31 32 38 0d 03 84 43 f2 63 6f 6c 6f 75 72 73 28 |128...C.colours(| 00000970 41 25 2a 48 25 3e 3e 37 2c 42 25 2a 48 25 3e 3e |A%*H%>>7,B%*H%>>| 00000980 37 2c 43 25 2a 48 25 3e 3e 37 2c 44 25 2a 48 25 |7,C%*H%>>7,D%*H%| 00000990 3e 3e 37 2c 45 25 2a 48 25 3e 3e 37 2c 46 25 2a |>>7,E%*H%>>7,F%*| 000009a0 48 25 3e 3e 37 29 0d 03 8e 0c fd 48 25 3e 3d 31 |H%>>7).....H%>=1| 000009b0 32 38 0d 03 98 05 e1 0d 03 a2 05 3a 0d 03 ac 20 |28.........:... | 000009c0 dd f2 66 61 64 65 6f 75 74 28 41 25 2c 42 25 2c |..fadeout(A%,B%,| 000009d0 43 25 2c 44 25 2c 45 25 2c 46 25 29 0d 03 b6 23 |C%,D%,E%,F%)...#| 000009e0 4e 54 25 3d 91 3a f5 3a 48 25 3d 31 32 38 2d 91 |NT%=.:.:H%=128-.| 000009f0 2b 4e 54 25 3a e7 48 25 3c 30 8c 48 25 3d 30 0d |+NT%:.H%<0.H%=0.| 00000a00 03 c0 43 f2 63 6f 6c 6f 75 72 73 28 41 25 2a 48 |..C.colours(A%*H| 00000a10 25 3e 3e 37 2c 42 25 2a 48 25 3e 3e 37 2c 43 25 |%>>7,B%*H%>>7,C%| 00000a20 2a 48 25 3e 3e 37 2c 44 25 2a 48 25 3e 3e 37 2c |*H%>>7,D%*H%>>7,| 00000a30 45 25 2a 48 25 3e 3e 37 2c 46 25 2a 48 25 3e 3e |E%*H%>>7,F%*H%>>| 00000a40 37 29 0d 03 ca 0a fd 48 25 3c 3d 30 0d 03 d4 05 |7).....H%<=0....| 00000a50 e1 0d 03 de 05 3a 0d 03 e8 1a dd f2 66 61 6e 63 |.....:......fanc| 00000a60 79 70 72 69 6e 74 28 54 24 2c 58 25 2c 59 25 29 |yprint(T$,X%,Y%)| 00000a70 0d 03 f2 1a 59 25 2b 3d 31 35 3a 58 25 2d 3d a9 |....Y%+=15:X%-=.| 00000a80 28 54 24 29 3c 3c 34 3a ef 35 0d 03 fc 23 e6 30 |(T$)<<4:.5...#.0| 00000a90 2c 28 33 3c 3c 30 29 2b 28 31 3c 3c 32 29 3a ec |,(3<<0)+(1<<2):.| 00000aa0 58 25 2d 34 2c 59 25 2b 34 3a f1 54 24 0d 04 06 |X%-4,Y%+4:.T$...| 00000ab0 23 e6 30 2c 28 31 3c 3c 30 29 2b 28 33 3c 3c 32 |#.0,(1<<0)+(3<<2| 00000ac0 29 3a ec 58 25 2b 34 2c 59 25 2b 34 3a f1 54 24 |):.X%+4,Y%+4:.T$| 00000ad0 0d 04 10 23 e6 30 2c 28 31 3c 3c 30 29 2b 28 30 |...#.0,(1<<0)+(0| 00000ae0 3c 3c 32 29 3a ec 58 25 2d 34 2c 59 25 2d 34 3a |<<2):.X%-4,Y%-4:| 00000af0 f1 54 24 0d 04 1a 23 e6 30 2c 28 30 3c 3c 30 29 |.T$...#.0,(0<<0)| 00000b00 2b 28 31 3c 3c 32 29 3a ec 58 25 2b 34 2c 59 25 |+(1<<2):.X%+4,Y%| 00000b10 2d 34 3a f1 54 24 0d 04 24 21 e6 30 2c 28 32 3c |-4:.T$..$!.0,(2<| 00000b20 3c 30 29 2b 28 32 3c 3c 32 29 3a ec 58 25 2c 59 |<0)+(2<<2):.X%,Y| 00000b30 25 2b 34 3a f1 54 24 0d 04 2e 21 e6 30 2c 28 32 |%+4:.T$...!.0,(2| 00000b40 3c 3c 30 29 2b 28 30 3c 3c 32 29 3a ec 58 25 2d |<<0)+(0<<2):.X%-| 00000b50 34 2c 59 25 3a f1 54 24 0d 04 38 21 e6 30 2c 28 |4,Y%:.T$..8!.0,(| 00000b60 30 3c 3c 30 29 2b 28 32 3c 3c 32 29 3a ec 58 25 |0<<0)+(2<<2):.X%| 00000b70 2d 34 2c 59 25 3a f1 54 24 0d 04 42 21 e6 30 2c |-4,Y%:.T$..B!.0,| 00000b80 28 30 3c 3c 30 29 2b 28 32 3c 3c 32 29 3a ec 58 |(0<<0)+(2<<2):.X| 00000b90 25 2c 59 25 2d 34 3a f1 54 24 0d 04 4c 1f e6 30 |%,Y%-4:.T$..L..0| 00000ba0 2c 28 31 3c 3c 31 29 2b 28 31 3c 3c 32 29 3a ec |,(1<<1)+(1<<2):.| 00000bb0 58 25 2c 59 25 3a f1 54 24 0d 04 56 08 ef 34 3a |X%,Y%:.T$..V..4:| 00000bc0 87 0d 04 60 05 e1 0d 04 6a 05 3a 0d 04 74 13 dd |...`....j.:..t..| 00000bd0 a4 61 64 72 28 52 25 2c 41 25 2c 49 25 29 0d 04 |.adr(R%,A%,I%)..| 00000be0 7e 2c e7 28 50 25 80 33 29 3c 3e 30 8c f1 22 43 |~,.(P%.3)<>0.."C| 00000bf0 6f 64 65 20 69 73 6e 27 74 20 77 6f 72 64 20 61 |ode isn't word a| 00000c00 6c 69 67 6e 65 64 21 22 3a e0 0d 04 88 28 ea 4e |ligned!":....(.N| 00000c10 25 2c 4f 25 2c 48 25 2c 55 25 3a 48 25 3d 41 25 |%,O%,H%,U%:H%=A%| 00000c20 2d 28 50 25 2b 38 29 3a 4e 25 3d 30 3a 4f 25 3d |-(P%+8):N%=0:O%=| 00000c30 31 35 0d 04 92 13 e3 55 25 3d 31 b8 49 25 3a e7 |15.....U%=1.I%:.| 00000c40 48 25 3d 30 8c 0d 04 9c 17 5b 4f 50 54 20 54 25 |H%=0.....[OPT T%| 00000c50 3a 4d 4f 56 20 52 25 2c 4f 25 3a 5d 0d 04 a6 20 |:MOV R%,O%:]... | 00000c60 cc c8 95 28 48 25 80 33 29 3d 30 3a 48 25 3d 48 |...(H%.3)=0:H%=H| 00000c70 25 3e 3e 32 3a 4e 25 2b 3d 32 3a ce 0d 04 b0 10 |%>>2:N%+=2:.....| 00000c80 e7 28 48 25 80 32 35 36 29 3d 30 8c 0d 04 ba 30 |.(H%.256)=0....0| 00000c90 5b 4f 50 54 20 54 25 3a 41 44 44 20 52 25 2c 4f |[OPT T%:ADD R%,O| 00000ca0 25 2c 23 28 48 25 80 32 35 35 29 3c 3c 4e 25 3a |%,#(H%.255)<<N%:| 00000cb0 5d 3a 48 25 2d 3d 48 25 80 32 35 35 0d 04 c4 39 |]:H%-=H%.255...9| 00000cc0 cc 5b 4f 50 54 20 54 25 3a 53 55 42 20 52 25 2c |.[OPT T%:SUB R%,| 00000cd0 4f 25 2c 23 28 32 35 36 2d 48 25 80 32 35 35 29 |O%,#(256-H%.255)| 00000ce0 3c 3c 4e 25 3a 5d 3a 48 25 2b 3d 32 35 36 2d 48 |<<N%:]:H%+=256-H| 00000cf0 25 80 32 35 35 0d 04 ce 05 cd 0d 04 d8 0d cd 3a |%.255..........:| 00000d00 4f 25 3d 52 25 3a ed 0d 04 e2 4a e7 48 25 3c 3e |O%=R%:....J.H%<>| 00000d10 30 8c f1 22 43 6f 75 6c 64 20 6e 6f 74 20 41 44 |0.."Could not AD| 00000d20 52 20 74 6f 20 22 3b 41 25 3b 22 20 69 6e 20 22 |R to ";A%;" in "| 00000d30 3b 49 25 3b 22 20 69 6e 73 74 72 75 63 74 69 6f |;I%;" instructio| 00000d40 6e 73 20 28 52 25 3d 22 3b 52 25 3b 22 29 22 3a |ns (R%=";R%;")":| 00000d50 e0 0d 04 ec 07 3d 54 25 0d 04 f6 05 3a 0d 05 00 |.....=T%....:...| 00000d60 0e dd f2 61 73 73 65 6d 62 6c 65 0d 05 0a 16 e3 |...assemble.....| 00000d70 54 25 3d 30 b8 32 88 32 3a 50 25 3d 63 6f 64 65 |T%=0.2.2:P%=code| 00000d80 25 0d 05 14 0b 5b 4f 50 54 20 54 25 0d 05 1e 0a |%....[OPT T%....| 00000d90 2e 6c 69 6e 6b 25 0d 05 28 23 45 51 55 44 20 2d |.link%..(#EQUD -| 00000da0 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d |1:EQUD -1:EQUD -| 00000db0 31 3a 45 51 55 44 20 2d 31 0d 05 32 10 2e 73 70 |1:EQUD -1..2..sp| 00000dc0 25 3a 45 51 55 44 20 2d 31 0d 05 3c 05 3a 0d 05 |%:EQUD -1..<.:..| 00000dd0 46 1e 2e 76 64 75 76 61 72 73 25 3a 45 51 55 44 |F..vduvars%:EQUD| 00000de0 20 31 34 38 3a 45 51 55 44 20 2d 31 0d 05 50 15 | 148:EQUD -1..P.| 00000df0 2e 73 63 72 61 64 64 72 25 3a 45 51 55 44 20 2d |.scraddr%:EQUD -| 00000e00 31 0d 05 5a 12 2e 62 61 6e 6b 25 3a 45 51 55 44 |1..Z..bank%:EQUD| 00000e10 20 2d 31 0d 05 64 05 3a 0d 05 6e 0b 2e 66 72 61 | -1..d.:..n..fra| 00000e20 6d 65 25 0d 05 78 0f 53 54 52 20 52 31 33 2c 73 |me%..x.STR R13,s| 00000e30 70 25 0d 05 82 13 53 54 52 20 52 31 34 2c 6c 69 |p%....STR R14,li| 00000e40 6e 6b 25 2b 30 0d 05 8c 10 4c 44 52 20 52 31 2c |nk%+0....LDR R1,| 00000e50 62 61 6e 6b 25 0d 05 96 0e 80 20 52 31 2c 52 31 |bank%..... R1,R1| 00000e60 2c 23 31 0d 05 a0 10 41 44 44 20 52 31 2c 52 31 |,#1....ADD R1,R1| 00000e70 2c 23 31 0d 05 aa 10 53 54 52 20 52 31 2c 62 61 |,#1....STR R1,ba| 00000e80 6e 6b 25 0d 05 b4 0f 4d 4f 56 20 52 30 2c 23 31 |nk%....MOV R0,#1| 00000e90 31 32 0d 05 be 11 53 57 49 20 22 4f 53 5f 42 79 |12....SWI "OS_By| 00000ea0 74 65 22 0d 05 c8 13 41 44 52 20 52 30 2c 76 64 |te"....ADR R0,vd| 00000eb0 75 76 61 72 73 25 0d 05 d2 13 41 44 52 20 52 31 |uvars%....ADR R1| 00000ec0 2c 73 63 72 61 64 64 72 25 0d 05 dc 1d 53 57 49 |,scraddr%....SWI| 00000ed0 20 22 4f 53 5f 52 65 61 64 56 64 75 56 61 72 69 | "OS_ReadVduVari| 00000ee0 61 62 6c 65 73 22 0d 05 e6 14 3b 20 44 72 61 77 |ables"....; Draw| 00000ef0 20 74 68 65 20 66 72 61 6d 65 0d 05 f0 10 42 4c | the frame....BL| 00000f00 20 64 72 61 77 62 61 63 6b 25 0d 05 fa 11 42 4c | drawback%....BL| 00000f10 20 61 6e 69 6d 61 74 69 6f 6e 25 0d 06 04 0e 42 | animation%....B| 00000f20 4c 20 72 6f 74 61 74 65 25 0d 06 0e 11 42 4c 20 |L rotate%....BL | 00000f30 74 72 61 6e 73 66 6f 72 6d 25 0d 06 18 0c 42 4c |transform%....BL| 00000f40 20 73 6f 72 74 25 0d 06 22 11 42 4c 20 70 6c 6f | sort%..".BL plo| 00000f50 74 73 68 61 70 65 25 0d 06 2c 1c 3b 20 44 69 73 |tshape%..,.; Dis| 00000f60 70 6c 61 79 20 74 68 65 20 6e 65 77 20 73 63 72 |play the new scr| 00000f70 65 65 6e 0d 06 36 0e 4d 4f 56 20 52 30 2c 23 31 |een..6.MOV R0,#1| 00000f80 39 0d 06 40 11 53 57 49 20 22 4f 53 5f 42 79 74 |9..@.SWI "OS_Byt| 00000f90 65 22 0d 06 4a 10 4c 44 52 20 52 31 2c 62 61 6e |e"..J.LDR R1,ban| 00000fa0 6b 25 0d 06 54 0f 4d 4f 56 20 52 30 2c 23 31 31 |k%..T.MOV R0,#11| 00000fb0 33 0d 06 5e 11 53 57 49 20 22 4f 53 5f 42 79 74 |3..^.SWI "OS_Byt| 00000fc0 65 22 0d 06 68 13 4c 44 52 20 52 31 34 2c 6c 69 |e"..h.LDR R14,li| 00000fd0 6e 6b 25 2b 30 0d 06 72 0f 4c 44 52 20 52 31 33 |nk%+0..r.LDR R13| 00000fe0 2c 73 70 25 0d 06 7c 0e 4d 4f 56 20 50 43 2c 52 |,sp%..|.MOV PC,R| 00000ff0 31 34 0d 06 86 05 3a 0d 06 90 11 2e 74 65 6d 70 |14....:.....temp| 00001000 73 74 6f 72 65 66 74 25 0d 06 9a 23 45 51 55 44 |storeft%...#EQUD| 00001010 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 | -1:EQUD -1:EQUD| 00001020 20 2d 31 3a 45 51 55 44 20 2d 31 0d 06 a4 23 45 | -1:EQUD -1...#E| 00001030 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 |QUD -1:EQUD -1:E| 00001040 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 0d 06 |QUD -1:EQUD -1..| 00001050 ae 05 3a 0d 06 b8 0e 2e 66 69 6e 64 74 75 62 65 |..:.....findtube| 00001060 25 0d 06 c2 18 41 44 52 20 52 31 33 2c 74 65 6d |%....ADR R13,tem| 00001070 70 73 74 6f 72 65 66 74 25 0d 06 cc 19 53 54 4d |pstoreft%....STM| 00001080 49 41 20 52 31 33 2c 7b 52 30 2d 52 33 2c 52 31 |IA R13,{R0-R3,R1| 00001090 34 7d 0d 06 d6 17 4f 50 54 20 a4 61 64 72 28 31 |4}....OPT .adr(1| 000010a0 33 2c 73 70 72 25 2c 32 29 0d 06 e0 0d 43 4d 50 |3,spr%,2)....CMP| 000010b0 20 52 32 2c 23 30 0d 06 ea 12 52 53 42 4c 54 20 | R2,#0....RSBLT | 000010c0 52 30 2c 52 30 2c 23 30 0d 06 f4 12 52 53 42 4c |R0,R0,#0....RSBL| 000010d0 54 20 52 31 2c 52 31 2c 23 30 0d 06 fe 12 52 53 |T R1,R1,#0....RS| 000010e0 42 4c 54 20 52 32 2c 52 32 2c 23 30 0d 07 08 0d |BLT R2,R2,#0....| 000010f0 43 4d 50 20 52 31 2c 23 30 0d 07 12 18 41 44 44 |CMP R1,#0....ADD| 00001100 47 45 20 52 31 33 2c 52 31 33 2c 23 36 3c 3c 31 |GE R13,R13,#6<<1| 00001110 30 0d 07 1c 12 52 53 42 4c 54 20 52 31 2c 52 31 |0....RSBLT R1,R1| 00001120 2c 23 30 0d 07 26 0d 43 4d 50 20 52 30 2c 23 30 |,#0..&.CMP R0,#0| 00001130 0d 07 30 18 41 44 44 4c 54 20 52 31 33 2c 52 31 |..0.ADDLT R13,R1| 00001140 33 2c 23 33 3c 3c 31 30 0d 07 3a 12 52 53 42 4c |3,#3<<10..:.RSBL| 00001150 54 20 52 30 2c 52 30 2c 23 30 0d 07 44 0d 43 4d |T R0,R0,#0..D.CM| 00001160 50 20 52 31 2c 52 30 0d 07 4e 0f 43 4d 50 47 54 |P R1,R0..N.CMPGT| 00001170 20 52 31 2c 52 32 0d 07 58 0f 42 47 54 20 79 62 | R1,R2..X.BGT yb| 00001180 69 67 66 74 25 0d 07 62 0d 43 4d 50 20 52 32 2c |igft%..b.CMP R2,| 00001190 52 30 0d 07 6c 0f 42 47 54 20 7a 62 69 67 66 74 |R0..l.BGT zbigft| 000011a0 25 0d 07 76 0c 2e 78 62 69 67 66 74 25 0d 07 80 |%..v..xbigft%...| 000011b0 16 41 44 44 20 52 31 33 2c 52 31 33 2c 23 31 3c |.ADD R13,R13,#1<| 000011c0 3c 31 30 0d 07 8a 0e 2e 65 6e 64 62 69 67 66 74 |<10.....endbigft| 000011d0 25 0d 07 94 13 43 4d 50 20 52 31 2c 52 30 2c 41 |%....CMP R1,R0,A| 000011e0 53 52 23 31 0d 07 9e 18 53 55 42 47 45 20 52 31 |SR#1....SUBGE R1| 000011f0 2c 52 31 2c 52 30 2c 41 53 52 23 31 0d 07 a8 19 |,R1,R0,ASR#1....| 00001200 41 44 44 47 45 20 52 31 33 2c 52 31 33 2c 23 39 |ADDGE R13,R13,#9| 00001210 36 3c 3c 31 30 0d 07 b2 13 43 4d 50 20 52 31 2c |6<<10....CMP R1,| 00001220 52 30 2c 41 53 52 23 32 0d 07 bc 19 41 44 44 47 |R0,ASR#2....ADDG| 00001230 45 20 52 31 33 2c 52 31 33 2c 23 34 38 3c 3c 31 |E R13,R13,#48<<1| 00001240 30 0d 07 c6 13 43 4d 50 20 52 32 2c 52 30 2c 41 |0....CMP R2,R0,A| 00001250 53 52 23 31 0d 07 d0 18 53 55 42 47 45 20 52 32 |SR#1....SUBGE R2| 00001260 2c 52 32 2c 52 30 2c 41 53 52 23 31 0d 07 da 19 |,R2,R0,ASR#1....| 00001270 41 44 44 47 45 20 52 31 33 2c 52 31 33 2c 23 32 |ADDGE R13,R13,#2| 00001280 34 3c 3c 31 30 0d 07 e4 13 43 4d 50 20 52 32 2c |4<<10....CMP R2,| 00001290 52 30 2c 41 53 52 23 32 0d 07 ee 19 41 44 44 47 |R0,ASR#2....ADDG| 000012a0 45 20 52 31 33 2c 52 31 33 2c 23 31 32 3c 3c 31 |E R13,R13,#12<<1| 000012b0 30 0d 07 f8 11 2e 65 6e 64 66 69 6e 64 74 75 62 |0.....endfindtub| 000012c0 65 25 0d 08 02 17 41 44 52 20 52 33 2c 74 65 6d |e%....ADR R3,tem| 000012d0 70 73 74 6f 72 65 66 74 25 0d 08 0c 18 4c 44 4d |pstoreft%....LDM| 000012e0 49 41 20 52 33 2c 7b 52 30 2d 52 33 2c 52 31 34 |IA R3,{R0-R3,R14| 000012f0 7d 0d 08 16 0e 4d 4f 56 20 50 43 2c 52 31 34 0d |}....MOV PC,R14.| 00001300 08 20 05 3a 0d 08 2a 0c 2e 79 62 69 67 66 74 25 |. .:..*..ybigft%| 00001310 0d 08 34 16 41 44 44 20 52 31 33 2c 52 31 33 2c |..4.ADD R13,R13,| 00001320 23 32 3c 3c 31 30 0d 08 3e 0d 4d 4f 56 20 52 33 |#2<<10..>.MOV R3| 00001330 2c 52 30 0d 08 48 0d 4d 4f 56 20 52 30 2c 52 31 |,R0..H.MOV R0,R1| 00001340 0d 08 52 0d 4d 4f 56 20 52 31 2c 52 32 0d 08 5c |..R.MOV R1,R2..\| 00001350 0d 4d 4f 56 20 52 32 2c 52 33 0d 08 66 0f 42 20 |.MOV R2,R3..f.B | 00001360 65 6e 64 62 69 67 66 74 25 0d 08 70 05 3a 0d 08 |endbigft%..p.:..| 00001370 7a 0c 2e 7a 62 69 67 66 74 25 0d 08 84 0d 4d 4f |z..zbigft%....MO| 00001380 56 20 52 33 2c 52 32 0d 08 8e 0d 4d 4f 56 20 52 |V R3,R2....MOV R| 00001390 32 2c 52 31 0d 08 98 0d 4d 4f 56 20 52 31 2c 52 |2,R1....MOV R1,R| 000013a0 30 0d 08 a2 0d 4d 4f 56 20 52 30 2c 52 33 0d 08 |0....MOV R0,R3..| 000013b0 ac 0f 42 20 65 6e 64 62 69 67 66 74 25 0d 08 b6 |..B endbigft%...| 000013c0 05 3a 0d 08 c0 11 2e 74 65 6d 70 73 74 6f 72 65 |.:.....tempstore| 000013d0 64 73 25 0d 08 ca 23 45 51 55 44 20 2d 31 3a 45 |ds%...#EQUD -1:E| 000013e0 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 |QUD -1:EQUD -1:E| 000013f0 51 55 44 20 2d 31 0d 08 d4 23 45 51 55 44 20 2d |QUD -1...#EQUD -| 00001400 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d |1:EQUD -1:EQUD -| 00001410 31 3a 45 51 55 44 20 2d 31 0d 08 de 23 45 51 55 |1:EQUD -1...#EQU| 00001420 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 |D -1:EQUD -1:EQU| 00001430 44 20 2d 31 3a 45 51 55 44 20 2d 31 0d 08 e8 23 |D -1:EQUD -1...#| 00001440 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a |EQUD -1:EQUD -1:| 00001450 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 0d |EQUD -1:EQUD -1.| 00001460 08 f2 05 3a 0d 08 fc 10 2e 64 72 61 77 73 70 72 |...:.....drawspr| 00001470 69 74 65 25 0d 09 06 11 3b 20 43 6f 72 72 75 70 |ite%....; Corrup| 00001480 74 73 20 52 32 0d 09 10 17 41 44 52 20 52 32 2c |ts R2....ADR R2,| 00001490 74 65 6d 70 73 74 6f 72 65 64 73 25 0d 09 1a 26 |tempstoreds%...&| 000014a0 53 54 4d 49 41 20 52 32 2c 7b 52 30 2d 52 31 2c |STMIA R2,{R0-R1,| 000014b0 52 33 2d 52 39 2c 52 31 31 2c 52 31 33 2d 52 31 |R3-R9,R11,R13-R1| 000014c0 34 7d 0d 09 24 28 53 55 42 20 52 30 2c 52 30 2c |4}..$(SUB R0,R0,| 000014d0 23 31 35 2e 35 2a 28 31 3c 3c 41 43 25 29 3a 3b |#15.5*(1<<AC%):;| 000014e0 20 54 4c 20 63 6f 72 6e 65 72 0d 09 2e 1c 53 55 | TL corner....SU| 000014f0 42 20 52 31 2c 52 31 2c 23 31 35 2e 35 2a 28 31 |B R1,R1,#15.5*(1| 00001500 3c 3c 41 43 25 29 0d 09 38 15 4d 4f 56 20 52 30 |<<AC%)..8.MOV R0| 00001510 2c 52 30 2c 4c 53 52 23 41 43 25 0d 09 42 15 4d |,R0,LSR#AC%..B.M| 00001520 4f 56 20 52 31 2c 52 31 2c 4c 53 52 23 41 43 25 |OV R1,R1,LSR#AC%| 00001530 0d 09 4c 0f 43 4d 50 20 52 30 2c 23 32 38 38 0d |..L.CMP R0,#288.| 00001540 09 56 11 43 4d 50 4c 45 20 52 31 2c 23 32 32 34 |.V.CMPLE R1,#224| 00001550 0d 09 60 2f 42 47 54 20 65 6e 64 64 72 61 77 73 |..`/BGT enddraws| 00001560 70 72 69 74 65 25 3a 3b 20 28 50 61 72 74 69 61 |prite%:; (Partia| 00001570 6c 6c 79 29 20 6f 66 66 20 73 63 72 65 65 6e 0d |lly) off screen.| 00001580 09 6a 12 42 49 43 20 52 31 33 2c 52 31 33 2c 23 |.j.BIC R13,R13,#| 00001590 31 0d 09 74 14 4c 44 52 20 52 31 34 2c 73 63 72 |1..t.LDR R14,scr| 000015a0 61 64 64 72 25 0d 09 7e 18 41 44 44 20 52 31 34 |addr%..~.ADD R14| 000015b0 2c 52 31 34 2c 52 31 2c 41 53 4c 23 35 0d 09 88 |,R14,R1,ASL#5...| 000015c0 18 41 44 44 20 52 31 34 2c 52 31 34 2c 52 31 2c |.ADD R14,R14,R1,| 000015d0 41 53 4c 23 37 0d 09 92 1f 80 20 52 32 2c 52 30 |ASL#7..... R2,R0| 000015e0 2c 23 37 3a 3b 20 57 6f 72 64 20 61 6c 69 67 6e |,#7:; Word align| 000015f0 6d 65 6e 74 0d 09 9c 13 4d 4f 56 20 52 30 2c 52 |ment....MOV R0,R| 00001600 30 2c 4c 53 52 23 33 0d 09 a6 29 41 44 44 20 52 |0,LSR#3...)ADD R| 00001610 31 34 2c 52 31 34 2c 52 30 2c 41 53 4c 23 32 3a |14,R14,R0,ASL#2:| 00001620 3b 20 53 63 72 65 65 6e 20 61 64 64 72 65 73 73 |; Screen address| 00001630 0d 09 b0 0f 4d 4f 56 20 52 31 31 2c 23 33 32 0d |....MOV R11,#32.| 00001640 09 ba 15 41 44 52 20 52 31 2c 72 6f 75 74 69 6e |...ADR R1,routin| 00001650 65 64 73 25 0d 09 c4 18 4c 44 52 20 52 30 2c 5b |eds%....LDR R0,[| 00001660 52 31 2c 52 32 2c 41 53 4c 23 32 5d 0d 09 ce 10 |R1,R2,ASL#2]....| 00001670 41 44 44 20 50 43 2c 52 31 2c 52 30 0d 09 d8 0d |ADD PC,R1,R0....| 00001680 4d 4f 56 20 52 30 2c 52 30 0d 09 e2 05 3a 0d 09 |MOV R0,R0....:..| 00001690 ec 13 2e 65 6e 64 64 72 61 77 73 70 72 69 74 65 |...enddrawsprite| 000016a0 25 0d 09 f6 17 41 44 52 20 52 32 2c 74 65 6d 70 |%....ADR R2,temp| 000016b0 73 74 6f 72 65 64 73 25 0d 0a 00 26 4c 44 4d 49 |storeds%...&LDMI| 000016c0 41 20 52 32 2c 7b 52 30 2d 52 31 2c 52 33 2d 52 |A R2,{R0-R1,R3-R| 000016d0 39 2c 52 31 31 2c 52 31 33 2d 52 31 34 7d 0d 0a |9,R11,R13-R14}..| 000016e0 0a 0e 4d 4f 56 20 50 43 2c 52 31 34 0d 0a 14 05 |..MOV PC,R14....| 000016f0 3a 0d 0a 1e 0f 2e 72 6f 75 74 69 6e 65 64 73 25 |:.....routineds%| 00001700 0d 0a 28 15 5d 3a e3 55 25 3d 30 b8 37 3a 5b 4f |..(.]:.U%=0.7:[O| 00001710 50 54 20 54 25 0d 0a 32 22 45 51 55 44 20 65 6e |PT T%..2"EQUD en| 00001720 64 64 72 61 77 73 70 72 69 74 65 25 2d 72 6f 75 |ddrawsprite%-rou| 00001730 74 69 6e 65 64 73 25 0d 0a 3c 0f 5d 3a ed 3a 5b |tineds%..<.]:.:[| 00001740 4f 50 54 20 54 25 0d 0a 46 05 3a 0d 0a 50 2d 5d |OPT T%..F.:..P-]| 00001750 3a 72 6f 75 74 69 6e 65 64 73 25 21 28 30 3c 3c |:routineds%!(0<<| 00001760 32 29 3d 50 25 2d 72 6f 75 74 69 6e 65 64 73 25 |2)=P%-routineds%| 00001770 3a 5b 4f 50 54 20 54 25 0d 0a 5a 0b 2e 79 6c 6f |:[OPT T%..Z..ylo| 00001780 6f 70 25 0d 0a 64 15 4c 44 4d 49 41 20 52 31 34 |op%..d.LDMIA R14| 00001790 2c 7b 52 30 2d 52 33 7d 0d 0a 6e 16 4c 44 4d 49 |,{R0-R3}..n.LDMI| 000017a0 41 20 52 31 33 21 2c 7b 52 35 2d 52 38 7d 0d 0a |A R13!,{R5-R8}..| 000017b0 78 1c 42 49 43 20 52 30 2c 52 30 2c 52 36 3a 84 |x.BIC R0,R0,R6:.| 000017c0 52 20 52 30 2c 52 30 2c 52 35 0d 0a 82 1c 42 49 |R R0,R0,R5....BI| 000017d0 43 20 52 31 2c 52 31 2c 52 38 3a 84 52 20 52 31 |C R1,R1,R8:.R R1| 000017e0 2c 52 31 2c 52 37 0d 0a 8c 16 4c 44 4d 49 41 20 |,R1,R7....LDMIA | 000017f0 52 31 33 21 2c 7b 52 35 2d 52 38 7d 0d 0a 96 1c |R13!,{R5-R8}....| 00001800 42 49 43 20 52 32 2c 52 32 2c 52 36 3a 84 52 20 |BIC R2,R2,R6:.R | 00001810 52 32 2c 52 32 2c 52 35 0d 0a a0 1c 42 49 43 20 |R2,R2,R5....BIC | 00001820 52 33 2c 52 33 2c 52 38 3a 84 52 20 52 33 2c 52 |R3,R3,R8:.R R3,R| 00001830 33 2c 52 37 0d 0a aa 15 53 54 4d 49 41 20 52 31 |3,R7....STMIA R1| 00001840 34 2c 7b 52 30 2d 52 33 7d 0d 0a b4 14 41 44 44 |4,{R0-R3}....ADD| 00001850 20 52 31 34 2c 52 31 34 2c 23 31 36 30 0d 0a be | R14,R14,#160...| 00001860 13 53 55 42 53 20 52 31 31 2c 52 31 31 2c 23 31 |.SUBS R11,R11,#1| 00001870 0d 0a c8 0e 42 47 54 20 79 6c 6f 6f 70 25 0d 0a |....BGT yloop%..| 00001880 d2 14 42 20 65 6e 64 64 72 61 77 73 70 72 69 74 |..B enddrawsprit| 00001890 65 25 0d 0a dc 05 3a 0d 0a e6 36 5d 3a e3 55 25 |e%....:...6]:.U%| 000018a0 3d 31 b8 37 3a 72 6f 75 74 69 6e 65 64 73 25 21 |=1.7:routineds%!| 000018b0 28 55 25 3c 3c 32 29 3d 50 25 2d 72 6f 75 74 69 |(U%<<2)=P%-routi| 000018c0 6e 65 64 73 25 3a 5b 4f 50 54 20 54 25 0d 0a f0 |neds%:[OPT T%...| 000018d0 0b 2e 79 6c 6f 6f 70 25 0d 0a fa 15 4c 44 4d 49 |..yloop%....LDMI| 000018e0 41 20 52 31 34 2c 7b 52 30 2d 52 34 7d 0d 0b 04 |A R14,{R0-R4}...| 000018f0 16 4c 44 4d 49 41 20 52 31 33 21 2c 7b 52 35 2d |.LDMIA R13!,{R5-| 00001900 52 38 7d 0d 0b 0e 61 42 49 43 20 52 30 2c 52 30 |R8}...aBIC R0,R0| 00001910 2c 52 36 2c 4c 53 4c 23 55 25 3c 3c 32 3a 84 52 |,R6,LSL#U%<<2:.R| 00001920 20 52 30 2c 52 30 2c 52 35 2c 4c 53 4c 23 55 25 | R0,R0,R5,LSL#U%| 00001930 3c 3c 32 3a 42 49 43 20 52 31 2c 52 31 2c 52 36 |<<2:BIC R1,R1,R6| 00001940 2c 4c 53 52 23 38 2d 55 25 3c 3c 32 3a 84 52 20 |,LSR#8-U%<<2:.R | 00001950 52 31 2c 52 31 2c 52 35 2c 4c 53 52 23 38 2d 55 |R1,R1,R5,LSR#8-U| 00001960 25 3c 3c 32 0d 0b 18 61 42 49 43 20 52 31 2c 52 |%<<2...aBIC R1,R| 00001970 31 2c 52 38 2c 4c 53 4c 23 55 25 3c 3c 32 3a 84 |1,R8,LSL#U%<<2:.| 00001980 52 20 52 31 2c 52 31 2c 52 37 2c 4c 53 4c 23 55 |R R1,R1,R7,LSL#U| 00001990 25 3c 3c 32 3a 42 49 43 20 52 32 2c 52 32 2c 52 |%<<2:BIC R2,R2,R| 000019a0 38 2c 4c 53 52 23 38 2d 55 25 3c 3c 32 3a 84 52 |8,LSR#8-U%<<2:.R| 000019b0 20 52 32 2c 52 32 2c 52 37 2c 4c 53 52 23 38 2d | R2,R2,R7,LSR#8-| 000019c0 55 25 3c 3c 32 0d 0b 22 16 4c 44 4d 49 41 20 52 |U%<<2..".LDMIA R| 000019d0 31 33 21 2c 7b 52 35 2d 52 38 7d 0d 0b 2c 61 42 |13!,{R5-R8}..,aB| 000019e0 49 43 20 52 32 2c 52 32 2c 52 36 2c 4c 53 4c 23 |IC R2,R2,R6,LSL#| 000019f0 55 25 3c 3c 32 3a 84 52 20 52 32 2c 52 32 2c 52 |U%<<2:.R R2,R2,R| 00001a00 35 2c 4c 53 4c 23 55 25 3c 3c 32 3a 42 49 43 20 |5,LSL#U%<<2:BIC | 00001a10 52 33 2c 52 33 2c 52 36 2c 4c 53 52 23 38 2d 55 |R3,R3,R6,LSR#8-U| 00001a20 25 3c 3c 32 3a 84 52 20 52 33 2c 52 33 2c 52 35 |%<<2:.R R3,R3,R5| 00001a30 2c 4c 53 52 23 38 2d 55 25 3c 3c 32 0d 0b 36 61 |,LSR#8-U%<<2..6a| 00001a40 42 49 43 20 52 33 2c 52 33 2c 52 38 2c 4c 53 4c |BIC R3,R3,R8,LSL| 00001a50 23 55 25 3c 3c 32 3a 84 52 20 52 33 2c 52 33 2c |#U%<<2:.R R3,R3,| 00001a60 52 37 2c 4c 53 4c 23 55 25 3c 3c 32 3a 42 49 43 |R7,LSL#U%<<2:BIC| 00001a70 20 52 34 2c 52 34 2c 52 38 2c 4c 53 52 23 38 2d | R4,R4,R8,LSR#8-| 00001a80 55 25 3c 3c 32 3a 84 52 20 52 34 2c 52 34 2c 52 |U%<<2:.R R4,R4,R| 00001a90 37 2c 4c 53 52 23 38 2d 55 25 3c 3c 32 0d 0b 40 |7,LSR#8-U%<<2..@| 00001aa0 15 53 54 4d 49 41 20 52 31 34 2c 7b 52 30 2d 52 |.STMIA R14,{R0-R| 00001ab0 34 7d 0d 0b 4a 14 41 44 44 20 52 31 34 2c 52 31 |4}..J.ADD R14,R1| 00001ac0 34 2c 23 31 36 30 0d 0b 54 13 53 55 42 53 20 52 |4,#160..T.SUBS R| 00001ad0 31 31 2c 52 31 31 2c 23 31 0d 0b 5e 0e 42 47 54 |11,R11,#1..^.BGT| 00001ae0 20 79 6c 6f 6f 70 25 0d 0b 68 14 42 20 65 6e 64 | yloop%..h.B end| 00001af0 64 72 61 77 73 70 72 69 74 65 25 0d 0b 72 0f 5d |drawsprite%..r.]| 00001b00 3a ed 3a 5b 4f 50 54 20 54 25 0d 0b 7c 05 3a 0d |:.:[OPT T%..|.:.| 00001b10 0b 86 11 2e 74 65 6d 70 73 74 6f 72 65 64 74 25 |....tempstoredt%| 00001b20 0d 0b 90 23 45 51 55 44 20 2d 31 3a 45 51 55 44 |...#EQUD -1:EQUD| 00001b30 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 | -1:EQUD -1:EQUD| 00001b40 20 2d 31 0d 0b 9a 23 45 51 55 44 20 2d 31 3a 45 | -1...#EQUD -1:E| 00001b50 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 |QUD -1:EQUD -1:E| 00001b60 51 55 44 20 2d 31 0d 0b a4 23 45 51 55 44 20 2d |QUD -1...#EQUD -| 00001b70 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d |1:EQUD -1:EQUD -| 00001b80 31 3a 45 51 55 44 20 2d 31 0d 0b ae 23 45 51 55 |1:EQUD -1...#EQU| 00001b90 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 |D -1:EQUD -1:EQU| 00001ba0 44 20 2d 31 3a 45 51 55 44 20 2d 31 0d 0b b8 05 |D -1:EQUD -1....| 00001bb0 3a 0d 0b c2 0e 2e 64 72 61 77 74 75 62 65 25 0d |:.....drawtube%.| 00001bc0 0b cc 12 3b 20 43 6f 72 72 75 70 74 73 20 52 31 |...; Corrupts R1| 00001bd0 33 0d 0b d6 2e 3b 20 45 78 70 65 63 74 73 20 52 |3....; Expects R| 00001be0 30 2d 52 31 20 74 6f 20 62 65 20 74 68 65 20 64 |0-R1 to be the d| 00001bf0 69 72 65 63 74 69 6f 6e 20 76 65 63 74 6f 72 0d |irection vector.| 00001c00 0b e0 2d 3b 20 45 78 70 65 63 74 73 20 52 33 2d |..-; Expects R3-| 00001c10 52 34 28 2c 52 35 29 20 74 6f 20 62 65 20 73 74 |R4(,R5) to be st| 00001c20 61 72 74 20 70 6f 73 69 74 69 6f 6e 0d 0b ea 2a |art position...*| 00001c30 3b 20 45 78 70 65 63 74 73 20 52 36 20 74 6f 20 |; Expects R6 to | 00001c40 62 65 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 |be the number of| 00001c50 20 73 74 65 70 73 0d 0b f4 18 41 44 52 20 52 31 | steps....ADR R1| 00001c60 33 2c 74 65 6d 70 73 74 6f 72 65 64 74 25 0d 0b |3,tempstoredt%..| 00001c70 fe 1a 53 54 4d 49 41 20 52 31 33 2c 7b 52 30 2d |..STMIA R13,{R0-| 00001c80 52 31 32 2c 52 31 34 7d 0d 0c 08 0d 43 4d 50 20 |R12,R14}....CMP | 00001c90 52 32 2c 23 30 0d 0c 12 2e 41 44 44 47 54 20 52 |R2,#0....ADDGT R| 00001ca0 33 2c 52 33 2c 52 30 3a 3b 20 4d 75 73 74 20 73 |3,R3,R0:; Must s| 00001cb0 74 61 72 74 20 61 74 20 74 68 65 20 66 61 72 20 |tart at the far | 00001cc0 65 6e 64 0d 0c 1c 12 41 44 44 47 54 20 52 34 2c |end....ADDGT R4,| 00001cd0 52 34 2c 52 31 0d 0c 26 12 41 44 44 47 54 20 52 |R4,R1..&.ADDGT R| 00001ce0 35 2c 52 35 2c 52 32 0d 0c 30 3b 52 53 42 47 54 |5,R5,R2..0;RSBGT| 00001cf0 20 52 30 2c 52 30 2c 23 30 3a 3b 20 4d 75 73 74 | R0,R0,#0:; Must| 00001d00 20 68 61 76 65 20 76 65 63 74 6f 72 20 66 61 63 | have vector fac| 00001d10 69 6e 67 20 74 6f 77 61 72 64 73 20 76 69 65 77 |ing towards view| 00001d20 65 72 0d 0c 3a 12 52 53 42 47 54 20 52 31 2c 52 |er..:.RSBGT R1,R| 00001d30 31 2c 23 30 0d 0c 44 12 52 53 42 47 54 20 52 32 |1,#0..D.RSBGT R2| 00001d40 2c 52 32 2c 23 30 0d 0c 4e 10 42 4c 20 66 69 6e |,R2,#0..N.BL fin| 00001d50 64 74 75 62 65 25 0d 0c 58 16 3b 20 44 69 76 69 |dtube%..X.; Divi| 00001d60 64 65 20 31 3c 3c 38 20 62 79 20 33 0d 0c 62 10 |de 1<<8 by 3..b.| 00001d70 4d 4f 56 20 52 37 2c 23 31 3c 3c 38 0d 0c 6c 0d |MOV R7,#1<<8..l.| 00001d80 4d 4f 56 20 52 38 2c 23 30 0d 0c 76 18 5d 3a e3 |MOV R8,#0..v.]:.| 00001d90 55 25 3d 37 b8 31 88 2d 31 3a 5b 4f 50 54 20 54 |U%=7.1.-1:[OPT T| 00001da0 25 0d 0c 80 14 43 4d 50 20 52 36 2c 52 37 2c 41 |%....CMP R6,R7,A| 00001db0 53 52 23 55 25 0d 0c 8a 19 53 55 42 4c 45 20 52 |SR#U%....SUBLE R| 00001dc0 37 2c 52 37 2c 52 36 2c 41 53 4c 23 55 25 0d 0c |7,R7,R6,ASL#U%..| 00001dd0 94 16 41 44 44 4c 45 20 52 38 2c 52 38 2c 23 31 |..ADDLE R8,R8,#1| 00001de0 3c 3c 55 25 0d 0c 9e 0f 5d 3a ed 3a 5b 4f 50 54 |<<U%....]:.:[OPT| 00001df0 20 54 25 0d 0c a8 0d 43 4d 50 20 52 36 2c 52 37 | T%....CMP R6,R7| 00001e00 0d 0c b2 12 41 44 44 4c 45 20 52 38 2c 52 38 2c |....ADDLE R8,R8,| 00001e10 23 31 0d 0c bc 13 4d 4f 56 20 52 35 2c 52 31 2c |#1....MOV R5,R1,| 00001e20 41 53 52 23 38 0d 0c c6 0d 4d 4f 56 20 52 31 2c |ASR#8....MOV R1,| 00001e30 52 34 0d 0c d0 13 4d 4f 56 20 52 34 2c 52 30 2c |R4....MOV R4,R0,| 00001e40 41 53 52 23 38 0d 0c da 0d 4d 4f 56 20 52 30 2c |ASR#8....MOV R0,| 00001e50 52 33 0d 0c e4 22 4d 55 4c 20 52 34 2c 52 38 2c |R3..."MUL R4,R8,| 00001e60 52 34 3a 3b 20 56 65 63 74 6f 72 20 70 65 72 20 |R4:; Vector per | 00001e70 73 74 65 70 0d 0c ee 10 4d 55 4c 20 52 35 2c 52 |step....MUL R5,R| 00001e80 38 2c 52 35 0d 0c f8 32 41 44 44 20 52 30 2c 52 |8,R5...2ADD R0,R| 00001e90 30 2c 52 34 2c 41 53 52 23 31 3a 3b 20 48 61 6c |0,R4,ASR#1:; Hal| 00001ea0 66 20 77 61 79 20 61 6c 6f 6e 67 20 66 69 72 73 |f way along firs| 00001eb0 74 20 73 74 65 70 0d 0d 02 16 41 44 44 20 52 31 |t step....ADD R1| 00001ec0 2c 52 31 2c 52 35 2c 41 53 52 23 31 0d 0d 0c 0e |,R1,R5,ASR#1....| 00001ed0 2e 73 74 65 70 6c 6f 6f 70 25 0d 0d 16 12 42 4c |.steploop%....BL| 00001ee0 20 64 72 61 77 73 70 72 69 74 65 25 0d 0d 20 10 | drawsprite%.. .| 00001ef0 41 44 44 20 52 30 2c 52 30 2c 52 34 0d 0d 2a 10 |ADD R0,R0,R4..*.| 00001f00 41 44 44 20 52 31 2c 52 31 2c 52 35 0d 0d 34 11 |ADD R1,R1,R5..4.| 00001f10 53 55 42 53 20 52 36 2c 52 36 2c 23 31 0d 0d 3e |SUBS R6,R6,#1..>| 00001f20 11 42 47 54 20 73 74 65 70 6c 6f 6f 70 25 0d 0d |.BGT steploop%..| 00001f30 48 18 41 44 52 20 52 31 33 2c 74 65 6d 70 73 74 |H.ADR R13,tempst| 00001f40 6f 72 65 64 74 25 0d 0d 52 1a 4c 44 4d 49 41 20 |oredt%..R.LDMIA | 00001f50 52 31 33 2c 7b 52 30 2d 52 31 32 2c 52 31 34 7d |R13,{R0-R12,R14}| 00001f60 0d 0d 5c 0e 4d 4f 56 20 50 43 2c 52 31 34 0d 0d |..\.MOV PC,R14..| 00001f70 66 05 3a 0d 0d 70 14 2e 74 65 6d 70 73 74 6f 72 |f.:..p..tempstor| 00001f80 65 74 72 61 6e 73 25 0d 0d 7a 23 45 51 55 44 20 |etrans%..z#EQUD | 00001f90 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 |-1:EQUD -1:EQUD | 00001fa0 2d 31 3a 45 51 55 44 20 2d 31 0d 0d 84 23 45 51 |-1:EQUD -1...#EQ| 00001fb0 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 |UD -1:EQUD -1:EQ| 00001fc0 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 0d 0d 8e |UD -1:EQUD -1...| 00001fd0 23 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 |#EQUD -1:EQUD -1| 00001fe0 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 |:EQUD -1:EQUD -1| 00001ff0 0d 0d 98 05 3a 0d 0d a2 0a 2e 76 69 65 77 25 0d |....:.....view%.| 00002000 0d ac 28 45 51 55 44 20 31 3c 3c 56 43 25 3a 45 |..(EQUD 1<<VC%:E| 00002010 51 55 44 20 30 3a 45 51 55 44 20 30 3a 3b 20 58 |QUD 0:EQUD 0:; X| 00002020 2d 76 65 63 74 6f 72 0d 0d b6 28 45 51 55 44 20 |-vector...(EQUD | 00002030 30 3a 45 51 55 44 20 31 3c 3c 56 43 25 3a 45 51 |0:EQUD 1<<VC%:EQ| 00002040 55 44 20 30 3a 3b 20 59 2d 76 65 63 74 6f 72 0d |UD 0:; Y-vector.| 00002050 0d c0 28 45 51 55 44 20 30 3a 45 51 55 44 20 30 |..(EQUD 0:EQUD 0| 00002060 3a 45 51 55 44 20 31 3c 3c 56 43 25 3a 3b 20 5a |:EQUD 1<<VC%:; Z| 00002070 2d 76 65 63 74 6f 72 0d 0d ca 05 3a 0d 0d d4 0f |-vector....:....| 00002080 2e 74 72 61 6e 73 66 6f 72 6d 25 0d 0d de 11 3b |.transform%....;| 00002090 20 43 6f 72 72 75 70 74 73 20 52 30 0d 0d e8 1a | Corrupts R0....| 000020a0 41 44 52 20 52 30 2c 74 65 6d 70 73 74 6f 72 65 |ADR R0,tempstore| 000020b0 74 72 61 6e 73 25 0d 0d f2 18 53 54 4d 49 41 20 |trans%....STMIA | 000020c0 52 30 2c 7b 52 31 2d 52 39 2c 52 31 34 7d 0d 0d |R0,{R1-R9,R14}..| 000020d0 fc 17 4f 50 54 20 a4 61 64 72 28 31 34 2c 70 6f |..OPT .adr(14,po| 000020e0 73 25 2c 32 29 0d 0e 06 0d 2e 70 6f 73 6c 6f 6f |s%,2).....posloo| 000020f0 70 25 0d 0e 10 10 4c 44 52 20 52 39 2c 5b 52 31 |p%....LDR R9,[R1| 00002100 34 5d 0d 0e 1a 23 43 4d 4e 20 52 39 2c 23 31 3a |4]...#CMN R9,#1:| 00002110 3b 20 50 6f 73 20 6c 69 73 74 20 74 65 72 6d 69 |; Pos list termi| 00002120 6e 61 74 6f 72 0d 0e 24 15 42 45 51 20 65 6e 64 |nator..$.BEQ end| 00002130 74 72 61 6e 73 66 6f 72 6d 25 0d 0e 2e 31 42 49 |transform%...1BI| 00002140 43 20 52 30 2c 52 39 2c 23 31 3a 3b 20 43 6c 65 |C R0,R9,#1:; Cle| 00002150 61 72 20 74 68 65 20 22 61 6c 72 65 61 64 79 20 |ar the "already | 00002160 64 72 61 77 6e 22 20 66 6c 61 67 0d 0e 38 10 41 |drawn" flag..8.A| 00002170 44 52 20 52 37 2c 76 69 65 77 25 0d 0e 42 10 3b |DR R7,view%..B.;| 00002180 20 58 2a 58 2d 76 65 63 74 6f 72 0d 0e 4c 14 4d | X*X-vector..L.M| 00002190 4f 56 20 52 38 2c 52 39 2c 4c 53 52 23 32 34 0d |OV R8,R9,LSR#24.| 000021a0 0e 56 13 4d 4f 56 20 52 39 2c 52 39 2c 4c 53 4c |.V.MOV R9,R9,LSL| 000021b0 23 38 0d 0e 60 15 4c 44 4d 49 41 20 52 37 21 2c |#8..`.LDMIA R7!,| 000021c0 7b 52 34 2d 52 36 7d 0d 0e 6a 10 4d 55 4c 20 52 |{R4-R6}..j.MUL R| 000021d0 31 2c 52 38 2c 52 34 0d 0e 74 16 53 55 42 20 52 |1,R8,R4..t.SUB R| 000021e0 31 2c 52 31 2c 52 34 2c 41 53 4c 23 37 0d 0e 7e |1,R1,R4,ASL#7..~| 000021f0 10 4d 55 4c 20 52 32 2c 52 38 2c 52 35 0d 0e 88 |.MUL R2,R8,R5...| 00002200 16 53 55 42 20 52 32 2c 52 32 2c 52 35 2c 41 53 |.SUB R2,R2,R5,AS| 00002210 4c 23 37 0d 0e 92 10 4d 55 4c 20 52 33 2c 52 38 |L#7....MUL R3,R8| 00002220 2c 52 36 0d 0e 9c 16 53 55 42 20 52 33 2c 52 33 |,R6....SUB R3,R3| 00002230 2c 52 36 2c 41 53 4c 23 37 0d 0e a6 10 3b 20 59 |,R6,ASL#7....; Y| 00002240 2a 59 2d 76 65 63 74 6f 72 0d 0e b0 14 4d 4f 56 |*Y-vector....MOV| 00002250 20 52 38 2c 52 39 2c 4c 53 52 23 32 34 0d 0e ba | R8,R9,LSR#24...| 00002260 13 4d 4f 56 20 52 39 2c 52 39 2c 4c 53 4c 23 38 |.MOV R9,R9,LSL#8| 00002270 0d 0e c4 15 4c 44 4d 49 41 20 52 37 21 2c 7b 52 |....LDMIA R7!,{R| 00002280 34 2d 52 36 7d 0d 0e ce 13 4d 4c 41 20 52 31 2c |4-R6}....MLA R1,| 00002290 52 38 2c 52 34 2c 52 31 0d 0e d8 16 53 55 42 20 |R8,R4,R1....SUB | 000022a0 52 31 2c 52 31 2c 52 34 2c 41 53 4c 23 37 0d 0e |R1,R1,R4,ASL#7..| 000022b0 e2 13 4d 4c 41 20 52 32 2c 52 38 2c 52 35 2c 52 |..MLA R2,R8,R5,R| 000022c0 32 0d 0e ec 16 53 55 42 20 52 32 2c 52 32 2c 52 |2....SUB R2,R2,R| 000022d0 35 2c 41 53 4c 23 37 0d 0e f6 13 4d 4c 41 20 52 |5,ASL#7....MLA R| 000022e0 33 2c 52 38 2c 52 36 2c 52 33 0d 0f 00 16 53 55 |3,R8,R6,R3....SU| 000022f0 42 20 52 33 2c 52 33 2c 52 36 2c 41 53 4c 23 37 |B R3,R3,R6,ASL#7| 00002300 0d 0f 0a 10 3b 20 5a 2a 5a 2d 76 65 63 74 6f 72 |....; Z*Z-vector| 00002310 0d 0f 14 14 4d 4f 56 20 52 38 2c 52 39 2c 4c 53 |....MOV R8,R9,LS| 00002320 52 23 32 34 0d 0f 1e 13 4d 4f 56 20 52 39 2c 52 |R#24....MOV R9,R| 00002330 39 2c 4c 53 4c 23 38 0d 0f 28 15 4c 44 4d 49 41 |9,LSL#8..(.LDMIA| 00002340 20 52 37 21 2c 7b 52 34 2d 52 36 7d 0d 0f 32 13 | R7!,{R4-R6}..2.| 00002350 4d 4c 41 20 52 31 2c 52 38 2c 52 34 2c 52 31 0d |MLA R1,R8,R4,R1.| 00002360 0f 3c 16 53 55 42 20 52 31 2c 52 31 2c 52 34 2c |.<.SUB R1,R1,R4,| 00002370 41 53 4c 23 37 0d 0f 46 13 4d 4c 41 20 52 32 2c |ASL#7..F.MLA R2,| 00002380 52 38 2c 52 35 2c 52 32 0d 0f 50 16 53 55 42 20 |R8,R5,R2..P.SUB | 00002390 52 32 2c 52 32 2c 52 35 2c 41 53 4c 23 37 0d 0f |R2,R2,R5,ASL#7..| 000023a0 5a 13 4d 4c 41 20 52 33 2c 52 38 2c 52 36 2c 52 |Z.MLA R3,R8,R6,R| 000023b0 33 0d 0f 64 16 53 55 42 20 52 33 2c 52 33 2c 52 |3..d.SUB R3,R3,R| 000023c0 36 2c 41 53 4c 23 37 0d 0f 6e 19 4d 4f 56 20 52 |6,ASL#7..n.MOV R| 000023d0 31 2c 52 31 2c 41 53 4c 23 41 43 25 2d 56 43 25 |1,R1,ASL#AC%-VC%| 000023e0 0d 0f 78 19 4d 4f 56 20 52 32 2c 52 32 2c 41 53 |..x.MOV R2,R2,AS| 000023f0 4c 23 41 43 25 2d 56 43 25 0d 0f 82 19 4d 4f 56 |L#AC%-VC%....MOV| 00002400 20 52 33 2c 52 33 2c 41 53 4c 23 41 43 25 2d 56 | R3,R3,ASL#AC%-V| 00002410 43 25 0d 0f 8c 17 41 44 44 20 52 31 2c 52 31 2c |C%....ADD R1,R1,| 00002420 23 31 36 30 3c 3c 41 43 25 0d 0f 96 17 41 44 44 |#160<<AC%....ADD| 00002430 20 52 32 2c 52 32 2c 23 31 32 38 3c 3c 41 43 25 | R2,R2,#128<<AC%| 00002440 0d 0f a0 19 53 54 4d 49 41 20 52 31 34 21 2c 7b |....STMIA R14!,{| 00002450 52 30 2c 52 31 2d 52 33 7d 0d 0f aa 0e 42 20 70 |R0,R1-R3}....B p| 00002460 6f 73 6c 6f 6f 70 25 0d 0f b4 05 3a 0d 0f be 12 |osloop%....:....| 00002470 2e 65 6e 64 74 72 61 6e 73 66 6f 72 6d 25 0d 0f |.endtransform%..| 00002480 c8 1a 41 44 52 20 52 30 2c 74 65 6d 70 73 74 6f |..ADR R0,tempsto| 00002490 72 65 74 72 61 6e 73 25 0d 0f d2 18 4c 44 4d 49 |retrans%....LDMI| 000024a0 41 20 52 30 2c 7b 52 31 2d 52 39 2c 52 31 34 7d |A R0,{R1-R9,R14}| 000024b0 0d 0f dc 0e 4d 4f 56 20 50 43 2c 52 31 34 0d 0f |....MOV PC,R14..| 000024c0 e6 05 3a 0d 0f f0 13 2e 74 65 6d 70 73 74 6f 72 |..:.....tempstor| 000024d0 65 73 6f 72 74 25 0d 0f fa 23 45 51 55 44 20 2d |esort%...#EQUD -| 000024e0 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d |1:EQUD -1:EQUD -| 000024f0 31 3a 45 51 55 44 20 2d 31 0d 10 04 23 45 51 55 |1:EQUD -1...#EQU| 00002500 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 |D -1:EQUD -1:EQU| 00002510 44 20 2d 31 3a 45 51 55 44 20 2d 31 0d 10 0e 05 |D -1:EQUD -1....| 00002520 3a 0d 10 18 0a 2e 73 6f 72 74 25 0d 10 22 11 3b |:.....sort%..".;| 00002530 20 43 6f 72 72 75 70 74 73 20 52 30 0d 10 2c 19 | Corrupts R0..,.| 00002540 41 44 52 20 52 30 2c 74 65 6d 70 73 74 6f 72 65 |ADR R0,tempstore| 00002550 73 6f 72 74 25 0d 10 36 1c 53 54 4d 49 41 20 52 |sort%..6.STMIA R| 00002560 30 2c 7b 52 30 2d 52 31 2c 52 31 31 2d 52 31 34 |0,{R0-R1,R11-R14| 00002570 7d 0d 10 40 36 3b 20 43 6f 6d 70 69 6c 65 20 61 |}..@6; Compile a| 00002580 20 6c 69 73 74 20 6f 66 20 6c 69 6e 65 73 2c 20 | list of lines, | 00002590 77 69 74 68 20 64 69 73 74 61 6e 63 65 73 20 61 |with distances a| 000025a0 74 74 61 63 68 65 64 0d 10 4a 2a 4f 50 54 20 a4 |ttached..J*OPT .| 000025b0 61 64 72 28 31 34 2c 70 6f 73 25 2b 31 32 2c 32 |adr(14,pos%+12,2| 000025c0 29 3a 3b 20 5a 2d 63 6f 6f 72 64 69 6e 61 74 65 |):; Z-coordinate| 000025d0 73 0d 10 54 19 4f 50 54 20 a4 61 64 72 28 31 33 |s..T.OPT .adr(13| 000025e0 2c 6c 69 6e 65 73 25 2c 32 29 0d 10 5e 19 4f 50 |,lines%,2)..^.OP| 000025f0 54 20 a4 61 64 72 28 31 32 2c 73 6c 69 73 74 25 |T .adr(12,slist%| 00002600 2c 32 29 0d 10 68 0e 4d 4f 56 20 52 31 31 2c 23 |,2)..h.MOV R11,#| 00002610 30 0d 10 72 0e 2e 6c 69 6e 65 6c 6f 6f 70 25 0d |0..r..lineloop%.| 00002620 10 7c 13 4c 44 52 20 52 30 2c 5b 52 31 33 5d 2c |.|.LDR R0,[R13],| 00002630 23 34 0d 10 86 0d 43 4d 4e 20 52 30 2c 23 31 0d |#4....CMN R0,#1.| 00002640 10 90 11 42 45 51 20 65 6e 64 73 6f 72 74 31 25 |...BEQ endsort1%| 00002650 0d 10 9a 14 80 20 52 31 2c 52 30 2c 23 32 35 35 |..... R1,R0,#255| 00002660 3c 3c 31 36 0d 10 a4 14 80 20 52 30 2c 52 30 2c |<<16..... R0,R0,| 00002670 23 32 35 35 3c 3c 32 34 0d 10 ae 1c 4c 44 52 20 |#255<<24....LDR | 00002680 52 30 2c 5b 52 31 34 2c 52 30 2c 4c 53 52 23 32 |R0,[R14,R0,LSR#2| 00002690 34 2d 34 5d 0d 10 b8 1c 4c 44 52 20 52 31 2c 5b |4-4]....LDR R1,[| 000026a0 52 31 34 2c 52 31 2c 4c 53 52 23 31 36 2d 34 5d |R14,R1,LSR#16-4]| 000026b0 0d 10 c2 10 41 44 44 20 52 30 2c 52 30 2c 52 31 |....ADD R0,R0,R1| 000026c0 0d 10 cc 13 4d 4f 56 20 52 30 2c 52 30 2c 41 53 |....MOV R0,R0,AS| 000026d0 52 23 31 0d 10 d6 12 42 49 43 20 52 30 2c 52 30 |R#1....BIC R0,R0| 000026e0 2c 23 32 35 35 0d 10 e0 10 84 52 20 52 30 2c 52 |,#255.....R R0,R| 000026f0 30 2c 52 31 31 0d 10 ea 13 53 54 52 20 52 30 2c |0,R11....STR R0,| 00002700 5b 52 31 32 5d 2c 23 34 0d 10 f4 12 41 44 44 20 |[R12],#4....ADD | 00002710 52 31 31 2c 52 31 31 2c 23 31 0d 10 fe 0f 42 20 |R11,R11,#1....B | 00002720 6c 69 6e 65 6c 6f 6f 70 25 0d 11 08 05 3a 0d 11 |lineloop%....:..| 00002730 12 0e 2e 65 6e 64 73 6f 72 74 31 25 0d 11 1c 14 |...endsort1%....| 00002740 53 54 52 20 52 30 2c 5b 52 31 32 5d 2c 23 2d 34 |STR R0,[R12],#-4| 00002750 0d 11 26 0f 3b 20 53 6f 72 74 20 74 68 65 6d 0d |..&.; Sort them.| 00002760 11 30 19 4f 50 54 20 a4 61 64 72 28 31 34 2c 73 |.0.OPT .adr(14,s| 00002770 6c 69 73 74 25 2c 32 29 0d 11 3a 15 3b 20 52 31 |list%,2)..:.; R1| 00002780 32 20 69 73 20 6c 61 73 74 20 6f 6e 65 0d 11 44 |2 is last one..D| 00002790 0f 43 4d 50 20 52 31 32 2c 52 31 34 0d 11 4e 22 |.CMP R12,R14..N"| 000027a0 42 4c 45 20 65 6e 64 73 6f 72 74 32 25 3a 3b 20 |BLE endsort2%:; | 000027b0 30 20 6f 72 20 31 20 6f 66 20 74 68 65 6d 0d 11 |0 or 1 of them..| 000027c0 58 0d 2e 6f 75 74 6c 6f 6f 70 25 0d 11 62 15 4c |X..outloop%..b.L| 000027d0 44 4d 49 41 20 52 31 34 2c 7b 52 30 2d 52 31 7d |DMIA R14,{R0-R1}| 000027e0 0d 11 6c 0f 4d 4f 56 20 52 31 33 2c 52 31 34 0d |..l.MOV R13,R14.| 000027f0 11 76 0c 2e 69 6e 6c 6f 6f 70 25 0d 11 80 0d 43 |.v..inloop%....C| 00002800 4d 50 20 52 30 2c 52 31 0d 11 8a 15 53 54 52 47 |MP R0,R1....STRG| 00002810 54 20 52 30 2c 5b 52 31 33 5d 2c 23 34 0d 11 94 |T R0,[R13],#4...| 00002820 0f 4d 4f 56 47 54 20 52 30 2c 52 31 0d 11 9e 15 |.MOVGT R0,R1....| 00002830 53 54 52 4c 45 20 52 31 2c 5b 52 31 33 5d 2c 23 |STRLE R1,[R13],#| 00002840 34 0d 11 a8 13 4c 44 52 20 52 31 2c 5b 52 31 33 |4....LDR R1,[R13| 00002850 2c 23 34 5d 0d 11 b2 0f 43 4d 50 20 52 31 33 2c |,#4]....CMP R13,| 00002860 52 31 32 0d 11 bc 0f 42 4c 54 20 69 6e 6c 6f 6f |R12....BLT inloo| 00002870 70 25 0d 11 c6 10 53 54 52 20 52 30 2c 5b 52 31 |p%....STR R0,[R1| 00002880 33 5d 0d 11 d0 12 53 55 42 20 52 31 32 2c 52 31 |3]....SUB R12,R1| 00002890 32 2c 23 34 0d 11 da 0f 43 4d 50 20 52 31 32 2c |2,#4....CMP R12,| 000028a0 52 31 34 0d 11 e4 10 42 47 54 20 6f 75 74 6c 6f |R14....BGT outlo| 000028b0 6f 70 25 0d 11 ee 0e 2e 65 6e 64 73 6f 72 74 32 |op%.....endsort2| 000028c0 25 0d 11 f8 19 41 44 52 20 52 30 2c 74 65 6d 70 |%....ADR R0,temp| 000028d0 73 74 6f 72 65 73 6f 72 74 25 0d 12 02 1c 4c 44 |storesort%....LD| 000028e0 4d 49 41 20 52 30 2c 7b 52 30 2d 52 31 2c 52 31 |MIA R0,{R0-R1,R1| 000028f0 31 2d 52 31 34 7d 0d 12 0c 0e 4d 4f 56 20 50 43 |1-R14}....MOV PC| 00002900 2c 52 31 34 0d 12 16 05 3a 0d 12 20 11 2e 74 65 |,R14....:.. ..te| 00002910 6d 70 73 74 6f 72 65 70 73 25 0d 12 2a 23 45 51 |mpstoreps%..*#EQ| 00002920 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 |UD -1:EQUD -1:EQ| 00002930 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 0d 12 34 |UD -1:EQUD -1..4| 00002940 23 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 |#EQUD -1:EQUD -1| 00002950 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 |:EQUD -1:EQUD -1| 00002960 0d 12 3e 23 45 51 55 44 20 2d 31 3a 45 51 55 44 |..>#EQUD -1:EQUD| 00002970 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 | -1:EQUD -1:EQUD| 00002980 20 2d 31 0d 12 48 23 45 51 55 44 20 2d 31 3a 45 | -1..H#EQUD -1:E| 00002990 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 |QUD -1:EQUD -1:E| 000029a0 51 55 44 20 2d 31 0d 12 52 05 3a 0d 12 5c 0f 2e |QUD -1..R.:..\..| 000029b0 70 6c 6f 74 73 68 61 70 65 25 0d 12 66 12 3b 20 |plotshape%..f.; | 000029c0 52 30 20 63 6f 72 72 75 70 74 65 64 0d 12 70 17 |R0 corrupted..p.| 000029d0 41 44 52 20 52 30 2c 74 65 6d 70 73 74 6f 72 65 |ADR R0,tempstore| 000029e0 70 73 25 0d 12 7a 15 53 54 4d 49 41 20 52 30 2c |ps%..z.STMIA R0,| 000029f0 7b 52 31 2d 52 31 34 7d 0d 12 84 17 4f 50 54 20 |{R1-R14}....OPT | 00002a00 a4 61 64 72 28 31 30 2c 70 6f 73 25 2c 32 29 0d |.adr(10,pos%,2).| 00002a10 12 8e 19 4f 50 54 20 a4 61 64 72 28 31 31 2c 6c |...OPT .adr(11,l| 00002a20 69 6e 65 73 25 2c 32 29 0d 12 98 19 4f 50 54 20 |ines%,2)....OPT | 00002a30 a4 61 64 72 28 31 32 2c 73 6c 69 73 74 25 2c 32 |.adr(12,slist%,2| 00002a40 29 0d 12 a2 0e 2e 70 6c 6f 74 6c 6f 6f 70 25 0d |).....plotloop%.| 00002a50 12 ac 13 4c 44 52 20 52 30 2c 5b 52 31 32 5d 2c |...LDR R0,[R12],| 00002a60 23 34 0d 12 b6 0d 43 4d 4e 20 52 30 2c 23 31 0d |#4....CMN R0,#1.| 00002a70 12 c0 15 42 45 51 20 65 6e 64 70 6c 6f 74 73 68 |...BEQ endplotsh| 00002a80 61 70 65 25 0d 12 ca 10 80 20 52 30 2c 52 30 2c |ape%..... R0,R0,| 00002a90 23 32 35 35 0d 12 d4 19 4c 44 52 20 52 30 2c 5b |#255....LDR R0,[| 00002aa0 52 31 31 2c 52 30 2c 41 53 4c 23 32 5d 0d 12 de |R11,R0,ASL#2]...| 00002ab0 13 80 20 52 36 2c 52 30 2c 23 32 35 35 3c 3c 38 |.. R6,R0,#255<<8| 00002ac0 0d 12 e8 13 4d 4f 56 20 52 36 2c 52 36 2c 4c 53 |....MOV R6,R6,LS| 00002ad0 52 23 38 0d 12 f2 14 80 20 52 33 2c 52 30 2c 23 |R#8..... R3,R0,#| 00002ae0 32 35 35 3c 3c 32 34 0d 12 fc 14 80 20 52 34 2c |255<<24..... R4,| 00002af0 52 30 2c 23 32 35 35 3c 3c 31 36 0d 13 06 1a 41 |R0,#255<<16....A| 00002b00 44 44 20 52 33 2c 52 31 30 2c 52 33 2c 4c 53 52 |DD R3,R10,R3,LSR| 00002b10 23 32 34 2d 34 0d 13 10 1a 41 44 44 20 52 34 2c |#24-4....ADD R4,| 00002b20 52 31 30 2c 52 34 2c 4c 53 52 23 31 36 2d 34 0d |R10,R4,LSR#16-4.| 00002b30 13 1a 2a 4f 50 54 20 a4 61 64 72 28 31 33 2c 73 |..*OPT .adr(13,s| 00002b40 70 72 25 2b 28 31 39 32 3c 3c 31 30 29 2c 32 29 |pr%+(192<<10),2)| 00002b50 3a 3b 20 53 70 68 65 72 65 0d 13 24 0f 4c 44 52 |:; Sphere..$.LDR| 00002b60 20 52 30 2c 5b 52 33 5d 0d 13 2e 0d 54 53 54 20 | R0,[R3]....TST | 00002b70 52 30 2c 23 31 0d 13 38 18 42 4e 45 20 61 6c 72 |R0,#1..8.BNE alr| 00002b80 65 61 64 79 70 6c 6f 74 74 65 64 31 25 0d 13 42 |eadyplotted1%..B| 00002b90 0f 84 52 20 52 30 2c 52 30 2c 23 31 0d 13 4c 0f |..R R0,R0,#1..L.| 00002ba0 53 54 52 20 52 30 2c 5b 52 33 5d 0d 13 56 14 4c |STR R0,[R3]..V.L| 00002bb0 44 4d 49 42 20 52 33 2c 7b 52 30 2d 52 31 7d 0d |DMIB R3,{R0-R1}.| 00002bc0 13 60 12 42 4c 20 64 72 61 77 73 70 72 69 74 65 |.`.BL drawsprite| 00002bd0 25 0d 13 6a 15 2e 61 6c 72 65 61 64 79 70 6c 6f |%..j..alreadyplo| 00002be0 74 74 65 64 31 25 0d 13 74 0f 4c 44 52 20 52 30 |tted1%..t.LDR R0| 00002bf0 2c 5b 52 34 5d 0d 13 7e 0d 54 53 54 20 52 30 2c |,[R4]..~.TST R0,| 00002c00 23 31 0d 13 88 18 42 4e 45 20 61 6c 72 65 61 64 |#1....BNE alread| 00002c10 79 70 6c 6f 74 74 65 64 32 25 0d 13 92 0f 84 52 |yplotted2%.....R| 00002c20 20 52 30 2c 52 30 2c 23 31 0d 13 9c 0f 53 54 52 | R0,R0,#1....STR| 00002c30 20 52 30 2c 5b 52 34 5d 0d 13 a6 14 4c 44 4d 49 | R0,[R4]....LDMI| 00002c40 42 20 52 34 2c 7b 52 30 2d 52 31 7d 0d 13 b0 12 |B R4,{R0-R1}....| 00002c50 42 4c 20 64 72 61 77 73 70 72 69 74 65 25 0d 13 |BL drawsprite%..| 00002c60 ba 15 2e 61 6c 72 65 61 64 79 70 6c 6f 74 74 65 |...alreadyplotte| 00002c70 64 32 25 0d 13 c4 14 4c 44 4d 49 42 20 52 33 2c |d2%....LDMIB R3,| 00002c80 7b 52 30 2d 52 32 7d 0d 13 ce 14 4c 44 4d 49 42 |{R0-R2}....LDMIB| 00002c90 20 52 34 2c 7b 52 33 2d 52 35 7d 0d 13 d8 10 53 | R4,{R3-R5}....S| 00002ca0 55 42 20 52 30 2c 52 30 2c 52 33 0d 13 e2 10 53 |UB R0,R0,R3....S| 00002cb0 55 42 20 52 31 2c 52 31 2c 52 34 0d 13 ec 10 53 |UB R1,R1,R4....S| 00002cc0 55 42 20 52 32 2c 52 32 2c 52 35 0d 13 f6 10 42 |UB R2,R2,R5....B| 00002cd0 4c 20 64 72 61 77 74 75 62 65 25 0d 14 00 0f 42 |L drawtube%....B| 00002ce0 20 70 6c 6f 74 6c 6f 6f 70 25 0d 14 0a 05 3a 0d | plotloop%....:.| 00002cf0 14 14 12 2e 65 6e 64 70 6c 6f 74 73 68 61 70 65 |....endplotshape| 00002d00 25 0d 14 1e 17 41 44 52 20 52 30 2c 74 65 6d 70 |%....ADR R0,temp| 00002d10 73 74 6f 72 65 70 73 25 0d 14 28 15 4c 44 4d 49 |storeps%..(.LDMI| 00002d20 41 20 52 30 2c 7b 52 31 2d 52 31 34 7d 0d 14 32 |A R0,{R1-R14}..2| 00002d30 0e 4d 4f 56 20 50 43 2c 52 31 34 0d 14 3c 05 3a |.MOV PC,R14..<.:| 00002d40 0d 14 46 12 2e 74 65 6d 70 73 74 6f 72 65 72 6f |..F..tempstorero| 00002d50 74 25 0d 14 50 23 45 51 55 44 20 2d 31 3a 45 51 |t%..P#EQUD -1:EQ| 00002d60 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 |UD -1:EQUD -1:EQ| 00002d70 55 44 20 2d 31 0d 14 5a 23 45 51 55 44 20 2d 31 |UD -1..Z#EQUD -1| 00002d80 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 |:EQUD -1:EQUD -1| 00002d90 3a 45 51 55 44 20 2d 31 0d 14 64 23 45 51 55 44 |:EQUD -1..d#EQUD| 00002da0 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 | -1:EQUD -1:EQUD| 00002db0 20 2d 31 3a 45 51 55 44 20 2d 31 0d 14 6e 23 45 | -1:EQUD -1..n#E| 00002dc0 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 |QUD -1:EQUD -1:E| 00002dd0 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 0d 14 |QUD -1:EQUD -1..| 00002de0 78 05 3a 0d 14 82 0c 2e 72 6f 74 61 74 65 25 0d |x.:.....rotate%.| 00002df0 14 8c 11 3b 20 43 6f 72 72 75 70 74 73 20 52 30 |...; Corrupts R0| 00002e00 0d 14 96 18 41 44 52 20 52 30 2c 74 65 6d 70 73 |....ADR R0,temps| 00002e10 74 6f 72 65 72 6f 74 25 0d 14 a0 15 53 54 4d 49 |torerot%....STMI| 00002e20 41 20 52 30 2c 7b 52 31 2d 52 31 34 7d 0d 14 aa |A R0,{R1-R14}...| 00002e30 13 3b 20 54 68 65 20 72 6f 74 61 74 69 6f 6e 73 |.; The rotations| 00002e40 0d 14 b4 17 4f 50 54 20 a4 61 64 72 28 31 34 2c |....OPT .adr(14,| 00002e50 73 69 6e 25 2c 32 29 0d 14 be 38 4d 4f 56 20 52 |sin%,2)...8MOV R| 00002e60 30 2c 23 31 3c 3c 56 43 25 3a 4d 4f 56 20 52 31 |0,#1<<VC%:MOV R1| 00002e70 2c 23 30 3a 4d 4f 56 20 52 32 2c 23 30 3a 3b 20 |,#0:MOV R2,#0:; | 00002e80 49 64 65 6e 74 69 74 79 20 6d 61 74 72 69 78 0d |Identity matrix.| 00002e90 14 c8 26 4d 4f 56 20 52 33 2c 23 30 3a 4d 4f 56 |..&MOV R3,#0:MOV| 00002ea0 20 52 34 2c 23 31 3c 3c 56 43 25 3a 4d 4f 56 20 | R4,#1<<VC%:MOV | 00002eb0 52 35 2c 23 30 0d 14 d2 26 4d 4f 56 20 52 36 2c |R5,#0...&MOV R6,| 00002ec0 23 30 3a 4d 4f 56 20 52 37 2c 23 30 3a 4d 4f 56 |#0:MOV R7,#0:MOV| 00002ed0 20 52 38 2c 23 31 3c 3c 56 43 25 0d 14 dc 15 3b | R8,#1<<VC%....;| 00002ee0 20 58 2d 61 78 69 73 20 72 6f 74 61 74 69 6f 6e | X-axis rotation| 00002ef0 0d 14 e6 15 4c 44 52 20 52 31 32 2c 61 6e 67 6c |....LDR R12,angl| 00002f00 65 73 25 2b 30 0d 14 f0 12 80 20 52 31 32 2c 52 |es%+0..... R12,R| 00002f10 31 32 2c 23 32 35 35 0d 14 fa 19 41 44 44 20 52 |12,#255....ADD R| 00002f20 31 32 2c 52 31 34 2c 52 31 32 2c 41 53 4c 23 32 |12,R14,R12,ASL#2| 00002f30 0d 15 04 1c 4c 44 52 20 52 31 33 2c 5b 52 31 32 |....LDR R13,[R12| 00002f40 2c 23 63 6f 73 25 2d 73 69 6e 25 5d 0d 15 0e 11 |,#cos%-sin%]....| 00002f50 4c 44 52 20 52 31 32 2c 5b 52 31 32 5d 0d 15 18 |LDR R12,[R12]...| 00002f60 17 5d 3a e3 55 25 3d 30 b8 38 88 33 3a 5b 4f 50 |.]:.U%=0.8.3:[OP| 00002f70 54 20 54 25 0d 15 22 11 4d 4f 56 20 52 39 2c 28 |T T%..".MOV R9,(| 00002f80 55 25 2b 32 29 0d 15 2c 15 4d 55 4c 20 28 55 25 |U%+2)..,.MUL (U%| 00002f90 2b 32 29 2c 52 31 33 2c 52 39 0d 15 36 20 4d 4c |+2),R13,R9..6 ML| 00002fa0 41 20 28 55 25 2b 32 29 2c 52 31 32 2c 28 55 25 |A (U%+2),R12,(U%| 00002fb0 2b 31 29 2c 28 55 25 2b 32 29 0d 15 40 19 4d 55 |+1),(U%+2)..@.MU| 00002fc0 4c 20 28 55 25 2b 31 29 2c 52 31 33 2c 28 55 25 |L (U%+1),R13,(U%| 00002fd0 2b 31 29 0d 15 4a 11 4d 55 4c 20 52 39 2c 52 31 |+1)..J.MUL R9,R1| 00002fe0 32 2c 52 39 0d 15 54 18 53 55 42 20 28 55 25 2b |2,R9..T.SUB (U%+| 00002ff0 31 29 2c 28 55 25 2b 31 29 2c 52 39 0d 15 5e 1d |1),(U%+1),R9..^.| 00003000 4d 4f 56 20 28 55 25 2b 31 29 2c 28 55 25 2b 31 |MOV (U%+1),(U%+1| 00003010 29 2c 41 53 52 23 53 43 25 0d 15 68 1d 4d 4f 56 |),ASR#SC%..h.MOV| 00003020 20 28 55 25 2b 32 29 2c 28 55 25 2b 32 29 2c 41 | (U%+2),(U%+2),A| 00003030 53 52 23 53 43 25 0d 15 72 0f 5d 3a ed 3a 5b 4f |SR#SC%..r.]:.:[O| 00003040 50 54 20 54 25 0d 15 7c 15 3b 20 59 2d 61 78 69 |PT T%..|.; Y-axi| 00003050 73 20 72 6f 74 61 74 69 6f 6e 0d 15 86 15 4c 44 |s rotation....LD| 00003060 52 20 52 31 32 2c 61 6e 67 6c 65 73 25 2b 34 0d |R R12,angles%+4.| 00003070 15 90 12 80 20 52 31 32 2c 52 31 32 2c 23 32 35 |.... R12,R12,#25| 00003080 35 0d 15 9a 19 41 44 44 20 52 31 32 2c 52 31 34 |5....ADD R12,R14| 00003090 2c 52 31 32 2c 41 53 4c 23 32 0d 15 a4 1c 4c 44 |,R12,ASL#2....LD| 000030a0 52 20 52 31 33 2c 5b 52 31 32 2c 23 63 6f 73 25 |R R13,[R12,#cos%| 000030b0 2d 73 69 6e 25 5d 0d 15 ae 11 4c 44 52 20 52 31 |-sin%]....LDR R1| 000030c0 32 2c 5b 52 31 32 5d 0d 15 b8 17 5d 3a e3 55 25 |2,[R12]....]:.U%| 000030d0 3d 30 b8 38 88 33 3a 5b 4f 50 54 20 54 25 0d 15 |=0.8.3:[OPT T%..| 000030e0 c2 0d 4d 4f 56 20 52 39 2c 55 25 0d 15 cc 11 4d |..MOV R9,U%....M| 000030f0 55 4c 20 55 25 2c 52 31 33 2c 52 39 0d 15 d6 18 |UL U%,R13,R9....| 00003100 4d 4c 41 20 55 25 2c 52 31 32 2c 28 55 25 2b 32 |MLA U%,R12,(U%+2| 00003110 29 2c 55 25 0d 15 e0 19 4d 55 4c 20 28 55 25 2b |),U%....MUL (U%+| 00003120 32 29 2c 52 31 33 2c 28 55 25 2b 32 29 0d 15 ea |2),R13,(U%+2)...| 00003130 11 4d 55 4c 20 52 39 2c 52 31 32 2c 52 39 0d 15 |.MUL R9,R12,R9..| 00003140 f4 18 53 55 42 20 28 55 25 2b 32 29 2c 28 55 25 |..SUB (U%+2),(U%| 00003150 2b 32 29 2c 52 39 0d 15 fe 1d 4d 4f 56 20 28 55 |+2),R9....MOV (U| 00003160 25 2b 32 29 2c 28 55 25 2b 32 29 2c 41 53 52 23 |%+2),(U%+2),ASR#| 00003170 53 43 25 0d 16 08 15 4d 4f 56 20 55 25 2c 55 25 |SC%....MOV U%,U%| 00003180 2c 41 53 52 23 53 43 25 0d 16 12 0f 5d 3a ed 3a |,ASR#SC%....]:.:| 00003190 5b 4f 50 54 20 54 25 0d 16 1c 15 3b 20 5a 2d 61 |[OPT T%....; Z-a| 000031a0 78 69 73 20 72 6f 74 61 74 69 6f 6e 0d 16 26 15 |xis rotation..&.| 000031b0 4c 44 52 20 52 31 32 2c 61 6e 67 6c 65 73 25 2b |LDR R12,angles%+| 000031c0 38 0d 16 30 12 80 20 52 31 32 2c 52 31 32 2c 23 |8..0.. R12,R12,#| 000031d0 32 35 35 0d 16 3a 19 41 44 44 20 52 31 32 2c 52 |255..:.ADD R12,R| 000031e0 31 34 2c 52 31 32 2c 41 53 4c 23 32 0d 16 44 1c |14,R12,ASL#2..D.| 000031f0 4c 44 52 20 52 31 33 2c 5b 52 31 32 2c 23 63 6f |LDR R13,[R12,#co| 00003200 73 25 2d 73 69 6e 25 5d 0d 16 4e 11 4c 44 52 20 |s%-sin%]..N.LDR | 00003210 52 31 32 2c 5b 52 31 32 5d 0d 16 58 17 5d 3a e3 |R12,[R12]..X.]:.| 00003220 55 25 3d 30 b8 38 88 33 3a 5b 4f 50 54 20 54 25 |U%=0.8.3:[OPT T%| 00003230 0d 16 62 11 4d 4f 56 20 52 39 2c 28 55 25 2b 31 |..b.MOV R9,(U%+1| 00003240 29 0d 16 6c 15 4d 55 4c 20 28 55 25 2b 31 29 2c |)..l.MUL (U%+1),| 00003250 52 31 33 2c 52 39 0d 16 76 1c 4d 4c 41 20 28 55 |R13,R9..v.MLA (U| 00003260 25 2b 31 29 2c 52 31 32 2c 55 25 2c 28 55 25 2b |%+1),R12,U%,(U%+| 00003270 31 29 0d 16 80 11 4d 55 4c 20 55 25 2c 52 31 33 |1)....MUL U%,R13| 00003280 2c 55 25 0d 16 8a 11 4d 55 4c 20 52 39 2c 52 31 |,U%....MUL R9,R1| 00003290 32 2c 52 39 0d 16 94 10 53 55 42 20 55 25 2c 55 |2,R9....SUB U%,U| 000032a0 25 2c 52 39 0d 16 9e 15 4d 4f 56 20 55 25 2c 55 |%,R9....MOV U%,U| 000032b0 25 2c 41 53 52 23 53 43 25 0d 16 a8 1d 4d 4f 56 |%,ASR#SC%....MOV| 000032c0 20 28 55 25 2b 31 29 2c 28 55 25 2b 31 29 2c 41 | (U%+1),(U%+1),A| 000032d0 53 52 23 53 43 25 0d 16 b2 0f 5d 3a ed 3a 5b 4f |SR#SC%....]:.:[O| 000032e0 50 54 20 54 25 0d 16 bc 18 4f 50 54 20 a4 61 64 |PT T%....OPT .ad| 000032f0 72 28 31 32 2c 76 69 65 77 25 2c 32 29 0d 16 c6 |r(12,view%,2)...| 00003300 15 53 54 4d 49 41 20 52 31 32 2c 7b 52 30 2d 52 |.STMIA R12,{R0-R| 00003310 38 7d 0d 16 d0 18 41 44 52 20 52 30 2c 74 65 6d |8}....ADR R0,tem| 00003320 70 73 74 6f 72 65 72 6f 74 25 0d 16 da 15 4c 44 |pstorerot%....LD| 00003330 4d 49 41 20 52 30 2c 7b 52 31 2d 52 31 34 7d 0d |MIA R0,{R1-R14}.| 00003340 16 e4 0e 4d 4f 56 20 50 43 2c 52 31 34 0d 16 ee |...MOV PC,R14...| 00003350 05 3a 0d 16 f8 13 2e 74 65 6d 70 73 74 6f 72 65 |.:.....tempstore| 00003360 61 6e 69 6d 25 0d 17 02 23 45 51 55 44 20 2d 31 |anim%...#EQUD -1| 00003370 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 |:EQUD -1:EQUD -1| 00003380 3a 45 51 55 44 20 2d 31 0d 17 0c 23 45 51 55 44 |:EQUD -1...#EQUD| 00003390 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 | -1:EQUD -1:EQUD| 000033a0 20 2d 31 3a 45 51 55 44 20 2d 31 0d 17 16 23 45 | -1:EQUD -1...#E| 000033b0 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 |QUD -1:EQUD -1:E| 000033c0 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 0d 17 |QUD -1:EQUD -1..| 000033d0 20 23 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d | #EQUD -1:EQUD -| 000033e0 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d |1:EQUD -1:EQUD -| 000033f0 31 0d 17 2a 05 3a 0d 17 34 13 2e 72 61 6e 64 6f |1..*.:..4..rando| 00003400 6d 25 3a 45 51 55 44 20 31 0d 17 3e 13 2e 63 6f |m%:EQUD 1..>..co| 00003410 6c 6e 6f 25 3a 45 51 55 44 20 31 35 0d 17 48 05 |lno%:EQUD 15..H.| 00003420 3a 0d 17 52 0c 2e 61 6e 67 6c 65 73 25 0d 17 5c |:..R..angles%..\| 00003430 18 45 51 55 44 20 30 3a 45 51 55 44 20 30 3a 45 |.EQUD 0:EQUD 0:E| 00003440 51 55 44 20 30 0d 17 66 18 45 51 55 44 20 31 3a |QUD 0..f.EQUD 1:| 00003450 45 51 55 44 20 32 3a 45 51 55 44 20 33 0d 17 70 |EQUD 2:EQUD 3..p| 00003460 0d 2e 63 6f 6c 6f 75 72 73 25 0d 17 7a 1a 45 51 |..colours%..z.EQ| 00003470 55 44 20 30 3a 45 51 55 44 20 38 35 3a 45 51 55 |UD 0:EQUD 85:EQU| 00003480 44 20 38 35 0d 17 84 19 45 51 55 44 20 38 35 3a |D 85....EQUD 85:| 00003490 45 51 55 44 20 30 3a 45 51 55 44 20 30 0d 17 8e |EQUD 0:EQUD 0...| 000034a0 18 45 51 55 44 20 30 3a 45 51 55 44 20 30 3a 45 |.EQUD 0:EQUD 0:E| 000034b0 51 55 44 20 30 0d 17 98 18 45 51 55 44 20 30 3a |QUD 0....EQUD 0:| 000034c0 45 51 55 44 20 30 3a 45 51 55 44 20 30 0d 17 a2 |EQUD 0:EQUD 0...| 000034d0 05 3a 0d 17 ac 0f 2e 61 6e 69 6d 61 74 69 6f 6e |.:.....animation| 000034e0 25 0d 17 b6 11 3b 20 43 6f 72 72 75 70 74 73 20 |%....; Corrupts | 000034f0 52 30 0d 17 c0 19 41 44 52 20 52 30 2c 74 65 6d |R0....ADR R0,tem| 00003500 70 73 74 6f 72 65 61 6e 69 6d 25 0d 17 ca 15 53 |pstoreanim%....S| 00003510 54 4d 49 41 20 52 30 2c 7b 52 31 2d 52 31 34 7d |TMIA R0,{R1-R14}| 00003520 0d 17 d4 13 4c 44 52 20 52 31 34 2c 72 61 6e 64 |....LDR R14,rand| 00003530 6f 6d 25 0d 17 de 16 3b 20 49 6e 63 72 65 6d 65 |om%....; Increme| 00003540 6e 74 20 61 6e 67 6c 65 73 0d 17 e8 13 41 44 52 |nt angles....ADR| 00003550 20 52 31 33 2c 61 6e 67 6c 65 73 25 0d 17 f2 15 | R13,angles%....| 00003560 4c 44 4d 49 41 20 52 31 33 2c 7b 52 30 2d 52 35 |LDMIA R13,{R0-R5| 00003570 7d 0d 17 fc 19 41 44 44 20 52 31 34 2c 52 31 34 |}....ADD R14,R14| 00003580 2c 52 31 34 2c 41 53 4c 23 38 0d 18 06 16 54 53 |,R14,ASL#8....TS| 00003590 54 20 52 31 34 2c 23 26 46 46 30 30 30 30 30 30 |T R14,#&FF000000| 000035a0 0d 18 10 18 42 4e 45 20 64 6f 6e 74 63 68 61 6e |....BNE dontchan| 000035b0 67 65 73 70 65 65 64 25 0d 18 1a 19 41 44 44 20 |gespeed%....ADD | 000035c0 52 31 34 2c 52 31 34 2c 52 31 34 2c 41 53 4c 23 |R14,R14,R14,ASL#| 000035d0 38 0d 18 24 17 4d 4f 56 20 52 33 2c 52 31 34 2c |8..$.MOV R3,R14,| 000035e0 41 53 52 23 33 31 2d 31 0d 18 2e 19 41 44 44 20 |ASR#31-1....ADD | 000035f0 52 31 34 2c 52 31 34 2c 52 31 34 2c 41 53 4c 23 |R14,R14,R14,ASL#| 00003600 38 0d 18 38 17 4d 4f 56 20 52 34 2c 52 31 34 2c |8..8.MOV R4,R14,| 00003610 41 53 52 23 33 31 2d 31 0d 18 42 19 41 44 44 20 |ASR#31-1..B.ADD | 00003620 52 31 34 2c 52 31 34 2c 52 31 34 2c 41 53 4c 23 |R14,R14,R14,ASL#| 00003630 38 0d 18 4c 17 4d 4f 56 20 52 35 2c 52 31 34 2c |8..L.MOV R5,R14,| 00003640 41 53 52 23 33 31 2d 31 0d 18 56 15 2e 64 6f 6e |ASR#31-1..V..don| 00003650 74 63 68 61 6e 67 65 73 70 65 65 64 25 0d 18 60 |tchangespeed%..`| 00003660 10 41 44 44 20 52 30 2c 52 30 2c 52 33 0d 18 6a |.ADD R0,R0,R3..j| 00003670 10 41 44 44 20 52 31 2c 52 31 2c 52 34 0d 18 74 |.ADD R1,R1,R4..t| 00003680 10 41 44 44 20 52 32 2c 52 32 2c 52 35 0d 18 7e |.ADD R2,R2,R5..~| 00003690 15 53 54 4d 49 41 20 52 31 33 2c 7b 52 30 2d 52 |.STMIA R13,{R0-R| 000036a0 35 7d 0d 18 88 17 3b 20 49 6e 63 72 65 6d 65 6e |5}....; Incremen| 000036b0 74 20 63 6f 6c 6f 75 72 73 0d 18 92 14 41 44 52 |t colours....ADR| 000036c0 20 52 31 33 2c 63 6f 6c 6f 75 72 73 25 0d 18 9c | R13,colours%...| 000036d0 16 4c 44 4d 49 41 20 52 31 33 2c 7b 52 30 2d 52 |.LDMIA R13,{R0-R| 000036e0 31 31 7d 0d 18 a6 19 41 44 44 20 52 31 34 2c 52 |11}....ADD R14,R| 000036f0 31 34 2c 52 31 34 2c 41 53 4c 23 37 0d 18 b0 16 |14,R14,ASL#7....| 00003700 54 53 54 20 52 31 34 2c 23 26 46 45 30 30 30 30 |TST R14,#&FE0000| 00003710 30 30 0d 18 ba 19 42 4e 45 20 64 6f 6e 74 63 68 |00....BNE dontch| 00003720 61 6e 67 65 63 6f 6c 6f 75 72 31 0d 18 c4 12 54 |angecolour1....T| 00003730 53 54 20 52 31 34 2c 23 31 3c 3c 32 34 0d 18 ce |ST R14,#1<<24...| 00003740 0c ec 51 20 52 30 2c 23 30 0d 18 d8 10 4d 4f 56 |..Q R0,#0....MOV| 00003750 4e 45 20 52 30 2c 23 38 35 0d 18 e2 12 54 53 54 |NE R0,#85....TST| 00003760 20 52 31 34 2c 23 31 3c 3c 32 33 0d 18 ec 0c ec | R14,#1<<23.....| 00003770 51 20 52 31 2c 23 30 0d 18 f6 10 4d 4f 56 4e 45 |Q R1,#0....MOVNE| 00003780 20 52 31 2c 23 38 35 0d 19 00 12 54 53 54 20 52 | R1,#85....TST R| 00003790 31 34 2c 23 31 3c 3c 32 32 0d 19 0a 0c ec 51 20 |14,#1<<22.....Q | 000037a0 52 32 2c 23 30 0d 19 14 10 4d 4f 56 4e 45 20 52 |R2,#0....MOVNE R| 000037b0 32 2c 23 38 35 0d 19 1e 16 2e 64 6f 6e 74 63 68 |2,#85.....dontch| 000037c0 61 6e 67 65 63 6f 6c 6f 75 72 31 0d 19 28 19 41 |angecolour1..(.A| 000037d0 44 44 20 52 31 34 2c 52 31 34 2c 52 31 34 2c 41 |DD R14,R14,R14,A| 000037e0 53 4c 23 37 0d 19 32 16 54 53 54 20 52 31 34 2c |SL#7..2.TST R14,| 000037f0 23 26 46 45 30 30 30 30 30 30 0d 19 3c 19 42 4e |#&FE000000..<.BN| 00003800 45 20 64 6f 6e 74 63 68 61 6e 67 65 63 6f 6c 6f |E dontchangecolo| 00003810 75 72 32 0d 19 46 12 54 53 54 20 52 31 34 2c 23 |ur2..F.TST R14,#| 00003820 31 3c 3c 32 34 0d 19 50 0c ec 51 20 52 33 2c 23 |1<<24..P..Q R3,#| 00003830 30 0d 19 5a 10 4d 4f 56 4e 45 20 52 33 2c 23 38 |0..Z.MOVNE R3,#8| 00003840 35 0d 19 64 12 54 53 54 20 52 31 34 2c 23 31 3c |5..d.TST R14,#1<| 00003850 3c 32 33 0d 19 6e 0c ec 51 20 52 34 2c 23 30 0d |<23..n..Q R4,#0.| 00003860 19 78 10 4d 4f 56 4e 45 20 52 34 2c 23 38 35 0d |.x.MOVNE R4,#85.| 00003870 19 82 12 54 53 54 20 52 31 34 2c 23 31 3c 3c 32 |...TST R14,#1<<2| 00003880 32 0d 19 8c 0c ec 51 20 52 35 2c 23 30 0d 19 96 |2.....Q R5,#0...| 00003890 10 4d 4f 56 4e 45 20 52 35 2c 23 38 35 0d 19 a0 |.MOVNE R5,#85...| 000038a0 16 2e 64 6f 6e 74 63 68 61 6e 67 65 63 6f 6c 6f |..dontchangecolo| 000038b0 75 72 32 0d 19 aa 16 5d 3a e3 55 25 3d 36 b8 31 |ur2....]:.U%=6.1| 000038c0 31 3a 5b 4f 50 54 20 54 25 0d 19 b4 11 43 4d 50 |1:[OPT T%....CMP| 000038d0 20 55 25 2c 28 55 25 2d 36 29 0d 19 be 12 41 44 | U%,(U%-6)....AD| 000038e0 44 4c 54 20 55 25 2c 55 25 2c 23 31 0d 19 c8 12 |DLT U%,U%,#1....| 000038f0 53 55 42 47 54 20 55 25 2c 55 25 2c 23 31 0d 19 |SUBGT U%,U%,#1..| 00003900 d2 0f 5d 3a ed 3a 5b 4f 50 54 20 54 25 0d 19 dc |..]:.:[OPT T%...| 00003910 16 53 54 4d 49 41 20 52 31 33 2c 7b 52 30 2d 52 |.STMIA R13,{R0-R| 00003920 31 31 7d 0d 19 e6 16 3b 20 52 65 64 65 66 69 6e |11}....; Redefin| 00003930 65 20 63 6f 6c 6f 75 72 73 0d 19 f0 12 4c 44 52 |e colours....LDR| 00003940 20 52 31 32 2c 63 6f 6c 6e 6f 25 0d 19 fa 12 41 | R12,colno%....A| 00003950 44 44 20 52 31 32 2c 52 31 32 2c 23 35 0d 1a 04 |DD R12,R12,#5...| 00003960 11 80 20 52 31 32 2c 52 31 32 2c 23 31 35 0d 1a |.. R12,R12,#15..| 00003970 0e 12 53 54 52 20 52 31 32 2c 63 6f 6c 6e 6f 25 |..STR R12,colno%| 00003980 0d 1a 18 0d 2e 63 6f 6c 6c 6f 6f 70 25 0d 1a 22 |.....colloop%.."| 00003990 13 53 57 49 20 26 31 31 33 3a 3b 20 ef 31 39 2c |.SWI &113:; .19,| 000039a0 0d 1a 2c 0e 4d 4f 56 20 52 30 2c 52 31 32 0d 1a |..,.MOV R0,R12..| 000039b0 36 1d 53 57 49 20 22 4f 53 5f 57 72 69 74 65 43 |6.SWI "OS_WriteC| 000039c0 22 3a 3b 20 63 6f 6c 6f 75 72 2c 0d 1a 40 21 53 |":; colour,..@!S| 000039d0 57 49 20 26 31 31 30 3a 3b 20 20 20 20 20 20 20 |WI &110:; | 000039e0 20 20 20 20 20 20 20 20 20 31 36 2c 0d 1a 4a 0f | 16,..J.| 000039f0 80 20 52 31 2c 52 31 32 2c 23 33 0d 1a 54 14 4d |. R1,R12,#3..T.M| 00003a00 4f 56 20 52 32 2c 52 31 32 2c 4c 53 52 23 32 0d |OV R2,R12,LSR#2.| 00003a10 1a 5e 10 4d 55 4c 20 52 30 2c 52 31 2c 52 36 0d |.^.MUL R0,R1,R6.| 00003a20 1a 68 13 4d 4c 41 20 52 30 2c 52 32 2c 52 39 2c |.h.MLA R0,R2,R9,| 00003a30 52 30 0d 1a 72 0f 43 4d 50 20 52 30 2c 23 32 35 |R0..r.CMP R0,#25| 00003a40 35 0d 1a 7c 11 4d 4f 56 47 54 20 52 30 2c 23 32 |5..|.MOVGT R0,#2| 00003a50 35 35 0d 1a 86 26 53 57 49 20 22 4f 53 5f 57 72 |55...&SWI "OS_Wr| 00003a60 69 74 65 43 22 3a 3b 20 20 20 20 20 20 20 20 20 |iteC":; | 00003a70 20 20 20 20 52 65 64 2c 0d 1a 90 10 4d 55 4c 20 | Red,....MUL | 00003a80 52 30 2c 52 31 2c 52 37 0d 1a 9a 14 4d 4c 41 20 |R0,R1,R7....MLA | 00003a90 52 30 2c 52 32 2c 52 31 30 2c 52 30 0d 1a a4 0f |R0,R2,R10,R0....| 00003aa0 43 4d 50 20 52 30 2c 23 32 35 35 0d 1a ae 11 4d |CMP R0,#255....M| 00003ab0 4f 56 47 54 20 52 30 2c 23 32 35 35 0d 1a b8 2d |OVGT R0,#255...-| 00003ac0 53 57 49 20 22 4f 53 5f 57 72 69 74 65 43 22 3a |SWI "OS_WriteC":| 00003ad0 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |; | 00003ae0 20 20 20 47 72 65 65 6e 2c 0d 1a c2 10 4d 55 4c | Green,....MUL| 00003af0 20 52 30 2c 52 31 2c 52 38 0d 1a cc 14 4d 4c 41 | R0,R1,R8....MLA| 00003b00 20 52 30 2c 52 32 2c 52 31 31 2c 52 30 0d 1a d6 | R0,R2,R11,R0...| 00003b10 0f 43 4d 50 20 52 30 2c 23 32 35 35 0d 1a e0 11 |.CMP R0,#255....| 00003b20 4d 4f 56 47 54 20 52 30 2c 23 32 35 35 0d 1a ea |MOVGT R0,#255...| 00003b30 32 53 57 49 20 22 4f 53 5f 57 72 69 74 65 43 22 |2SWI "OS_WriteC"| 00003b40 3a 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |:; | 00003b50 20 20 20 20 20 20 20 20 20 20 20 42 6c 75 65 0d | Blue.| 00003b60 1a f4 12 41 44 44 20 52 31 34 2c 52 31 34 2c 23 |...ADD R14,R14,#| 00003b70 31 0d 1a fe 13 53 54 52 20 52 31 34 2c 72 61 6e |1....STR R14,ran| 00003b80 64 6f 6d 25 0d 1b 08 19 41 44 52 20 52 30 2c 74 |dom%....ADR R0,t| 00003b90 65 6d 70 73 74 6f 72 65 61 6e 69 6d 25 0d 1b 12 |empstoreanim%...| 00003ba0 15 4c 44 4d 49 41 20 52 30 2c 7b 52 31 2d 52 31 |.LDMIA R0,{R1-R1| 00003bb0 34 7d 0d 1b 1c 0e 4d 4f 56 20 50 43 2c 52 31 34 |4}....MOV PC,R14| 00003bc0 0d 1b 26 05 3a 0d 1b 30 11 2e 74 65 6d 70 73 74 |..&.:..0..tempst| 00003bd0 6f 72 65 64 62 25 0d 1b 3a 23 45 51 55 44 20 2d |oredb%..:#EQUD -| 00003be0 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d |1:EQUD -1:EQUD -| 00003bf0 31 3a 45 51 55 44 20 2d 31 0d 1b 44 23 45 51 55 |1:EQUD -1..D#EQU| 00003c00 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 |D -1:EQUD -1:EQU| 00003c10 44 20 2d 31 3a 45 51 55 44 20 2d 31 0d 1b 4e 23 |D -1:EQUD -1..N#| 00003c20 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 3a |EQUD -1:EQUD -1:| 00003c30 45 51 55 44 20 2d 31 3a 45 51 55 44 20 2d 31 0d |EQUD -1:EQUD -1.| 00003c40 1b 58 23 45 51 55 44 20 2d 31 3a 45 51 55 44 20 |.X#EQUD -1:EQUD | 00003c50 2d 31 3a 45 51 55 44 20 2d 31 3a 45 51 55 44 20 |-1:EQUD -1:EQUD | 00003c60 2d 31 0d 1b 62 05 3a 0d 1b 6c 0e 2e 64 72 61 77 |-1..b.:..l..draw| 00003c70 62 61 63 6b 25 0d 1b 76 11 3b 20 43 6f 72 72 75 |back%..v.; Corru| 00003c80 70 74 73 20 52 30 0d 1b 80 17 41 44 52 20 52 30 |pts R0....ADR R0| 00003c90 2c 74 65 6d 70 73 74 6f 72 65 64 62 25 0d 1b 8a |,tempstoredb%...| 00003ca0 15 53 54 4d 49 41 20 52 30 2c 7b 52 31 2d 52 31 |.STMIA R0,{R1-R1| 00003cb0 34 7d 0d 1b 94 14 4c 44 52 20 52 31 34 2c 73 63 |4}....LDR R14,sc| 00003cc0 72 61 64 64 72 25 0d 1b 9e 16 41 44 44 20 52 31 |raddr%....ADD R1| 00003cd0 34 2c 52 31 34 2c 23 33 32 3e 3e 31 0d 1b a8 20 |4,R14,#32>>1... | 00003ce0 4f 50 54 20 a4 61 64 72 28 31 33 2c 62 61 63 6b |OPT .adr(13,back| 00003cf0 25 2b 28 33 32 3e 3e 31 29 2c 33 29 0d 1b b2 10 |%+(32>>1),3)....| 00003d00 4d 4f 56 20 52 31 32 2c 23 32 35 36 0d 1b bc 0b |MOV R12,#256....| 00003d10 2e 79 6c 6f 6f 70 25 0d 1b c6 1b 5d 3a e3 55 25 |.yloop%....]:.U%| 00003d20 3d 30 b8 32 35 35 88 38 2a 38 3a 5b 4f 50 54 20 |=0.255.8*8:[OPT | 00003d30 54 25 0d 1b d0 16 4c 44 4d 49 41 20 52 31 33 21 |T%....LDMIA R13!| 00003d40 2c 7b 52 30 2d 52 37 7d 0d 1b da 16 53 54 4d 49 |,{R0-R7}....STMI| 00003d50 41 20 52 31 34 21 2c 7b 52 30 2d 52 37 7d 0d 1b |A R14!,{R0-R7}..| 00003d60 e4 0f 5d 3a ed 3a 5b 4f 50 54 20 54 25 0d 1b ee |..]:.:[OPT T%...| 00003d70 1b 41 44 44 20 52 31 33 2c 52 31 33 2c 23 33 32 |.ADD R13,R13,#32| 00003d80 30 2d 32 35 36 3e 3e 31 0d 1b f8 1b 41 44 44 20 |0-256>>1....ADD | 00003d90 52 31 34 2c 52 31 34 2c 23 33 32 30 2d 32 35 36 |R14,R14,#320-256| 00003da0 3e 3e 31 0d 1c 02 13 53 55 42 53 20 52 31 32 2c |>>1....SUBS R12,| 00003db0 52 31 32 2c 23 31 0d 1c 0c 0e 42 47 54 20 79 6c |R12,#1....BGT yl| 00003dc0 6f 6f 70 25 0d 1c 16 17 41 44 52 20 52 30 2c 74 |oop%....ADR R0,t| 00003dd0 65 6d 70 73 74 6f 72 65 64 62 25 0d 1c 20 15 4c |empstoredb%.. .L| 00003de0 44 4d 49 41 20 52 30 2c 7b 52 31 2d 52 31 34 7d |DMIA R0,{R1-R14}| 00003df0 0d 1c 2a 0e 4d 4f 56 20 50 43 2c 52 31 34 0d 1c |..*.MOV PC,R14..| 00003e00 34 05 3a 0d 1c 3e 30 5d 3a e7 50 25 3e 65 6e 64 |4.:..>0]:.P%>end| 00003e10 63 6f 64 65 25 8c 85 32 35 35 2c 22 4e 6f 74 20 |code%..255,"Not | 00003e20 65 6e 6f 75 67 68 20 63 6f 64 65 20 6d 65 6d 6f |enough code memo| 00003e30 72 79 22 0d 1c 48 05 ed 0d 1c 52 05 e1 0d ff |ry"..H....R....| 00003e3f