Home » Archimedes archive » Acorn Computing » 1994 09 subscription disc.adf » 9409s » MEMCPatch/MEMCPatSrc
MEMCPatch/MEMCPatSrc
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 Computing » 1994 09 subscription disc.adf » 9409s |
Filename: | MEMCPatch/MEMCPatSrc |
Read OK: | ✔ |
File size: | 1512 bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
10REM > MEMCPatSrc 20DIM code &400 30 40sp = 13 50lr = 14 60pc = 15 70 80Service_Reset = &27 90V_FLAG = 1<<28 100 110FOR pass=0 TO 3 STEP 3 120P%=code 130[OPT pass 140.module_base 150 DCD 0 160 DCD initialise - module_base 170 DCD finalise - module_base 180 DCD service - module_base 190 DCD title_string - module_base 200 DCD help_string - module_base 210 DCD help_table - module_base 220 230; --------------------------------------------------------------------------------------------------------- 240 250.initialise 260 STMFD sp !, {lr} 270 BL claim_swi_vector 280 LDMFD sp !, {pc} 290 300; --------------------------------------------------------------------------------------------------------- 310 320.finalise 330 STMFD sp !, {lr} 340 BL release_swi_vector 350 LDMFD sp !, {pc} 360 370; --------------------------------------------------------------------------------------------------------- 380 390.service 400 CMP r1, #Service_Reset 410 MOVNES pc, lr 420 STMFD sp !,{r0-r5,lr} 430 BL claim_swi_vector 440 LDMFD sp !,{r0-r5,pc}^ 450 460; --------------------------------------------------------------------------------------------------------- 470 480.title_string 490 EQUS "MEMCPatch":DCB 0 500 510.help_string 520 EQUS "MEMC Patch":EQUB 9::EQUS "1.01 (27 Nov 1993)":EQUB 0 530.help_table 540 EQUS "PatchingMEMC" 550 EQUB 0:ALIGN 560 EQUD 0 570 EQUD 0 580 EQUD 0 590 EQUD help_text - module_base 600.help_text 610 EQUS "The MEMC Patch module prevents the setting of bit 6 of the MEMC":EQUB 13 620 EQUS "control register which otherwise crashes the machine.":EQUB 0 630 ALIGN 640 650; --------------------------------------------------------------------------------------------------------- 660 670.release_swi_vector 680 MOV r0, #8 690 LDR r1, [r0] 700 LDR r2, new_branch ; check that our SWI decoder hasn't been replaced 710 CMP r1, r2 720 LDREQ r1, old_branch ; replace original decoder if it hasn't 730 STREQ r1, [r0] 740 MOVEQ r0, #0 750 STREQ r1, old_branch 760 MOVEQS pc, lr 770 780 LDR r2, old_branch ; if the old branch is already there then do nothing 790 CMP r1, r2 800 MOVEQS pc, lr 810 820 ADR r0, error_block ; otherwise return an error 830 ORRS pc, lr, #V_FLAG 840 850.error_block DCD &103 860 EQUS "Can't detach SWI handler":DCB 0 870 ALIGN 880 890; --------------------------------------------------------------------------------------------------------- 900 910.claim_swi_vector 920 MOV r0, #8 930 LDR r0, [r0] ; get branch to SWI handler 940 STR r0, old_branch 950 960 ADR r1, second_branch-8 ; insert in our own code 970 SUB r0, r0, r1, LSR #2 980 990 BIC r0, r0, #&FF000000 ; handle SUB overflow for when old branch < replacement. 1000 ORR r0, r0, #&EA000000 1010 1020 STR r0, second_branch 1030 1040 ADD r0, r0, #(second_branch-first_branch) / 4 1050 SUB r0, r0, #&D0000000 1060 STR r0, first_branch ; convert to a BNE 1070 1080 MOV r1, #8 1090 ADR r0, swi_patch-8-8 1100 MOV r0, r0, LSR #2 1110 ADD r0, r0, #&EA000000 1120 STR r0, [r1] 1130 STR r0, new_branch ; put in a branch to our code 1140 1150 MOVS pc, lr 1160 1170; --------------------------------------------------------------------------------------------------------- 1180 1190.swi_patch 1200 STMFD sp !,{lr} 1210 BIC lr, lr, #&FC000003 1220 LDR lr, [lr,#-4] ; get SWI instruction 1230 1240 BIC lr, lr, #&FF000000 1250 BIC lr, lr, #&20000 1260 1270 CMP lr, #&1A ; is it OS_UpdateMEMC ? 1280 LDMNEFD sp !, {lr} ; otherwise drop through to SWI handler 1290.first_branch 1300 DCD 0 1310 1320 ANDS lr, r0, #1<<6 ; is bit 6 of new data set ? If so Z=FALSE else Z=TRUE 1330 BEQ continue ; if bit 6 is not set then Z=TRUE and drop through to OS_UpdateMEMC 1340 ANDS lr, r1, #1<<6 ; is bit 6 of mask set ? If so Z=FALSE else Z=TRUE 1350 BEQ continue ; if bit 6 is mot set then Z=TRUE and drop through to OS_UpdateMEMC 1360 BIC r0,r0,#1<<6 ;clear bit 6 of new data 1370 BIC r1,r1,#1<<6 ;clear bit 6 of mask 1380 B continue ;do OS_UpdateMEMC 1390 1400.continue 1410 LDMFD sp !, {lr} 1420.second_branch 1430 DCD 0 1440.old_branch 1450 DCD 0 ; branch to original SWI decoder 1460.new_branch 1470 DCD 0 ; branch to our new SWI decoder 1480 1490] 1500NEXT pass 1510SYS "OS_File",10,"MEMCPatch",&FFA,,code,P% 1520END
� > MEMCPatSrc � code &400 (sp = 13 2lr = 14 <pc = 15 F PService_Reset = &27 ZV_FLAG = 1<<28 d n� pass=0 � 3 � 3 xP%=code � [OPT pass �.module_base � DCD 0 �, DCD initialise - module_base �* DCD finalise - module_base �) DCD service - module_base �. DCD title_string - module_base �- DCD help_string - module_base �, DCD help_table - module_base � �o; --------------------------------------------------------------------------------------------------------- � �.initialise STMFD sp !, {lr} $ BL claim_swi_vector LDMFD sp !, {pc} " ,o; --------------------------------------------------------------------------------------------------------- 6 @ .finalise J STMFD sp !, {lr} T& BL release_swi_vector ^ LDMFD sp !, {pc} h ro; --------------------------------------------------------------------------------------------------------- | �.service �& CMP r1, #Service_Reset � MOVNES pc, lr �# STMFD sp !,{r0-r5,lr} �$ BL claim_swi_vector �$ LDMFD sp !,{r0-r5,pc}^ � �o; --------------------------------------------------------------------------------------------------------- � �.title_string �& EQUS "MEMCPatch":DCB 0 � �.help_string J EQUS "MEMC Patch":EQUB 9::EQUS "1.01 (27 Nov 1993)":EQUB 0 .help_table EQUS "PatchingMEMC" & EQUB 0:ALIGN 0 EQUD 0 : EQUD 0 D EQUD 0 N( EQUD help_text - module_base X.help_text b^ EQUS "The MEMC Patch module prevents the setting of bit 6 of the MEMC":EQUB 13 lS EQUS "control register which otherwise crashes the machine.":EQUB 0 v ALIGN � �o; --------------------------------------------------------------------------------------------------------- � �.release_swi_vector � MOV r0, #8 � LDR r1, [r0] �e LDR r2, new_branch ; check that our SWI decoder hasn't been replaced � CMP r1, r2 �[ LDREQ r1, old_branch ; replace original decoder if it hasn't � STREQ r1, [r0] � �Q r0, #0 �" STREQ r1, old_branch � �QS pc, lr h LDR r2, old_branch ; if the old branch is already there then do nothing CMP r1, r2 �QS pc, lr * 4O ADR r0, error_block ; otherwise return an error > �RS pc, lr, #V_FLAG H R!.error_block DCD &103 \= EQUS "Can't detach SWI handler":DCB 0 f ALIGN p zo; --------------------------------------------------------------------------------------------------------- � �.claim_swi_vector � MOV r0, #8 �O LDR r0, [r0] ; get branch to SWI handler �" STR r0, old_branch � �L ADR r1, second_branch-8 ; insert in our own code �& SUB r0, r0, r1, LSR #2 � �l BIC r0, r0, #&FF000000 ; handle SUB overflow for when old branch < replacement. �% �R r0, r0, #&EA000000 � �% STR r0, second_branch = ADD r0, r0, #(second_branch-first_branch) / 4 & SUB r0, r0, #&D0000000 $F STR r0, first_branch ; convert to a BNE . 8 MOV r1, #8 B% ADR r0, swi_patch-8-8 L" MOV r0, r0, LSR #2 V& ADD r0, r0, #&EA000000 ` STR r0, [r1] jQ STR r0, new_branch ; put in a branch to our code t ~ MOVS pc, lr � �o; --------------------------------------------------------------------------------------------------------- � �.swi_patch � STMFD sp !,{lr} �& BIC lr, lr, #&FC000003 �I LDR lr, [lr,#-4] ; get SWI instruction � �& BIC lr, lr, #&FF000000 �# BIC lr, lr, #&20000 � �K CMP lr, #&1A ; is it OS_UpdateMEMC ? [ LDMNEFD sp !, {lr} ; otherwise drop through to SWI handler .first_branch DCD 0 (a �S lr, r0, #1<<6 ; is bit 6 of new data set ? If so Z=� else Z=� 2t BEQ continue ; if bit 6 is not set then Z=� and drop through to OS_UpdateMEMC <] �S lr, r1, #1<<6 ; is bit 6 of mask set ? If so Z=� else Z=� Ft BEQ continue ; if bit 6 is mot set then Z=� and drop through to OS_UpdateMEMC PL BIC r0,r0,#1<<6 ;clear bit 6 of new data ZH BIC r1,r1,#1<<6 ;clear bit 6 of mask dE B continue ;do OS_UpdateMEMC n x .continue � LDMFD sp !, {lr} �.second_branch � DCD 0 �.old_branch �T DCD 0 ; branch to original SWI decoder �.new_branch �S DCD 0 ; branch to our new SWI decoder � �] � � pass �-ș "OS_File",10,"MEMCPatch",&FFA,,code,P% �� �
00000000 0d 00 0a 12 f4 20 3e 20 4d 45 4d 43 50 61 74 53 |..... > MEMCPatS| 00000010 72 63 0d 00 14 0f de 20 63 6f 64 65 20 26 34 30 |rc..... code &40| 00000020 30 0d 00 1e 04 0d 00 28 0b 73 70 20 3d 20 31 33 |0......(.sp = 13| 00000030 0d 00 32 0b 6c 72 20 3d 20 31 34 0d 00 3c 0b 70 |..2.lr = 14..<.p| 00000040 63 20 3d 20 31 35 0d 00 46 04 0d 00 50 1d 53 65 |c = 15..F...P.Se| 00000050 72 76 69 63 65 5f 52 65 73 65 74 20 20 20 3d 20 |rvice_Reset = | 00000060 20 20 20 20 26 32 37 0d 00 5a 1f 56 5f 46 4c 41 | &27..Z.V_FLA| 00000070 47 20 20 20 20 20 20 20 20 20 20 3d 20 20 20 20 |G = | 00000080 20 31 3c 3c 32 38 0d 00 64 04 0d 00 6e 14 e3 20 | 1<<28..d...n.. | 00000090 70 61 73 73 3d 30 20 b8 20 33 20 88 20 33 0d 00 |pass=0 . 3 . 3..| 000000a0 78 0b 50 25 3d 63 6f 64 65 0d 00 82 0d 5b 4f 50 |x.P%=code....[OP| 000000b0 54 20 70 61 73 73 0d 00 8c 10 2e 6d 6f 64 75 6c |T pass.....modul| 000000c0 65 5f 62 61 73 65 0d 00 96 15 20 20 20 20 20 20 |e_base.... | 000000d0 20 20 44 43 44 20 20 20 20 20 30 0d 00 a0 2c 20 | DCD 0..., | 000000e0 20 20 20 20 20 20 20 44 43 44 20 20 20 20 20 69 | DCD i| 000000f0 6e 69 74 69 61 6c 69 73 65 20 2d 20 6d 6f 64 75 |nitialise - modu| 00000100 6c 65 5f 62 61 73 65 0d 00 aa 2a 20 20 20 20 20 |le_base...* | 00000110 20 20 20 44 43 44 20 20 20 20 20 66 69 6e 61 6c | DCD final| 00000120 69 73 65 20 2d 20 6d 6f 64 75 6c 65 5f 62 61 73 |ise - module_bas| 00000130 65 0d 00 b4 29 20 20 20 20 20 20 20 20 44 43 44 |e...) DCD| 00000140 20 20 20 20 20 73 65 72 76 69 63 65 20 2d 20 6d | service - m| 00000150 6f 64 75 6c 65 5f 62 61 73 65 0d 00 be 2e 20 20 |odule_base.... | 00000160 20 20 20 20 20 20 44 43 44 20 20 20 20 20 74 69 | DCD ti| 00000170 74 6c 65 5f 73 74 72 69 6e 67 20 2d 20 6d 6f 64 |tle_string - mod| 00000180 75 6c 65 5f 62 61 73 65 0d 00 c8 2d 20 20 20 20 |ule_base...- | 00000190 20 20 20 20 44 43 44 20 20 20 20 20 68 65 6c 70 | DCD help| 000001a0 5f 73 74 72 69 6e 67 20 2d 20 6d 6f 64 75 6c 65 |_string - module| 000001b0 5f 62 61 73 65 0d 00 d2 2c 20 20 20 20 20 20 20 |_base..., | 000001c0 20 44 43 44 20 20 20 20 20 68 65 6c 70 5f 74 61 | DCD help_ta| 000001d0 62 6c 65 20 2d 20 6d 6f 64 75 6c 65 5f 62 61 73 |ble - module_bas| 000001e0 65 0d 00 dc 04 0d 00 e6 6f 3b 20 2d 2d 2d 2d 2d |e.......o; -----| 000001f0 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d |----------------| * 00000250 2d 2d 2d 2d 0d 00 f0 04 0d 00 fa 0f 2e 69 6e 69 |----.........ini| 00000260 74 69 61 6c 69 73 65 0d 01 04 1e 20 20 20 20 20 |tialise.... | 00000270 20 20 20 53 54 4d 46 44 20 20 20 73 70 20 21 2c | STMFD sp !,| 00000280 20 7b 6c 72 7d 0d 01 0e 24 20 20 20 20 20 20 20 | {lr}...$ | 00000290 20 42 4c 20 20 20 20 20 20 63 6c 61 69 6d 5f 73 | BL claim_s| 000002a0 77 69 5f 76 65 63 74 6f 72 0d 01 18 1e 20 20 20 |wi_vector.... | 000002b0 20 20 20 20 20 4c 44 4d 46 44 20 20 20 73 70 20 | LDMFD sp | 000002c0 21 2c 20 7b 70 63 7d 0d 01 22 04 0d 01 2c 6f 3b |!, {pc}.."...,o;| 000002d0 20 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d | ---------------| 000002e0 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d |----------------| * 00000330 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0d 01 36 04 0d 01 |----------..6...| 00000340 40 0d 2e 66 69 6e 61 6c 69 73 65 0d 01 4a 1e 20 |@..finalise..J. | 00000350 20 20 20 20 20 20 20 53 54 4d 46 44 20 20 20 73 | STMFD s| 00000360 70 20 21 2c 20 7b 6c 72 7d 0d 01 54 26 20 20 20 |p !, {lr}..T& | 00000370 20 20 20 20 20 42 4c 20 20 20 20 20 20 72 65 6c | BL rel| 00000380 65 61 73 65 5f 73 77 69 5f 76 65 63 74 6f 72 0d |ease_swi_vector.| 00000390 01 5e 1e 20 20 20 20 20 20 20 20 4c 44 4d 46 44 |.^. LDMFD| 000003a0 20 20 20 73 70 20 21 2c 20 7b 70 63 7d 0d 01 68 | sp !, {pc}..h| 000003b0 04 0d 01 72 6f 3b 20 2d 2d 2d 2d 2d 2d 2d 2d 2d |...ro; ---------| 000003c0 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d |----------------| * 00000420 0d 01 7c 04 0d 01 86 0c 2e 73 65 72 76 69 63 65 |..|......service| 00000430 0d 01 90 26 20 20 20 20 20 20 20 20 43 4d 50 20 |...& CMP | 00000440 20 20 20 20 72 31 2c 20 23 53 65 72 76 69 63 65 | r1, #Service| 00000450 5f 52 65 73 65 74 0d 01 9a 1a 20 20 20 20 20 20 |_Reset.... | 00000460 20 20 4d 4f 56 4e 45 53 20 20 70 63 2c 20 6c 72 | MOVNES pc, lr| 00000470 0d 01 a4 23 20 20 20 20 20 20 20 20 53 54 4d 46 |...# STMF| 00000480 44 20 20 20 73 70 20 21 2c 7b 72 30 2d 72 35 2c |D sp !,{r0-r5,| 00000490 6c 72 7d 0d 01 ae 24 20 20 20 20 20 20 20 20 42 |lr}...$ B| 000004a0 4c 20 20 20 20 20 20 63 6c 61 69 6d 5f 73 77 69 |L claim_swi| 000004b0 5f 76 65 63 74 6f 72 0d 01 b8 24 20 20 20 20 20 |_vector...$ | 000004c0 20 20 20 4c 44 4d 46 44 20 20 20 73 70 20 21 2c | LDMFD sp !,| 000004d0 7b 72 30 2d 72 35 2c 70 63 7d 5e 0d 01 c2 04 0d |{r0-r5,pc}^.....| 000004e0 01 cc 6f 3b 20 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d |..o; -----------| 000004f0 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d |----------------| * 00000540 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0d 01 |--------------..| 00000550 d6 04 0d 01 e0 11 2e 74 69 74 6c 65 5f 73 74 72 |.......title_str| 00000560 69 6e 67 0d 01 ea 26 20 20 20 20 20 20 20 20 45 |ing...& E| 00000570 51 55 53 20 20 20 20 20 22 4d 45 4d 43 50 61 74 |QUS "MEMCPat| 00000580 63 68 22 3a 44 43 42 20 30 0d 01 f4 04 0d 01 fe |ch":DCB 0.......| 00000590 10 2e 68 65 6c 70 5f 73 74 72 69 6e 67 0d 02 08 |..help_string...| 000005a0 4a 20 20 20 20 20 20 20 20 45 51 55 53 20 20 20 |J EQUS | 000005b0 20 20 22 4d 45 4d 43 20 50 61 74 63 68 22 3a 45 | "MEMC Patch":E| 000005c0 51 55 42 20 39 3a 3a 45 51 55 53 20 22 31 2e 30 |QUB 9::EQUS "1.0| 000005d0 31 20 28 32 37 20 4e 6f 76 20 31 39 39 33 29 22 |1 (27 Nov 1993)"| 000005e0 3a 45 51 55 42 20 30 0d 02 12 0f 2e 68 65 6c 70 |:EQUB 0.....help| 000005f0 5f 74 61 62 6c 65 0d 02 1c 1f 20 20 20 20 20 20 |_table.... | 00000600 20 20 45 51 55 53 20 22 50 61 74 63 68 69 6e 67 | EQUS "Patching| 00000610 4d 45 4d 43 22 0d 02 26 18 20 20 20 20 20 20 20 |MEMC"..&. | 00000620 20 45 51 55 42 20 30 3a 41 4c 49 47 4e 0d 02 30 | EQUB 0:ALIGN..0| 00000630 12 20 20 20 20 20 20 20 20 45 51 55 44 20 30 0d |. EQUD 0.| 00000640 02 3a 12 20 20 20 20 20 20 20 20 45 51 55 44 20 |.:. EQUD | 00000650 30 0d 02 44 12 20 20 20 20 20 20 20 20 45 51 55 |0..D. EQU| 00000660 44 20 30 0d 02 4e 28 20 20 20 20 20 20 20 20 45 |D 0..N( E| 00000670 51 55 44 20 68 65 6c 70 5f 74 65 78 74 20 2d 20 |QUD help_text - | 00000680 6d 6f 64 75 6c 65 5f 62 61 73 65 0d 02 58 0e 2e |module_base..X..| 00000690 68 65 6c 70 5f 74 65 78 74 0d 02 62 5e 20 20 20 |help_text..b^ | 000006a0 20 20 20 20 20 45 51 55 53 20 20 20 20 20 22 54 | EQUS "T| 000006b0 68 65 20 4d 45 4d 43 20 50 61 74 63 68 20 6d 6f |he MEMC Patch mo| 000006c0 64 75 6c 65 20 70 72 65 76 65 6e 74 73 20 74 68 |dule prevents th| 000006d0 65 20 73 65 74 74 69 6e 67 20 6f 66 20 62 69 74 |e setting of bit| 000006e0 20 36 20 6f 66 20 74 68 65 20 4d 45 4d 43 22 3a | 6 of the MEMC":| 000006f0 45 51 55 42 20 31 33 0d 02 6c 53 20 20 20 20 20 |EQUB 13..lS | 00000700 20 20 20 45 51 55 53 20 20 20 20 20 22 63 6f 6e | EQUS "con| 00000710 74 72 6f 6c 20 72 65 67 69 73 74 65 72 20 77 68 |trol register wh| 00000720 69 63 68 20 6f 74 68 65 72 77 69 73 65 20 63 72 |ich otherwise cr| 00000730 61 73 68 65 73 20 74 68 65 20 6d 61 63 68 69 6e |ashes the machin| 00000740 65 2e 22 3a 45 51 55 42 20 30 0d 02 76 11 20 20 |e.":EQUB 0..v. | 00000750 20 20 20 20 20 20 41 4c 49 47 4e 0d 02 80 04 0d | ALIGN.....| 00000760 02 8a 6f 3b 20 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d |..o; -----------| 00000770 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d |----------------| * 000007c0 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0d 02 |--------------..| 000007d0 94 04 0d 02 9e 17 2e 72 65 6c 65 61 73 65 5f 73 |.......release_s| 000007e0 77 69 5f 76 65 63 74 6f 72 0d 02 a8 1a 20 20 20 |wi_vector.... | 000007f0 20 20 20 20 20 4d 4f 56 20 20 20 20 20 72 30 2c | MOV r0,| 00000800 20 23 38 0d 02 b2 1c 20 20 20 20 20 20 20 20 4c | #8.... L| 00000810 44 52 20 20 20 20 20 72 31 2c 20 5b 72 30 5d 0d |DR r1, [r0].| 00000820 02 bc 65 20 20 20 20 20 20 20 20 4c 44 52 20 20 |..e LDR | 00000830 20 20 20 72 32 2c 20 6e 65 77 5f 62 72 61 6e 63 | r2, new_branc| 00000840 68 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |h | 00000850 20 20 20 3b 20 63 68 65 63 6b 20 74 68 61 74 20 | ; check that | 00000860 6f 75 72 20 53 57 49 20 64 65 63 6f 64 65 72 20 |our SWI decoder | 00000870 68 61 73 6e 27 74 20 62 65 65 6e 20 72 65 70 6c |hasn't been repl| 00000880 61 63 65 64 0d 02 c6 1a 20 20 20 20 20 20 20 20 |aced.... | 00000890 43 4d 50 20 20 20 20 20 72 31 2c 20 72 32 0d 02 |CMP r1, r2..| 000008a0 d0 5b 20 20 20 20 20 20 20 20 4c 44 52 45 51 20 |.[ LDREQ | 000008b0 20 20 72 31 2c 20 6f 6c 64 5f 62 72 61 6e 63 68 | r1, old_branch| 000008c0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000008d0 20 20 3b 20 72 65 70 6c 61 63 65 20 6f 72 69 67 | ; replace orig| 000008e0 69 6e 61 6c 20 64 65 63 6f 64 65 72 20 69 66 20 |inal decoder if | 000008f0 69 74 20 68 61 73 6e 27 74 0d 02 da 1c 20 20 20 |it hasn't.... | 00000900 20 20 20 20 20 53 54 52 45 51 20 20 20 72 31 2c | STREQ r1,| 00000910 20 5b 72 30 5d 0d 02 e4 17 20 20 20 20 20 20 20 | [r0].... | 00000920 20 ec 51 20 20 20 72 30 2c 20 23 30 0d 02 ee 22 | .Q r0, #0..."| 00000930 20 20 20 20 20 20 20 20 53 54 52 45 51 20 20 20 | STREQ | 00000940 72 31 2c 20 6f 6c 64 5f 62 72 61 6e 63 68 0d 02 |r1, old_branch..| 00000950 f8 17 20 20 20 20 20 20 20 20 ec 51 53 20 20 70 |.. .QS p| 00000960 63 2c 20 6c 72 0d 03 02 04 0d 03 0c 68 20 20 20 |c, lr.......h | 00000970 20 20 20 20 20 4c 44 52 20 20 20 20 20 72 32 2c | LDR r2,| 00000980 20 6f 6c 64 5f 62 72 61 6e 63 68 20 20 20 20 20 | old_branch | 00000990 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 69 | ; i| 000009a0 66 20 74 68 65 20 6f 6c 64 20 62 72 61 6e 63 68 |f the old branch| 000009b0 20 69 73 20 61 6c 72 65 61 64 79 20 74 68 65 72 | is already ther| 000009c0 65 20 74 68 65 6e 20 64 6f 20 6e 6f 74 68 69 6e |e then do nothin| 000009d0 67 0d 03 16 1a 20 20 20 20 20 20 20 20 43 4d 50 |g.... CMP| 000009e0 20 20 20 20 20 72 31 2c 20 72 32 0d 03 20 17 20 | r1, r2.. . | 000009f0 20 20 20 20 20 20 20 ec 51 53 20 20 70 63 2c 20 | .QS pc, | 00000a00 6c 72 0d 03 2a 04 0d 03 34 4f 20 20 20 20 20 20 |lr..*...4O | 00000a10 20 20 41 44 52 20 20 20 72 30 2c 20 65 72 72 6f | ADR r0, erro| 00000a20 72 5f 62 6c 6f 63 6b 20 20 20 20 20 20 20 20 20 |r_block | 00000a30 20 20 20 20 20 20 20 20 20 20 3b 20 6f 74 68 65 | ; othe| 00000a40 72 77 69 73 65 20 72 65 74 75 72 6e 20 61 6e 20 |rwise return an | 00000a50 65 72 72 6f 72 0d 03 3e 20 20 20 20 20 20 20 20 |error..> | 00000a60 20 84 52 53 20 20 70 63 2c 20 6c 72 2c 20 23 56 | .RS pc, lr, #V| 00000a70 5f 46 4c 41 47 0d 03 48 04 0d 03 52 21 2e 65 72 |_FLAG..H...R!.er| 00000a80 72 6f 72 5f 62 6c 6f 63 6b 20 20 20 20 20 44 43 |ror_block DC| 00000a90 44 20 20 20 20 20 26 31 30 33 0d 03 5c 3d 20 20 |D &103..\= | 00000aa0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 45 51 | EQ| 00000ab0 55 53 20 20 20 20 20 22 43 61 6e 27 74 20 64 65 |US "Can't de| 00000ac0 74 61 63 68 20 53 57 49 20 68 61 6e 64 6c 65 72 |tach SWI handler| 00000ad0 22 3a 44 43 42 20 30 0d 03 66 19 20 20 20 20 20 |":DCB 0..f. | 00000ae0 20 20 20 20 20 20 20 20 20 20 20 41 4c 49 47 4e | ALIGN| 00000af0 0d 03 70 04 0d 03 7a 6f 3b 20 2d 2d 2d 2d 2d 2d |..p...zo; ------| 00000b00 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d |----------------| * 00000b60 2d 2d 2d 0d 03 84 04 0d 03 8e 15 2e 63 6c 61 69 |---.........clai| 00000b70 6d 5f 73 77 69 5f 76 65 63 74 6f 72 0d 03 98 1a |m_swi_vector....| 00000b80 20 20 20 20 20 20 20 20 4d 4f 56 20 20 20 20 20 | MOV | 00000b90 72 30 2c 20 23 38 0d 03 a2 4f 20 20 20 20 20 20 |r0, #8...O | 00000ba0 20 20 4c 44 52 20 20 20 20 20 72 30 2c 20 5b 72 | LDR r0, [r| 00000bb0 30 5d 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |0] | 00000bc0 20 20 20 20 20 20 20 20 20 20 3b 20 67 65 74 20 | ; get | 00000bd0 62 72 61 6e 63 68 20 74 6f 20 53 57 49 20 68 61 |branch to SWI ha| 00000be0 6e 64 6c 65 72 0d 03 ac 22 20 20 20 20 20 20 20 |ndler..." | 00000bf0 20 53 54 52 20 20 20 20 20 72 30 2c 20 6f 6c 64 | STR r0, old| 00000c00 5f 62 72 61 6e 63 68 0d 03 b6 04 0d 03 c0 4c 20 |_branch.......L | 00000c10 20 20 20 20 20 20 20 41 44 52 20 20 20 20 20 72 | ADR r| 00000c20 31 2c 20 73 65 63 6f 6e 64 5f 62 72 61 6e 63 68 |1, second_branch| 00000c30 2d 38 20 20 20 20 20 20 20 20 20 20 20 20 20 3b |-8 ;| 00000c40 20 69 6e 73 65 72 74 20 69 6e 20 6f 75 72 20 6f | insert in our o| 00000c50 77 6e 20 63 6f 64 65 0d 03 ca 26 20 20 20 20 20 |wn code...& | 00000c60 20 20 20 53 55 42 20 20 20 20 20 72 30 2c 20 72 | SUB r0, r| 00000c70 30 2c 20 72 31 2c 20 4c 53 52 20 23 32 0d 03 d4 |0, r1, LSR #2...| 00000c80 04 0d 03 de 6c 20 20 20 20 20 20 20 20 42 49 43 |....l BIC| 00000c90 20 20 20 20 20 72 30 2c 20 72 30 2c 20 23 26 46 | r0, r0, #&F| 00000ca0 46 30 30 30 30 30 30 20 20 20 20 20 20 20 20 20 |F000000 | 00000cb0 20 20 20 20 20 3b 20 68 61 6e 64 6c 65 20 53 55 | ; handle SU| 00000cc0 42 20 6f 76 65 72 66 6c 6f 77 20 66 6f 72 20 77 |B overflow for w| 00000cd0 68 65 6e 20 6f 6c 64 20 62 72 61 6e 63 68 20 3c |hen old branch <| 00000ce0 20 72 65 70 6c 61 63 65 6d 65 6e 74 2e 0d 03 e8 | replacement....| 00000cf0 25 20 20 20 20 20 20 20 20 84 52 20 20 20 20 20 |% .R | 00000d00 72 30 2c 20 72 30 2c 20 23 26 45 41 30 30 30 30 |r0, r0, #&EA0000| 00000d10 30 30 0d 03 f2 04 0d 03 fc 25 20 20 20 20 20 20 |00.......% | 00000d20 20 20 53 54 52 20 20 20 20 20 72 30 2c 20 73 65 | STR r0, se| 00000d30 63 6f 6e 64 5f 62 72 61 6e 63 68 0d 04 06 04 0d |cond_branch.....| 00000d40 04 10 3d 20 20 20 20 20 20 20 20 41 44 44 20 20 |..= ADD | 00000d50 20 20 20 72 30 2c 20 72 30 2c 20 23 28 73 65 63 | r0, r0, #(sec| 00000d60 6f 6e 64 5f 62 72 61 6e 63 68 2d 66 69 72 73 74 |ond_branch-first| 00000d70 5f 62 72 61 6e 63 68 29 20 2f 20 34 0d 04 1a 26 |_branch) / 4...&| 00000d80 20 20 20 20 20 20 20 20 53 55 42 20 20 20 20 20 | SUB | 00000d90 72 30 2c 20 72 30 2c 20 23 26 44 30 30 30 30 30 |r0, r0, #&D00000| 00000da0 30 30 0d 04 24 46 20 20 20 20 20 20 20 20 53 54 |00..$F ST| 00000db0 52 20 20 20 20 20 72 30 2c 20 66 69 72 73 74 5f |R r0, first_| 00000dc0 62 72 61 6e 63 68 20 20 20 20 20 20 20 20 20 20 |branch | 00000dd0 20 20 20 20 20 20 3b 20 63 6f 6e 76 65 72 74 20 | ; convert | 00000de0 74 6f 20 61 20 42 4e 45 0d 04 2e 04 0d 04 38 1a |to a BNE......8.| 00000df0 20 20 20 20 20 20 20 20 4d 4f 56 20 20 20 20 20 | MOV | 00000e00 72 31 2c 20 23 38 0d 04 42 25 20 20 20 20 20 20 |r1, #8..B% | 00000e10 20 20 41 44 52 20 20 20 20 20 72 30 2c 20 73 77 | ADR r0, sw| 00000e20 69 5f 70 61 74 63 68 2d 38 2d 38 0d 04 4c 22 20 |i_patch-8-8..L" | 00000e30 20 20 20 20 20 20 20 4d 4f 56 20 20 20 20 20 72 | MOV r| 00000e40 30 2c 20 72 30 2c 20 4c 53 52 20 23 32 0d 04 56 |0, r0, LSR #2..V| 00000e50 26 20 20 20 20 20 20 20 20 41 44 44 20 20 20 20 |& ADD | 00000e60 20 72 30 2c 20 72 30 2c 20 23 26 45 41 30 30 30 | r0, r0, #&EA000| 00000e70 30 30 30 0d 04 60 1c 20 20 20 20 20 20 20 20 53 |000..`. S| 00000e80 54 52 20 20 20 20 20 72 30 2c 20 5b 72 31 5d 0d |TR r0, [r1].| 00000e90 04 6a 51 20 20 20 20 20 20 20 20 53 54 52 20 20 |.jQ STR | 00000ea0 20 20 20 72 30 2c 20 6e 65 77 5f 62 72 61 6e 63 | r0, new_branc| 00000eb0 68 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |h | 00000ec0 20 20 20 3b 20 70 75 74 20 69 6e 20 61 20 62 72 | ; put in a br| 00000ed0 61 6e 63 68 20 74 6f 20 6f 75 72 20 63 6f 64 65 |anch to our code| 00000ee0 0d 04 74 04 0d 04 7e 1b 20 20 20 20 20 20 20 20 |..t...~. | 00000ef0 4d 4f 56 53 20 20 20 20 20 70 63 2c 20 6c 72 0d |MOVS pc, lr.| 00000f00 04 88 04 0d 04 92 6f 3b 20 2d 2d 2d 2d 2d 2d 2d |......o; -------| 00000f10 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d |----------------| * 00000f70 2d 2d 0d 04 9c 04 0d 04 a6 0e 2e 73 77 69 5f 70 |--.........swi_p| 00000f80 61 74 63 68 0d 04 b0 1d 20 20 20 20 20 20 20 20 |atch.... | 00000f90 53 54 4d 46 44 20 20 20 73 70 20 21 2c 7b 6c 72 |STMFD sp !,{lr| 00000fa0 7d 0d 04 ba 26 20 20 20 20 20 20 20 20 42 49 43 |}...& BIC| 00000fb0 20 20 20 20 20 6c 72 2c 20 6c 72 2c 20 23 26 46 | lr, lr, #&F| 00000fc0 43 30 30 30 30 30 33 0d 04 c4 49 20 20 20 20 20 |C000003...I | 00000fd0 20 20 20 4c 44 52 20 20 20 20 20 6c 72 2c 20 5b | LDR lr, [| 00000fe0 6c 72 2c 23 2d 34 5d 20 20 20 20 20 20 20 20 20 |lr,#-4] | 00000ff0 20 20 20 20 20 20 20 20 20 20 20 3b 20 67 65 74 | ; get| 00001000 20 53 57 49 20 69 6e 73 74 72 75 63 74 69 6f 6e | SWI instruction| 00001010 0d 04 ce 04 0d 04 d8 26 20 20 20 20 20 20 20 20 |.......& | 00001020 42 49 43 20 20 20 20 20 6c 72 2c 20 6c 72 2c 20 |BIC lr, lr, | 00001030 23 26 46 46 30 30 30 30 30 30 0d 04 e2 23 20 20 |#&FF000000...# | 00001040 20 20 20 20 20 20 42 49 43 20 20 20 20 20 6c 72 | BIC lr| 00001050 2c 20 6c 72 2c 20 23 26 32 30 30 30 30 0d 04 ec |, lr, #&20000...| 00001060 04 0d 04 f6 4b 20 20 20 20 20 20 20 20 43 4d 50 |....K CMP| 00001070 20 20 20 20 20 6c 72 2c 20 23 26 31 41 20 20 20 | lr, #&1A | 00001080 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001090 20 20 20 20 20 3b 20 69 73 20 69 74 20 4f 53 5f | ; is it OS_| 000010a0 55 70 64 61 74 65 4d 45 4d 43 20 3f 0d 05 00 5b |UpdateMEMC ?...[| 000010b0 20 20 20 20 20 20 20 20 4c 44 4d 4e 45 46 44 20 | LDMNEFD | 000010c0 73 70 20 21 2c 20 7b 6c 72 7d 20 20 20 20 20 20 |sp !, {lr} | 000010d0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000010e0 3b 20 6f 74 68 65 72 77 69 73 65 20 64 72 6f 70 |; otherwise drop| 000010f0 20 74 68 72 6f 75 67 68 20 74 6f 20 53 57 49 20 | through to SWI | 00001100 68 61 6e 64 6c 65 72 0d 05 0a 11 2e 66 69 72 73 |handler.....firs| 00001110 74 5f 62 72 61 6e 63 68 0d 05 14 15 20 20 20 20 |t_branch.... | 00001120 20 20 20 20 44 43 44 20 20 20 20 20 30 0d 05 1e | DCD 0...| 00001130 04 0d 05 28 61 20 20 20 20 20 20 20 20 80 53 20 |...(a .S | 00001140 20 20 20 6c 72 2c 20 72 30 2c 20 23 31 3c 3c 36 | lr, r0, #1<<6| 00001150 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001160 20 20 20 3b 20 69 73 20 62 69 74 20 36 20 6f 66 | ; is bit 6 of| 00001170 20 6e 65 77 20 64 61 74 61 20 73 65 74 20 3f 20 | new data set ? | 00001180 49 66 20 73 6f 20 5a 3d a3 20 65 6c 73 65 20 5a |If so Z=. else Z| 00001190 3d b9 0d 05 32 74 20 20 20 20 20 20 20 20 42 45 |=...2t BE| 000011a0 51 20 20 20 20 20 63 6f 6e 74 69 6e 75 65 20 20 |Q continue | 000011b0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000011c0 20 20 20 20 20 20 3b 20 69 66 20 62 69 74 20 36 | ; if bit 6| 000011d0 20 69 73 20 6e 6f 74 20 73 65 74 20 74 68 65 6e | is not set then| 000011e0 20 5a 3d b9 20 61 6e 64 20 64 72 6f 70 20 74 68 | Z=. and drop th| 000011f0 72 6f 75 67 68 20 74 6f 20 4f 53 5f 55 70 64 61 |rough to OS_Upda| 00001200 74 65 4d 45 4d 43 0d 05 3c 5d 20 20 20 20 20 20 |teMEMC..<] | 00001210 20 20 80 53 20 20 20 20 6c 72 2c 20 72 31 2c 20 | .S lr, r1, | 00001220 23 31 3c 3c 36 20 20 20 20 20 20 20 20 20 20 20 |#1<<6 | 00001230 20 20 20 20 20 20 20 20 3b 20 69 73 20 62 69 74 | ; is bit| 00001240 20 36 20 6f 66 20 6d 61 73 6b 20 73 65 74 20 3f | 6 of mask set ?| 00001250 20 49 66 20 73 6f 20 5a 3d a3 20 65 6c 73 65 20 | If so Z=. else | 00001260 5a 3d b9 0d 05 46 74 20 20 20 20 20 20 20 20 42 |Z=...Ft B| 00001270 45 51 20 20 20 20 20 63 6f 6e 74 69 6e 75 65 20 |EQ continue | 00001280 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001290 20 20 20 20 20 20 20 3b 20 69 66 20 62 69 74 20 | ; if bit | 000012a0 36 20 69 73 20 6d 6f 74 20 73 65 74 20 74 68 65 |6 is mot set the| 000012b0 6e 20 5a 3d b9 20 61 6e 64 20 64 72 6f 70 20 74 |n Z=. and drop t| 000012c0 68 72 6f 75 67 68 20 74 6f 20 4f 53 5f 55 70 64 |hrough to OS_Upd| 000012d0 61 74 65 4d 45 4d 43 0d 05 50 4c 20 20 20 20 20 |ateMEMC..PL | 000012e0 20 20 20 42 49 43 20 20 20 20 20 20 72 30 2c 72 | BIC r0,r| 000012f0 30 2c 23 31 3c 3c 36 20 20 20 20 20 20 20 20 20 |0,#1<<6 | 00001300 20 20 20 20 20 20 20 20 20 20 20 3b 63 6c 65 61 | ;clea| 00001310 72 20 62 69 74 20 36 20 6f 66 20 6e 65 77 20 64 |r bit 6 of new d| 00001320 61 74 61 0d 05 5a 48 20 20 20 20 20 20 20 20 42 |ata..ZH B| 00001330 49 43 20 20 20 20 20 20 72 31 2c 72 31 2c 23 31 |IC r1,r1,#1| 00001340 3c 3c 36 20 20 20 20 20 20 20 20 20 20 20 20 20 |<<6 | 00001350 20 20 20 20 20 20 20 3b 63 6c 65 61 72 20 62 69 | ;clear bi| 00001360 74 20 36 20 6f 66 20 6d 61 73 6b 0d 05 64 45 20 |t 6 of mask..dE | 00001370 20 20 20 20 20 20 20 42 20 63 6f 6e 74 69 6e 75 | B continu| 00001380 65 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |e | 00001390 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b | ;| 000013a0 64 6f 20 4f 53 5f 55 70 64 61 74 65 4d 45 4d 43 |do OS_UpdateMEMC| 000013b0 0d 05 6e 04 0d 05 78 0d 2e 63 6f 6e 74 69 6e 75 |..n...x..continu| 000013c0 65 0d 05 82 1e 20 20 20 20 20 20 20 20 4c 44 4d |e.... LDM| 000013d0 46 44 20 20 20 73 70 20 21 2c 20 7b 6c 72 7d 0d |FD sp !, {lr}.| 000013e0 05 8c 12 2e 73 65 63 6f 6e 64 5f 62 72 61 6e 63 |....second_branc| 000013f0 68 0d 05 96 15 20 20 20 20 20 20 20 20 44 43 44 |h.... DCD| 00001400 20 20 20 20 20 30 0d 05 a0 0f 2e 6f 6c 64 5f 62 | 0.....old_b| 00001410 72 61 6e 63 68 0d 05 aa 54 20 20 20 20 20 20 20 |ranch...T | 00001420 20 44 43 44 20 20 20 20 20 30 20 20 20 20 20 20 | DCD 0 | 00001430 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001440 20 20 20 20 20 20 20 20 20 3b 20 62 72 61 6e 63 | ; branc| 00001450 68 20 74 6f 20 6f 72 69 67 69 6e 61 6c 20 53 57 |h to original SW| 00001460 49 20 64 65 63 6f 64 65 72 0d 05 b4 0f 2e 6e 65 |I decoder.....ne| 00001470 77 5f 62 72 61 6e 63 68 0d 05 be 53 20 20 20 20 |w_branch...S | 00001480 20 20 20 20 44 43 44 20 20 20 20 20 30 20 20 20 | DCD 0 | 00001490 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000014a0 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 62 72 | ; br| 000014b0 61 6e 63 68 20 74 6f 20 6f 75 72 20 6e 65 77 20 |anch to our new | 000014c0 53 57 49 20 64 65 63 6f 64 65 72 0d 05 c8 04 0d |SWI decoder.....| 000014d0 05 d2 05 5d 0d 05 dc 0a ed 20 70 61 73 73 0d 05 |...]..... pass..| 000014e0 e6 2d c8 99 20 22 4f 53 5f 46 69 6c 65 22 2c 31 |.-.. "OS_File",1| 000014f0 30 2c 22 4d 45 4d 43 50 61 74 63 68 22 2c 26 46 |0,"MEMCPatch",&F| 00001500 46 41 2c 2c 63 6f 64 65 2c 50 25 0d 05 f0 05 e0 |FA,,code,P%.....| 00001510 0d ff |..| 00001512