Home » Archimedes archive » Acorn User » AU 1993-08.adf » !StarInfo_StarInfo » MemSpeed
MemSpeed
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 1993-08.adf » !StarInfo_StarInfo |
Filename: | MemSpeed |
Read OK: | ✔ |
File size: | 06B5 bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
10REM >MemSpeed (Info14) 20REM By Nick Craig-Wood 30REM For 32-bit machines 40REM (c) BAU August 1993 50: 60cycles=25000 70fudge=1.25 80PROCcode 90at%=@% 100: 110ON ERROR @%=at%:PROCcache(TRUE):PRINTREPORT$;" at line ";ERL:END 120n=0 130sum=0 140REPEAT 150 speed=FNmemspeed 160 sum+=speed 170 n+=1 180 @%="g10.9" 190 PRINT "Average = ";INT(sum/n);"Hz, This test = ";INT(speed);" Hz" 200 @%="f10.3" 210 PRINT " Rounded = ";sum/n/1000000;"Mhz" 220UNTIL INKEY$(0)<>"" 230END 240: 250DEF PROCcache(state) 260IF FNarm3 THEN 270 IF state THEN 280 *Cache On 290 ELSE 300 *Cache Off 310 ENDIF 320ENDIF 330ENDPROC 340: 350DEF FNarm3 360SYS "XOS_SWINumberFromString","Cache_Flush" TO ;f% 370=(f% AND 1)<>0 380: 390DEF FNmemspeed 400PROCcache(FALSE) 410PROCpause(20) 420time=USR(timetrial) 430PROCpause(20) 440PROCcache(TRUE) 450=fudge*cycles/((65535-time)/2E6) 460 470DEF PROCpause(t%) 480t%+=TIME:REPEAT:UNTIL TIME>t% 490ENDPROC 500: 510DEF PROCcode 520t1low= &50 530t1high= &54 540t1go= &58 550t1latch=&5C 560codesize=256*1024 570DIM code codesize 580sp=13:link=14:pc=15 590pass=8 600P%=code:L%=code+codesize 610[OPT pass 620 630.timetrial 640 STMFD (sp)!,{link} 650 SWI "OS_EnterOS" 660 670 MOV R0,#%00000<<8 680 MOV R1,#%11111<<8 690 SWI "OS_UpdateMEMC" 700 710 SWI "OS_IntOff" 720 730 MOV R12,#&3200000 740 750 MOV R0,#&FF 760 STRB R0,[R12,#t1low] 770 STRB R0,[R12,#t1high] 780 790 STRB R0,[R12,#t1go] 800] 810FOR i%=1 TO cycles 820[OPT pass 830 ADD R0,R0,#1 840] 850IF (i% MOD 100)=0 PRINTcycles-i%;CHR$13; 860NEXT i% 870[OPT pass 880 STRB R0,[R12,#t1latch] 890 900 LDRB R0,[R12,#t1low] 910 LDRB R1,[R12,#t1high] 920 ORR R11,R0,R1,lsl#8 930 940 MOV R0,#%11101<<8 950 MOV R1,#%11111<<8 960 SWI "OS_UpdateMEMC" 970 980 TEQP pc,#0 990 MOV R0,R0 1000 1010 MOV R0,R11 1020 LDMFD (sp)!,{pc}^ 1030] 1040ENDPROC
� >MemSpeed (Info14) � By Nick Craig-Wood � For 32-bit machines (� (c) BAU August 1993 2: <cycles=25000 Ffudge=1.25 P �code Z at%=@% d: n,� � @%=at%:�cache(�):�$;" at line ";�:� xn=0 � sum=0 �� � speed=�memspeed � sum+=speed � n+=1 � @%="g10.9" �? � "Average = ";�(sum/n);"Hz, This test = ";�(speed);" Hz" � @%="f10.3" �) � " Rounded = ";sum/n/1000000;"Mhz" �� �(0)<>"" �� �: �� �cache(state) � �arm3 � � state � *Cache On " � , *Cache Off 6 � @� J� T: ^� �arm3 h4ș "XOS_SWINumberFromString","Cache_Flush" � ;f% r=(f% � 1)<>0 |: �� �memspeed � �cache(�) ��pause(20) �time=�(timetrial) ��pause(20) � �cache(�) �$=fudge*cycles/((65535-time)/2E6) � �� �pause(t%) �t%+=�:�:� �>t% �� �: �� �code t1low= &50 t1high= &54 t1go= &58 &t1latch=&5C 0codesize=256*1024 :� code codesize Dsp=13:link=14:pc=15 N pass=8 XP%=code:L%=code+codesize b [OPT pass l v.timetrial � STMFD (sp)!,{link} � SWI "OS_EnterOS" � � MOV R0,#%00000<<8 � MOV R1,#%11111<<8 � SWI "OS_UpdateMEMC" � � SWI "OS_IntOff" � � MOV R12,#&3200000 � � MOV R0,#&FF � STRB R0,[R12,#t1low] STRB R0,[R12,#t1high] STRB R0,[R12,#t1go] ] *� i%=1 � cycles 4 [OPT pass > ADD R0,R0,#1 H] R"� (i% � 100)=0 �cycles-i%;�13; \� i% f [OPT pass p STRB R0,[R12,#t1latch] z � LDRB R0,[R12,#t1low] � LDRB R1,[R12,#t1high] � �R R11,R0,R1,lsl#8 � � MOV R0,#%11101<<8 � MOV R1,#%11111<<8 � SWI "OS_UpdateMEMC" � � TEQP pc,#0 � MOV R0,R0 � � MOV R0,R11 � LDMFD (sp)!,{pc}^ ] � �
00000000 0d 00 0a 1c f4 20 20 20 20 20 3e 4d 65 6d 53 70 |..... >MemSp| 00000010 65 65 64 20 28 49 6e 66 6f 31 34 29 0d 00 14 19 |eed (Info14)....| 00000020 f4 20 42 79 20 20 4e 69 63 6b 20 43 72 61 69 67 |. By Nick Craig| 00000030 2d 57 6f 6f 64 0d 00 1e 19 f4 20 46 6f 72 20 33 |-Wood..... For 3| 00000040 32 2d 62 69 74 20 6d 61 63 68 69 6e 65 73 0d 00 |2-bit machines..| 00000050 28 19 f4 20 28 63 29 20 42 41 55 20 41 75 67 75 |(.. (c) BAU Augu| 00000060 73 74 20 31 39 39 33 0d 00 32 05 3a 0d 00 3c 10 |st 1993..2.:..<.| 00000070 63 79 63 6c 65 73 3d 32 35 30 30 30 0d 00 46 0e |cycles=25000..F.| 00000080 66 75 64 67 65 3d 31 2e 32 35 0d 00 50 09 f2 63 |fudge=1.25..P..c| 00000090 6f 64 65 0d 00 5a 0a 61 74 25 3d 40 25 0d 00 64 |ode..Z.at%=@%..d| 000000a0 05 3a 0d 00 6e 2c ee 20 85 20 40 25 3d 61 74 25 |.:..n,. . @%=at%| 000000b0 3a f2 63 61 63 68 65 28 b9 29 3a f1 f6 24 3b 22 |:.cache(.):..$;"| 000000c0 20 61 74 20 6c 69 6e 65 20 22 3b 9e 3a e0 0d 00 | at line ";.:...| 000000d0 78 07 6e 3d 30 0d 00 82 09 73 75 6d 3d 30 0d 00 |x.n=0....sum=0..| 000000e0 8c 05 f5 0d 00 96 14 20 73 70 65 65 64 3d a4 6d |....... speed=.m| 000000f0 65 6d 73 70 65 65 64 0d 00 a0 0f 20 73 75 6d 2b |emspeed.... sum+| 00000100 3d 73 70 65 65 64 0d 00 aa 09 20 6e 2b 3d 31 0d |=speed.... n+=1.| 00000110 00 b4 0f 20 40 25 3d 22 67 31 30 2e 39 22 0d 00 |... @%="g10.9"..| 00000120 be 3f 20 f1 20 22 41 76 65 72 61 67 65 20 3d 20 |.? . "Average = | 00000130 22 3b a8 28 73 75 6d 2f 6e 29 3b 22 48 7a 2c 20 |";.(sum/n);"Hz, | 00000140 20 54 68 69 73 20 74 65 73 74 20 3d 20 22 3b a8 | This test = ";.| 00000150 28 73 70 65 65 64 29 3b 22 20 48 7a 22 0d 00 c8 |(speed);" Hz"...| 00000160 0f 20 40 25 3d 22 66 31 30 2e 33 22 0d 00 d2 29 |. @%="f10.3"...)| 00000170 20 f1 20 22 20 20 52 6f 75 6e 64 65 64 20 3d 20 | . " Rounded = | 00000180 22 3b 73 75 6d 2f 6e 2f 31 30 30 30 30 30 30 3b |";sum/n/1000000;| 00000190 22 4d 68 7a 22 0d 00 dc 0e fd 20 bf 28 30 29 3c |"Mhz"..... .(0)<| 000001a0 3e 22 22 0d 00 e6 05 e0 0d 00 f0 05 3a 0d 00 fa |>"".........:...| 000001b0 13 dd 20 f2 63 61 63 68 65 28 73 74 61 74 65 29 |.. .cache(state)| 000001c0 0d 01 04 0d e7 20 a4 61 72 6d 33 20 8c 0d 01 0e |..... .arm3 ....| 000001d0 0e 20 e7 20 73 74 61 74 65 20 8c 0d 01 18 0f 20 |. . state ..... | 000001e0 20 2a 43 61 63 68 65 20 4f 6e 0d 01 22 06 20 cc | *Cache On..". .| 000001f0 0d 01 2c 10 20 20 2a 43 61 63 68 65 20 4f 66 66 |..,. *Cache Off| 00000200 0d 01 36 06 20 cd 0d 01 40 05 cd 0d 01 4a 05 e1 |..6. ...@....J..| 00000210 0d 01 54 05 3a 0d 01 5e 0b dd 20 a4 61 72 6d 33 |..T.:..^.. .arm3| 00000220 0d 01 68 34 c8 99 20 22 58 4f 53 5f 53 57 49 4e |..h4.. "XOS_SWIN| 00000230 75 6d 62 65 72 46 72 6f 6d 53 74 72 69 6e 67 22 |umberFromString"| 00000240 2c 22 43 61 63 68 65 5f 46 6c 75 73 68 22 20 b8 |,"Cache_Flush" .| 00000250 20 3b 66 25 0d 01 72 10 3d 28 66 25 20 80 20 31 | ;f%..r.=(f% . 1| 00000260 29 3c 3e 30 0d 01 7c 05 3a 0d 01 86 0f dd 20 a4 |)<>0..|.:..... .| 00000270 6d 65 6d 73 70 65 65 64 0d 01 90 0d f2 63 61 63 |memspeed.....cac| 00000280 68 65 28 a3 29 0d 01 9a 0e f2 70 61 75 73 65 28 |he(.).....pause(| 00000290 32 30 29 0d 01 a4 15 74 69 6d 65 3d ba 28 74 69 |20)....time=.(ti| 000002a0 6d 65 74 72 69 61 6c 29 0d 01 ae 0e f2 70 61 75 |metrial).....pau| 000002b0 73 65 28 32 30 29 0d 01 b8 0d f2 63 61 63 68 65 |se(20).....cache| 000002c0 28 b9 29 0d 01 c2 24 3d 66 75 64 67 65 2a 63 79 |(.)...$=fudge*cy| 000002d0 63 6c 65 73 2f 28 28 36 35 35 33 35 2d 74 69 6d |cles/((65535-tim| 000002e0 65 29 2f 32 45 36 29 0d 01 cc 04 0d 01 d6 10 dd |e)/2E6).........| 000002f0 20 f2 70 61 75 73 65 28 74 25 29 0d 01 e0 12 74 | .pause(t%)....t| 00000300 25 2b 3d 91 3a f5 3a fd 20 91 3e 74 25 0d 01 ea |%+=.:.:. .>t%...| 00000310 05 e1 0d 01 f4 05 3a 0d 01 fe 0b dd 20 f2 63 6f |......:..... .co| 00000320 64 65 0d 02 08 0f 74 31 6c 6f 77 3d 20 20 26 35 |de....t1low= &5| 00000330 30 0d 02 12 0f 74 31 68 69 67 68 3d 20 26 35 34 |0....t1high= &54| 00000340 0d 02 1c 0f 74 31 67 6f 3d 20 20 20 26 35 38 0d |....t1go= &58.| 00000350 02 26 0f 74 31 6c 61 74 63 68 3d 26 35 43 0d 02 |.&.t1latch=&5C..| 00000360 30 15 63 6f 64 65 73 69 7a 65 3d 32 35 36 2a 31 |0.codesize=256*1| 00000370 30 32 34 0d 02 3a 13 de 20 63 6f 64 65 20 63 6f |024..:.. code co| 00000380 64 65 73 69 7a 65 0d 02 44 17 73 70 3d 31 33 3a |desize..D.sp=13:| 00000390 6c 69 6e 6b 3d 31 34 3a 70 63 3d 31 35 0d 02 4e |link=14:pc=15..N| 000003a0 0a 70 61 73 73 3d 38 0d 02 58 1c 50 25 3d 63 6f |.pass=8..X.P%=co| 000003b0 64 65 3a 4c 25 3d 63 6f 64 65 2b 63 6f 64 65 73 |de:L%=code+codes| 000003c0 69 7a 65 0d 02 62 0d 5b 4f 50 54 20 70 61 73 73 |ize..b.[OPT pass| 000003d0 0d 02 6c 04 0d 02 76 0e 2e 74 69 6d 65 74 72 69 |..l...v..timetri| 000003e0 61 6c 0d 02 80 19 20 20 20 53 54 4d 46 44 20 28 |al.... STMFD (| 000003f0 73 70 29 21 2c 7b 6c 69 6e 6b 7d 0d 02 8a 19 20 |sp)!,{link}.... | 00000400 20 20 53 57 49 20 20 20 22 4f 53 5f 45 6e 74 65 | SWI "OS_Ente| 00000410 72 4f 53 22 0d 02 94 04 0d 02 9e 1a 20 20 20 4d |rOS"........ M| 00000420 4f 56 20 20 20 52 30 2c 23 25 30 30 30 30 30 3c |OV R0,#%00000<| 00000430 3c 38 0d 02 a8 1a 20 20 20 4d 4f 56 20 20 20 52 |<8.... MOV R| 00000440 31 2c 23 25 31 31 31 31 31 3c 3c 38 0d 02 b2 1c |1,#%11111<<8....| 00000450 20 20 20 53 57 49 20 20 20 22 4f 53 5f 55 70 64 | SWI "OS_Upd| 00000460 61 74 65 4d 45 4d 43 22 0d 02 bc 04 0d 02 c6 18 |ateMEMC"........| 00000470 20 20 20 53 57 49 20 20 20 22 4f 53 5f 49 6e 74 | SWI "OS_Int| 00000480 4f 66 66 22 0d 02 d0 04 0d 02 da 1a 20 20 20 4d |Off"........ M| 00000490 4f 56 20 20 20 52 31 32 2c 23 26 33 32 30 30 30 |OV R12,#&32000| 000004a0 30 30 0d 02 e4 04 0d 02 ee 14 20 20 20 4d 4f 56 |00........ MOV| 000004b0 20 20 20 52 30 2c 23 26 46 46 0d 02 f8 1c 20 20 | R0,#&FF.... | 000004c0 20 53 54 52 42 20 20 52 30 2c 5b 52 31 32 2c 23 | STRB R0,[R12,#| 000004d0 74 31 6c 6f 77 5d 0d 03 02 1d 20 20 20 53 54 52 |t1low].... STR| 000004e0 42 20 20 52 30 2c 5b 52 31 32 2c 23 74 31 68 69 |B R0,[R12,#t1hi| 000004f0 67 68 5d 0d 03 0c 04 0d 03 16 1b 20 20 20 53 54 |gh]........ ST| 00000500 52 42 20 20 52 30 2c 5b 52 31 32 2c 23 74 31 67 |RB R0,[R12,#t1g| 00000510 6f 5d 0d 03 20 05 5d 0d 03 2a 13 e3 20 69 25 3d |o].. .]..*.. i%=| 00000520 31 20 b8 20 63 79 63 6c 65 73 0d 03 34 0d 5b 4f |1 . cycles..4.[O| 00000530 50 54 20 70 61 73 73 0d 03 3e 15 20 20 20 41 44 |PT pass..>. AD| 00000540 44 20 20 20 52 30 2c 52 30 2c 23 31 0d 03 48 05 |D R0,R0,#1..H.| 00000550 5d 0d 03 52 22 e7 20 28 69 25 20 83 20 31 30 30 |]..R". (i% . 100| 00000560 29 3d 30 20 f1 63 79 63 6c 65 73 2d 69 25 3b bd |)=0 .cycles-i%;.| 00000570 31 33 3b 0d 03 5c 08 ed 20 69 25 0d 03 66 0d 5b |13;..\.. i%..f.[| 00000580 4f 50 54 20 70 61 73 73 0d 03 70 1e 20 20 20 53 |OPT pass..p. S| 00000590 54 52 42 20 20 52 30 2c 5b 52 31 32 2c 23 74 31 |TRB R0,[R12,#t1| 000005a0 6c 61 74 63 68 5d 0d 03 7a 04 0d 03 84 1c 20 20 |latch]..z..... | 000005b0 20 4c 44 52 42 20 20 52 30 2c 5b 52 31 32 2c 23 | LDRB R0,[R12,#| 000005c0 74 31 6c 6f 77 5d 0d 03 8e 1d 20 20 20 4c 44 52 |t1low].... LDR| 000005d0 42 20 20 52 31 2c 5b 52 31 32 2c 23 74 31 68 69 |B R1,[R12,#t1hi| 000005e0 67 68 5d 0d 03 98 1b 20 20 20 84 52 20 20 20 52 |gh].... .R R| 000005f0 31 31 2c 52 30 2c 52 31 2c 6c 73 6c 23 38 0d 03 |11,R0,R1,lsl#8..| 00000600 a2 04 0d 03 ac 1a 20 20 20 4d 4f 56 20 20 20 52 |...... MOV R| 00000610 30 2c 23 25 31 31 31 30 31 3c 3c 38 0d 03 b6 1a |0,#%11101<<8....| 00000620 20 20 20 4d 4f 56 20 20 20 52 31 2c 23 25 31 31 | MOV R1,#%11| 00000630 31 31 31 3c 3c 38 0d 03 c0 1c 20 20 20 53 57 49 |111<<8.... SWI| 00000640 20 20 20 22 4f 53 5f 55 70 64 61 74 65 4d 45 4d | "OS_UpdateMEM| 00000650 43 22 0d 03 ca 04 0d 03 d4 12 20 20 20 54 45 51 |C"........ TEQ| 00000660 50 20 20 70 63 2c 23 30 0d 03 de 12 20 20 20 4d |P pc,#0.... M| 00000670 4f 56 20 20 20 52 30 2c 52 30 0d 03 e8 04 0d 03 |OV R0,R0......| 00000680 f2 13 20 20 20 4d 4f 56 20 20 20 52 30 2c 52 31 |.. MOV R0,R1| 00000690 31 0d 03 fc 18 20 20 20 4c 44 4d 46 44 20 28 73 |1.... LDMFD (s| 000006a0 70 29 21 2c 7b 70 63 7d 5e 0d 04 06 05 5d 0d 04 |p)!,{pc}^....]..| 000006b0 10 05 e1 0d ff |.....| 000006b5