Home » Archimedes archive » Acorn User » AU 1998-09.adf » Regulars » StarInfo/Brobecker/EnvMap
StarInfo/Brobecker/EnvMap
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 1998-09.adf » Regulars |
Filename: | StarInfo/Brobecker/EnvMap |
Read OK: | ✔ |
File size: | 1E64 bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
10REM>>> Environment Mapping 20REM Alain BROBECKER (baah/Arm's Tech) on 05-Apr-1998 30 40REM==== ASM CODE ============================================================ 50DIMcode% 1024:FORopt%=0TO2STEP2:P%=code%:[opt opt% 60.old_stack ; Used to save r13, will overwrite on 'envmap' routine 70 80;\\\\\\\\\\\\\\\\\\\\\\\\\\\ 90; Calculate Environment Map > 100;/////////////////////////// 110;This routine creates the environment map. We calculate the intensity as an 120;affine function of the distance d=SQR(x^2+y^2). To allow dithering in mode12, 130;pixel_table contains a raster when offset is positive (even lines) and another 140;one when offset is negative (odd lines). 150; r0=adress where to save 128*128 environment map 160.envmap 170 stmfd r13!,{r0-r6,r14} 180 adr r1,pixel_table ; intensity to mode12_pixel table 190 mov r2,#256 ; y coord 200.env_y 210 mov r3,#256 ; x coord 220 sub r5,r2,#128 ; r5=y-128 230 mul r4,r5,r5 ; r4=(y-128)^2 240.env_x 250 sub r14,r3,#128 ; r14=x-128 260 mla r6,r14,r14,r4 ; r6=(x-128)^2+(y-128)^2 270 FNsqrt(5,6,14) ; r5=sqrt((x-128)^2+(y-128)^2) 280 mov r5,r5,lsl #1 290 rsbS r5,r5,#255 ; r5=255-2*sqrt(...) 300 movMI r5,#0 310 tst r2,#1 ; Parity of line? 320 ldrEQB r5,[r1,r5,lsr #3] 330 ldrNEB r5,[r1,-r5,lsr #3] 340 strB r5,[r0],#1 ; Save pixel 350 subS r3,r3,#1:bNE env_x ; Next pixel 360 subS r2,r2,#1:bNE env_y ; Next line 370 ldmfd r13!,{r0-r6,pc}^ 380 390 dcd &feffffff:dcd &dcddedee:dcd &babbcbcc:dcd &9899a9aa 400 dcd &76778788:dcd &54556566:dcd &32334344:dcd &10112122 410.pixel_table 420 dcd &12110100:dcd &34332322:dcd &56554544:dcd &78776766 430 dcd &9a998988:dcd &bcbbabaa:dcd &deddcdcc:dcd &ffffefee 440 450;\\\\\\\\\\\\\\\\\\\\\\\\\\\\ 460; Compute Displacements Table> 470;//////////////////////////// 480;This routine use the height field image to create the displacement table. 490;Formulaes are disp_x(x;y)=h(x+1;y)-h(x-1;y) & disp_y(x;y)=h(x;y+1)-h(x;y-1). 500; r0=adress of heights 510; r1=table which will contain disp_x, disp_y 520.displacements 530 stmfd r13!,{r0-r5,r14} 540 mov r2,#0 ; y<<24 550.disp_y 560 mov r3,#0 ; x<<24 570.disp_x 580 add r5,r0,r2,lsr #16 ; r5=h(0;y) 590 sub r4,r3,#1<<24 ; r4=(x-1 mod 255)<<24 600 ldrB r4,[r5,r4,lsr #24] ; r4=h(x-1;y) 610 add r14,r3,#1<<24 ; r14=(x+1 mod 255)<<24 620 ldrB r14,[r5,r14,lsr #24] ; r14=h(x+1;y) 630 sub r4,r14,r4 ; r4=h(x+1;y)-h(x-1;y) 640 mov r4,r4,asr #1 650 add r4,r4,#128 660 strB r4,[r1],#1 670 add r5,r0,r3,lsr #24 ; r5=h(x;0) 680 sub r4,r2,#1<<24 ; r4=(y-1 mod 255)<<24 690 ldrB r4,[r5,r4,lsr #16] ; r4=h(x;y-1) 700 add r14,r2,#1<<24 ; r14=(y+1 mod 255)<<24 710 ldrB r14,[r5,r14,lsr #16] ; r14=h(x;y+1) 720 sub r4,r14,r4 ; r4=h(x;y+1)-h(x;y-1) 730 mov r4,r4,asr #1 740 add r4,r4,#128 750 strB r4,[r1],#1 760 addS r3,r3,#1<<24:bNE disp_x ; x=(x+1 mod255)<<24, continue if <>0 770 addS r2,r2,#1<<24:bNE disp_x ; y=(y+1 mod255)<<24, continue if <>0 780 ldmfd r13!,{r0-r5,pc}^ 790 800;\\\\\\\\\\\\\\\\\\\\\\\\\\ 810; Draw Environment Mapping > 820;////////////////////////// 830;For each screen pixel we compute which pixel to copy from environment map. 840;Formula is screen(x;y)=envmap(disp_x(x;y)+lx-x;disp_y(x;y)+ly-y). 850; r0=vram 860; r1=table with disp_x, disp_y 870; r2=adress of 256*256 environment map 880; r3=lx 890; r4=ly 900.draw_env 910 stmfd r13!,{r0-r12,r14} 920 str r13,old_stack 930 mov r5,#0 ; r5=y<<24 940.draw_y 950 mov r6,#0 ; r6=x<<24 960 sub r11,r4,r5,lsr #24 ; r11=ly-y 970.draw_x4 980 sub r12,r3,r6,lsr #24 ; r12=lx-x 990 ldmia r1!,{r13,r14} ; Load 4*2 displacements 1000 mov r9,#0 ; Will contain 4 points 1010 and r7,r13,#&ff ; r7=disp_x 1020 and r8,r13,#&ff00 ; r8=disp_y<<8 1030 addS r7,r7,r12 ; r7=dx=disp_x+lx-x 1040 addGES r8,r8,r11,lsl #8 ; r8=dy<<8=(disp_y+ly-y)<<8 1050 bMI draw_next1 ; Don't draw if dx<0 or dy<0 1060 cmp r7,#&ff 1070 cmpLE r8,#&ff00 1080 addLE r8,r7,r8 ; If dx<256 and dy<256, r8=dy<<8+dx 1090 ldrLEB r9,[r2,r8] ; And put envmap(dx;dy) in r9 1100.draw_next1 1110 sub r12,r12,#1 ; lx-x-=1 (ie x+=1) 1120 and r7,r13,#&ff0000 ; Similar, 2nd pixel 1130 addS r7,r7,r12,lsl #16 1140 addGES r8,r11,r13,lsr #24 1150 bMI draw_next2 1160 cmp r7,#&ff0000 1170 cmpLE r8,#&ff 1180 addLE r8,r7,r8,lsl #24 1190 ldrLEB r8,[r2,r8,lsr #16] 1200 addLE r9,r9,r8,lsl #8 1210.draw_next2 1220 sub r12,r12,#1 1230 and r7,r14,#&ff ; 3rd pixel 1240 and r8,r14,#&ff00 1250 addS r7,r7,r12 1260 addGES r8,r8,r11,lsl #8 1270 bMI draw_next3 1280 cmp r7,#&ff 1290 cmpLE r8,#&ff00 1300 addLE r8,r7,r8 1310 ldrLEB r8,[r2,r8] 1320 addLE r9,r9,r8,lsl #16 1330.draw_next3 1340 sub r12,r12,#1 1350 and r7,r14,#&ff0000 ; 4th pixel 1360 addS r7,r7,r12,lsl #16 1370 addGES r8,r11,r14,lsr #24 1380 bMI draw_next4 1390 cmp r7,#&ff0000 1400 cmpLE r8,#&ff 1410 addLE r8,r7,r8,lsl #24 1420 ldrLEB r8,[r2,r8,lsr #16] 1430 addLE r9,r9,r8,lsl #24 1440.draw_next4 1450 str r9,[r0],#4 ; Save 4 pixels 1460 addS r6,r6,#4<<24:bNE draw_x4 ; x+=4<<24, continue if <>0 1470 add r0,r0,#320-256 ; Next vram line 1480 addS r5,r5,#1<<24:bNE draw_y ; y+=1<<24, continue if <>0 1490 ldr r13,old_stack 1500 ldmfd r13!,{r0-r12,pc}^ 1510 1520]:NEXTopt%:PRINT"Assembly code is ";P%-code%;" bytes long" 1530 1540REM==== BASIC CODE ========================================================== 1550DIMenvmap% 65536 1560DIMdisp% 65536*2 1570REMLoad height field and compute displacements 1580PRINT"Computing displacements" 1590A%=envmap%:B%=disp% 1600f%=OPENIN("Height256"):SYS"OS_GBPB",4,f%,A%,65536:CLOSE#f% 1610CALLdisplacements 1620REMCreate environment map 1630PRINT"Computing environment map" 1640A%=envmap%:CALLenvmap 1650 1660REMScreen & color initialisation. Then let the show begin. 1670MODE15:MODE12:OFF:DIMv% 8:!v%=148:v%!4=-1:SYS"OS_ReadVduVariables",v%,v%:v%=!v% 1680FORc%=1TO15 1690 b%=c%*17+34:IFb%>255THENb%=255 1700 COLOURc%,c%*17,c%*17,b% 1710NEXTc% 1720b%=2 1730B%=disp% 1740C%=envmap% 1750REPEAT 1760 WAIT:SYS"OS_Byte",&71,b%:b%=b%EOR3:SYS"OS_Byte",&70,b% 1770 A%=v%+(b%>>1)*81920+32 1780 MOUSEx%,y%,z% 1790 D%=(x%>>2)-32:E%=256-(y%>>2) 1800 CALLdraw_env 1810UNTILFALSE 1820 1830REM==== MACROS ==================================================== 1840REMm0=sqrt(m1). 1850DEFFNsqrt(m0,m1,m2) 1860LOCALn% 1870[opt opt% 1880 mov m0,#0 ; This is ripped from Jan/BASS. 1890 mov m2,#1<<30 ; | 1900 cmp m1,m2 ; | 1910 subHS m1,m0,m2 ; | 1920 adc m0,m0,m0 ; | 1930]:FORn%=2TO30STEP2:[opt opt% 1940 add m2,m0,#1<<30 ; | 1950 cmp m1,m2,ror #n% ; | 1960 subHS m1,m1,m2,ror #n% ; | 1970 adc m0,m0,m0 ; End of ripped code. 1980]:NEXTn%:[opt opt% 1990 cmp m1,m0 ; Flags=val-root. 2000 addPL m0,m0,#1 ; Round to nearest integer. 2010]:=""
�>>> Environment Mapping 9� Alain BROBECKER (baah/Arm's Tech) on 05-Apr-1998 (O�==== ASM CODE ============================================================ 2.�code% 1024:�opt%=0�2�2:P%=code%:[opt opt% <R.old_stack ; Used to save r13, will overwrite on 'envmap' routine F P ;\\\\\\\\\\\\\\\\\\\\\\\\\\\ Z!; Calculate Environment Map > d ;/////////////////////////// nO;This routine creates the environment map. We calculate the intensity as an xP;affine function of the distance d=�(x^2+y^2). To allow dithering in mode12, �S;pixel_table contains a raster when offset is positive (even lines) and another �-;one when offset is negative (odd lines). �?; r0=adress where to save 128*128 environment map �.envmap � stmfd r13!,{r0-r6,r14} �I adr r1,pixel_table ; intensity to mode12_pixel table �1 mov r2,#256 ; y coord � .env_y �1 mov r3,#256 ; x coord �2 sub r5,r2,#128 ; r5=y-128 �6 mul r4,r5,r5 ; r4=(y-128)^2 � .env_x �3 sub r14,r3,#128 ; r14=x-128 @ mla r6,r14,r14,r4 ; r6=(x-128)^2+(y-128)^2 E �sqrt(5,6,14) ; r5=sqrt((x-128)^2+(y-128)^2) mov r5,r5,lsl #1 "< rsbS r5,r5,#255 ; r5=255-2*sqrt(...) , movMI r5,#0 69 tst r2,#1 ; Parity of line? @! ldrEQB r5,[r1,r5,lsr #3] J" ldrNEB r5,[r1,-r5,lsr #3] T4 strB r5,[r0],#1 ; Save pixel ^4 subS r3,r3,#1:bNE env_x ; Next pixel h3 subS r2,r2,#1:bNE env_y ; Next line r ldmfd r13!,{r0-r6,pc}^ | �= dcd &feffffff:dcd &dcddedee:dcd &babbcbcc:dcd &9899a9aa �= dcd &76778788:dcd &54556566:dcd &32334344:dcd &10112122 �.pixel_table �= dcd &12110100:dcd &34332322:dcd &56554544:dcd &78776766 �= dcd &9a998988:dcd &bcbbabaa:dcd &deddcdcc:dcd &ffffefee � �!;\\\\\\\\\\\\\\\\\\\\\\\\\\\\ �"; Compute Displacements Table> �!;//////////////////////////// �N;This routine use the height field image to create the displacement table. �Q;Formulaes are disp_x(x;y)=h(x+1;y)-h(x-1;y) & disp_y(x;y)=h(x;y+1)-h(x;y-1). �$; r0=adress of heights �:; r1=table which will contain disp_x, disp_y .displacements stmfd r13!,{r0-r5,r14} / mov r2,#0 ; y<<24 &.disp_y 0/ mov r3,#0 ; x<<24 :.disp_x D3 add r5,r0,r2,lsr #16 ; r5=h(0;y) N> sub r4,r3,#1<<24 ; r4=(x-1 mod 255)<<24 X5 ldrB r4,[r5,r4,lsr #24] ; r4=h(x-1;y) b? add r14,r3,#1<<24 ; r14=(x+1 mod 255)<<24 l6 ldrB r14,[r5,r14,lsr #24] ; r14=h(x+1;y) v> sub r4,r14,r4 ; r4=h(x+1;y)-h(x-1;y) � mov r4,r4,asr #1 � add r4,r4,#128 � strB r4,[r1],#1 �3 add r5,r0,r3,lsr #24 ; r5=h(x;0) �> sub r4,r2,#1<<24 ; r4=(y-1 mod 255)<<24 �5 ldrB r4,[r5,r4,lsr #16] ; r4=h(x;y-1) �? add r14,r2,#1<<24 ; r14=(y+1 mod 255)<<24 �6 ldrB r14,[r5,r14,lsr #16] ; r14=h(x;y+1) �> sub r4,r14,r4 ; r4=h(x;y+1)-h(x;y-1) � mov r4,r4,asr #1 � add r4,r4,#128 � strB r4,[r1],#1 �M addS r3,r3,#1<<24:bNE disp_x ; x=(x+1 mod255)<<24, continue if <>0 M addS r2,r2,#1<<24:bNE disp_x ; y=(y+1 mod255)<<24, continue if <>0 ldmfd r13!,{r0-r5,pc}^ ;\\\\\\\\\\\\\\\\\\\\\\\\\\ * ; Draw Environment Mapping > 4;////////////////////////// >O;For each screen pixel we compute which pixel to copy from environment map. HF;Formula is screen(x;y)=envmap(disp_x(x;y)+lx-x;disp_y(x;y)+ly-y). R; r0=vram \,; r1=table with disp_x, disp_y f4; r2=adress of 256*256 environment map p; r3=lx z; r4=ly � .draw_env �! stmfd r13!,{r0-r12,r14} � str r13,old_stack �2 mov r5,#0 ; r5=y<<24 �.draw_y �2 mov r6,#0 ; r6=x<<24 �2 sub r11,r4,r5,lsr #24 ; r11=ly-y �.draw_x4 �2 sub r12,r3,r6,lsr #24 ; r12=lx-x �@ ldmia r1!,{r13,r14} ; Load 4*2 displacements �? mov r9,#0 ; Will contain 4 points �3 and r7,r13,#&ff ; r7=disp_x �6 and r8,r13,#&ff00 ; r8=disp_y<<8 ; addS r7,r7,r12 ; r7=dx=disp_x+lx-x C addGES r8,r8,r11,lsl #8 ; r8=dy<<8=(disp_y+ly-y)<<8 D bMI draw_next1 ; Don't draw if dx<0 or dy<0 $ cmp r7,#&ff . cmpLE r8,#&ff00 8K addLE r8,r7,r8 ; If dx<256 and dy<256, r8=dy<<8+dx BE ldrLEB r9,[r2,r8] ; And put envmap(dx;dy) in r9 L.draw_next1 V; sub r12,r12,#1 ; lx-x-=1 (ie x+=1) `< and r7,r13,#&ff0000 ; Similar, 2nd pixel j! addS r7,r7,r12,lsl #16 t" addGES r8,r11,r13,lsr #24 ~ bMI draw_next2 � cmp r7,#&ff0000 � cmpLE r8,#&ff �" addLE r8,r7,r8,lsl #24 �" ldrLEB r8,[r2,r8,lsr #16] � addLE r9,r9,r8,lsl #8 �.draw_next2 � sub r12,r12,#1 �3 and r7,r14,#&ff ; 3rd pixel � and r8,r14,#&ff00 � addS r7,r7,r12 � addGES r8,r8,r11,lsl #8 � bMI draw_next3 cmp r7,#&ff cmpLE r8,#&ff00 addLE r8,r7,r8 ldrLEB r8,[r2,r8] ( addLE r9,r9,r8,lsl #16 2.draw_next3 < sub r12,r12,#1 F3 and r7,r14,#&ff0000 ; 4th pixel P! addS r7,r7,r12,lsl #16 Z" addGES r8,r11,r14,lsr #24 d bMI draw_next4 n cmp r7,#&ff0000 x cmpLE r8,#&ff � addLE r8,r7,r8,lsl #24 �" ldrLEB r8,[r2,r8,lsr #16] � addLE r9,r9,r8,lsl #24 �.draw_next4 �7 str r9,[r0],#4 ; Save 4 pixels �C addS r6,r6,#4<<24:bNE draw_x4 ; x+=4<<24, continue if <>0 �8 add r0,r0,#320-256 ; Next vram line �C addS r5,r5,#1<<24:bNE draw_y ; y+=1<<24, continue if <>0 � ldr r13,old_stack �! ldmfd r13!,{r0-r12,pc}^ � �7]:�opt%:�"Assembly code is ";P%-code%;" bytes long" � O�==== BASIC CODE ========================================================== �envmap% 65536 �disp% 65536*2 "0�Load height field and compute displacements ,�"Computing displacements" 6A%=envmap%:B%=disp% @4f%=�("Height256"):ș"OS_GBPB",4,f%,A%,65536:�#f% J�displacements T�Create environment map ^ �"Computing environment map" hA%=envmap%:�envmap r |<�Screen & color initialisation. Then let the show begin. �H�15:�12:�:�v% 8:!v%=148:v%!4=-1:ș"OS_ReadVduVariables",v%,v%:v%=!v% ��c%=1�15 � b%=c%*17+34:�b%>255�b%=255 � �c%,c%*17,c%*17,b% ��c% �b%=2 �B%=disp% �C%=envmap% �� �5 Ȗ:ș"OS_Byte",&71,b%:b%=b%�3:ș"OS_Byte",&70,b% � A%=v%+(b%>>1)*81920+32 � ȗx%,y%,z% �! D%=(x%>>2)-32:E%=256-(y%>>2) �draw_env �� &E�==== MACROS ==================================================== 0�m0=sqrt(m1). :ݤsqrt(m0,m1,m2) D�n% N [opt opt% XG mov m0,#0 ; This is ripped from Jan/BASS. b, mov m2,#1<<30 ; | l, cmp m1,m2 ; | v, subHS m1,m0,m2 ; | �, adc m0,m0,m0 ; | �]:�n%=2�30�2:[opt opt% �, add m2,m0,#1<<30 ; | �, cmp m1,m2,ror #n% ; | �, subHS m1,m1,m2,ror #n% ; | �= adc m0,m0,m0 ; End of ripped code. �]:�n%:[opt opt% �9 cmp m1,m0 ; Flags=val-root. �C addPL m0,m0,#1 ; Round to nearest integer. � ]:="" �
00000000 0d 00 0a 1c f4 3e 3e 3e 20 45 6e 76 69 72 6f 6e |.....>>> Environ| 00000010 6d 65 6e 74 20 4d 61 70 70 69 6e 67 0d 00 14 39 |ment Mapping...9| 00000020 f4 20 20 20 20 41 6c 61 69 6e 20 42 52 4f 42 45 |. Alain BROBE| 00000030 43 4b 45 52 20 28 62 61 61 68 2f 41 72 6d 27 73 |CKER (baah/Arm's| 00000040 20 54 65 63 68 29 20 6f 6e 20 30 35 2d 41 70 72 | Tech) on 05-Apr| 00000050 2d 31 39 39 38 0d 00 1e 04 0d 00 28 4f f4 3d 3d |-1998......(O.==| 00000060 3d 3d 20 41 53 4d 20 43 4f 44 45 20 3d 3d 3d 3d |== ASM CODE ====| 00000070 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d |================| * 000000a0 3d 3d 3d 3d 3d 3d 3d 3d 0d 00 32 2e de 63 6f 64 |========..2..cod| 000000b0 65 25 20 31 30 32 34 3a e3 6f 70 74 25 3d 30 b8 |e% 1024:.opt%=0.| 000000c0 32 88 32 3a 50 25 3d 63 6f 64 65 25 3a 5b 6f 70 |2.2:P%=code%:[op| 000000d0 74 20 6f 70 74 25 0d 00 3c 52 2e 6f 6c 64 5f 73 |t opt%..<R.old_s| 000000e0 74 61 63 6b 20 20 20 20 20 20 20 20 20 20 20 20 |tack | 000000f0 20 20 3b 20 55 73 65 64 20 74 6f 20 73 61 76 65 | ; Used to save| 00000100 20 72 31 33 2c 20 77 69 6c 6c 20 6f 76 65 72 77 | r13, will overw| 00000110 72 69 74 65 20 6f 6e 20 27 65 6e 76 6d 61 70 27 |rite on 'envmap'| 00000120 20 72 6f 75 74 69 6e 65 0d 00 46 04 0d 00 50 20 | routine..F...P | 00000130 3b 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c |;\\\\\\\\\\\\\\\| 00000140 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 0d 00 5a 21 |\\\\\\\\\\\\..Z!| 00000150 3b 20 43 61 6c 63 75 6c 61 74 65 20 45 6e 76 69 |; Calculate Envi| 00000160 72 6f 6e 6d 65 6e 74 20 4d 61 70 20 3e 0d 00 64 |ronment Map >..d| 00000170 20 3b 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f | ;//////////////| 00000180 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 00 6e |/////////////..n| 00000190 4f 3b 54 68 69 73 20 72 6f 75 74 69 6e 65 20 63 |O;This routine c| 000001a0 72 65 61 74 65 73 20 74 68 65 20 65 6e 76 69 72 |reates the envir| 000001b0 6f 6e 6d 65 6e 74 20 6d 61 70 2e 20 57 65 20 63 |onment map. We c| 000001c0 61 6c 63 75 6c 61 74 65 20 74 68 65 20 69 6e 74 |alculate the int| 000001d0 65 6e 73 69 74 79 20 61 73 20 61 6e 0d 00 78 50 |ensity as an..xP| 000001e0 3b 61 66 66 69 6e 65 20 66 75 6e 63 74 69 6f 6e |;affine function| 000001f0 20 6f 66 20 74 68 65 20 64 69 73 74 61 6e 63 65 | of the distance| 00000200 20 64 3d b6 28 78 5e 32 2b 79 5e 32 29 2e 20 54 | d=.(x^2+y^2). T| 00000210 6f 20 61 6c 6c 6f 77 20 64 69 74 68 65 72 69 6e |o allow ditherin| 00000220 67 20 69 6e 20 6d 6f 64 65 31 32 2c 0d 00 82 53 |g in mode12,...S| 00000230 3b 70 69 78 65 6c 5f 74 61 62 6c 65 20 63 6f 6e |;pixel_table con| 00000240 74 61 69 6e 73 20 61 20 72 61 73 74 65 72 20 77 |tains a raster w| 00000250 68 65 6e 20 6f 66 66 73 65 74 20 69 73 20 70 6f |hen offset is po| 00000260 73 69 74 69 76 65 20 28 65 76 65 6e 20 6c 69 6e |sitive (even lin| 00000270 65 73 29 20 61 6e 64 20 61 6e 6f 74 68 65 72 0d |es) and another.| 00000280 00 8c 2d 3b 6f 6e 65 20 77 68 65 6e 20 6f 66 66 |..-;one when off| 00000290 73 65 74 20 69 73 20 6e 65 67 61 74 69 76 65 20 |set is negative | 000002a0 28 6f 64 64 20 6c 69 6e 65 73 29 2e 0d 00 96 3f |(odd lines)....?| 000002b0 3b 20 20 20 20 20 20 20 20 20 20 20 72 30 3d 61 |; r0=a| 000002c0 64 72 65 73 73 20 77 68 65 72 65 20 74 6f 20 73 |dress where to s| 000002d0 61 76 65 20 31 32 38 2a 31 32 38 20 65 6e 76 69 |ave 128*128 envi| 000002e0 72 6f 6e 6d 65 6e 74 20 6d 61 70 0d 00 a0 0b 2e |ronment map.....| 000002f0 65 6e 76 6d 61 70 0d 00 aa 20 20 20 73 74 6d 66 |envmap... stmf| 00000300 64 20 20 20 20 20 72 31 33 21 2c 7b 72 30 2d 72 |d r13!,{r0-r| 00000310 36 2c 72 31 34 7d 0d 00 b4 49 20 20 61 64 72 20 |6,r14}...I adr | 00000320 20 20 20 20 20 20 72 31 2c 70 69 78 65 6c 5f 74 | r1,pixel_t| 00000330 61 62 6c 65 20 20 20 20 20 20 20 20 20 20 3b 20 |able ; | 00000340 69 6e 74 65 6e 73 69 74 79 20 74 6f 20 6d 6f 64 |intensity to mod| 00000350 65 31 32 5f 70 69 78 65 6c 20 74 61 62 6c 65 0d |e12_pixel table.| 00000360 00 be 31 20 20 6d 6f 76 20 20 20 20 20 20 20 72 |..1 mov r| 00000370 32 2c 23 32 35 36 20 20 20 20 20 20 20 20 20 20 |2,#256 | 00000380 20 20 20 20 20 20 20 3b 20 79 20 63 6f 6f 72 64 | ; y coord| 00000390 0d 00 c8 0a 2e 65 6e 76 5f 79 0d 00 d2 31 20 20 |.....env_y...1 | 000003a0 6d 6f 76 20 20 20 20 20 20 20 72 33 2c 23 32 35 |mov r3,#25| 000003b0 36 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |6 | 000003c0 20 20 3b 20 78 20 63 6f 6f 72 64 0d 00 dc 32 20 | ; x coord...2 | 000003d0 20 73 75 62 20 20 20 20 20 20 20 72 35 2c 72 32 | sub r5,r2| 000003e0 2c 23 31 32 38 20 20 20 20 20 20 20 20 20 20 20 |,#128 | 000003f0 20 20 20 3b 20 72 35 3d 79 2d 31 32 38 0d 00 e6 | ; r5=y-128...| 00000400 36 20 20 6d 75 6c 20 20 20 20 20 20 20 72 34 2c |6 mul r4,| 00000410 72 35 2c 72 35 20 20 20 20 20 20 20 20 20 20 20 |r5,r5 | 00000420 20 20 20 20 20 3b 20 72 34 3d 28 79 2d 31 32 38 | ; r4=(y-128| 00000430 29 5e 32 0d 00 f0 0a 2e 65 6e 76 5f 78 0d 00 fa |)^2.....env_x...| 00000440 33 20 20 73 75 62 20 20 20 20 20 20 20 72 31 34 |3 sub r14| 00000450 2c 72 33 2c 23 31 32 38 20 20 20 20 20 20 20 20 |,r3,#128 | 00000460 20 20 20 20 20 3b 20 72 31 34 3d 78 2d 31 32 38 | ; r14=x-128| 00000470 0d 01 04 40 20 20 6d 6c 61 20 20 20 20 20 20 20 |...@ mla | 00000480 72 36 2c 72 31 34 2c 72 31 34 2c 72 34 20 20 20 |r6,r14,r14,r4 | 00000490 20 20 20 20 20 20 20 20 3b 20 72 36 3d 28 78 2d | ; r6=(x-| 000004a0 31 32 38 29 5e 32 2b 28 79 2d 31 32 38 29 5e 32 |128)^2+(y-128)^2| 000004b0 0d 01 0e 45 20 20 a4 73 71 72 74 28 35 2c 36 2c |...E .sqrt(5,6,| 000004c0 31 34 29 20 20 20 20 20 20 20 20 20 20 20 20 20 |14) | 000004d0 20 20 20 20 20 20 20 3b 20 72 35 3d 73 71 72 74 | ; r5=sqrt| 000004e0 28 28 78 2d 31 32 38 29 5e 32 2b 28 79 2d 31 32 |((x-128)^2+(y-12| 000004f0 38 29 5e 32 29 0d 01 18 1c 20 20 6d 6f 76 20 20 |8)^2).... mov | 00000500 20 20 20 20 20 72 35 2c 72 35 2c 6c 73 6c 20 23 | r5,r5,lsl #| 00000510 31 0d 01 22 3c 20 20 72 73 62 53 20 20 20 20 20 |1.."< rsbS | 00000520 20 72 35 2c 72 35 2c 23 32 35 35 20 20 20 20 20 | r5,r5,#255 | 00000530 20 20 20 20 20 20 20 20 20 3b 20 72 35 3d 32 35 | ; r5=25| 00000540 35 2d 32 2a 73 71 72 74 28 2e 2e 2e 29 0d 01 2c |5-2*sqrt(...)..,| 00000550 15 20 20 6d 6f 76 4d 49 20 20 20 20 20 72 35 2c |. movMI r5,| 00000560 23 30 0d 01 36 39 20 20 74 73 74 20 20 20 20 20 |#0..69 tst | 00000570 20 20 72 32 2c 23 31 20 20 20 20 20 20 20 20 20 | r2,#1 | 00000580 20 20 20 20 20 20 20 20 20 20 3b 20 50 61 72 69 | ; Pari| 00000590 74 79 20 6f 66 20 6c 69 6e 65 3f 0d 01 40 21 20 |ty of line?..@! | 000005a0 20 6c 64 72 45 51 42 20 20 20 20 72 35 2c 5b 72 | ldrEQB r5,[r| 000005b0 31 2c 72 35 2c 6c 73 72 20 23 33 5d 0d 01 4a 22 |1,r5,lsr #3]..J"| 000005c0 20 20 6c 64 72 4e 45 42 20 20 20 20 72 35 2c 5b | ldrNEB r5,[| 000005d0 72 31 2c 2d 72 35 2c 6c 73 72 20 23 33 5d 0d 01 |r1,-r5,lsr #3]..| 000005e0 54 34 20 20 73 74 72 42 20 20 20 20 20 20 72 35 |T4 strB r5| 000005f0 2c 5b 72 30 5d 2c 23 31 20 20 20 20 20 20 20 20 |,[r0],#1 | 00000600 20 20 20 20 20 20 3b 20 53 61 76 65 20 70 69 78 | ; Save pix| 00000610 65 6c 0d 01 5e 34 20 73 75 62 53 20 72 33 2c 72 |el..^4 subS r3,r| 00000620 33 2c 23 31 3a 62 4e 45 20 65 6e 76 5f 78 20 20 |3,#1:bNE env_x | 00000630 20 20 20 20 20 20 20 20 20 20 3b 20 4e 65 78 74 | ; Next| 00000640 20 70 69 78 65 6c 0d 01 68 33 20 73 75 62 53 20 | pixel..h3 subS | 00000650 72 32 2c 72 32 2c 23 31 3a 62 4e 45 20 65 6e 76 |r2,r2,#1:bNE env| 00000660 5f 79 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 |_y ; | 00000670 4e 65 78 74 20 6c 69 6e 65 0d 01 72 20 20 20 6c |Next line..r l| 00000680 64 6d 66 64 20 20 20 20 20 72 31 33 21 2c 7b 72 |dmfd r13!,{r| 00000690 30 2d 72 36 2c 70 63 7d 5e 0d 01 7c 04 0d 01 86 |0-r6,pc}^..|....| 000006a0 3d 20 20 64 63 64 20 26 66 65 66 66 66 66 66 66 |= dcd &feffffff| 000006b0 3a 64 63 64 20 26 64 63 64 64 65 64 65 65 3a 64 |:dcd &dcddedee:d| 000006c0 63 64 20 26 62 61 62 62 63 62 63 63 3a 64 63 64 |cd &babbcbcc:dcd| 000006d0 20 26 39 38 39 39 61 39 61 61 0d 01 90 3d 20 20 | &9899a9aa...= | 000006e0 64 63 64 20 26 37 36 37 37 38 37 38 38 3a 64 63 |dcd &76778788:dc| 000006f0 64 20 26 35 34 35 35 36 35 36 36 3a 64 63 64 20 |d &54556566:dcd | 00000700 26 33 32 33 33 34 33 34 34 3a 64 63 64 20 26 31 |&32334344:dcd &1| 00000710 30 31 31 32 31 32 32 0d 01 9a 10 2e 70 69 78 65 |0112122.....pixe| 00000720 6c 5f 74 61 62 6c 65 0d 01 a4 3d 20 20 64 63 64 |l_table...= dcd| 00000730 20 26 31 32 31 31 30 31 30 30 3a 64 63 64 20 26 | &12110100:dcd &| 00000740 33 34 33 33 32 33 32 32 3a 64 63 64 20 26 35 36 |34332322:dcd &56| 00000750 35 35 34 35 34 34 3a 64 63 64 20 26 37 38 37 37 |554544:dcd &7877| 00000760 36 37 36 36 0d 01 ae 3d 20 20 64 63 64 20 26 39 |6766...= dcd &9| 00000770 61 39 39 38 39 38 38 3a 64 63 64 20 26 62 63 62 |a998988:dcd &bcb| 00000780 62 61 62 61 61 3a 64 63 64 20 26 64 65 64 64 63 |babaa:dcd &deddc| 00000790 64 63 63 3a 64 63 64 20 26 66 66 66 66 65 66 65 |dcc:dcd &ffffefe| 000007a0 65 0d 01 b8 04 0d 01 c2 21 3b 5c 5c 5c 5c 5c 5c |e.......!;\\\\\\| 000007b0 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c |\\\\\\\\\\\\\\\\| 000007c0 5c 5c 5c 5c 5c 5c 0d 01 cc 22 3b 20 43 6f 6d 70 |\\\\\\..."; Comp| 000007d0 75 74 65 20 44 69 73 70 6c 61 63 65 6d 65 6e 74 |ute Displacement| 000007e0 73 20 54 61 62 6c 65 3e 0d 01 d6 21 3b 2f 2f 2f |s Table>...!;///| 000007f0 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f |////////////////| 00000800 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 01 e0 4e 3b 54 68 |/////////...N;Th| 00000810 69 73 20 72 6f 75 74 69 6e 65 20 75 73 65 20 74 |is routine use t| 00000820 68 65 20 68 65 69 67 68 74 20 66 69 65 6c 64 20 |he height field | 00000830 69 6d 61 67 65 20 74 6f 20 63 72 65 61 74 65 20 |image to create | 00000840 74 68 65 20 64 69 73 70 6c 61 63 65 6d 65 6e 74 |the displacement| 00000850 20 74 61 62 6c 65 2e 0d 01 ea 51 3b 46 6f 72 6d | table....Q;Form| 00000860 75 6c 61 65 73 20 61 72 65 20 64 69 73 70 5f 78 |ulaes are disp_x| 00000870 28 78 3b 79 29 3d 68 28 78 2b 31 3b 79 29 2d 68 |(x;y)=h(x+1;y)-h| 00000880 28 78 2d 31 3b 79 29 20 26 20 64 69 73 70 5f 79 |(x-1;y) & disp_y| 00000890 28 78 3b 79 29 3d 68 28 78 3b 79 2b 31 29 2d 68 |(x;y)=h(x;y+1)-h| 000008a0 28 78 3b 79 2d 31 29 2e 0d 01 f4 24 3b 20 20 20 |(x;y-1)....$; | 000008b0 20 20 20 20 20 20 20 20 72 30 3d 61 64 72 65 73 | r0=adres| 000008c0 73 20 6f 66 20 68 65 69 67 68 74 73 0d 01 fe 3a |s of heights...:| 000008d0 3b 20 20 20 20 20 20 20 20 20 20 20 72 31 3d 74 |; r1=t| 000008e0 61 62 6c 65 20 77 68 69 63 68 20 77 69 6c 6c 20 |able which will | 000008f0 63 6f 6e 74 61 69 6e 20 64 69 73 70 5f 78 2c 20 |contain disp_x, | 00000900 64 69 73 70 5f 79 0d 02 08 12 2e 64 69 73 70 6c |disp_y.....displ| 00000910 61 63 65 6d 65 6e 74 73 0d 02 12 20 20 20 73 74 |acements... st| 00000920 6d 66 64 20 20 20 20 20 72 31 33 21 2c 7b 72 30 |mfd r13!,{r0| 00000930 2d 72 35 2c 72 31 34 7d 0d 02 1c 2f 20 20 6d 6f |-r5,r14}.../ mo| 00000940 76 20 20 20 20 20 20 20 72 32 2c 23 30 20 20 20 |v r2,#0 | 00000950 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00000960 3b 20 79 3c 3c 32 34 0d 02 26 0b 2e 64 69 73 70 |; y<<24..&..disp| 00000970 5f 79 0d 02 30 2f 20 20 6d 6f 76 20 20 20 20 20 |_y..0/ mov | 00000980 20 20 72 33 2c 23 30 20 20 20 20 20 20 20 20 20 | r3,#0 | 00000990 20 20 20 20 20 20 20 20 20 20 3b 20 78 3c 3c 32 | ; x<<2| 000009a0 34 0d 02 3a 0b 2e 64 69 73 70 5f 78 0d 02 44 33 |4..:..disp_x..D3| 000009b0 20 20 61 64 64 20 20 20 20 20 20 20 72 35 2c 72 | add r5,r| 000009c0 30 2c 72 32 2c 6c 73 72 20 23 31 36 20 20 20 20 |0,r2,lsr #16 | 000009d0 20 20 20 20 3b 20 72 35 3d 68 28 30 3b 79 29 0d | ; r5=h(0;y).| 000009e0 02 4e 3e 20 20 73 75 62 20 20 20 20 20 20 20 72 |.N> sub r| 000009f0 34 2c 72 33 2c 23 31 3c 3c 32 34 20 20 20 20 20 |4,r3,#1<<24 | 00000a00 20 20 20 20 20 20 20 3b 20 72 34 3d 28 78 2d 31 | ; r4=(x-1| 00000a10 20 6d 6f 64 20 32 35 35 29 3c 3c 32 34 0d 02 58 | mod 255)<<24..X| 00000a20 35 20 20 6c 64 72 42 20 20 20 20 20 20 72 34 2c |5 ldrB r4,| 00000a30 5b 72 35 2c 72 34 2c 6c 73 72 20 23 32 34 5d 20 |[r5,r4,lsr #24] | 00000a40 20 20 20 20 20 3b 20 72 34 3d 68 28 78 2d 31 3b | ; r4=h(x-1;| 00000a50 79 29 0d 02 62 3f 20 20 61 64 64 20 20 20 20 20 |y)..b? add | 00000a60 20 20 72 31 34 2c 72 33 2c 23 31 3c 3c 32 34 20 | r14,r3,#1<<24 | 00000a70 20 20 20 20 20 20 20 20 20 20 3b 20 72 31 34 3d | ; r14=| 00000a80 28 78 2b 31 20 6d 6f 64 20 32 35 35 29 3c 3c 32 |(x+1 mod 255)<<2| 00000a90 34 0d 02 6c 36 20 20 6c 64 72 42 20 20 20 20 20 |4..l6 ldrB | 00000aa0 20 72 31 34 2c 5b 72 35 2c 72 31 34 2c 6c 73 72 | r14,[r5,r14,lsr| 00000ab0 20 23 32 34 5d 20 20 20 20 3b 20 72 31 34 3d 68 | #24] ; r14=h| 00000ac0 28 78 2b 31 3b 79 29 0d 02 76 3e 20 20 73 75 62 |(x+1;y)..v> sub| 00000ad0 20 20 20 20 20 20 20 72 34 2c 72 31 34 2c 72 34 | r4,r14,r4| 00000ae0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b | ;| 00000af0 20 72 34 3d 68 28 78 2b 31 3b 79 29 2d 68 28 78 | r4=h(x+1;y)-h(x| 00000b00 2d 31 3b 79 29 0d 02 80 1c 20 20 6d 6f 76 20 20 |-1;y).... mov | 00000b10 20 20 20 20 20 72 34 2c 72 34 2c 61 73 72 20 23 | r4,r4,asr #| 00000b20 31 0d 02 8a 1a 20 20 61 64 64 20 20 20 20 20 20 |1.... add | 00000b30 20 72 34 2c 72 34 2c 23 31 32 38 0d 02 94 1a 20 | r4,r4,#128.... | 00000b40 20 73 74 72 42 20 20 20 20 20 20 72 34 2c 5b 72 | strB r4,[r| 00000b50 31 5d 2c 23 31 0d 02 9e 33 20 20 61 64 64 20 20 |1],#1...3 add | 00000b60 20 20 20 20 20 72 35 2c 72 30 2c 72 33 2c 6c 73 | r5,r0,r3,ls| 00000b70 72 20 23 32 34 20 20 20 20 20 20 20 20 3b 20 72 |r #24 ; r| 00000b80 35 3d 68 28 78 3b 30 29 0d 02 a8 3e 20 20 73 75 |5=h(x;0)...> su| 00000b90 62 20 20 20 20 20 20 20 72 34 2c 72 32 2c 23 31 |b r4,r2,#1| 00000ba0 3c 3c 32 34 20 20 20 20 20 20 20 20 20 20 20 20 |<<24 | 00000bb0 3b 20 72 34 3d 28 79 2d 31 20 6d 6f 64 20 32 35 |; r4=(y-1 mod 25| 00000bc0 35 29 3c 3c 32 34 0d 02 b2 35 20 20 6c 64 72 42 |5)<<24...5 ldrB| 00000bd0 20 20 20 20 20 20 72 34 2c 5b 72 35 2c 72 34 2c | r4,[r5,r4,| 00000be0 6c 73 72 20 23 31 36 5d 20 20 20 20 20 20 3b 20 |lsr #16] ; | 00000bf0 72 34 3d 68 28 78 3b 79 2d 31 29 0d 02 bc 3f 20 |r4=h(x;y-1)...? | 00000c00 20 61 64 64 20 20 20 20 20 20 20 72 31 34 2c 72 | add r14,r| 00000c10 32 2c 23 31 3c 3c 32 34 20 20 20 20 20 20 20 20 |2,#1<<24 | 00000c20 20 20 20 3b 20 72 31 34 3d 28 79 2b 31 20 6d 6f | ; r14=(y+1 mo| 00000c30 64 20 32 35 35 29 3c 3c 32 34 0d 02 c6 36 20 20 |d 255)<<24...6 | 00000c40 6c 64 72 42 20 20 20 20 20 20 72 31 34 2c 5b 72 |ldrB r14,[r| 00000c50 35 2c 72 31 34 2c 6c 73 72 20 23 31 36 5d 20 20 |5,r14,lsr #16] | 00000c60 20 20 3b 20 72 31 34 3d 68 28 78 3b 79 2b 31 29 | ; r14=h(x;y+1)| 00000c70 0d 02 d0 3e 20 20 73 75 62 20 20 20 20 20 20 20 |...> sub | 00000c80 72 34 2c 72 31 34 2c 72 34 20 20 20 20 20 20 20 |r4,r14,r4 | 00000c90 20 20 20 20 20 20 20 20 3b 20 72 34 3d 68 28 78 | ; r4=h(x| 00000ca0 3b 79 2b 31 29 2d 68 28 78 3b 79 2d 31 29 0d 02 |;y+1)-h(x;y-1)..| 00000cb0 da 1c 20 20 6d 6f 76 20 20 20 20 20 20 20 72 34 |.. mov r4| 00000cc0 2c 72 34 2c 61 73 72 20 23 31 0d 02 e4 1a 20 20 |,r4,asr #1.... | 00000cd0 61 64 64 20 20 20 20 20 20 20 72 34 2c 72 34 2c |add r4,r4,| 00000ce0 23 31 32 38 0d 02 ee 1a 20 20 73 74 72 42 20 20 |#128.... strB | 00000cf0 20 20 20 20 72 34 2c 5b 72 31 5d 2c 23 31 0d 02 | r4,[r1],#1..| 00000d00 f8 4d 20 61 64 64 53 20 72 33 2c 72 33 2c 23 31 |.M addS r3,r3,#1| 00000d10 3c 3c 32 34 3a 62 4e 45 20 64 69 73 70 5f 78 20 |<<24:bNE disp_x | 00000d20 20 20 20 20 20 20 3b 20 78 3d 28 78 2b 31 20 6d | ; x=(x+1 m| 00000d30 6f 64 32 35 35 29 3c 3c 32 34 2c 20 63 6f 6e 74 |od255)<<24, cont| 00000d40 69 6e 75 65 20 69 66 20 3c 3e 30 0d 03 02 4d 20 |inue if <>0...M | 00000d50 61 64 64 53 20 72 32 2c 72 32 2c 23 31 3c 3c 32 |addS r2,r2,#1<<2| 00000d60 34 3a 62 4e 45 20 64 69 73 70 5f 78 20 20 20 20 |4:bNE disp_x | 00000d70 20 20 20 3b 20 79 3d 28 79 2b 31 20 6d 6f 64 32 | ; y=(y+1 mod2| 00000d80 35 35 29 3c 3c 32 34 2c 20 63 6f 6e 74 69 6e 75 |55)<<24, continu| 00000d90 65 20 69 66 20 3c 3e 30 0d 03 0c 20 20 20 6c 64 |e if <>0... ld| 00000da0 6d 66 64 20 20 20 20 20 72 31 33 21 2c 7b 72 30 |mfd r13!,{r0| 00000db0 2d 72 35 2c 70 63 7d 5e 0d 03 16 04 0d 03 20 1f |-r5,pc}^...... .| 00000dc0 3b 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c |;\\\\\\\\\\\\\\\| 00000dd0 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 5c 0d 03 2a 20 3b |\\\\\\\\\\\..* ;| 00000de0 20 44 72 61 77 20 45 6e 76 69 72 6f 6e 6d 65 6e | Draw Environmen| 00000df0 74 20 4d 61 70 70 69 6e 67 20 3e 0d 03 34 1f 3b |t Mapping >..4.;| 00000e00 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f |////////////////| 00000e10 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 03 3e 4f 3b 46 |//////////..>O;F| 00000e20 6f 72 20 65 61 63 68 20 73 63 72 65 65 6e 20 70 |or each screen p| 00000e30 69 78 65 6c 20 77 65 20 63 6f 6d 70 75 74 65 20 |ixel we compute | 00000e40 77 68 69 63 68 20 70 69 78 65 6c 20 74 6f 20 63 |which pixel to c| 00000e50 6f 70 79 20 66 72 6f 6d 20 65 6e 76 69 72 6f 6e |opy from environ| 00000e60 6d 65 6e 74 20 6d 61 70 2e 0d 03 48 46 3b 46 6f |ment map...HF;Fo| 00000e70 72 6d 75 6c 61 20 69 73 20 73 63 72 65 65 6e 28 |rmula is screen(| 00000e80 78 3b 79 29 3d 65 6e 76 6d 61 70 28 64 69 73 70 |x;y)=envmap(disp| 00000e90 5f 78 28 78 3b 79 29 2b 6c 78 2d 78 3b 64 69 73 |_x(x;y)+lx-x;dis| 00000ea0 70 5f 79 28 78 3b 79 29 2b 6c 79 2d 79 29 2e 0d |p_y(x;y)+ly-y)..| 00000eb0 03 52 17 3b 20 20 20 20 20 20 20 20 20 20 20 72 |.R.; r| 00000ec0 30 3d 76 72 61 6d 0d 03 5c 2c 3b 20 20 20 20 20 |0=vram..\,; | 00000ed0 20 20 20 20 20 20 72 31 3d 74 61 62 6c 65 20 77 | r1=table w| 00000ee0 69 74 68 20 64 69 73 70 5f 78 2c 20 64 69 73 70 |ith disp_x, disp| 00000ef0 5f 79 0d 03 66 34 3b 20 20 20 20 20 20 20 20 20 |_y..f4; | 00000f00 20 20 72 32 3d 61 64 72 65 73 73 20 6f 66 20 32 | r2=adress of 2| 00000f10 35 36 2a 32 35 36 20 65 6e 76 69 72 6f 6e 6d 65 |56*256 environme| 00000f20 6e 74 20 6d 61 70 0d 03 70 15 3b 20 20 20 20 20 |nt map..p.; | 00000f30 20 20 20 20 20 20 72 33 3d 6c 78 0d 03 7a 15 3b | r3=lx..z.;| 00000f40 20 20 20 20 20 20 20 20 20 20 20 72 34 3d 6c 79 | r4=ly| 00000f50 0d 03 84 0d 2e 64 72 61 77 5f 65 6e 76 0d 03 8e |.....draw_env...| 00000f60 21 20 20 73 74 6d 66 64 20 20 20 20 20 72 31 33 |! stmfd r13| 00000f70 21 2c 7b 72 30 2d 72 31 32 2c 72 31 34 7d 0d 03 |!,{r0-r12,r14}..| 00000f80 98 1d 20 20 73 74 72 20 20 20 20 20 20 20 72 31 |.. str r1| 00000f90 33 2c 6f 6c 64 5f 73 74 61 63 6b 0d 03 a2 32 20 |3,old_stack...2 | 00000fa0 20 6d 6f 76 20 20 20 20 20 20 20 72 35 2c 23 30 | mov r5,#0| 00000fb0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00000fc0 20 20 20 3b 20 72 35 3d 79 3c 3c 32 34 0d 03 ac | ; r5=y<<24...| 00000fd0 0b 2e 64 72 61 77 5f 79 0d 03 b6 32 20 20 6d 6f |..draw_y...2 mo| 00000fe0 76 20 20 20 20 20 20 20 72 36 2c 23 30 20 20 20 |v r6,#0 | 00000ff0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001000 3b 20 72 36 3d 78 3c 3c 32 34 0d 03 c0 32 20 20 |; r6=x<<24...2 | 00001010 73 75 62 20 20 20 20 20 20 20 72 31 31 2c 72 34 |sub r11,r4| 00001020 2c 72 35 2c 6c 73 72 20 23 32 34 20 20 20 20 20 |,r5,lsr #24 | 00001030 20 20 3b 20 72 31 31 3d 6c 79 2d 79 0d 03 ca 0c | ; r11=ly-y....| 00001040 2e 64 72 61 77 5f 78 34 0d 03 d4 32 20 20 73 75 |.draw_x4...2 su| 00001050 62 20 20 20 20 20 20 20 72 31 32 2c 72 33 2c 72 |b r12,r3,r| 00001060 36 2c 6c 73 72 20 23 32 34 20 20 20 20 20 20 20 |6,lsr #24 | 00001070 3b 20 72 31 32 3d 6c 78 2d 78 0d 03 de 40 20 20 |; r12=lx-x...@ | 00001080 6c 64 6d 69 61 20 20 20 20 20 72 31 21 2c 7b 72 |ldmia r1!,{r| 00001090 31 33 2c 72 31 34 7d 20 20 20 20 20 20 20 20 20 |13,r14} | 000010a0 20 20 3b 20 4c 6f 61 64 20 34 2a 32 20 64 69 73 | ; Load 4*2 dis| 000010b0 70 6c 61 63 65 6d 65 6e 74 73 0d 03 e8 3f 20 20 |placements...? | 000010c0 6d 6f 76 20 20 20 20 20 20 20 72 39 2c 23 30 20 |mov r9,#0 | 000010d0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000010e0 20 20 3b 20 57 69 6c 6c 20 63 6f 6e 74 61 69 6e | ; Will contain| 000010f0 20 34 20 70 6f 69 6e 74 73 0d 03 f2 33 20 20 61 | 4 points...3 a| 00001100 6e 64 20 20 20 20 20 20 20 72 37 2c 72 31 33 2c |nd r7,r13,| 00001110 23 26 66 66 20 20 20 20 20 20 20 20 20 20 20 20 |#&ff | 00001120 20 3b 20 72 37 3d 64 69 73 70 5f 78 0d 03 fc 36 | ; r7=disp_x...6| 00001130 20 20 61 6e 64 20 20 20 20 20 20 20 72 38 2c 72 | and r8,r| 00001140 31 33 2c 23 26 66 66 30 30 20 20 20 20 20 20 20 |13,#&ff00 | 00001150 20 20 20 20 3b 20 72 38 3d 64 69 73 70 5f 79 3c | ; r8=disp_y<| 00001160 3c 38 0d 04 06 3b 20 20 61 64 64 53 20 20 20 20 |<8...; addS | 00001170 20 20 72 37 2c 72 37 2c 72 31 32 20 20 20 20 20 | r7,r7,r12 | 00001180 20 20 20 20 20 20 20 20 20 20 3b 20 72 37 3d 64 | ; r7=d| 00001190 78 3d 64 69 73 70 5f 78 2b 6c 78 2d 78 0d 04 10 |x=disp_x+lx-x...| 000011a0 43 20 20 61 64 64 47 45 53 20 20 20 20 72 38 2c |C addGES r8,| 000011b0 72 38 2c 72 31 31 2c 6c 73 6c 20 23 38 20 20 20 |r8,r11,lsl #8 | 000011c0 20 20 20 20 20 3b 20 72 38 3d 64 79 3c 3c 38 3d | ; r8=dy<<8=| 000011d0 28 64 69 73 70 5f 79 2b 6c 79 2d 79 29 3c 3c 38 |(disp_y+ly-y)<<8| 000011e0 0d 04 1a 44 20 20 62 4d 49 20 20 20 20 20 20 20 |...D bMI | 000011f0 64 72 61 77 5f 6e 65 78 74 31 20 20 20 20 20 20 |draw_next1 | 00001200 20 20 20 20 20 20 20 20 3b 20 44 6f 6e 27 74 20 | ; Don't | 00001210 64 72 61 77 20 69 66 20 64 78 3c 30 20 6f 72 20 |draw if dx<0 or | 00001220 64 79 3c 30 0d 04 24 17 20 20 63 6d 70 20 20 20 |dy<0..$. cmp | 00001230 20 20 20 20 72 37 2c 23 26 66 66 0d 04 2e 19 20 | r7,#&ff.... | 00001240 20 63 6d 70 4c 45 20 20 20 20 20 72 38 2c 23 26 | cmpLE r8,#&| 00001250 66 66 30 30 0d 04 38 4b 20 20 61 64 64 4c 45 20 |ff00..8K addLE | 00001260 20 20 20 20 72 38 2c 72 37 2c 72 38 20 20 20 20 | r8,r7,r8 | 00001270 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 49 66 | ; If| 00001280 20 64 78 3c 32 35 36 20 61 6e 64 20 64 79 3c 32 | dx<256 and dy<2| 00001290 35 36 2c 20 72 38 3d 64 79 3c 3c 38 2b 64 78 0d |56, r8=dy<<8+dx.| 000012a0 04 42 45 20 20 6c 64 72 4c 45 42 20 20 20 20 72 |.BE ldrLEB r| 000012b0 39 2c 5b 72 32 2c 72 38 5d 20 20 20 20 20 20 20 |9,[r2,r8] | 000012c0 20 20 20 20 20 20 20 3b 20 41 6e 64 20 70 75 74 | ; And put| 000012d0 20 65 6e 76 6d 61 70 28 64 78 3b 64 79 29 20 69 | envmap(dx;dy) i| 000012e0 6e 20 72 39 0d 04 4c 0f 2e 64 72 61 77 5f 6e 65 |n r9..L..draw_ne| 000012f0 78 74 31 0d 04 56 3b 20 20 73 75 62 20 20 20 20 |xt1..V; sub | 00001300 20 20 20 72 31 32 2c 72 31 32 2c 23 31 20 20 20 | r12,r12,#1 | 00001310 20 20 20 20 20 20 20 20 20 20 20 3b 20 6c 78 2d | ; lx-| 00001320 78 2d 3d 31 20 28 69 65 20 78 2b 3d 31 29 0d 04 |x-=1 (ie x+=1)..| 00001330 60 3c 20 20 61 6e 64 20 20 20 20 20 20 20 72 37 |`< and r7| 00001340 2c 72 31 33 2c 23 26 66 66 30 30 30 30 20 20 20 |,r13,#&ff0000 | 00001350 20 20 20 20 20 20 3b 20 53 69 6d 69 6c 61 72 2c | ; Similar,| 00001360 20 32 6e 64 20 70 69 78 65 6c 0d 04 6a 21 20 20 | 2nd pixel..j! | 00001370 61 64 64 53 20 20 20 20 20 20 72 37 2c 72 37 2c |addS r7,r7,| 00001380 72 31 32 2c 6c 73 6c 20 23 31 36 0d 04 74 22 20 |r12,lsl #16..t" | 00001390 20 61 64 64 47 45 53 20 20 20 20 72 38 2c 72 31 | addGES r8,r1| 000013a0 31 2c 72 31 33 2c 6c 73 72 20 23 32 34 0d 04 7e |1,r13,lsr #24..~| 000013b0 1a 20 20 62 4d 49 20 20 20 20 20 20 20 64 72 61 |. bMI dra| 000013c0 77 5f 6e 65 78 74 32 0d 04 88 1b 20 20 63 6d 70 |w_next2.... cmp| 000013d0 20 20 20 20 20 20 20 72 37 2c 23 26 66 66 30 30 | r7,#&ff00| 000013e0 30 30 0d 04 92 17 20 20 63 6d 70 4c 45 20 20 20 |00.... cmpLE | 000013f0 20 20 72 38 2c 23 26 66 66 0d 04 9c 22 20 20 61 | r8,#&ff..." a| 00001400 64 64 4c 45 20 20 20 20 20 72 38 2c 72 37 2c 72 |ddLE r8,r7,r| 00001410 38 2c 6c 73 6c 20 23 32 34 20 20 0d 04 a6 22 20 |8,lsl #24 ..." | 00001420 20 6c 64 72 4c 45 42 20 20 20 20 72 38 2c 5b 72 | ldrLEB r8,[r| 00001430 32 2c 72 38 2c 6c 73 72 20 23 31 36 5d 0d 04 b0 |2,r8,lsr #16]...| 00001440 1f 20 20 61 64 64 4c 45 20 20 20 20 20 72 39 2c |. addLE r9,| 00001450 72 39 2c 72 38 2c 6c 73 6c 20 23 38 0d 04 ba 0f |r9,r8,lsl #8....| 00001460 2e 64 72 61 77 5f 6e 65 78 74 32 0d 04 c4 1a 20 |.draw_next2.... | 00001470 20 73 75 62 20 20 20 20 20 20 20 72 31 32 2c 72 | sub r12,r| 00001480 31 32 2c 23 31 0d 04 ce 33 20 20 61 6e 64 20 20 |12,#1...3 and | 00001490 20 20 20 20 20 72 37 2c 72 31 34 2c 23 26 66 66 | r7,r14,#&ff| 000014a0 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 33 | ; 3| 000014b0 72 64 20 70 69 78 65 6c 0d 04 d8 1d 20 20 61 6e |rd pixel.... an| 000014c0 64 20 20 20 20 20 20 20 72 38 2c 72 31 34 2c 23 |d r8,r14,#| 000014d0 26 66 66 30 30 0d 04 e2 19 20 20 61 64 64 53 20 |&ff00.... addS | 000014e0 20 20 20 20 20 72 37 2c 72 37 2c 72 31 32 0d 04 | r7,r7,r12..| 000014f0 ec 20 20 20 61 64 64 47 45 53 20 20 20 20 72 38 |. addGES r8| 00001500 2c 72 38 2c 72 31 31 2c 6c 73 6c 20 23 38 0d 04 |,r8,r11,lsl #8..| 00001510 f6 1a 20 20 62 4d 49 20 20 20 20 20 20 20 64 72 |.. bMI dr| 00001520 61 77 5f 6e 65 78 74 33 0d 05 00 17 20 20 63 6d |aw_next3.... cm| 00001530 70 20 20 20 20 20 20 20 72 37 2c 23 26 66 66 0d |p r7,#&ff.| 00001540 05 0a 19 20 20 63 6d 70 4c 45 20 20 20 20 20 72 |... cmpLE r| 00001550 38 2c 23 26 66 66 30 30 0d 05 14 18 20 20 61 64 |8,#&ff00.... ad| 00001560 64 4c 45 20 20 20 20 20 72 38 2c 72 37 2c 72 38 |dLE r8,r7,r8| 00001570 0d 05 1e 1a 20 20 6c 64 72 4c 45 42 20 20 20 20 |.... ldrLEB | 00001580 72 38 2c 5b 72 32 2c 72 38 5d 0d 05 28 20 20 20 |r8,[r2,r8]..( | 00001590 61 64 64 4c 45 20 20 20 20 20 72 39 2c 72 39 2c |addLE r9,r9,| 000015a0 72 38 2c 6c 73 6c 20 23 31 36 0d 05 32 0f 2e 64 |r8,lsl #16..2..d| 000015b0 72 61 77 5f 6e 65 78 74 33 0d 05 3c 1a 20 20 73 |raw_next3..<. s| 000015c0 75 62 20 20 20 20 20 20 20 72 31 32 2c 72 31 32 |ub r12,r12| 000015d0 2c 23 31 0d 05 46 33 20 20 61 6e 64 20 20 20 20 |,#1..F3 and | 000015e0 20 20 20 72 37 2c 72 31 34 2c 23 26 66 66 30 30 | r7,r14,#&ff00| 000015f0 30 30 20 20 20 20 20 20 20 20 20 3b 20 34 74 68 |00 ; 4th| 00001600 20 70 69 78 65 6c 0d 05 50 21 20 20 61 64 64 53 | pixel..P! addS| 00001610 20 20 20 20 20 20 72 37 2c 72 37 2c 72 31 32 2c | r7,r7,r12,| 00001620 6c 73 6c 20 23 31 36 0d 05 5a 22 20 20 61 64 64 |lsl #16..Z" add| 00001630 47 45 53 20 20 20 20 72 38 2c 72 31 31 2c 72 31 |GES r8,r11,r1| 00001640 34 2c 6c 73 72 20 23 32 34 0d 05 64 1a 20 20 62 |4,lsr #24..d. b| 00001650 4d 49 20 20 20 20 20 20 20 64 72 61 77 5f 6e 65 |MI draw_ne| 00001660 78 74 34 0d 05 6e 1b 20 20 63 6d 70 20 20 20 20 |xt4..n. cmp | 00001670 20 20 20 72 37 2c 23 26 66 66 30 30 30 30 0d 05 | r7,#&ff0000..| 00001680 78 17 20 20 63 6d 70 4c 45 20 20 20 20 20 72 38 |x. cmpLE r8| 00001690 2c 23 26 66 66 0d 05 82 20 20 20 61 64 64 4c 45 |,#&ff... addLE| 000016a0 20 20 20 20 20 72 38 2c 72 37 2c 72 38 2c 6c 73 | r8,r7,r8,ls| 000016b0 6c 20 23 32 34 0d 05 8c 22 20 20 6c 64 72 4c 45 |l #24..." ldrLE| 000016c0 42 20 20 20 20 72 38 2c 5b 72 32 2c 72 38 2c 6c |B r8,[r2,r8,l| 000016d0 73 72 20 23 31 36 5d 0d 05 96 20 20 20 61 64 64 |sr #16]... add| 000016e0 4c 45 20 20 20 20 20 72 39 2c 72 39 2c 72 38 2c |LE r9,r9,r8,| 000016f0 6c 73 6c 20 23 32 34 0d 05 a0 0f 2e 64 72 61 77 |lsl #24.....draw| 00001700 5f 6e 65 78 74 34 0d 05 aa 37 20 20 73 74 72 20 |_next4...7 str | 00001710 20 20 20 20 20 20 72 39 2c 5b 72 30 5d 2c 23 34 | r9,[r0],#4| 00001720 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 | ; | 00001730 53 61 76 65 20 34 20 70 69 78 65 6c 73 0d 05 b4 |Save 4 pixels...| 00001740 43 20 61 64 64 53 20 72 36 2c 72 36 2c 23 34 3c |C addS r6,r6,#4<| 00001750 3c 32 34 3a 62 4e 45 20 64 72 61 77 5f 78 34 20 |<24:bNE draw_x4 | 00001760 20 20 20 20 20 3b 20 78 2b 3d 34 3c 3c 32 34 2c | ; x+=4<<24,| 00001770 20 63 6f 6e 74 69 6e 75 65 20 69 66 20 3c 3e 30 | continue if <>0| 00001780 0d 05 be 38 20 20 61 64 64 20 20 20 20 20 20 20 |...8 add | 00001790 72 30 2c 72 30 2c 23 33 32 30 2d 32 35 36 20 20 |r0,r0,#320-256 | 000017a0 20 20 20 20 20 20 20 20 3b 20 4e 65 78 74 20 76 | ; Next v| 000017b0 72 61 6d 20 6c 69 6e 65 0d 05 c8 43 20 61 64 64 |ram line...C add| 000017c0 53 20 72 35 2c 72 35 2c 23 31 3c 3c 32 34 3a 62 |S r5,r5,#1<<24:b| 000017d0 4e 45 20 64 72 61 77 5f 79 20 20 20 20 20 20 20 |NE draw_y | 000017e0 3b 20 79 2b 3d 31 3c 3c 32 34 2c 20 63 6f 6e 74 |; y+=1<<24, cont| 000017f0 69 6e 75 65 20 69 66 20 3c 3e 30 0d 05 d2 1d 20 |inue if <>0.... | 00001800 20 6c 64 72 20 20 20 20 20 20 20 72 31 33 2c 6f | ldr r13,o| 00001810 6c 64 5f 73 74 61 63 6b 0d 05 dc 21 20 20 6c 64 |ld_stack...! ld| 00001820 6d 66 64 20 20 20 20 20 72 31 33 21 2c 7b 72 30 |mfd r13!,{r0| 00001830 2d 72 31 32 2c 70 63 7d 5e 0d 05 e6 06 20 20 0d |-r12,pc}^.... .| 00001840 05 f0 37 5d 3a ed 6f 70 74 25 3a f1 22 41 73 73 |..7]:.opt%:."Ass| 00001850 65 6d 62 6c 79 20 63 6f 64 65 20 69 73 20 22 3b |embly code is ";| 00001860 50 25 2d 63 6f 64 65 25 3b 22 20 62 79 74 65 73 |P%-code%;" bytes| 00001870 20 6c 6f 6e 67 22 0d 05 fa 04 0d 06 04 4f f4 3d | long".......O.=| 00001880 3d 3d 3d 20 42 41 53 49 43 20 43 4f 44 45 20 3d |=== BASIC CODE =| 00001890 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d |================| * 000018c0 3d 3d 3d 3d 3d 3d 3d 3d 3d 0d 06 0e 12 de 65 6e |=========.....en| 000018d0 76 6d 61 70 25 20 36 35 35 33 36 0d 06 18 12 de |vmap% 65536.....| 000018e0 64 69 73 70 25 20 36 35 35 33 36 2a 32 0d 06 22 |disp% 65536*2.."| 000018f0 30 f4 4c 6f 61 64 20 68 65 69 67 68 74 20 66 69 |0.Load height fi| 00001900 65 6c 64 20 61 6e 64 20 63 6f 6d 70 75 74 65 20 |eld and compute | 00001910 64 69 73 70 6c 61 63 65 6d 65 6e 74 73 0d 06 2c |displacements..,| 00001920 1f f1 22 43 6f 6d 70 75 74 69 6e 67 20 64 69 73 |.."Computing dis| 00001930 70 6c 61 63 65 6d 65 6e 74 73 22 20 0d 06 36 17 |placements" ..6.| 00001940 41 25 3d 65 6e 76 6d 61 70 25 3a 42 25 3d 64 69 |A%=envmap%:B%=di| 00001950 73 70 25 0d 06 40 34 66 25 3d 8e 28 22 48 65 69 |sp%..@4f%=.("Hei| 00001960 67 68 74 32 35 36 22 29 3a c8 99 22 4f 53 5f 47 |ght256"):.."OS_G| 00001970 42 50 42 22 2c 34 2c 66 25 2c 41 25 2c 36 35 35 |BPB",4,f%,A%,655| 00001980 33 36 3a d9 23 66 25 0d 06 4a 12 d6 64 69 73 70 |36:.#f%..J..disp| 00001990 6c 61 63 65 6d 65 6e 74 73 0d 06 54 1b f4 43 72 |lacements..T..Cr| 000019a0 65 61 74 65 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 |eate environment| 000019b0 20 6d 61 70 0d 06 5e 20 f1 22 43 6f 6d 70 75 74 | map..^ ."Comput| 000019c0 69 6e 67 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 20 |ing environment | 000019d0 6d 61 70 22 0d 06 68 16 41 25 3d 65 6e 76 6d 61 |map"..h.A%=envma| 000019e0 70 25 3a d6 65 6e 76 6d 61 70 0d 06 72 04 0d 06 |p%:.envmap..r...| 000019f0 7c 3c f4 53 63 72 65 65 6e 20 26 20 63 6f 6c 6f ||<.Screen & colo| 00001a00 72 20 69 6e 69 74 69 61 6c 69 73 61 74 69 6f 6e |r initialisation| 00001a10 2e 20 54 68 65 6e 20 6c 65 74 20 74 68 65 20 73 |. Then let the s| 00001a20 68 6f 77 20 62 65 67 69 6e 2e 0d 06 86 48 eb 31 |how begin....H.1| 00001a30 35 3a eb 31 32 3a 87 3a de 76 25 20 38 3a 21 76 |5:.12:.:.v% 8:!v| 00001a40 25 3d 31 34 38 3a 76 25 21 34 3d 2d 31 3a c8 99 |%=148:v%!4=-1:..| 00001a50 22 4f 53 5f 52 65 61 64 56 64 75 56 61 72 69 61 |"OS_ReadVduVaria| 00001a60 62 6c 65 73 22 2c 76 25 2c 76 25 3a 76 25 3d 21 |bles",v%,v%:v%=!| 00001a70 76 25 0d 06 90 0c e3 63 25 3d 31 b8 31 35 0d 06 |v%.....c%=1.15..| 00001a80 9a 1f 20 62 25 3d 63 25 2a 31 37 2b 33 34 3a e7 |.. b%=c%*17+34:.| 00001a90 62 25 3e 32 35 35 8c 62 25 3d 32 35 35 0d 06 a4 |b%>255.b%=255...| 00001aa0 17 20 fb 63 25 2c 63 25 2a 31 37 2c 63 25 2a 31 |. .c%,c%*17,c%*1| 00001ab0 37 2c 62 25 0d 06 ae 07 ed 63 25 0d 06 b8 08 62 |7,b%.....c%....b| 00001ac0 25 3d 32 0d 06 c2 0c 42 25 3d 64 69 73 70 25 0d |%=2....B%=disp%.| 00001ad0 06 cc 0e 43 25 3d 65 6e 76 6d 61 70 25 0d 06 d6 |...C%=envmap%...| 00001ae0 05 f5 0d 06 e0 35 20 c8 96 3a c8 99 22 4f 53 5f |.....5 ..:.."OS_| 00001af0 42 79 74 65 22 2c 26 37 31 2c 62 25 3a 62 25 3d |Byte",&71,b%:b%=| 00001b00 62 25 82 33 3a c8 99 22 4f 53 5f 42 79 74 65 22 |b%.3:.."OS_Byte"| 00001b10 2c 26 37 30 2c 62 25 0d 06 ea 1b 20 41 25 3d 76 |,&70,b%.... A%=v| 00001b20 25 2b 28 62 25 3e 3e 31 29 2a 38 31 39 32 30 2b |%+(b%>>1)*81920+| 00001b30 33 32 0d 06 f4 0f 20 c8 97 78 25 2c 79 25 2c 7a |32.... ..x%,y%,z| 00001b40 25 0d 06 fe 21 20 44 25 3d 28 78 25 3e 3e 32 29 |%...! D%=(x%>>2)| 00001b50 2d 33 32 3a 45 25 3d 32 35 36 2d 28 79 25 3e 3e |-32:E%=256-(y%>>| 00001b60 32 29 0d 07 08 0e 20 d6 64 72 61 77 5f 65 6e 76 |2).... .draw_env| 00001b70 0d 07 12 06 fd a3 0d 07 1c 04 0d 07 26 45 f4 3d |............&E.=| 00001b80 3d 3d 3d 20 4d 41 43 52 4f 53 20 3d 3d 3d 3d 3d |=== MACROS =====| 00001b90 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d |================| * 00001bb0 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 0d |===============.| 00001bc0 07 30 11 f4 6d 30 3d 73 71 72 74 28 6d 31 29 2e |.0..m0=sqrt(m1).| 00001bd0 0d 07 3a 14 dd a4 73 71 72 74 28 6d 30 2c 6d 31 |..:...sqrt(m0,m1| 00001be0 2c 6d 32 29 0d 07 44 07 ea 6e 25 0d 07 4e 0d 5b |,m2)..D..n%..N.[| 00001bf0 6f 70 74 20 6f 70 74 25 0d 07 58 47 20 20 6d 6f |opt opt%..XG mo| 00001c00 76 20 20 20 20 20 20 20 6d 30 2c 23 30 20 20 20 |v m0,#0 | 00001c10 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001c20 3b 20 54 68 69 73 20 69 73 20 72 69 70 70 65 64 |; This is ripped| 00001c30 20 66 72 6f 6d 20 4a 61 6e 2f 42 41 53 53 2e 0d | from Jan/BASS..| 00001c40 07 62 2c 20 20 6d 6f 76 20 20 20 20 20 20 20 6d |.b, mov m| 00001c50 32 2c 23 31 3c 3c 33 30 20 20 20 20 20 20 20 20 |2,#1<<30 | 00001c60 20 20 20 20 20 20 20 3b 20 20 7c 0d 07 6c 2c 20 | ; |..l, | 00001c70 20 63 6d 70 20 20 20 20 20 20 20 6d 31 2c 6d 32 | cmp m1,m2| 00001c80 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001c90 20 20 20 3b 20 20 7c 0d 07 76 2c 20 20 73 75 62 | ; |..v, sub| 00001ca0 48 53 20 20 20 20 20 6d 31 2c 6d 30 2c 6d 32 20 |HS m1,m0,m2 | 00001cb0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b | ;| 00001cc0 20 20 7c 0d 07 80 2c 20 20 61 64 63 20 20 20 20 | |..., adc | 00001cd0 20 20 20 6d 30 2c 6d 30 2c 6d 30 20 20 20 20 20 | m0,m0,m0 | 00001ce0 20 20 20 20 20 20 20 20 20 20 20 3b 20 20 7c 0d | ; |.| 00001cf0 07 8a 1a 5d 3a e3 6e 25 3d 32 b8 33 30 88 32 3a |...]:.n%=2.30.2:| 00001d00 5b 6f 70 74 20 6f 70 74 25 0d 07 94 2c 20 20 61 |[opt opt%..., a| 00001d10 64 64 20 20 20 20 20 20 20 6d 32 2c 6d 30 2c 23 |dd m2,m0,#| 00001d20 31 3c 3c 33 30 20 20 20 20 20 20 20 20 20 20 20 |1<<30 | 00001d30 20 3b 20 20 7c 0d 07 9e 2c 20 20 63 6d 70 20 20 | ; |..., cmp | 00001d40 20 20 20 20 20 6d 31 2c 6d 32 2c 72 6f 72 20 23 | m1,m2,ror #| 00001d50 6e 25 20 20 20 20 20 20 20 20 20 20 20 3b 20 20 |n% ; | 00001d60 7c 0d 07 a8 2c 20 20 73 75 62 48 53 20 20 20 20 ||..., subHS | 00001d70 20 6d 31 2c 6d 31 2c 6d 32 2c 72 6f 72 20 23 6e | m1,m1,m2,ror #n| 00001d80 25 20 20 20 20 20 20 20 20 3b 20 20 7c 0d 07 b2 |% ; |...| 00001d90 3d 20 20 61 64 63 20 20 20 20 20 20 20 6d 30 2c |= adc m0,| 00001da0 6d 30 2c 6d 30 20 20 20 20 20 20 20 20 20 20 20 |m0,m0 | 00001db0 20 20 20 20 20 3b 20 45 6e 64 20 6f 66 20 72 69 | ; End of ri| 00001dc0 70 70 65 64 20 63 6f 64 65 2e 0d 07 bc 13 5d 3a |pped code.....]:| 00001dd0 ed 6e 25 3a 5b 6f 70 74 20 6f 70 74 25 0d 07 c6 |.n%:[opt opt%...| 00001de0 39 20 20 63 6d 70 20 20 20 20 20 20 20 6d 31 2c |9 cmp m1,| 00001df0 6d 30 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |m0 | 00001e00 20 20 20 20 20 3b 20 46 6c 61 67 73 3d 76 61 6c | ; Flags=val| 00001e10 2d 72 6f 6f 74 2e 0d 07 d0 43 20 20 61 64 64 50 |-root....C addP| 00001e20 4c 20 20 20 20 20 6d 30 2c 6d 30 2c 23 31 20 20 |L m0,m0,#1 | 00001e30 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 | ; | 00001e40 52 6f 75 6e 64 20 74 6f 20 6e 65 61 72 65 73 74 |Round to nearest| 00001e50 20 69 6e 74 65 67 65 72 2e 0d 07 da 09 5d 3a 3d | integer.....]:=| 00001e60 22 22 0d ff |""..| 00001e64