---------Garfield Double Dares--------- A 4am crack 2015-09-05 --------------------------------------- Name: Garfield Double Dares Genre: educational Year: 1985 Publisher: Random House, Inc. Media: single-sided 5.25-inch floppy Previous cracks: Asimov has an uncredited crack Identical cracks: Garfield, Eat Your Words (crack no. 188) ~ Chapter 0 In Which Various Automated Tools Fail In Interesting Ways COPYA immediate disk read error Locksmith Fast Disk Backup unable to read any track EDD 4 bit copy (no sync, no count) copy works Copy ][+ nibble editor all tracks use standard prologues (address: D5 AA 96, data: D5 AA AD) but modified address epilogue (AA DE EB instead of DE AA EB) Disk Fixer ["O" -> "Input/Output Control"] set Address Epilogue to "AA DE EB" Success! All tracks readable! T00 -> looks like a DOS 3.3 RWTS T11 -> DOS 3.3 disk catalog T01,S09 -> startup program is "HELLO" Why didn't COPYA work? modified epilogue bytes (every track) Why didn't Locksmith FDB work? modified epilogue bytes (every track) EDD worked. What does that tell us? probably just structural protection (modified epilogue), no nibble check Next steps: 1. capture RWTS with AUTOTRACE 2. convert disk to standard format with Advanced Demuffin 3. patch RWTS to read standard format ~ Chapter 1 In Which We Attempt To Use The Original Disk As A Weapon Against Itself [S6,D1=original disk] [S6,D2=blank disk] [S5,D1=my work disk] ]PR#5 CAPTURING BOOT0 ...reboots slot 6... ...reboots slot 5... SAVING BOOT0 CAPTURING BOOT1 ...reboots slot 6... ...reboots slot 5... SAVING BOOT1 SAVING RWTS ]BRUN ADVANCED DEMUFFIN 1.5 ["5" to switch to slot 5] ["R" to load a new RWTS module] --> At $B8, load "RWTS" from drive 1 ["6" to switch to slot 6] ["C" to convert disk] --v-- ADVANCED DEMUFFIN 1.5 (C) 1983, 2014 ORIGINAL BY THE STACK UPDATES BY 4AM =======PRESS ANY KEY TO CONTINUE======= TRK:................................... +.5: 0123456789ABCDEF0123456789ABCDEF012 SC0:................................... SC1:................................... SC2:................................... SC3:................................... SC4:................................... SC5:................................... SC6:................................... SC7:................................... SC8:................................... SC9:................................... SCA:................................... SCB:................................... SCC:................................... SCD:................................... SCE:................................... SCF:................................... ======================================= 16SC $00,$00-$22,$0F BY1.0 S6,D1->S6,D2 --^-- ]PR#5 ]CATALOG,S6,D2 C1983 DSR^C#254 065 FREE B 011 BPLATE.CPRS A 021 GDDTITLE I 003 APPLESOFT B 011 TT.JCL B 042 FPBASIC B 016 BANK2.JCL B 009 RHYME.LNK B 004 DIR MSGS T 002 TIMDAT A 025 GDD WORD BANK.SML B 020 DATA4 B 016 MSG RTN A 025 GDDMAIN.SML T 102 DATAFIL B 002 BANK1 SWITCH B 003 SRCH3 B 003 JCL.NEW.OBJ A 006 HELLO B 010 CONDENSED B 015 TP.JCL A 017 GDDSCORE B 007 RH.JCL T 002 TOPTEN B 005 CREDITS.LNK B 003 SP KEYS B 002 MUS.LNK B 006 DATA3 B 043 DATA5 ]RUN HELLO ...crashes... [S5,D1=DOS 3.3 master disk] ]PR#5 ]RUN HELLO,S6,D2 ...program loads and runs... So it doesn't like Diversi-DOS 64K (the DOS on my work disk). It's probably accessing DOS functions directly or assuming the RWTS parameter table is at specific address, instead of using the vectors on page 3. But it works when I boot an unmodified DOS 3.3 first, so it isn't checking for its original DOS at runtime. [S6,D1=demuffin'd copy] ]PR#6 ...grinds then crashes... The demuffin'd disk can't read itself. This is not unusual. ~ Chapter 2 In Which We Remove All Traces Of Copy Protection Using An Automated Tool That I Wrote For Just Such An Occasion [S6,D1=demuffin'd copy] [S5,D1=my work disk] ]PR#5 ]BRUN PDP ; fix epilogue byte checking in RWTS T00,S03,$91 change AA to DE T00,S03,$9B change DE to AA T00,S06,$AE change AA to DE T00,S06,$B3 change DE to AA Quod erat liberandum. --------------------------------------- A 4am crack No. 441 ------------------EOF------------------