Home » Archimedes archive » Acorn User » AU 1997-05 B.adf » Regulars » StarInfo/clouds/Brown/s/mapfn

StarInfo/clouds/Brown/s/mapfn

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 1997-05 B.adf » Regulars
Filename: StarInfo/clouds/Brown/s/mapfn
Read OK:
File size: 088C bytes
Load address: 0000
Exec address: 0000
File contents
	AREA |data$$dataarea|, DATA

diffx	DCD	0
diffz	DCD	0

divtab	DCD	0
	GBLA	fill
fill	SETA	1
	WHILE	fill<1322
	DCD	786432000/fill
fill	SETA	fill+1
	WEND


	AREA |code$$codearea|, CODE, READONLY

	EXPORT copy

; r0 source pointer
; r1 destination pointer
copy
	stmfd r13!,{r2-r12,r14}
	mov r2,#256
yloop
	mov r3,r0
	mov r5,#256
xloop
	ldr r4,[r3],#4
	str r4,[r1],#4
	subs r5,r5,#4
	bgt xloop
	add r0,r0,#320
	subs r2,r2,#1
	bgt yloop
	ldmfd r13!,{r2-r12,pc}



	EXPORT maptoceil

; entry* r0 - screenbase
;        r1 - srcbase
;        r2 - divtab
;        r3 - sin
;        r4 - cos
;        r5 - diff x
;        r6 - diff z
maptoceil
	stmfd r13!,{r0-r12,r14}

	ldmia r0,{r0-r6}   ; load a chunk of parameters

	adrl r2,divtab

	adrl r7,diffx
	stmia r7,{r5,r6}

	mov r5,#1020      ; y2

yloop2
	add r7,r5,#300
	ldr r7,[r2,r7,lsl #2]
	sub r7,r7,#589824  ; z

	mov r8,#640
	add r9,r7,#589824
	mul r8,r9,r8
	mov r8,r8,asr #10 ; x

	mul r9,r8,r4
	mla r11,r7,r3,r9   ; x3
	mul r10,r4,r7
	mul r8,r3,r8
	sub r10,r10,r8     ; z3


	                   ; z (r7) intact from before

	mov r8,#636       ; moved along a bit...
	add r9,r7,#589824
	mul r8,r9,r8
	mov r8,r8,asr #10 ; x

	mul r9,r8,r4
	mla r9,r7,r3,r9   ; x3
	mul r7,r4,r7
	mul r8,r3,r8
	sub r7,r7,r8      ; z3

	; line goes from (r11,r10) to (r9,r7)

	sub r7,r7,r10     ; make difference  z
	sub r9,r9,r11     ;                  x

	adrl r8,diffx     ; move around viewpoint a bit
	ldmia r8,{r8,r12}
	add r11,r11,r8,asl #22
	add r10,r10,r12,asl #22

	stmfd r13!,{r4}

	mov r6,#320

xloop2
	mov r12,r11,lsr #24
	mov r8,r10,lsr #24
	add r8,r8,r12,lsl #8

	ldrb r4,[r1,r8]

	add r11,r11,r9
	add r10,r10,r7


	mov r12,r11,lsr #24
	mov r8,r10,lsr #24
	add r8,r8,r12,lsl #8

	ldrb r8,[r1,r8]
	orr r4,r4,r8,lsl #8

	add r11,r11,r9
	add r10,r10,r7


	mov r12,r11,lsr #24
	mov r8,r10,lsr #24
	add r8,r8,r12,lsl #8

	ldrb r8,[r1,r8]
	orr r4,r4,r8,lsl #16

	add r11,r11,r9
	add r10,r10,r7


	mov r12,r11,lsr #24
	mov r8,r10,lsr #24
	add r8,r8,r12,lsl #8

	ldrb r8,[r1,r8]
	orr r4,r4,r8,lsl #24

	add r11,r11,r9
	add r10,r10,r7

	str r4,[r0],#4

	subs r6,r6,#4
	bgt xloop2

	ldmfd r13!,{r4}

	subs r5,r5,#4
	bge yloop2

	ldmfd r13!,{r0-r12,pc}

	END
00000000  0a 09 41 52 45 41 20 7c  64 61 74 61 24 24 64 61  |..AREA |data$$da|
00000010  74 61 61 72 65 61 7c 2c  20 44 41 54 41 0a 0a 64  |taarea|, DATA..d|
00000020  69 66 66 78 09 44 43 44  09 30 0a 64 69 66 66 7a  |iffx.DCD.0.diffz|
00000030  09 44 43 44 09 30 0a 0a  64 69 76 74 61 62 09 44  |.DCD.0..divtab.D|
00000040  43 44 09 30 0a 09 47 42  4c 41 09 66 69 6c 6c 0a  |CD.0..GBLA.fill.|
00000050  66 69 6c 6c 09 53 45 54  41 09 31 0a 09 57 48 49  |fill.SETA.1..WHI|
00000060  4c 45 09 66 69 6c 6c 3c  31 33 32 32 0a 09 44 43  |LE.fill<1322..DC|
00000070  44 09 37 38 36 34 33 32  30 30 30 2f 66 69 6c 6c  |D.786432000/fill|
00000080  0a 66 69 6c 6c 09 53 45  54 41 09 66 69 6c 6c 2b  |.fill.SETA.fill+|
00000090  31 0a 09 57 45 4e 44 0a  0a 0a 09 41 52 45 41 20  |1..WEND....AREA |
000000a0  7c 63 6f 64 65 24 24 63  6f 64 65 61 72 65 61 7c  ||code$$codearea||
000000b0  2c 20 43 4f 44 45 2c 20  52 45 41 44 4f 4e 4c 59  |, CODE, READONLY|
000000c0  0a 0a 09 45 58 50 4f 52  54 20 63 6f 70 79 0a 0a  |...EXPORT copy..|
000000d0  3b 20 72 30 20 73 6f 75  72 63 65 20 70 6f 69 6e  |; r0 source poin|
000000e0  74 65 72 0a 3b 20 72 31  20 64 65 73 74 69 6e 61  |ter.; r1 destina|
000000f0  74 69 6f 6e 20 70 6f 69  6e 74 65 72 0a 63 6f 70  |tion pointer.cop|
00000100  79 0a 09 73 74 6d 66 64  20 72 31 33 21 2c 7b 72  |y..stmfd r13!,{r|
00000110  32 2d 72 31 32 2c 72 31  34 7d 0a 09 6d 6f 76 20  |2-r12,r14}..mov |
00000120  72 32 2c 23 32 35 36 0a  79 6c 6f 6f 70 0a 09 6d  |r2,#256.yloop..m|
00000130  6f 76 20 72 33 2c 72 30  0a 09 6d 6f 76 20 72 35  |ov r3,r0..mov r5|
00000140  2c 23 32 35 36 0a 78 6c  6f 6f 70 0a 09 6c 64 72  |,#256.xloop..ldr|
00000150  20 72 34 2c 5b 72 33 5d  2c 23 34 0a 09 73 74 72  | r4,[r3],#4..str|
00000160  20 72 34 2c 5b 72 31 5d  2c 23 34 0a 09 73 75 62  | r4,[r1],#4..sub|
00000170  73 20 72 35 2c 72 35 2c  23 34 0a 09 62 67 74 20  |s r5,r5,#4..bgt |
00000180  78 6c 6f 6f 70 0a 09 61  64 64 20 72 30 2c 72 30  |xloop..add r0,r0|
00000190  2c 23 33 32 30 0a 09 73  75 62 73 20 72 32 2c 72  |,#320..subs r2,r|
000001a0  32 2c 23 31 0a 09 62 67  74 20 79 6c 6f 6f 70 0a  |2,#1..bgt yloop.|
000001b0  09 6c 64 6d 66 64 20 72  31 33 21 2c 7b 72 32 2d  |.ldmfd r13!,{r2-|
000001c0  72 31 32 2c 70 63 7d 0a  0a 0a 0a 09 45 58 50 4f  |r12,pc}.....EXPO|
000001d0  52 54 20 6d 61 70 74 6f  63 65 69 6c 0a 0a 3b 20  |RT maptoceil..; |
000001e0  65 6e 74 72 79 2a 20 72  30 20 2d 20 73 63 72 65  |entry* r0 - scre|
000001f0  65 6e 62 61 73 65 0a 3b  20 20 20 20 20 20 20 20  |enbase.;        |
00000200  72 31 20 2d 20 73 72 63  62 61 73 65 0a 3b 20 20  |r1 - srcbase.;  |
00000210  20 20 20 20 20 20 72 32  20 2d 20 64 69 76 74 61  |      r2 - divta|
00000220  62 0a 3b 20 20 20 20 20  20 20 20 72 33 20 2d 20  |b.;        r3 - |
00000230  73 69 6e 0a 3b 20 20 20  20 20 20 20 20 72 34 20  |sin.;        r4 |
00000240  2d 20 63 6f 73 0a 3b 20  20 20 20 20 20 20 20 72  |- cos.;        r|
00000250  35 20 2d 20 64 69 66 66  20 78 0a 3b 20 20 20 20  |5 - diff x.;    |
00000260  20 20 20 20 72 36 20 2d  20 64 69 66 66 20 7a 0a  |    r6 - diff z.|
00000270  6d 61 70 74 6f 63 65 69  6c 0a 09 73 74 6d 66 64  |maptoceil..stmfd|
00000280  20 72 31 33 21 2c 7b 72  30 2d 72 31 32 2c 72 31  | r13!,{r0-r12,r1|
00000290  34 7d 0a 0a 09 6c 64 6d  69 61 20 72 30 2c 7b 72  |4}...ldmia r0,{r|
000002a0  30 2d 72 36 7d 20 20 20  3b 20 6c 6f 61 64 20 61  |0-r6}   ; load a|
000002b0  20 63 68 75 6e 6b 20 6f  66 20 70 61 72 61 6d 65  | chunk of parame|
000002c0  74 65 72 73 0a 0a 09 61  64 72 6c 20 72 32 2c 64  |ters...adrl r2,d|
000002d0  69 76 74 61 62 0a 0a 09  61 64 72 6c 20 72 37 2c  |ivtab...adrl r7,|
000002e0  64 69 66 66 78 0a 09 73  74 6d 69 61 20 72 37 2c  |diffx..stmia r7,|
000002f0  7b 72 35 2c 72 36 7d 0a  0a 09 6d 6f 76 20 72 35  |{r5,r6}...mov r5|
00000300  2c 23 31 30 32 30 20 20  20 20 20 20 3b 20 79 32  |,#1020      ; y2|
00000310  0a 0a 79 6c 6f 6f 70 32  0a 09 61 64 64 20 72 37  |..yloop2..add r7|
00000320  2c 72 35 2c 23 33 30 30  0a 09 6c 64 72 20 72 37  |,r5,#300..ldr r7|
00000330  2c 5b 72 32 2c 72 37 2c  6c 73 6c 20 23 32 5d 0a  |,[r2,r7,lsl #2].|
00000340  09 73 75 62 20 72 37 2c  72 37 2c 23 35 38 39 38  |.sub r7,r7,#5898|
00000350  32 34 20 20 3b 20 7a 0a  0a 09 6d 6f 76 20 72 38  |24  ; z...mov r8|
00000360  2c 23 36 34 30 0a 09 61  64 64 20 72 39 2c 72 37  |,#640..add r9,r7|
00000370  2c 23 35 38 39 38 32 34  0a 09 6d 75 6c 20 72 38  |,#589824..mul r8|
00000380  2c 72 39 2c 72 38 0a 09  6d 6f 76 20 72 38 2c 72  |,r9,r8..mov r8,r|
00000390  38 2c 61 73 72 20 23 31  30 20 3b 20 78 0a 0a 09  |8,asr #10 ; x...|
000003a0  6d 75 6c 20 72 39 2c 72  38 2c 72 34 0a 09 6d 6c  |mul r9,r8,r4..ml|
000003b0  61 20 72 31 31 2c 72 37  2c 72 33 2c 72 39 20 20  |a r11,r7,r3,r9  |
000003c0  20 3b 20 78 33 0a 09 6d  75 6c 20 72 31 30 2c 72  | ; x3..mul r10,r|
000003d0  34 2c 72 37 0a 09 6d 75  6c 20 72 38 2c 72 33 2c  |4,r7..mul r8,r3,|
000003e0  72 38 0a 09 73 75 62 20  72 31 30 2c 72 31 30 2c  |r8..sub r10,r10,|
000003f0  72 38 20 20 20 20 20 3b  20 7a 33 0a 0a 0a 09 20  |r8     ; z3.... |
00000400  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
00000410  20 20 3b 20 7a 20 28 72  37 29 20 69 6e 74 61 63  |  ; z (r7) intac|
00000420  74 20 66 72 6f 6d 20 62  65 66 6f 72 65 0a 0a 09  |t from before...|
00000430  6d 6f 76 20 72 38 2c 23  36 33 36 20 20 20 20 20  |mov r8,#636     |
00000440  20 20 3b 20 6d 6f 76 65  64 20 61 6c 6f 6e 67 20  |  ; moved along |
00000450  61 20 62 69 74 2e 2e 2e  0a 09 61 64 64 20 72 39  |a bit.....add r9|
00000460  2c 72 37 2c 23 35 38 39  38 32 34 0a 09 6d 75 6c  |,r7,#589824..mul|
00000470  20 72 38 2c 72 39 2c 72  38 0a 09 6d 6f 76 20 72  | r8,r9,r8..mov r|
00000480  38 2c 72 38 2c 61 73 72  20 23 31 30 20 3b 20 78  |8,r8,asr #10 ; x|
00000490  0a 0a 09 6d 75 6c 20 72  39 2c 72 38 2c 72 34 0a  |...mul r9,r8,r4.|
000004a0  09 6d 6c 61 20 72 39 2c  72 37 2c 72 33 2c 72 39  |.mla r9,r7,r3,r9|
000004b0  20 20 20 3b 20 78 33 0a  09 6d 75 6c 20 72 37 2c  |   ; x3..mul r7,|
000004c0  72 34 2c 72 37 0a 09 6d  75 6c 20 72 38 2c 72 33  |r4,r7..mul r8,r3|
000004d0  2c 72 38 0a 09 73 75 62  20 72 37 2c 72 37 2c 72  |,r8..sub r7,r7,r|
000004e0  38 20 20 20 20 20 20 3b  20 7a 33 0a 0a 09 3b 20  |8      ; z3...; |
000004f0  6c 69 6e 65 20 67 6f 65  73 20 66 72 6f 6d 20 28  |line goes from (|
00000500  72 31 31 2c 72 31 30 29  20 74 6f 20 28 72 39 2c  |r11,r10) to (r9,|
00000510  72 37 29 0a 0a 09 73 75  62 20 72 37 2c 72 37 2c  |r7)...sub r7,r7,|
00000520  72 31 30 20 20 20 20 20  3b 20 6d 61 6b 65 20 64  |r10     ; make d|
00000530  69 66 66 65 72 65 6e 63  65 20 20 7a 0a 09 73 75  |ifference  z..su|
00000540  62 20 72 39 2c 72 39 2c  72 31 31 20 20 20 20 20  |b r9,r9,r11     |
00000550  3b 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |;               |
00000560  20 20 20 78 0a 0a 09 61  64 72 6c 20 72 38 2c 64  |   x...adrl r8,d|
00000570  69 66 66 78 20 20 20 20  20 3b 20 6d 6f 76 65 20  |iffx     ; move |
00000580  61 72 6f 75 6e 64 20 76  69 65 77 70 6f 69 6e 74  |around viewpoint|
00000590  20 61 20 62 69 74 0a 09  6c 64 6d 69 61 20 72 38  | a bit..ldmia r8|
000005a0  2c 7b 72 38 2c 72 31 32  7d 0a 09 61 64 64 20 72  |,{r8,r12}..add r|
000005b0  31 31 2c 72 31 31 2c 72  38 2c 61 73 6c 20 23 32  |11,r11,r8,asl #2|
000005c0  32 0a 09 61 64 64 20 72  31 30 2c 72 31 30 2c 72  |2..add r10,r10,r|
000005d0  31 32 2c 61 73 6c 20 23  32 32 0a 0a 09 73 74 6d  |12,asl #22...stm|
000005e0  66 64 20 72 31 33 21 2c  7b 72 34 7d 0a 0a 09 6d  |fd r13!,{r4}...m|
000005f0  6f 76 20 72 36 2c 23 33  32 30 0a 0a 78 6c 6f 6f  |ov r6,#320..xloo|
00000600  70 32 0a 09 6d 6f 76 20  72 31 32 2c 72 31 31 2c  |p2..mov r12,r11,|
00000610  6c 73 72 20 23 32 34 0a  09 6d 6f 76 20 72 38 2c  |lsr #24..mov r8,|
00000620  72 31 30 2c 6c 73 72 20  23 32 34 0a 09 61 64 64  |r10,lsr #24..add|
00000630  20 72 38 2c 72 38 2c 72  31 32 2c 6c 73 6c 20 23  | r8,r8,r12,lsl #|
00000640  38 0a 0a 09 6c 64 72 62  20 72 34 2c 5b 72 31 2c  |8...ldrb r4,[r1,|
00000650  72 38 5d 0a 0a 09 61 64  64 20 72 31 31 2c 72 31  |r8]...add r11,r1|
00000660  31 2c 72 39 0a 09 61 64  64 20 72 31 30 2c 72 31  |1,r9..add r10,r1|
00000670  30 2c 72 37 0a 0a 0a 09  6d 6f 76 20 72 31 32 2c  |0,r7....mov r12,|
00000680  72 31 31 2c 6c 73 72 20  23 32 34 0a 09 6d 6f 76  |r11,lsr #24..mov|
00000690  20 72 38 2c 72 31 30 2c  6c 73 72 20 23 32 34 0a  | r8,r10,lsr #24.|
000006a0  09 61 64 64 20 72 38 2c  72 38 2c 72 31 32 2c 6c  |.add r8,r8,r12,l|
000006b0  73 6c 20 23 38 0a 0a 09  6c 64 72 62 20 72 38 2c  |sl #8...ldrb r8,|
000006c0  5b 72 31 2c 72 38 5d 0a  09 6f 72 72 20 72 34 2c  |[r1,r8]..orr r4,|
000006d0  72 34 2c 72 38 2c 6c 73  6c 20 23 38 0a 0a 09 61  |r4,r8,lsl #8...a|
000006e0  64 64 20 72 31 31 2c 72  31 31 2c 72 39 0a 09 61  |dd r11,r11,r9..a|
000006f0  64 64 20 72 31 30 2c 72  31 30 2c 72 37 0a 0a 0a  |dd r10,r10,r7...|
00000700  09 6d 6f 76 20 72 31 32  2c 72 31 31 2c 6c 73 72  |.mov r12,r11,lsr|
00000710  20 23 32 34 0a 09 6d 6f  76 20 72 38 2c 72 31 30  | #24..mov r8,r10|
00000720  2c 6c 73 72 20 23 32 34  0a 09 61 64 64 20 72 38  |,lsr #24..add r8|
00000730  2c 72 38 2c 72 31 32 2c  6c 73 6c 20 23 38 0a 0a  |,r8,r12,lsl #8..|
00000740  09 6c 64 72 62 20 72 38  2c 5b 72 31 2c 72 38 5d  |.ldrb r8,[r1,r8]|
00000750  0a 09 6f 72 72 20 72 34  2c 72 34 2c 72 38 2c 6c  |..orr r4,r4,r8,l|
00000760  73 6c 20 23 31 36 0a 0a  09 61 64 64 20 72 31 31  |sl #16...add r11|
00000770  2c 72 31 31 2c 72 39 0a  09 61 64 64 20 72 31 30  |,r11,r9..add r10|
00000780  2c 72 31 30 2c 72 37 0a  0a 0a 09 6d 6f 76 20 72  |,r10,r7....mov r|
00000790  31 32 2c 72 31 31 2c 6c  73 72 20 23 32 34 0a 09  |12,r11,lsr #24..|
000007a0  6d 6f 76 20 72 38 2c 72  31 30 2c 6c 73 72 20 23  |mov r8,r10,lsr #|
000007b0  32 34 0a 09 61 64 64 20  72 38 2c 72 38 2c 72 31  |24..add r8,r8,r1|
000007c0  32 2c 6c 73 6c 20 23 38  0a 0a 09 6c 64 72 62 20  |2,lsl #8...ldrb |
000007d0  72 38 2c 5b 72 31 2c 72  38 5d 0a 09 6f 72 72 20  |r8,[r1,r8]..orr |
000007e0  72 34 2c 72 34 2c 72 38  2c 6c 73 6c 20 23 32 34  |r4,r4,r8,lsl #24|
000007f0  0a 0a 09 61 64 64 20 72  31 31 2c 72 31 31 2c 72  |...add r11,r11,r|
00000800  39 0a 09 61 64 64 20 72  31 30 2c 72 31 30 2c 72  |9..add r10,r10,r|
00000810  37 0a 0a 09 73 74 72 20  72 34 2c 5b 72 30 5d 2c  |7...str r4,[r0],|
00000820  23 34 0a 0a 09 73 75 62  73 20 72 36 2c 72 36 2c  |#4...subs r6,r6,|
00000830  23 34 0a 09 62 67 74 20  78 6c 6f 6f 70 32 0a 0a  |#4..bgt xloop2..|
00000840  09 6c 64 6d 66 64 20 72  31 33 21 2c 7b 72 34 7d  |.ldmfd r13!,{r4}|
00000850  0a 0a 09 73 75 62 73 20  72 35 2c 72 35 2c 23 34  |...subs r5,r5,#4|
00000860  0a 09 62 67 65 20 79 6c  6f 6f 70 32 0a 0a 09 6c  |..bge yloop2...l|
00000870  64 6d 66 64 20 72 31 33  21 2c 7b 72 30 2d 72 31  |dmfd r13!,{r0-r1|
00000880  32 2c 70 63 7d 0a 0a 09  45 4e 44 0a              |2,pc}...END.|
0000088c