Home » Archimedes archive » Acorn User » AU 1996-12 B.adf » Regulars_2 » StarInfo/Turnbull/WibbleTri

StarInfo/Turnbull/WibbleTri

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 1996-12 B.adf » Regulars_2
Filename: StarInfo/Turnbull/WibbleTri
Read OK:
File size: 1BE0 bytes
Load address: 0000
Exec address: 0000
File contents
   10MODE13:MODE9:OFF
   20FORT%=0TO4:COLOURT%,255*T%/4,255*T%/4,255*T%/4:NEXT
   30PROCconstants
   40DIMspace%spacelen%:P%=space%
   50code%=P%:P%+=codelen%
   60grid%=P%:P%+=16*width%*height%
   70PROCassemble
   80PROCsetup
   90*POINTER 1
  100MOUSERECTANGLE0,1024-32*height%,32*width%-1,32*height%-1
  110REPEAT
  120REPEAT
  130CALLframe%
  140MOUSEX1%,Y1%,Z%
  150IFINKEY(-99)THEN*ScreenSave TYU
  160UNTILZ%>0
  170A%=grid%+16*((X1%>>5)+width%*(1023-Y1%>>5))
  180P%=!A%>>16:Q%=A%!8>>16
  190REPEAT
  200CALLframe%
  210MOUSEX%,Y%,Z%
  220!A%=P%+(X1%-X%<<16-5)/width%<<16:A%!4=0
  230A%!8=Q%+(Y%-Y1%<<16-5)/height%<<16:A%!12=0
  240UNTILZ%=0
  250UNTIL0
  260END
  270:
  280:
  290DEFPROCconstants
  300spacelen%=&80000
  310codelen%=&4000
  320PRINT"Please choose:"''"1 ... Full screen"'"2 ... 1/2 screen"'"3 ... 1/5 screen"
  330REPEAT:A$=GET$:UNTILA$>="1"ANDA$<="3"
  340CASEA$OF
  350WHEN"1":width%=40:height%=32
  360WHEN"2":width%=24:height%=24
  370WHEN"3":width%=16:height%=16
  380ENDCASE
  390CLS
  400KK%=6:FF%=8
  410ENDPROC
  420:
  430DEFPROCsetup
  440DIMW%(width%-1),H%(height%-1)
  450FORX%=0TOwidth%-1:W%(X%)=(1<<16)*X%/width%<<16:NEXT
  460FORY%=0TOheight%-1:H%(Y%)=(1<<16)*Y%/height%<<16:NEXT
  470U%=grid%:FORY%=0TOheight%-1:FORX%=0TOwidth%-1
  480!U%=W%(X%):U%!4=H%(Y%)>>>7:U%!8=H%(Y%):U%!12=W%(X%)>>>7
  490U%+=16:NEXT,
  500ENDPROC
  510:
  520REM ************************************************************************
  530:
  540DEFPROCmode(X%,Y%,C%)
  550DIMJ%64:P%=J%:[OPT 2
  560EQUD 1:EQUD X%:EQUD Y%:EQUD C%:EQUD -1
  570]:IFC%=3THEN[OPT 2:EQUD 3:EQUD 255:]
  580[OPT 2:EQUD -1:]:MODEJ%
  590ENDPROC
  600:
  610DEFFNadr(R%,A%,I%)
  620IF(P%AND3)<>0THENPRINT"Code isn't word aligned!":END
  630IF(T%AND2)=0THENP%+=I%<<2:=T%
  640LOCALN%,O%,H%,U%:H%=A%-(P%+8):N%=0:O%=15
  650FORU%=1TOI%:IFH%=0THEN
  660[OPT T%:MOV R%,O%:]
  670ELSEWHILE(H%AND3)=0:H%=H%>>2:N%+=2:ENDWHILE
  680IF(H%AND256)=0THEN
  690[OPT T%:ADD R%,O%,#(H%AND255)<<N%:]:H%-=H%AND255
  700ELSE[OPT T%:SUB R%,O%,#(256-H%AND255)<<N%:]:H%+=256-H%AND255
  710ENDIF
  720ENDIF:O%=R%:NEXT
  730IFH%<>0THENPRINT"Could not ADR to &";~A%;" in ";I%;" instructions (R%=";R%;")":END
  740=T%
  750:
  760DEFFNmakej(J%,N%,dummy%)
  770FORU%=0TON%-1:[OPT T%
  780EQUD dummy%-J%
  790]:NEXT:=T%
  800:
  810DEFFNregisterj(J%,N%)
  820IFP%<J%THENERROR255,"j routines must come after j table (J%=&"+STR$~J%+")"
  830J%!(N%<<2)=P%-J%
  840=T%
  850:
  860REM Does R=S*C+O
  870REM Copes with R=O
  880REM Takes registers R, S and O and constant C
  890:
  900DEFFNmla(R%,S%,C%,O%)
  910IFC%=0THEN[OPT T%:MOV R%,O%:]
  920LOCALN%
  930N%=0:WHILEC%<>0
  940WHILE(C%AND1)=0:N%+=1:C%=C%>>1:ENDWHILE
  950IF(C%AND2)=0THEN
  960[OPT T%:ADD R%,O%,S%,ASL#N%:]:C%-=1
  970ELSE[OPT T%:SUB R%,O%,S%,ASL#N%:]:C%+=1
  980ENDIF:O%=R%:ENDWHILE
  990=T%
 1000:
 1010REM Does R+=[(N<<F) div D]*C
 1020REM Also N=(N<<F) mod D
 1030REM M is maximum expected value of (N<<F) div D
 1040REM Copes with (N<<F) bigger than 2^32
 1050REM N and D are unsigned
 1060REM Takes registers R, N, D and constants C, F and M
 1070:
 1080DEFFNdiva(R%,N%,F%,D%,C%,M%)
 1090LOCALU%
 1100M%=1+INT(LN(M%)/LN(2))
 1110IFM%>F%+1THEN
 1120FORU%=M%-1TOF%+1STEP-1:[OPT T%
 1130CMP D%,N%,ASR#U%-F%
 1140SUBLE N%,N%,D%,ASL#U%-F%
 1150ADDLE R%,R%,#C%<<U%
 1160]:NEXT
 1170ENDIF:IFM%>F%THEN
 1180[OPT T%
 1190CMP N%,D%
 1200SUBGE N%,N%,D%
 1210ADDGE R%,R%,#C%<<F%
 1220]
 1230ENDIF:IFF%>0THEN
 1240FORU%=F%-1TO0STEP-1:[OPT T%
 1250RSBS N%,D%,N%,ASL#1
 1260ADDLT N%,N%,D%
 1270ADDGE R%,R%,#C%<<U%
 1280]:NEXT
 1290ENDIF:=T%
 1300:
 1310REM ************************************************************************
 1320:
 1330DEFPROCassemble
 1340FORT%=0TO2STEP2:P%=code%
 1350[OPT T%
 1360:
 1370.vduvars%:EQUD 148:EQUD -1
 1380.scraddr%:EQUD -1
 1390:
 1400.bank%:EQUD 1
 1410:
 1420.lasttime%:EQUD -1
 1430:
 1440.frame%
 1450STMFD R13!,{R0-R12,R14}
 1460LDR R1,bank%
 1470CMP R1,#1
 1480MOVEQ R1,#2
 1490MOVNE R1,#1
 1500STR R1,bank%
 1510MOV R0,#112
 1520SWI "OS_Byte"
 1530ADR R0,vduvars%
 1540ADR R1,scraddr%
 1550SWI "OS_ReadVduVariables"
 1560MOV R0,#19
 1570SWI "OS_Byte"
 1580SWI "OS_ReadMonotonicTime"
 1590MOV R0,R0,ASR#1
 1600LDR R1,lasttime%
 1610STR R0,lasttime%
 1620SUB R0,R0,R1
 1630CMP R0,#10
 1640MOVHI R0,#10
 1650.timeloop%
 1660BL forces%
 1670BL move%
 1680SUBS R0,R0,#1
 1690BGT timeloop%
 1700BL plot%
 1710LDR R1,bank%
 1720MOV R0,#113
 1730SWI "OS_Byte"
 1740LDMFD R13!,{R0-R12,PC}^
 1750:
 1760.forces%
 1770STMFD R13!,{R0-R12,R14}
 1780OPT FNadr(12,grid%,2)
 1790ADD R11,R12,#16*width%*height%
 1800SUB R11,R11,#16*width%
 1810MOV R8,#height%
 1820.yloop%
 1830ADD R10,R12,#16*width%
 1840SUB R10,R10,#16
 1850SUB R8,R8,#width%<<16
 1860.xloop%
 1870LDMIA R12,{R0-R1,R2-R3}
 1880LDMIA R11,{R4-R5,R6-R7}
 1890SUB R9,R4,R0
 1900ADD R1,R1,R9,ASR#KK%
 1910SUB R5,R5,R9,ASR#KK%
 1920SUB R9,R6,R2
 1930ADD R3,R3,R9,ASR#KK%
 1940SUB R7,R7,R9,ASR#KK%
 1950STMIA R11!,{R4-R5,R6-R7}
 1960LDMIA R10,{R4-R5,R6-R7}
 1970SUB R9,R4,R0
 1980ADD R1,R1,R9,ASR#KK%
 1990SUB R5,R5,R9,ASR#KK%
 2000SUB R9,R6,R2
 2010ADD R3,R3,R9,ASR#KK%
 2020SUB R7,R7,R9,ASR#KK%
 2030STMIA R10,{R4-R5,R6-R7}
 2040MOV R10,R12
 2050STMIA R12!,{R0-R1,R2-R3}
 2060ADDS R8,R8,#1<<16
 2070BLE xloop%
 2080SUB R11,R12,#16*width%
 2090SUBS R8,R8,#1
 2100BGT yloop%
 2110LDMFD R13!,{R0-R12,PC}^
 2120:
 2130.move%
 2140STMFD R13!,{R0-R12,R14}
 2150OPT FNadr(12,grid%,2)
 2160MOV R8,#width%*height%
 2170.loop%
 2180LDMIA R12,{R0-R1,R2-R3,R4-R5,R6-R7}
 2190SUBS R1,R1,R1,ASR#FF%
 2200SUBGT R1,R1,#1
 2210ADD R0,R0,R1
 2220SUBS R3,R3,R3,ASR#FF%
 2230SUBGT R3,R3,#1
 2240ADD R2,R2,R3
 2250SUBS R5,R5,R5,ASR#FF%
 2260SUBGT R5,R5,#1
 2270ADD R4,R4,R5
 2280SUBS R7,R7,R7,ASR#FF%
 2290SUBGT R7,R7,#1
 2300ADD R6,R6,R7
 2310STMIA R12!,{R0-R1,R2-R3,R4-R5,R6-R7}
 2320SUBS R8,R8,#2
 2330BGT loop%
 2340LDMFD R13!,{R0-R12,PC}^
 2350:
 2360.plot%
 2370STMFD R13!,{R0-R12,R14}
 2380LDR R14,scraddr%
 2390ADD R14,R14,#8*height%*160
 2400OPT FNadr(12,grid%,2)
 2410ADD R11,R12,#16*width%*height%
 2420SUB R11,R11,#16*width%
 2430MOV R8,#height%
 2440.yloop%
 2450ADD R14,R14,#8*width%>>3-2
 2460ADD R10,R12,#16*width%
 2470SUB R10,R10,#16
 2480ADD R9,R11,#16*width%
 2490SUB R9,R9,#16
 2500SUB R8,R8,#width%<<12
 2510.xloop%
 2520SUB R14,R14,#8>>3-2
 2530LDR R0,[R9]
 2540LDR R1,[R9,#8]
 2550LDR R2,[R10]
 2560LDR R3,[R10,#8]
 2570LDR R4,[R11]
 2580LDR R5,[R11,#8]
 2590LDR R6,[R12]
 2600LDR R7,[R12,#8]
 2610SUB R4,R4,R0
 2620MOV R4,R4,ASR#4
 2630SUB R5,R5,R1
 2640MOV R5,R5,ASR#4
 2650SUB R6,R6,R2
 2660MOV R6,R6,ASR#4
 2670SUB R7,R7,R3
 2680MOV R7,R7,ASR#4
 2690ADD R0,R0,R4,ASR#1
 2700ADD R1,R1,R5,ASR#1
 2710ADD R2,R2,R6,ASR#1
 2720ADD R3,R3,R7,ASR#1
 2730SUB R2,R2,R0
 2740MOV R2,R2,ASR#4
 2750SUB R3,R3,R1
 2760MOV R3,R3,ASR#4
 2770SUB R6,R6,R4
 2780MOV R6,R6,ASR#4
 2790SUB R7,R7,R5
 2800MOV R7,R7,ASR#4
 2810ADD R0,R0,R2,ASR#1
 2820ADD R1,R1,R3,ASR#1
 2830ADD R4,R4,R6,ASR#1
 2840ADD R5,R5,R7,ASR#1
 2850SUB R14,R14,#8*160
 2860ADD R8,R8,#8<<24
 2870.blitloop%
 2880MOV R11,#0
 2890]:FORU%=0TO7:[OPT T%
 2900SUB R12,R1,R0,LSR#1
 2910MOV R12,R12,LSR#32-8
 2920TST R12,R0,LSR#32-8
 2930ADDEQ R11,R11,#1<<4*U%
 2940ADD R0,R0,R4
 2950ADD R1,R1,R5
 2960SUB R12,R1,R0,LSR#1
 2970MOV R12,R12,LSR#32-8
 2980TST R12,R0,LSR#32-8
 2990ADDEQ R11,R11,#1<<4*U%
 3000ADD R0,R0,R4
 3010ADD R1,R1,R5
 3020]:NEXT:[OPT T%
 3030SUB R0,R0,R4,ASL#4
 3040SUB R1,R1,R5,ASL#4
 3050ADD R0,R0,R2
 3060ADD R1,R1,R3
 3070ADD R4,R4,R6
 3080ADD R5,R5,R7
 3090]:FORU%=0TO7:[OPT T%
 3100SUB R12,R1,R0,LSR#1
 3110MOV R12,R12,LSR#32-8
 3120TST R12,R0,LSR#32-8
 3130ADDEQ R11,R11,#1<<4*U%
 3140ADD R0,R0,R4
 3150ADD R1,R1,R5
 3160SUB R12,R1,R0,LSR#1
 3170MOV R12,R12,LSR#32-8
 3180TST R12,R0,LSR#32-8
 3190ADDEQ R11,R11,#1<<4*U%
 3200ADD R0,R0,R4
 3210ADD R1,R1,R5
 3220]:NEXT:[OPT T%
 3230SUB R0,R0,R4,ASL#4
 3240SUB R1,R1,R5,ASL#4
 3250ADD R0,R0,R2
 3260ADD R1,R1,R3
 3270ADD R4,R4,R6
 3280ADD R5,R5,R7
 3290STR R11,[R14],#160
 3300SUBS R8,R8,#1<<24
 3310BGT blitloop%
 3320MOV R12,R10
 3330SUB R10,R10,#16
 3340MOV R11,R9
 3350SUB R9,R9,#16
 3360ADDS R8,R8,#1<<12
 3370BLE xloop%
 3380SUB R14,R14,#8*160
 3390MOV R12,R11
 3400SUB R11,R11,#16*width%
 3410SUBS R8,R8,#1
 3420BGT yloop%
 3430LDMFD R13!,{R0-R12,PC}^
 3440:
 3450]:IFP%>code%+codelen%THENERROR255,"Code isn't big enough"
 3460NEXT
 3470ENDPROC

�13:�9:�
,�T%=0�4:�T%,255*T%/4,255*T%/4,255*T%/4:�
�constants
(�space%spacelen%:P%=space%
2code%=P%:P%+=codelen%
<"grid%=P%:P%+=16*width%*height%
F
�assemble
P
�setup
Z*POINTER 1
d2ȗȓ0,1024-32*height%,32*width%-1,32*height%-1
n�
x�
��frame%
�ȗX1%,Y1%,Z%
��(-99)�*ScreenSave TYU
�	�Z%>0
�/A%=grid%+16*((X1%>>5)+width%*(1023-Y1%>>5))
�P%=!A%>>16:Q%=A%!8>>16
��
��frame%
�ȗX%,Y%,Z%
�+!A%=P%+(X1%-X%<<16-5)/width%<<16:A%!4=0
�.A%!8=Q%+(Y%-Y1%<<16-5)/height%<<16:A%!12=0
�	�Z%=0
��0
�
:
:
"��constants
,spacelen%=&80000
6codelen%=&4000
@P�"Please choose:"''"1 ... Full screen"'"2 ... 1/2 screen"'"3 ... 1/5 screen"
J�:A$=�:�A$>="1"�A$<="3"
T	ȎA$�
^�"1":width%=40:height%=32
h�"2":width%=24:height%=24
r�"3":width%=16:height%=16
|�
��
�KK%=6:FF%=8
��
�:
���setup
��W%(width%-1),H%(height%-1)
�1�X%=0�width%-1:W%(X%)=(1<<16)*X%/width%<<16:�
�3�Y%=0�height%-1:H%(Y%)=(1<<16)*Y%/height%<<16:�
�+U%=grid%:�Y%=0�height%-1:�X%=0�width%-1
�;!U%=W%(X%):U%!4=H%(Y%)>>>7:U%!8=H%(Y%):U%!12=W%(X%)>>>7
�
U%+=16:�,
��
�:
N� ************************************************************************
:
��mode(X%,Y%,C%)
&�J%64:P%=J%:[OPT 2
0*EQUD 1:EQUD X%:EQUD Y%:EQUD C%:EQUD -1
:$]:�C%=3�[OPT 2:EQUD 3:EQUD 255:]
D[OPT 2:EQUD -1:]:�J%
N�
X:
bݤadr(R%,A%,I%)
l,�(P%�3)<>0��"Code isn't word aligned!":�
v�(T%�2)=0�P%+=I%<<2:=T%
�(�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%:�
�L�H%<>0��"Could not ADR to &";~A%;" in ";I%;" instructions (R%=";R%;")":�
�=T%
�:
�ݤmakej(J%,N%,dummy%)
�U%=0�N%-1:[OPT T%
EQUD dummy%-J%
]:�:=T%
 :
*ݤregisterj(J%,N%)
4C�P%<J%��255,"j routines must come after j table (J%=&"+�~J%+")"
>J%!(N%<<2)=P%-J%
H=T%
R:
\� Does R=S*C+O
f� Copes with R=O
p/� Takes registers R, S and O and constant C
z:
�ݤmla(R%,S%,C%,O%)
��C%=0�[OPT T%:MOV R%,O%:]
��N%
�N%=0:ȕC%<>0
�ȕ(C%�1)=0:N%+=1:C%=C%>>1:�
��(C%�2)=0�
�'[OPT T%:ADD R%,O%,S%,ASL#N%:]:C%-=1
�(�[OPT T%:SUB R%,O%,S%,ASL#N%:]:C%+=1
�
�:O%=R%:�
�=T%
�:
�� Does R+=[(N<<F) div D]*C
�� Also N=(N<<F) mod D
1� M is maximum expected value of (N<<F) div D
(� Copes with (N<<F) bigger than 2^32
� N and D are unsigned
$6� Takes registers R, N, D and constants C, F and M
.:
8ݤdiva(R%,N%,F%,D%,C%,M%)
B�U%
LM%=1+�(�(M%)/�(2))
V
�M%>F%+1�
`�U%=M%-1�F%+1�-1:[OPT T%
jCMP D%,N%,ASR#U%-F%
tSUBLE N%,N%,D%,ASL#U%-F%
~ADDLE R%,R%,#C%<<U%
�]:�
�
�:�M%>F%�
�[OPT T%
�
CMP N%,D%
�SUBGE N%,N%,D%
�ADDGE R%,R%,#C%<<F%
�]
��:�F%>0�
��U%=F%-1�0�-1:[OPT T%
�RSBS N%,D%,N%,ASL#1
�ADDLT N%,N%,D%
�ADDGE R%,R%,#C%<<U%
]:�

	�:=T%
:
N� ************************************************************************
(:
2��assemble
<�T%=0�2�2:P%=code%
F[OPT T%
P:
Z.vduvars%:EQUD 148:EQUD -1
d.scraddr%:EQUD -1
n:
x.bank%:EQUD 1
�:
�.lasttime%:EQUD -1
�:
�.frame%
�STMFD R13!,{R0-R12,R14}
�LDR R1,bank%
�
CMP R1,#1
��Q R1,#2
�MOVNE R1,#1
�STR R1,bank%
�MOV R0,#112
�SWI "OS_Byte"
�ADR R0,vduvars%
ADR R1,scraddr%
SWI "OS_ReadVduVariables"
MOV R0,#19
"SWI "OS_Byte"
,SWI "OS_ReadMonotonicTime"
6MOV R0,R0,ASR#1
@LDR R1,lasttime%
JSTR R0,lasttime%
TSUB R0,R0,R1
^CMP R0,#10
hMOVHI R0,#10
r.timeloop%
|BL forces%
�BL move%
�SUBS R0,R0,#1
�BGT timeloop%
�BL plot%
�LDR R1,bank%
�MOV R0,#113
�SWI "OS_Byte"
�LDMFD R13!,{R0-R12,PC}^
�:
�.forces%
�STMFD R13!,{R0-R12,R14}
�OPT �adr(12,grid%,2)
�"ADD R11,R12,#16*width%*height%
SUB R11,R11,#16*width%
MOV R8,#height%
.yloop%
&ADD R10,R12,#16*width%
0SUB R10,R10,#16
:SUB R8,R8,#width%<<16
D.xloop%
NLDMIA R12,{R0-R1,R2-R3}
XLDMIA R11,{R4-R5,R6-R7}
bSUB R9,R4,R0
lADD R1,R1,R9,ASR#KK%
vSUB R5,R5,R9,ASR#KK%
�SUB R9,R6,R2
�ADD R3,R3,R9,ASR#KK%
�SUB R7,R7,R9,ASR#KK%
�STMIA R11!,{R4-R5,R6-R7}
�LDMIA R10,{R4-R5,R6-R7}
�SUB R9,R4,R0
�ADD R1,R1,R9,ASR#KK%
�SUB R5,R5,R9,ASR#KK%
�SUB R9,R6,R2
�ADD R3,R3,R9,ASR#KK%
�SUB R7,R7,R9,ASR#KK%
�STMIA R10,{R4-R5,R6-R7}
�MOV R10,R12
STMIA R12!,{R0-R1,R2-R3}
ADDS R8,R8,#1<<16
BLE xloop%
 SUB R11,R12,#16*width%
*SUBS R8,R8,#1
4BGT yloop%
>LDMFD R13!,{R0-R12,PC}^
H:
R
.move%
\STMFD R13!,{R0-R12,R14}
fOPT �adr(12,grid%,2)
pMOV R8,#width%*height%
z
.loop%
�'LDMIA R12,{R0-R1,R2-R3,R4-R5,R6-R7}
�SUBS R1,R1,R1,ASR#FF%
�SUBGT R1,R1,#1
�ADD R0,R0,R1
�SUBS R3,R3,R3,ASR#FF%
�SUBGT R3,R3,#1
�ADD R2,R2,R3
�SUBS R5,R5,R5,ASR#FF%
�SUBGT R5,R5,#1
�ADD R4,R4,R5
�SUBS R7,R7,R7,ASR#FF%
�SUBGT R7,R7,#1
�ADD R6,R6,R7
	(STMIA R12!,{R0-R1,R2-R3,R4-R5,R6-R7}
	SUBS R8,R8,#2
	
BGT loop%
	$LDMFD R13!,{R0-R12,PC}^
	.:
	8
.plot%
	BSTMFD R13!,{R0-R12,R14}
	LLDR R14,scraddr%
	VADD R14,R14,#8*height%*160
	`OPT �adr(12,grid%,2)
	j"ADD R11,R12,#16*width%*height%
	tSUB R11,R11,#16*width%
	~MOV R8,#height%
	�.yloop%
	�ADD R14,R14,#8*width%>>3-2
	�ADD R10,R12,#16*width%
	�SUB R10,R10,#16
	�ADD R9,R11,#16*width%
	�SUB R9,R9,#16
	�SUB R8,R8,#width%<<12
	�.xloop%
	�SUB R14,R14,#8>>3-2
	�LDR R0,[R9]
	�LDR R1,[R9,#8]
	�LDR R2,[R10]
LDR R3,[R10,#8]

LDR R4,[R11]
LDR R5,[R11,#8]
LDR R6,[R12]
(LDR R7,[R12,#8]
2SUB R4,R4,R0
<MOV R4,R4,ASR#4
FSUB R5,R5,R1
PMOV R5,R5,ASR#4
ZSUB R6,R6,R2
dMOV R6,R6,ASR#4
nSUB R7,R7,R3
xMOV R7,R7,ASR#4
�ADD R0,R0,R4,ASR#1
�ADD R1,R1,R5,ASR#1
�ADD R2,R2,R6,ASR#1
�ADD R3,R3,R7,ASR#1
�SUB R2,R2,R0
�MOV R2,R2,ASR#4
�SUB R3,R3,R1
�MOV R3,R3,ASR#4
�SUB R6,R6,R4
�MOV R6,R6,ASR#4
�SUB R7,R7,R5
�MOV R7,R7,ASR#4
�ADD R0,R0,R2,ASR#1
ADD R1,R1,R3,ASR#1
ADD R4,R4,R6,ASR#1
ADD R5,R5,R7,ASR#1
"SUB R14,R14,#8*160
,ADD R8,R8,#8<<24
6.blitloop%
@MOV R11,#0
J]:�U%=0�7:[OPT T%
TSUB R12,R1,R0,LSR#1
^MOV R12,R12,LSR#32-8
hTST R12,R0,LSR#32-8
rADDEQ R11,R11,#1<<4*U%
|ADD R0,R0,R4
�ADD R1,R1,R5
�SUB R12,R1,R0,LSR#1
�MOV R12,R12,LSR#32-8
�TST R12,R0,LSR#32-8
�ADDEQ R11,R11,#1<<4*U%
�ADD R0,R0,R4
�ADD R1,R1,R5
�]:�:[OPT T%
�SUB R0,R0,R4,ASL#4
�SUB R1,R1,R5,ASL#4
�ADD R0,R0,R2
�ADD R1,R1,R3
�ADD R4,R4,R6
ADD R5,R5,R7
]:�U%=0�7:[OPT T%
SUB R12,R1,R0,LSR#1
&MOV R12,R12,LSR#32-8
0TST R12,R0,LSR#32-8
:ADDEQ R11,R11,#1<<4*U%
DADD R0,R0,R4
NADD R1,R1,R5
XSUB R12,R1,R0,LSR#1
bMOV R12,R12,LSR#32-8
lTST R12,R0,LSR#32-8
vADDEQ R11,R11,#1<<4*U%
�ADD R0,R0,R4
�ADD R1,R1,R5
�]:�:[OPT T%
�SUB R0,R0,R4,ASL#4
�SUB R1,R1,R5,ASL#4
�ADD R0,R0,R2
�ADD R1,R1,R3
�ADD R4,R4,R6
�ADD R5,R5,R7
�STR R11,[R14],#160
�SUBS R8,R8,#1<<24
�BGT blitloop%
�MOV R12,R10

SUB R10,R10,#16

MOV R11,R9

SUB R9,R9,#16

 ADDS R8,R8,#1<<12

*BLE xloop%

4SUB R14,R14,#8*160

>MOV R12,R11

HSUB R11,R11,#16*width%

RSUBS R8,R8,#1

\BGT yloop%

fLDMFD R13!,{R0-R12,PC}^

p:

z5]:�P%>code%+codelen%��255,"Code isn't big enough"

��

��
�
00000000  0d 00 0a 0c eb 31 33 3a  eb 39 3a 87 0d 00 14 2c  |.....13:.9:....,|
00000010  e3 54 25 3d 30 b8 34 3a  fb 54 25 2c 32 35 35 2a  |.T%=0.4:.T%,255*|
00000020  54 25 2f 34 2c 32 35 35  2a 54 25 2f 34 2c 32 35  |T%/4,255*T%/4,25|
00000030  35 2a 54 25 2f 34 3a ed  0d 00 1e 0e f2 63 6f 6e  |5*T%/4:......con|
00000040  73 74 61 6e 74 73 0d 00  28 1e de 73 70 61 63 65  |stants..(..space|
00000050  25 73 70 61 63 65 6c 65  6e 25 3a 50 25 3d 73 70  |%spacelen%:P%=sp|
00000060  61 63 65 25 0d 00 32 19  63 6f 64 65 25 3d 50 25  |ace%..2.code%=P%|
00000070  3a 50 25 2b 3d 63 6f 64  65 6c 65 6e 25 0d 00 3c  |:P%+=codelen%..<|
00000080  22 67 72 69 64 25 3d 50  25 3a 50 25 2b 3d 31 36  |"grid%=P%:P%+=16|
00000090  2a 77 69 64 74 68 25 2a  68 65 69 67 68 74 25 0d  |*width%*height%.|
000000a0  00 46 0d f2 61 73 73 65  6d 62 6c 65 0d 00 50 0a  |.F..assemble..P.|
000000b0  f2 73 65 74 75 70 0d 00  5a 0e 2a 50 4f 49 4e 54  |.setup..Z.*POINT|
000000c0  45 52 20 31 0d 00 64 32  c8 97 c8 93 30 2c 31 30  |ER 1..d2....0,10|
000000d0  32 34 2d 33 32 2a 68 65  69 67 68 74 25 2c 33 32  |24-32*height%,32|
000000e0  2a 77 69 64 74 68 25 2d  31 2c 33 32 2a 68 65 69  |*width%-1,32*hei|
000000f0  67 68 74 25 2d 31 0d 00  6e 05 f5 0d 00 78 05 f5  |ght%-1..n....x..|
00000100  0d 00 82 0b d6 66 72 61  6d 65 25 0d 00 8c 10 c8  |.....frame%.....|
00000110  97 58 31 25 2c 59 31 25  2c 5a 25 0d 00 96 1b e7  |.X1%,Y1%,Z%.....|
00000120  a6 28 2d 39 39 29 8c 2a  53 63 72 65 65 6e 53 61  |.(-99).*ScreenSa|
00000130  76 65 20 54 59 55 0d 00  a0 09 fd 5a 25 3e 30 0d  |ve TYU.....Z%>0.|
00000140  00 aa 2f 41 25 3d 67 72  69 64 25 2b 31 36 2a 28  |../A%=grid%+16*(|
00000150  28 58 31 25 3e 3e 35 29  2b 77 69 64 74 68 25 2a  |(X1%>>5)+width%*|
00000160  28 31 30 32 33 2d 59 31  25 3e 3e 35 29 29 0d 00  |(1023-Y1%>>5))..|
00000170  b4 1a 50 25 3d 21 41 25  3e 3e 31 36 3a 51 25 3d  |..P%=!A%>>16:Q%=|
00000180  41 25 21 38 3e 3e 31 36  0d 00 be 05 f5 0d 00 c8  |A%!8>>16........|
00000190  0b d6 66 72 61 6d 65 25  0d 00 d2 0e c8 97 58 25  |..frame%......X%|
000001a0  2c 59 25 2c 5a 25 0d 00  dc 2b 21 41 25 3d 50 25  |,Y%,Z%...+!A%=P%|
000001b0  2b 28 58 31 25 2d 58 25  3c 3c 31 36 2d 35 29 2f  |+(X1%-X%<<16-5)/|
000001c0  77 69 64 74 68 25 3c 3c  31 36 3a 41 25 21 34 3d  |width%<<16:A%!4=|
000001d0  30 0d 00 e6 2e 41 25 21  38 3d 51 25 2b 28 59 25  |0....A%!8=Q%+(Y%|
000001e0  2d 59 31 25 3c 3c 31 36  2d 35 29 2f 68 65 69 67  |-Y1%<<16-5)/heig|
000001f0  68 74 25 3c 3c 31 36 3a  41 25 21 31 32 3d 30 0d  |ht%<<16:A%!12=0.|
00000200  00 f0 09 fd 5a 25 3d 30  0d 00 fa 06 fd 30 0d 01  |....Z%=0.....0..|
00000210  04 05 e0 0d 01 0e 05 3a  0d 01 18 05 3a 0d 01 22  |.......:....:.."|
00000220  0f dd f2 63 6f 6e 73 74  61 6e 74 73 0d 01 2c 14  |...constants..,.|
00000230  73 70 61 63 65 6c 65 6e  25 3d 26 38 30 30 30 30  |spacelen%=&80000|
00000240  0d 01 36 12 63 6f 64 65  6c 65 6e 25 3d 26 34 30  |..6.codelen%=&40|
00000250  30 30 0d 01 40 50 f1 22  50 6c 65 61 73 65 20 63  |00..@P."Please c|
00000260  68 6f 6f 73 65 3a 22 27  27 22 31 20 2e 2e 2e 20  |hoose:"''"1 ... |
00000270  46 75 6c 6c 20 73 63 72  65 65 6e 22 27 22 32 20  |Full screen"'"2 |
00000280  2e 2e 2e 20 31 2f 32 20  73 63 72 65 65 6e 22 27  |... 1/2 screen"'|
00000290  22 33 20 2e 2e 2e 20 31  2f 35 20 73 63 72 65 65  |"3 ... 1/5 scree|
000002a0  6e 22 0d 01 4a 1b f5 3a  41 24 3d be 3a fd 41 24  |n"..J..:A$=.:.A$|
000002b0  3e 3d 22 31 22 80 41 24  3c 3d 22 33 22 0d 01 54  |>="1".A$<="3"..T|
000002c0  09 c8 8e 41 24 ca 0d 01  5e 1d c9 22 31 22 3a 77  |...A$...^.."1":w|
000002d0  69 64 74 68 25 3d 34 30  3a 68 65 69 67 68 74 25  |idth%=40:height%|
000002e0  3d 33 32 0d 01 68 1d c9  22 32 22 3a 77 69 64 74  |=32..h.."2":widt|
000002f0  68 25 3d 32 34 3a 68 65  69 67 68 74 25 3d 32 34  |h%=24:height%=24|
00000300  0d 01 72 1d c9 22 33 22  3a 77 69 64 74 68 25 3d  |..r.."3":width%=|
00000310  31 36 3a 68 65 69 67 68  74 25 3d 31 36 0d 01 7c  |16:height%=16..||
00000320  05 cb 0d 01 86 05 db 0d  01 90 0f 4b 4b 25 3d 36  |...........KK%=6|
00000330  3a 46 46 25 3d 38 0d 01  9a 05 e1 0d 01 a4 05 3a  |:FF%=8.........:|
00000340  0d 01 ae 0b dd f2 73 65  74 75 70 0d 01 b8 1f de  |......setup.....|
00000350  57 25 28 77 69 64 74 68  25 2d 31 29 2c 48 25 28  |W%(width%-1),H%(|
00000360  68 65 69 67 68 74 25 2d  31 29 0d 01 c2 31 e3 58  |height%-1)...1.X|
00000370  25 3d 30 b8 77 69 64 74  68 25 2d 31 3a 57 25 28  |%=0.width%-1:W%(|
00000380  58 25 29 3d 28 31 3c 3c  31 36 29 2a 58 25 2f 77  |X%)=(1<<16)*X%/w|
00000390  69 64 74 68 25 3c 3c 31  36 3a ed 0d 01 cc 33 e3  |idth%<<16:....3.|
000003a0  59 25 3d 30 b8 68 65 69  67 68 74 25 2d 31 3a 48  |Y%=0.height%-1:H|
000003b0  25 28 59 25 29 3d 28 31  3c 3c 31 36 29 2a 59 25  |%(Y%)=(1<<16)*Y%|
000003c0  2f 68 65 69 67 68 74 25  3c 3c 31 36 3a ed 0d 01  |/height%<<16:...|
000003d0  d6 2b 55 25 3d 67 72 69  64 25 3a e3 59 25 3d 30  |.+U%=grid%:.Y%=0|
000003e0  b8 68 65 69 67 68 74 25  2d 31 3a e3 58 25 3d 30  |.height%-1:.X%=0|
000003f0  b8 77 69 64 74 68 25 2d  31 0d 01 e0 3b 21 55 25  |.width%-1...;!U%|
00000400  3d 57 25 28 58 25 29 3a  55 25 21 34 3d 48 25 28  |=W%(X%):U%!4=H%(|
00000410  59 25 29 3e 3e 3e 37 3a  55 25 21 38 3d 48 25 28  |Y%)>>>7:U%!8=H%(|
00000420  59 25 29 3a 55 25 21 31  32 3d 57 25 28 58 25 29  |Y%):U%!12=W%(X%)|
00000430  3e 3e 3e 37 0d 01 ea 0d  55 25 2b 3d 31 36 3a ed  |>>>7....U%+=16:.|
00000440  2c 0d 01 f4 05 e1 0d 01  fe 05 3a 0d 02 08 4e f4  |,.........:...N.|
00000450  20 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  | ***************|
00000460  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
*
00000490  2a 2a 2a 2a 2a 2a 2a 2a  2a 0d 02 12 05 3a 0d 02  |*********....:..|
000004a0  1c 14 dd f2 6d 6f 64 65  28 58 25 2c 59 25 2c 43  |....mode(X%,Y%,C|
000004b0  25 29 0d 02 26 16 de 4a  25 36 34 3a 50 25 3d 4a  |%)..&..J%64:P%=J|
000004c0  25 3a 5b 4f 50 54 20 32  0d 02 30 2a 45 51 55 44  |%:[OPT 2..0*EQUD|
000004d0  20 31 3a 45 51 55 44 20  58 25 3a 45 51 55 44 20  | 1:EQUD X%:EQUD |
000004e0  59 25 3a 45 51 55 44 20  43 25 3a 45 51 55 44 20  |Y%:EQUD C%:EQUD |
000004f0  2d 31 0d 02 3a 24 5d 3a  e7 43 25 3d 33 8c 5b 4f  |-1..:$]:.C%=3.[O|
00000500  50 54 20 32 3a 45 51 55  44 20 33 3a 45 51 55 44  |PT 2:EQUD 3:EQUD|
00000510  20 32 35 35 3a 5d 0d 02  44 18 5b 4f 50 54 20 32  | 255:]..D.[OPT 2|
00000520  3a 45 51 55 44 20 2d 31  3a 5d 3a eb 4a 25 0d 02  |:EQUD -1:]:.J%..|
00000530  4e 05 e1 0d 02 58 05 3a  0d 02 62 13 dd a4 61 64  |N....X.:..b...ad|
00000540  72 28 52 25 2c 41 25 2c  49 25 29 0d 02 6c 2c e7  |r(R%,A%,I%)..l,.|
00000550  28 50 25 80 33 29 3c 3e  30 8c f1 22 43 6f 64 65  |(P%.3)<>0.."Code|
00000560  20 69 73 6e 27 74 20 77  6f 72 64 20 61 6c 69 67  | isn't word alig|
00000570  6e 65 64 21 22 3a e0 0d  02 76 1b e7 28 54 25 80  |ned!":...v..(T%.|
00000580  32 29 3d 30 8c 50 25 2b  3d 49 25 3c 3c 32 3a 3d  |2)=0.P%+=I%<<2:=|
00000590  54 25 0d 02 80 28 ea 4e  25 2c 4f 25 2c 48 25 2c  |T%...(.N%,O%,H%,|
000005a0  55 25 3a 48 25 3d 41 25  2d 28 50 25 2b 38 29 3a  |U%:H%=A%-(P%+8):|
000005b0  4e 25 3d 30 3a 4f 25 3d  31 35 0d 02 8a 13 e3 55  |N%=0:O%=15.....U|
000005c0  25 3d 31 b8 49 25 3a e7  48 25 3d 30 8c 0d 02 94  |%=1.I%:.H%=0....|
000005d0  17 5b 4f 50 54 20 54 25  3a 4d 4f 56 20 52 25 2c  |.[OPT T%:MOV R%,|
000005e0  4f 25 3a 5d 0d 02 9e 20  cc c8 95 28 48 25 80 33  |O%:]... ...(H%.3|
000005f0  29 3d 30 3a 48 25 3d 48  25 3e 3e 32 3a 4e 25 2b  |)=0:H%=H%>>2:N%+|
00000600  3d 32 3a ce 0d 02 a8 10  e7 28 48 25 80 32 35 36  |=2:......(H%.256|
00000610  29 3d 30 8c 0d 02 b2 30  5b 4f 50 54 20 54 25 3a  |)=0....0[OPT T%:|
00000620  41 44 44 20 52 25 2c 4f  25 2c 23 28 48 25 80 32  |ADD R%,O%,#(H%.2|
00000630  35 35 29 3c 3c 4e 25 3a  5d 3a 48 25 2d 3d 48 25  |55)<<N%:]:H%-=H%|
00000640  80 32 35 35 0d 02 bc 39  cc 5b 4f 50 54 20 54 25  |.255...9.[OPT T%|
00000650  3a 53 55 42 20 52 25 2c  4f 25 2c 23 28 32 35 36  |:SUB R%,O%,#(256|
00000660  2d 48 25 80 32 35 35 29  3c 3c 4e 25 3a 5d 3a 48  |-H%.255)<<N%:]:H|
00000670  25 2b 3d 32 35 36 2d 48  25 80 32 35 35 0d 02 c6  |%+=256-H%.255...|
00000680  05 cd 0d 02 d0 0d cd 3a  4f 25 3d 52 25 3a ed 0d  |.......:O%=R%:..|
00000690  02 da 4c e7 48 25 3c 3e  30 8c f1 22 43 6f 75 6c  |..L.H%<>0.."Coul|
000006a0  64 20 6e 6f 74 20 41 44  52 20 74 6f 20 26 22 3b  |d not ADR to &";|
000006b0  7e 41 25 3b 22 20 69 6e  20 22 3b 49 25 3b 22 20  |~A%;" in ";I%;" |
000006c0  69 6e 73 74 72 75 63 74  69 6f 6e 73 20 28 52 25  |instructions (R%|
000006d0  3d 22 3b 52 25 3b 22 29  22 3a e0 0d 02 e4 07 3d  |=";R%;")":.....=|
000006e0  54 25 0d 02 ee 05 3a 0d  02 f8 19 dd a4 6d 61 6b  |T%....:......mak|
000006f0  65 6a 28 4a 25 2c 4e 25  2c 64 75 6d 6d 79 25 29  |ej(J%,N%,dummy%)|
00000700  0d 03 02 16 e3 55 25 3d  30 b8 4e 25 2d 31 3a 5b  |.....U%=0.N%-1:[|
00000710  4f 50 54 20 54 25 0d 03  0c 12 45 51 55 44 20 64  |OPT T%....EQUD d|
00000720  75 6d 6d 79 25 2d 4a 25  0d 03 16 0b 5d 3a ed 3a  |ummy%-J%....]:.:|
00000730  3d 54 25 0d 03 20 05 3a  0d 03 2a 16 dd a4 72 65  |=T%.. .:..*...re|
00000740  67 69 73 74 65 72 6a 28  4a 25 2c 4e 25 29 0d 03  |gisterj(J%,N%)..|
00000750  34 43 e7 50 25 3c 4a 25  8c 85 32 35 35 2c 22 6a  |4C.P%<J%..255,"j|
00000760  20 72 6f 75 74 69 6e 65  73 20 6d 75 73 74 20 63  | routines must c|
00000770  6f 6d 65 20 61 66 74 65  72 20 6a 20 74 61 62 6c  |ome after j tabl|
00000780  65 20 28 4a 25 3d 26 22  2b c3 7e 4a 25 2b 22 29  |e (J%=&"+.~J%+")|
00000790  22 0d 03 3e 14 4a 25 21  28 4e 25 3c 3c 32 29 3d  |"..>.J%!(N%<<2)=|
000007a0  50 25 2d 4a 25 0d 03 48  07 3d 54 25 0d 03 52 05  |P%-J%..H.=T%..R.|
000007b0  3a 0d 03 5c 12 f4 20 44  6f 65 73 20 52 3d 53 2a  |:..\.. Does R=S*|
000007c0  43 2b 4f 0d 03 66 14 f4  20 43 6f 70 65 73 20 77  |C+O..f.. Copes w|
000007d0  69 74 68 20 52 3d 4f 0d  03 70 2f f4 20 54 61 6b  |ith R=O..p/. Tak|
000007e0  65 73 20 72 65 67 69 73  74 65 72 73 20 52 2c 20  |es registers R, |
000007f0  53 20 61 6e 64 20 4f 20  61 6e 64 20 63 6f 6e 73  |S and O and cons|
00000800  74 61 6e 74 20 43 0d 03  7a 05 3a 0d 03 84 16 dd  |tant C..z.:.....|
00000810  a4 6d 6c 61 28 52 25 2c  53 25 2c 43 25 2c 4f 25  |.mla(R%,S%,C%,O%|
00000820  29 0d 03 8e 1d e7 43 25  3d 30 8c 5b 4f 50 54 20  |).....C%=0.[OPT |
00000830  54 25 3a 4d 4f 56 20 52  25 2c 4f 25 3a 5d 0d 03  |T%:MOV R%,O%:]..|
00000840  98 07 ea 4e 25 0d 03 a2  10 4e 25 3d 30 3a c8 95  |...N%....N%=0:..|
00000850  43 25 3c 3e 30 0d 03 ac  1f c8 95 28 43 25 80 31  |C%<>0......(C%.1|
00000860  29 3d 30 3a 4e 25 2b 3d  31 3a 43 25 3d 43 25 3e  |)=0:N%+=1:C%=C%>|
00000870  3e 31 3a ce 0d 03 b6 0e  e7 28 43 25 80 32 29 3d  |>1:......(C%.2)=|
00000880  30 8c 0d 03 c0 27 5b 4f  50 54 20 54 25 3a 41 44  |0....'[OPT T%:AD|
00000890  44 20 52 25 2c 4f 25 2c  53 25 2c 41 53 4c 23 4e  |D R%,O%,S%,ASL#N|
000008a0  25 3a 5d 3a 43 25 2d 3d  31 0d 03 ca 28 cc 5b 4f  |%:]:C%-=1...(.[O|
000008b0  50 54 20 54 25 3a 53 55  42 20 52 25 2c 4f 25 2c  |PT T%:SUB R%,O%,|
000008c0  53 25 2c 41 53 4c 23 4e  25 3a 5d 3a 43 25 2b 3d  |S%,ASL#N%:]:C%+=|
000008d0  31 0d 03 d4 0d cd 3a 4f  25 3d 52 25 3a ce 0d 03  |1.....:O%=R%:...|
000008e0  de 07 3d 54 25 0d 03 e8  05 3a 0d 03 f2 1e f4 20  |..=T%....:..... |
000008f0  44 6f 65 73 20 52 2b 3d  5b 28 4e 3c 3c 46 29 20  |Does R+=[(N<<F) |
00000900  64 69 76 20 44 5d 2a 43  0d 03 fc 19 f4 20 41 6c  |div D]*C..... Al|
00000910  73 6f 20 4e 3d 28 4e 3c  3c 46 29 20 6d 6f 64 20  |so N=(N<<F) mod |
00000920  44 0d 04 06 31 f4 20 4d  20 69 73 20 6d 61 78 69  |D...1. M is maxi|
00000930  6d 75 6d 20 65 78 70 65  63 74 65 64 20 76 61 6c  |mum expected val|
00000940  75 65 20 6f 66 20 28 4e  3c 3c 46 29 20 64 69 76  |ue of (N<<F) div|
00000950  20 44 0d 04 10 28 f4 20  43 6f 70 65 73 20 77 69  | D...(. Copes wi|
00000960  74 68 20 28 4e 3c 3c 46  29 20 62 69 67 67 65 72  |th (N<<F) bigger|
00000970  20 74 68 61 6e 20 32 5e  33 32 0d 04 1a 1a f4 20  | than 2^32..... |
00000980  4e 20 61 6e 64 20 44 20  61 72 65 20 75 6e 73 69  |N and D are unsi|
00000990  67 6e 65 64 0d 04 24 36  f4 20 54 61 6b 65 73 20  |gned..$6. Takes |
000009a0  72 65 67 69 73 74 65 72  73 20 52 2c 20 4e 2c 20  |registers R, N, |
000009b0  44 20 61 6e 64 20 63 6f  6e 73 74 61 6e 74 73 20  |D and constants |
000009c0  43 2c 20 46 20 61 6e 64  20 4d 0d 04 2e 05 3a 0d  |C, F and M....:.|
000009d0  04 38 1d dd a4 64 69 76  61 28 52 25 2c 4e 25 2c  |.8...diva(R%,N%,|
000009e0  46 25 2c 44 25 2c 43 25  2c 4d 25 29 0d 04 42 07  |F%,D%,C%,M%)..B.|
000009f0  ea 55 25 0d 04 4c 16 4d  25 3d 31 2b a8 28 aa 28  |.U%..L.M%=1+.(.(|
00000a00  4d 25 29 2f aa 28 32 29  29 0d 04 56 0d e7 4d 25  |M%)/.(2))..V..M%|
00000a10  3e 46 25 2b 31 8c 0d 04  60 1c e3 55 25 3d 4d 25  |>F%+1...`..U%=M%|
00000a20  2d 31 b8 46 25 2b 31 88  2d 31 3a 5b 4f 50 54 20  |-1.F%+1.-1:[OPT |
00000a30  54 25 0d 04 6a 17 43 4d  50 20 44 25 2c 4e 25 2c  |T%..j.CMP D%,N%,|
00000a40  41 53 52 23 55 25 2d 46  25 0d 04 74 1c 53 55 42  |ASR#U%-F%..t.SUB|
00000a50  4c 45 20 4e 25 2c 4e 25  2c 44 25 2c 41 53 4c 23  |LE N%,N%,D%,ASL#|
00000a60  55 25 2d 46 25 0d 04 7e  17 41 44 44 4c 45 20 52  |U%-F%..~.ADDLE R|
00000a70  25 2c 52 25 2c 23 43 25  3c 3c 55 25 0d 04 88 07  |%,R%,#C%<<U%....|
00000a80  5d 3a ed 0d 04 92 0d cd  3a e7 4d 25 3e 46 25 8c  |]:......:.M%>F%.|
00000a90  0d 04 9c 0b 5b 4f 50 54  20 54 25 0d 04 a6 0d 43  |....[OPT T%....C|
00000aa0  4d 50 20 4e 25 2c 44 25  0d 04 b0 12 53 55 42 47  |MP N%,D%....SUBG|
00000ab0  45 20 4e 25 2c 4e 25 2c  44 25 0d 04 ba 17 41 44  |E N%,N%,D%....AD|
00000ac0  44 47 45 20 52 25 2c 52  25 2c 23 43 25 3c 3c 46  |DGE R%,R%,#C%<<F|
00000ad0  25 0d 04 c4 05 5d 0d 04  ce 0c cd 3a e7 46 25 3e  |%....].....:.F%>|
00000ae0  30 8c 0d 04 d8 19 e3 55  25 3d 46 25 2d 31 b8 30  |0......U%=F%-1.0|
00000af0  88 2d 31 3a 5b 4f 50 54  20 54 25 0d 04 e2 17 52  |.-1:[OPT T%....R|
00000b00  53 42 53 20 4e 25 2c 44  25 2c 4e 25 2c 41 53 4c  |SBS N%,D%,N%,ASL|
00000b10  23 31 0d 04 ec 12 41 44  44 4c 54 20 4e 25 2c 4e  |#1....ADDLT N%,N|
00000b20  25 2c 44 25 0d 04 f6 17  41 44 44 47 45 20 52 25  |%,D%....ADDGE R%|
00000b30  2c 52 25 2c 23 43 25 3c  3c 55 25 0d 05 00 07 5d  |,R%,#C%<<U%....]|
00000b40  3a ed 0d 05 0a 09 cd 3a  3d 54 25 0d 05 14 05 3a  |:......:=T%....:|
00000b50  0d 05 1e 4e f4 20 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |...N. **********|
00000b60  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
*
00000b90  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 0d 05  |**************..|
00000ba0  28 05 3a 0d 05 32 0e dd  f2 61 73 73 65 6d 62 6c  |(.:..2...assembl|
00000bb0  65 0d 05 3c 16 e3 54 25  3d 30 b8 32 88 32 3a 50  |e..<..T%=0.2.2:P|
00000bc0  25 3d 63 6f 64 65 25 0d  05 46 0b 5b 4f 50 54 20  |%=code%..F.[OPT |
00000bd0  54 25 0d 05 50 05 3a 0d  05 5a 1e 2e 76 64 75 76  |T%..P.:..Z..vduv|
00000be0  61 72 73 25 3a 45 51 55  44 20 31 34 38 3a 45 51  |ars%:EQUD 148:EQ|
00000bf0  55 44 20 2d 31 0d 05 64  15 2e 73 63 72 61 64 64  |UD -1..d..scradd|
00000c00  72 25 3a 45 51 55 44 20  2d 31 0d 05 6e 05 3a 0d  |r%:EQUD -1..n.:.|
00000c10  05 78 11 2e 62 61 6e 6b  25 3a 45 51 55 44 20 31  |.x..bank%:EQUD 1|
00000c20  0d 05 82 05 3a 0d 05 8c  16 2e 6c 61 73 74 74 69  |....:.....lastti|
00000c30  6d 65 25 3a 45 51 55 44  20 2d 31 0d 05 96 05 3a  |me%:EQUD -1....:|
00000c40  0d 05 a0 0b 2e 66 72 61  6d 65 25 0d 05 aa 1b 53  |.....frame%....S|
00000c50  54 4d 46 44 20 52 31 33  21 2c 7b 52 30 2d 52 31  |TMFD R13!,{R0-R1|
00000c60  32 2c 52 31 34 7d 0d 05  b4 10 4c 44 52 20 52 31  |2,R14}....LDR R1|
00000c70  2c 62 61 6e 6b 25 0d 05  be 0d 43 4d 50 20 52 31  |,bank%....CMP R1|
00000c80  2c 23 31 0d 05 c8 0c ec  51 20 52 31 2c 23 32 0d  |,#1.....Q R1,#2.|
00000c90  05 d2 0f 4d 4f 56 4e 45  20 52 31 2c 23 31 0d 05  |...MOVNE R1,#1..|
00000ca0  dc 10 53 54 52 20 52 31  2c 62 61 6e 6b 25 0d 05  |..STR R1,bank%..|
00000cb0  e6 0f 4d 4f 56 20 52 30  2c 23 31 31 32 0d 05 f0  |..MOV R0,#112...|
00000cc0  11 53 57 49 20 22 4f 53  5f 42 79 74 65 22 0d 05  |.SWI "OS_Byte"..|
00000cd0  fa 13 41 44 52 20 52 30  2c 76 64 75 76 61 72 73  |..ADR R0,vduvars|
00000ce0  25 0d 06 04 13 41 44 52  20 52 31 2c 73 63 72 61  |%....ADR R1,scra|
00000cf0  64 64 72 25 0d 06 0e 1d  53 57 49 20 22 4f 53 5f  |ddr%....SWI "OS_|
00000d00  52 65 61 64 56 64 75 56  61 72 69 61 62 6c 65 73  |ReadVduVariables|
00000d10  22 0d 06 18 0e 4d 4f 56  20 52 30 2c 23 31 39 0d  |"....MOV R0,#19.|
00000d20  06 22 11 53 57 49 20 22  4f 53 5f 42 79 74 65 22  |.".SWI "OS_Byte"|
00000d30  0d 06 2c 1e 53 57 49 20  22 4f 53 5f 52 65 61 64  |..,.SWI "OS_Read|
00000d40  4d 6f 6e 6f 74 6f 6e 69  63 54 69 6d 65 22 0d 06  |MonotonicTime"..|
00000d50  36 13 4d 4f 56 20 52 30  2c 52 30 2c 41 53 52 23  |6.MOV R0,R0,ASR#|
00000d60  31 0d 06 40 14 4c 44 52  20 52 31 2c 6c 61 73 74  |1..@.LDR R1,last|
00000d70  74 69 6d 65 25 0d 06 4a  14 53 54 52 20 52 30 2c  |time%..J.STR R0,|
00000d80  6c 61 73 74 74 69 6d 65  25 0d 06 54 10 53 55 42  |lasttime%..T.SUB|
00000d90  20 52 30 2c 52 30 2c 52  31 0d 06 5e 0e 43 4d 50  | R0,R0,R1..^.CMP|
00000da0  20 52 30 2c 23 31 30 0d  06 68 10 4d 4f 56 48 49  | R0,#10..h.MOVHI|
00000db0  20 52 30 2c 23 31 30 0d  06 72 0e 2e 74 69 6d 65  | R0,#10..r..time|
00000dc0  6c 6f 6f 70 25 0d 06 7c  0e 42 4c 20 66 6f 72 63  |loop%..|.BL forc|
00000dd0  65 73 25 0d 06 86 0c 42  4c 20 6d 6f 76 65 25 0d  |es%....BL move%.|
00000de0  06 90 11 53 55 42 53 20  52 30 2c 52 30 2c 23 31  |...SUBS R0,R0,#1|
00000df0  0d 06 9a 11 42 47 54 20  74 69 6d 65 6c 6f 6f 70  |....BGT timeloop|
00000e00  25 0d 06 a4 0c 42 4c 20  70 6c 6f 74 25 0d 06 ae  |%....BL plot%...|
00000e10  10 4c 44 52 20 52 31 2c  62 61 6e 6b 25 0d 06 b8  |.LDR R1,bank%...|
00000e20  0f 4d 4f 56 20 52 30 2c  23 31 31 33 0d 06 c2 11  |.MOV R0,#113....|
00000e30  53 57 49 20 22 4f 53 5f  42 79 74 65 22 0d 06 cc  |SWI "OS_Byte"...|
00000e40  1b 4c 44 4d 46 44 20 52  31 33 21 2c 7b 52 30 2d  |.LDMFD R13!,{R0-|
00000e50  52 31 32 2c 50 43 7d 5e  0d 06 d6 05 3a 0d 06 e0  |R12,PC}^....:...|
00000e60  0c 2e 66 6f 72 63 65 73  25 0d 06 ea 1b 53 54 4d  |..forces%....STM|
00000e70  46 44 20 52 31 33 21 2c  7b 52 30 2d 52 31 32 2c  |FD R13!,{R0-R12,|
00000e80  52 31 34 7d 0d 06 f4 18  4f 50 54 20 a4 61 64 72  |R14}....OPT .adr|
00000e90  28 31 32 2c 67 72 69 64  25 2c 32 29 0d 06 fe 22  |(12,grid%,2)..."|
00000ea0  41 44 44 20 52 31 31 2c  52 31 32 2c 23 31 36 2a  |ADD R11,R12,#16*|
00000eb0  77 69 64 74 68 25 2a 68  65 69 67 68 74 25 0d 07  |width%*height%..|
00000ec0  08 1a 53 55 42 20 52 31  31 2c 52 31 31 2c 23 31  |..SUB R11,R11,#1|
00000ed0  36 2a 77 69 64 74 68 25  0d 07 12 13 4d 4f 56 20  |6*width%....MOV |
00000ee0  52 38 2c 23 68 65 69 67  68 74 25 0d 07 1c 0b 2e  |R8,#height%.....|
00000ef0  79 6c 6f 6f 70 25 0d 07  26 1a 41 44 44 20 52 31  |yloop%..&.ADD R1|
00000f00  30 2c 52 31 32 2c 23 31  36 2a 77 69 64 74 68 25  |0,R12,#16*width%|
00000f10  0d 07 30 13 53 55 42 20  52 31 30 2c 52 31 30 2c  |..0.SUB R10,R10,|
00000f20  23 31 36 0d 07 3a 19 53  55 42 20 52 38 2c 52 38  |#16..:.SUB R8,R8|
00000f30  2c 23 77 69 64 74 68 25  3c 3c 31 36 0d 07 44 0b  |,#width%<<16..D.|
00000f40  2e 78 6c 6f 6f 70 25 0d  07 4e 1b 4c 44 4d 49 41  |.xloop%..N.LDMIA|
00000f50  20 52 31 32 2c 7b 52 30  2d 52 31 2c 52 32 2d 52  | R12,{R0-R1,R2-R|
00000f60  33 7d 0d 07 58 1b 4c 44  4d 49 41 20 52 31 31 2c  |3}..X.LDMIA R11,|
00000f70  7b 52 34 2d 52 35 2c 52  36 2d 52 37 7d 0d 07 62  |{R4-R5,R6-R7}..b|
00000f80  10 53 55 42 20 52 39 2c  52 34 2c 52 30 0d 07 6c  |.SUB R9,R4,R0..l|
00000f90  18 41 44 44 20 52 31 2c  52 31 2c 52 39 2c 41 53  |.ADD R1,R1,R9,AS|
00000fa0  52 23 4b 4b 25 0d 07 76  18 53 55 42 20 52 35 2c  |R#KK%..v.SUB R5,|
00000fb0  52 35 2c 52 39 2c 41 53  52 23 4b 4b 25 0d 07 80  |R5,R9,ASR#KK%...|
00000fc0  10 53 55 42 20 52 39 2c  52 36 2c 52 32 0d 07 8a  |.SUB R9,R6,R2...|
00000fd0  18 41 44 44 20 52 33 2c  52 33 2c 52 39 2c 41 53  |.ADD R3,R3,R9,AS|
00000fe0  52 23 4b 4b 25 0d 07 94  18 53 55 42 20 52 37 2c  |R#KK%....SUB R7,|
00000ff0  52 37 2c 52 39 2c 41 53  52 23 4b 4b 25 0d 07 9e  |R7,R9,ASR#KK%...|
00001000  1c 53 54 4d 49 41 20 52  31 31 21 2c 7b 52 34 2d  |.STMIA R11!,{R4-|
00001010  52 35 2c 52 36 2d 52 37  7d 0d 07 a8 1b 4c 44 4d  |R5,R6-R7}....LDM|
00001020  49 41 20 52 31 30 2c 7b  52 34 2d 52 35 2c 52 36  |IA R10,{R4-R5,R6|
00001030  2d 52 37 7d 0d 07 b2 10  53 55 42 20 52 39 2c 52  |-R7}....SUB R9,R|
00001040  34 2c 52 30 0d 07 bc 18  41 44 44 20 52 31 2c 52  |4,R0....ADD R1,R|
00001050  31 2c 52 39 2c 41 53 52  23 4b 4b 25 0d 07 c6 18  |1,R9,ASR#KK%....|
00001060  53 55 42 20 52 35 2c 52  35 2c 52 39 2c 41 53 52  |SUB R5,R5,R9,ASR|
00001070  23 4b 4b 25 0d 07 d0 10  53 55 42 20 52 39 2c 52  |#KK%....SUB R9,R|
00001080  36 2c 52 32 0d 07 da 18  41 44 44 20 52 33 2c 52  |6,R2....ADD R3,R|
00001090  33 2c 52 39 2c 41 53 52  23 4b 4b 25 0d 07 e4 18  |3,R9,ASR#KK%....|
000010a0  53 55 42 20 52 37 2c 52  37 2c 52 39 2c 41 53 52  |SUB R7,R7,R9,ASR|
000010b0  23 4b 4b 25 0d 07 ee 1b  53 54 4d 49 41 20 52 31  |#KK%....STMIA R1|
000010c0  30 2c 7b 52 34 2d 52 35  2c 52 36 2d 52 37 7d 0d  |0,{R4-R5,R6-R7}.|
000010d0  07 f8 0f 4d 4f 56 20 52  31 30 2c 52 31 32 0d 08  |...MOV R10,R12..|
000010e0  02 1c 53 54 4d 49 41 20  52 31 32 21 2c 7b 52 30  |..STMIA R12!,{R0|
000010f0  2d 52 31 2c 52 32 2d 52  33 7d 0d 08 0c 15 41 44  |-R1,R2-R3}....AD|
00001100  44 53 20 52 38 2c 52 38  2c 23 31 3c 3c 31 36 0d  |DS R8,R8,#1<<16.|
00001110  08 16 0e 42 4c 45 20 78  6c 6f 6f 70 25 0d 08 20  |...BLE xloop%.. |
00001120  1a 53 55 42 20 52 31 31  2c 52 31 32 2c 23 31 36  |.SUB R11,R12,#16|
00001130  2a 77 69 64 74 68 25 0d  08 2a 11 53 55 42 53 20  |*width%..*.SUBS |
00001140  52 38 2c 52 38 2c 23 31  0d 08 34 0e 42 47 54 20  |R8,R8,#1..4.BGT |
00001150  79 6c 6f 6f 70 25 0d 08  3e 1b 4c 44 4d 46 44 20  |yloop%..>.LDMFD |
00001160  52 31 33 21 2c 7b 52 30  2d 52 31 32 2c 50 43 7d  |R13!,{R0-R12,PC}|
00001170  5e 0d 08 48 05 3a 0d 08  52 0a 2e 6d 6f 76 65 25  |^..H.:..R..move%|
00001180  0d 08 5c 1b 53 54 4d 46  44 20 52 31 33 21 2c 7b  |..\.STMFD R13!,{|
00001190  52 30 2d 52 31 32 2c 52  31 34 7d 0d 08 66 18 4f  |R0-R12,R14}..f.O|
000011a0  50 54 20 a4 61 64 72 28  31 32 2c 67 72 69 64 25  |PT .adr(12,grid%|
000011b0  2c 32 29 0d 08 70 1a 4d  4f 56 20 52 38 2c 23 77  |,2)..p.MOV R8,#w|
000011c0  69 64 74 68 25 2a 68 65  69 67 68 74 25 0d 08 7a  |idth%*height%..z|
000011d0  0a 2e 6c 6f 6f 70 25 0d  08 84 27 4c 44 4d 49 41  |..loop%...'LDMIA|
000011e0  20 52 31 32 2c 7b 52 30  2d 52 31 2c 52 32 2d 52  | R12,{R0-R1,R2-R|
000011f0  33 2c 52 34 2d 52 35 2c  52 36 2d 52 37 7d 0d 08  |3,R4-R5,R6-R7}..|
00001200  8e 19 53 55 42 53 20 52  31 2c 52 31 2c 52 31 2c  |..SUBS R1,R1,R1,|
00001210  41 53 52 23 46 46 25 0d  08 98 12 53 55 42 47 54  |ASR#FF%....SUBGT|
00001220  20 52 31 2c 52 31 2c 23  31 0d 08 a2 10 41 44 44  | R1,R1,#1....ADD|
00001230  20 52 30 2c 52 30 2c 52  31 0d 08 ac 19 53 55 42  | R0,R0,R1....SUB|
00001240  53 20 52 33 2c 52 33 2c  52 33 2c 41 53 52 23 46  |S R3,R3,R3,ASR#F|
00001250  46 25 0d 08 b6 12 53 55  42 47 54 20 52 33 2c 52  |F%....SUBGT R3,R|
00001260  33 2c 23 31 0d 08 c0 10  41 44 44 20 52 32 2c 52  |3,#1....ADD R2,R|
00001270  32 2c 52 33 0d 08 ca 19  53 55 42 53 20 52 35 2c  |2,R3....SUBS R5,|
00001280  52 35 2c 52 35 2c 41 53  52 23 46 46 25 0d 08 d4  |R5,R5,ASR#FF%...|
00001290  12 53 55 42 47 54 20 52  35 2c 52 35 2c 23 31 0d  |.SUBGT R5,R5,#1.|
000012a0  08 de 10 41 44 44 20 52  34 2c 52 34 2c 52 35 0d  |...ADD R4,R4,R5.|
000012b0  08 e8 19 53 55 42 53 20  52 37 2c 52 37 2c 52 37  |...SUBS R7,R7,R7|
000012c0  2c 41 53 52 23 46 46 25  0d 08 f2 12 53 55 42 47  |,ASR#FF%....SUBG|
000012d0  54 20 52 37 2c 52 37 2c  23 31 0d 08 fc 10 41 44  |T R7,R7,#1....AD|
000012e0  44 20 52 36 2c 52 36 2c  52 37 0d 09 06 28 53 54  |D R6,R6,R7...(ST|
000012f0  4d 49 41 20 52 31 32 21  2c 7b 52 30 2d 52 31 2c  |MIA R12!,{R0-R1,|
00001300  52 32 2d 52 33 2c 52 34  2d 52 35 2c 52 36 2d 52  |R2-R3,R4-R5,R6-R|
00001310  37 7d 0d 09 10 11 53 55  42 53 20 52 38 2c 52 38  |7}....SUBS R8,R8|
00001320  2c 23 32 0d 09 1a 0d 42  47 54 20 6c 6f 6f 70 25  |,#2....BGT loop%|
00001330  0d 09 24 1b 4c 44 4d 46  44 20 52 31 33 21 2c 7b  |..$.LDMFD R13!,{|
00001340  52 30 2d 52 31 32 2c 50  43 7d 5e 0d 09 2e 05 3a  |R0-R12,PC}^....:|
00001350  0d 09 38 0a 2e 70 6c 6f  74 25 0d 09 42 1b 53 54  |..8..plot%..B.ST|
00001360  4d 46 44 20 52 31 33 21  2c 7b 52 30 2d 52 31 32  |MFD R13!,{R0-R12|
00001370  2c 52 31 34 7d 0d 09 4c  14 4c 44 52 20 52 31 34  |,R14}..L.LDR R14|
00001380  2c 73 63 72 61 64 64 72  25 0d 09 56 1e 41 44 44  |,scraddr%..V.ADD|
00001390  20 52 31 34 2c 52 31 34  2c 23 38 2a 68 65 69 67  | R14,R14,#8*heig|
000013a0  68 74 25 2a 31 36 30 0d  09 60 18 4f 50 54 20 a4  |ht%*160..`.OPT .|
000013b0  61 64 72 28 31 32 2c 67  72 69 64 25 2c 32 29 0d  |adr(12,grid%,2).|
000013c0  09 6a 22 41 44 44 20 52  31 31 2c 52 31 32 2c 23  |.j"ADD R11,R12,#|
000013d0  31 36 2a 77 69 64 74 68  25 2a 68 65 69 67 68 74  |16*width%*height|
000013e0  25 0d 09 74 1a 53 55 42  20 52 31 31 2c 52 31 31  |%..t.SUB R11,R11|
000013f0  2c 23 31 36 2a 77 69 64  74 68 25 0d 09 7e 13 4d  |,#16*width%..~.M|
00001400  4f 56 20 52 38 2c 23 68  65 69 67 68 74 25 0d 09  |OV R8,#height%..|
00001410  88 0b 2e 79 6c 6f 6f 70  25 0d 09 92 1e 41 44 44  |...yloop%....ADD|
00001420  20 52 31 34 2c 52 31 34  2c 23 38 2a 77 69 64 74  | R14,R14,#8*widt|
00001430  68 25 3e 3e 33 2d 32 0d  09 9c 1a 41 44 44 20 52  |h%>>3-2....ADD R|
00001440  31 30 2c 52 31 32 2c 23  31 36 2a 77 69 64 74 68  |10,R12,#16*width|
00001450  25 0d 09 a6 13 53 55 42  20 52 31 30 2c 52 31 30  |%....SUB R10,R10|
00001460  2c 23 31 36 0d 09 b0 19  41 44 44 20 52 39 2c 52  |,#16....ADD R9,R|
00001470  31 31 2c 23 31 36 2a 77  69 64 74 68 25 0d 09 ba  |11,#16*width%...|
00001480  11 53 55 42 20 52 39 2c  52 39 2c 23 31 36 0d 09  |.SUB R9,R9,#16..|
00001490  c4 19 53 55 42 20 52 38  2c 52 38 2c 23 77 69 64  |..SUB R8,R8,#wid|
000014a0  74 68 25 3c 3c 31 32 0d  09 ce 0b 2e 78 6c 6f 6f  |th%<<12.....xloo|
000014b0  70 25 0d 09 d8 17 53 55  42 20 52 31 34 2c 52 31  |p%....SUB R14,R1|
000014c0  34 2c 23 38 3e 3e 33 2d  32 0d 09 e2 0f 4c 44 52  |4,#8>>3-2....LDR|
000014d0  20 52 30 2c 5b 52 39 5d  0d 09 ec 12 4c 44 52 20  | R0,[R9]....LDR |
000014e0  52 31 2c 5b 52 39 2c 23  38 5d 0d 09 f6 10 4c 44  |R1,[R9,#8]....LD|
000014f0  52 20 52 32 2c 5b 52 31  30 5d 0d 0a 00 13 4c 44  |R R2,[R10]....LD|
00001500  52 20 52 33 2c 5b 52 31  30 2c 23 38 5d 0d 0a 0a  |R R3,[R10,#8]...|
00001510  10 4c 44 52 20 52 34 2c  5b 52 31 31 5d 0d 0a 14  |.LDR R4,[R11]...|
00001520  13 4c 44 52 20 52 35 2c  5b 52 31 31 2c 23 38 5d  |.LDR R5,[R11,#8]|
00001530  0d 0a 1e 10 4c 44 52 20  52 36 2c 5b 52 31 32 5d  |....LDR R6,[R12]|
00001540  0d 0a 28 13 4c 44 52 20  52 37 2c 5b 52 31 32 2c  |..(.LDR R7,[R12,|
00001550  23 38 5d 0d 0a 32 10 53  55 42 20 52 34 2c 52 34  |#8]..2.SUB R4,R4|
00001560  2c 52 30 0d 0a 3c 13 4d  4f 56 20 52 34 2c 52 34  |,R0..<.MOV R4,R4|
00001570  2c 41 53 52 23 34 0d 0a  46 10 53 55 42 20 52 35  |,ASR#4..F.SUB R5|
00001580  2c 52 35 2c 52 31 0d 0a  50 13 4d 4f 56 20 52 35  |,R5,R1..P.MOV R5|
00001590  2c 52 35 2c 41 53 52 23  34 0d 0a 5a 10 53 55 42  |,R5,ASR#4..Z.SUB|
000015a0  20 52 36 2c 52 36 2c 52  32 0d 0a 64 13 4d 4f 56  | R6,R6,R2..d.MOV|
000015b0  20 52 36 2c 52 36 2c 41  53 52 23 34 0d 0a 6e 10  | R6,R6,ASR#4..n.|
000015c0  53 55 42 20 52 37 2c 52  37 2c 52 33 0d 0a 78 13  |SUB R7,R7,R3..x.|
000015d0  4d 4f 56 20 52 37 2c 52  37 2c 41 53 52 23 34 0d  |MOV R7,R7,ASR#4.|
000015e0  0a 82 16 41 44 44 20 52  30 2c 52 30 2c 52 34 2c  |...ADD R0,R0,R4,|
000015f0  41 53 52 23 31 0d 0a 8c  16 41 44 44 20 52 31 2c  |ASR#1....ADD R1,|
00001600  52 31 2c 52 35 2c 41 53  52 23 31 0d 0a 96 16 41  |R1,R5,ASR#1....A|
00001610  44 44 20 52 32 2c 52 32  2c 52 36 2c 41 53 52 23  |DD R2,R2,R6,ASR#|
00001620  31 0d 0a a0 16 41 44 44  20 52 33 2c 52 33 2c 52  |1....ADD R3,R3,R|
00001630  37 2c 41 53 52 23 31 0d  0a aa 10 53 55 42 20 52  |7,ASR#1....SUB R|
00001640  32 2c 52 32 2c 52 30 0d  0a b4 13 4d 4f 56 20 52  |2,R2,R0....MOV R|
00001650  32 2c 52 32 2c 41 53 52  23 34 0d 0a be 10 53 55  |2,R2,ASR#4....SU|
00001660  42 20 52 33 2c 52 33 2c  52 31 0d 0a c8 13 4d 4f  |B R3,R3,R1....MO|
00001670  56 20 52 33 2c 52 33 2c  41 53 52 23 34 0d 0a d2  |V R3,R3,ASR#4...|
00001680  10 53 55 42 20 52 36 2c  52 36 2c 52 34 0d 0a dc  |.SUB R6,R6,R4...|
00001690  13 4d 4f 56 20 52 36 2c  52 36 2c 41 53 52 23 34  |.MOV R6,R6,ASR#4|
000016a0  0d 0a e6 10 53 55 42 20  52 37 2c 52 37 2c 52 35  |....SUB R7,R7,R5|
000016b0  0d 0a f0 13 4d 4f 56 20  52 37 2c 52 37 2c 41 53  |....MOV R7,R7,AS|
000016c0  52 23 34 0d 0a fa 16 41  44 44 20 52 30 2c 52 30  |R#4....ADD R0,R0|
000016d0  2c 52 32 2c 41 53 52 23  31 0d 0b 04 16 41 44 44  |,R2,ASR#1....ADD|
000016e0  20 52 31 2c 52 31 2c 52  33 2c 41 53 52 23 31 0d  | R1,R1,R3,ASR#1.|
000016f0  0b 0e 16 41 44 44 20 52  34 2c 52 34 2c 52 36 2c  |...ADD R4,R4,R6,|
00001700  41 53 52 23 31 0d 0b 18  16 41 44 44 20 52 35 2c  |ASR#1....ADD R5,|
00001710  52 35 2c 52 37 2c 41 53  52 23 31 0d 0b 22 16 53  |R5,R7,ASR#1..".S|
00001720  55 42 20 52 31 34 2c 52  31 34 2c 23 38 2a 31 36  |UB R14,R14,#8*16|
00001730  30 0d 0b 2c 14 41 44 44  20 52 38 2c 52 38 2c 23  |0..,.ADD R8,R8,#|
00001740  38 3c 3c 32 34 0d 0b 36  0e 2e 62 6c 69 74 6c 6f  |8<<24..6..blitlo|
00001750  6f 70 25 0d 0b 40 0e 4d  4f 56 20 52 31 31 2c 23  |op%..@.MOV R11,#|
00001760  30 0d 0b 4a 15 5d 3a e3  55 25 3d 30 b8 37 3a 5b  |0..J.]:.U%=0.7:[|
00001770  4f 50 54 20 54 25 0d 0b  54 17 53 55 42 20 52 31  |OPT T%..T.SUB R1|
00001780  32 2c 52 31 2c 52 30 2c  4c 53 52 23 31 0d 0b 5e  |2,R1,R0,LSR#1..^|
00001790  18 4d 4f 56 20 52 31 32  2c 52 31 32 2c 4c 53 52  |.MOV R12,R12,LSR|
000017a0  23 33 32 2d 38 0d 0b 68  17 54 53 54 20 52 31 32  |#32-8..h.TST R12|
000017b0  2c 52 30 2c 4c 53 52 23  33 32 2d 38 0d 0b 72 1a  |,R0,LSR#32-8..r.|
000017c0  41 44 44 45 51 20 52 31  31 2c 52 31 31 2c 23 31  |ADDEQ R11,R11,#1|
000017d0  3c 3c 34 2a 55 25 0d 0b  7c 10 41 44 44 20 52 30  |<<4*U%..|.ADD R0|
000017e0  2c 52 30 2c 52 34 0d 0b  86 10 41 44 44 20 52 31  |,R0,R4....ADD R1|
000017f0  2c 52 31 2c 52 35 0d 0b  90 17 53 55 42 20 52 31  |,R1,R5....SUB R1|
00001800  32 2c 52 31 2c 52 30 2c  4c 53 52 23 31 0d 0b 9a  |2,R1,R0,LSR#1...|
00001810  18 4d 4f 56 20 52 31 32  2c 52 31 32 2c 4c 53 52  |.MOV R12,R12,LSR|
00001820  23 33 32 2d 38 0d 0b a4  17 54 53 54 20 52 31 32  |#32-8....TST R12|
00001830  2c 52 30 2c 4c 53 52 23  33 32 2d 38 0d 0b ae 1a  |,R0,LSR#32-8....|
00001840  41 44 44 45 51 20 52 31  31 2c 52 31 31 2c 23 31  |ADDEQ R11,R11,#1|
00001850  3c 3c 34 2a 55 25 0d 0b  b8 10 41 44 44 20 52 30  |<<4*U%....ADD R0|
00001860  2c 52 30 2c 52 34 0d 0b  c2 10 41 44 44 20 52 31  |,R0,R4....ADD R1|
00001870  2c 52 31 2c 52 35 0d 0b  cc 0f 5d 3a ed 3a 5b 4f  |,R1,R5....]:.:[O|
00001880  50 54 20 54 25 0d 0b d6  16 53 55 42 20 52 30 2c  |PT T%....SUB R0,|
00001890  52 30 2c 52 34 2c 41 53  4c 23 34 0d 0b e0 16 53  |R0,R4,ASL#4....S|
000018a0  55 42 20 52 31 2c 52 31  2c 52 35 2c 41 53 4c 23  |UB R1,R1,R5,ASL#|
000018b0  34 0d 0b ea 10 41 44 44  20 52 30 2c 52 30 2c 52  |4....ADD R0,R0,R|
000018c0  32 0d 0b f4 10 41 44 44  20 52 31 2c 52 31 2c 52  |2....ADD R1,R1,R|
000018d0  33 0d 0b fe 10 41 44 44  20 52 34 2c 52 34 2c 52  |3....ADD R4,R4,R|
000018e0  36 0d 0c 08 10 41 44 44  20 52 35 2c 52 35 2c 52  |6....ADD R5,R5,R|
000018f0  37 0d 0c 12 15 5d 3a e3  55 25 3d 30 b8 37 3a 5b  |7....]:.U%=0.7:[|
00001900  4f 50 54 20 54 25 0d 0c  1c 17 53 55 42 20 52 31  |OPT T%....SUB R1|
00001910  32 2c 52 31 2c 52 30 2c  4c 53 52 23 31 0d 0c 26  |2,R1,R0,LSR#1..&|
00001920  18 4d 4f 56 20 52 31 32  2c 52 31 32 2c 4c 53 52  |.MOV R12,R12,LSR|
00001930  23 33 32 2d 38 0d 0c 30  17 54 53 54 20 52 31 32  |#32-8..0.TST R12|
00001940  2c 52 30 2c 4c 53 52 23  33 32 2d 38 0d 0c 3a 1a  |,R0,LSR#32-8..:.|
00001950  41 44 44 45 51 20 52 31  31 2c 52 31 31 2c 23 31  |ADDEQ R11,R11,#1|
00001960  3c 3c 34 2a 55 25 0d 0c  44 10 41 44 44 20 52 30  |<<4*U%..D.ADD R0|
00001970  2c 52 30 2c 52 34 0d 0c  4e 10 41 44 44 20 52 31  |,R0,R4..N.ADD R1|
00001980  2c 52 31 2c 52 35 0d 0c  58 17 53 55 42 20 52 31  |,R1,R5..X.SUB R1|
00001990  32 2c 52 31 2c 52 30 2c  4c 53 52 23 31 0d 0c 62  |2,R1,R0,LSR#1..b|
000019a0  18 4d 4f 56 20 52 31 32  2c 52 31 32 2c 4c 53 52  |.MOV R12,R12,LSR|
000019b0  23 33 32 2d 38 0d 0c 6c  17 54 53 54 20 52 31 32  |#32-8..l.TST R12|
000019c0  2c 52 30 2c 4c 53 52 23  33 32 2d 38 0d 0c 76 1a  |,R0,LSR#32-8..v.|
000019d0  41 44 44 45 51 20 52 31  31 2c 52 31 31 2c 23 31  |ADDEQ R11,R11,#1|
000019e0  3c 3c 34 2a 55 25 0d 0c  80 10 41 44 44 20 52 30  |<<4*U%....ADD R0|
000019f0  2c 52 30 2c 52 34 0d 0c  8a 10 41 44 44 20 52 31  |,R0,R4....ADD R1|
00001a00  2c 52 31 2c 52 35 0d 0c  94 0f 5d 3a ed 3a 5b 4f  |,R1,R5....]:.:[O|
00001a10  50 54 20 54 25 0d 0c 9e  16 53 55 42 20 52 30 2c  |PT T%....SUB R0,|
00001a20  52 30 2c 52 34 2c 41 53  4c 23 34 0d 0c a8 16 53  |R0,R4,ASL#4....S|
00001a30  55 42 20 52 31 2c 52 31  2c 52 35 2c 41 53 4c 23  |UB R1,R1,R5,ASL#|
00001a40  34 0d 0c b2 10 41 44 44  20 52 30 2c 52 30 2c 52  |4....ADD R0,R0,R|
00001a50  32 0d 0c bc 10 41 44 44  20 52 31 2c 52 31 2c 52  |2....ADD R1,R1,R|
00001a60  33 0d 0c c6 10 41 44 44  20 52 34 2c 52 34 2c 52  |3....ADD R4,R4,R|
00001a70  36 0d 0c d0 10 41 44 44  20 52 35 2c 52 35 2c 52  |6....ADD R5,R5,R|
00001a80  37 0d 0c da 16 53 54 52  20 52 31 31 2c 5b 52 31  |7....STR R11,[R1|
00001a90  34 5d 2c 23 31 36 30 0d  0c e4 15 53 55 42 53 20  |4],#160....SUBS |
00001aa0  52 38 2c 52 38 2c 23 31  3c 3c 32 34 0d 0c ee 11  |R8,R8,#1<<24....|
00001ab0  42 47 54 20 62 6c 69 74  6c 6f 6f 70 25 0d 0c f8  |BGT blitloop%...|
00001ac0  0f 4d 4f 56 20 52 31 32  2c 52 31 30 0d 0d 02 13  |.MOV R12,R10....|
00001ad0  53 55 42 20 52 31 30 2c  52 31 30 2c 23 31 36 0d  |SUB R10,R10,#16.|
00001ae0  0d 0c 0e 4d 4f 56 20 52  31 31 2c 52 39 0d 0d 16  |...MOV R11,R9...|
00001af0  11 53 55 42 20 52 39 2c  52 39 2c 23 31 36 0d 0d  |.SUB R9,R9,#16..|
00001b00  20 15 41 44 44 53 20 52  38 2c 52 38 2c 23 31 3c  | .ADDS R8,R8,#1<|
00001b10  3c 31 32 0d 0d 2a 0e 42  4c 45 20 78 6c 6f 6f 70  |<12..*.BLE xloop|
00001b20  25 0d 0d 34 16 53 55 42  20 52 31 34 2c 52 31 34  |%..4.SUB R14,R14|
00001b30  2c 23 38 2a 31 36 30 0d  0d 3e 0f 4d 4f 56 20 52  |,#8*160..>.MOV R|
00001b40  31 32 2c 52 31 31 0d 0d  48 1a 53 55 42 20 52 31  |12,R11..H.SUB R1|
00001b50  31 2c 52 31 31 2c 23 31  36 2a 77 69 64 74 68 25  |1,R11,#16*width%|
00001b60  0d 0d 52 11 53 55 42 53  20 52 38 2c 52 38 2c 23  |..R.SUBS R8,R8,#|
00001b70  31 0d 0d 5c 0e 42 47 54  20 79 6c 6f 6f 70 25 0d  |1..\.BGT yloop%.|
00001b80  0d 66 1b 4c 44 4d 46 44  20 52 31 33 21 2c 7b 52  |.f.LDMFD R13!,{R|
00001b90  30 2d 52 31 32 2c 50 43  7d 5e 0d 0d 70 05 3a 0d  |0-R12,PC}^..p.:.|
00001ba0  0d 7a 35 5d 3a e7 50 25  3e 63 6f 64 65 25 2b 63  |.z5]:.P%>code%+c|
00001bb0  6f 64 65 6c 65 6e 25 8c  85 32 35 35 2c 22 43 6f  |odelen%..255,"Co|
00001bc0  64 65 20 69 73 6e 27 74  20 62 69 67 20 65 6e 6f  |de isn't big eno|
00001bd0  75 67 68 22 0d 0d 84 05  ed 0d 0d 8e 05 e1 0d ff  |ugh"............|
00001be0