签到天数: 1934 天 [LV.Master]伴坛终老
|
1。准备工具和资料
2 s n: q5 ?$ b(1)NEORAINE 1.2.1.0+MK68KDIS.EXE(注:官方NEORAINE模拟器是不附带MK68KDIS.EXE,你要在官方网站另外下载MK68KDIS.EXE,并放在NEORAINE模拟器目录里,下载页面:http://rainemu.swishparty.co.uk/html/download/dev.html)
) f& S9 y2 e/ Y" K3 s( D(2)十六进制编辑器WINHEX或ULTRAEDIT
( g( K7 c+ h9 _8 N2 B! x(3)68K指令集资料) f6 {# a0 I0 v k/ b9 r. M
(4)笔、纸0 S) q+ A, P6 d
) J% ]" \/ J' O# _9 c! S6 [0 f) _本人以NEOGEOCD《合金弹头2》为例,目标命不减。* Z+ q& z; N5 M1 E' m& i0 `
% R j# P" d2 _0 Z* J4 D8 ]/ [, {
2。下载NEOGEOCD版《合金弹头2》,将ISO里面全部文件解压到任意目录下再重新打包压缩成ZIP,因NEORAINE不能提取ISO镜像里面文件出来反汇编,所以要先将ISO里文件解压出来再重新打包压缩成ZIP。
$ F; i2 k3 M: x5 m1 }6 U5 w
) Y8 L# o$ H6 Q6 H3。首先要找到游戏命数存放地址,我已经找到,命数存放地址是:101276
8 ]9 s0 h$ v: M5 h \# I9 a! z- s' v8 H9 A
4。运行NEORAINE模拟器,读取《合金弹头2》ZIP文件,进入游戏后,现在你看到生命数是2,如图1:; q& s$ f1 g0 c- |# m
( x/ e' `0 u7 p* C3 G' L
+ Z0 Y' ?" I( t. t6 o h
5。按ESC键进入NEORAINE菜单选择界面,选择Console,输入watch $101276 1 1回车,这样当有1字节数值1写入生命存放地址时就发生中断,说明一下watch指令格式,watch [read] [adr] [size] [value]
8 I( N0 b& I5 y' M: l Q- \$ D9 Q7 i% d3 _5 s( @
read不加的话,就是写,adr是地址,size是字节长度,value是数值,数值必须用十进制表示,监视读取101276地址2个字节数据,可以这样打:watch read $101276 2
, v" a" u0 t y: C2 L$ I& ~0 e9 _; {
要删除断点就输入watch del [n],n是断点编号
* J2 J6 n$ D0 A0 R5 ~& h
5 o% b. I! [' B, c4 X& O5 o$ P* }; U再输入watch查看一下断点是否设置好,提示"watch #0 adr:101276 size:1 read:0",说明一下,#0是断点编号,adr是地址,size是字节数,read是1的读,是0的不读。如图2:
0 V1 D W7 `9 f0 R! A% |7 G8 P$ @! }
2 x" ?( I3 O1 k% D) f( b3 F3 J
提示:关于其他NEORAINE的控制台指令用法请输入help查看。9 d/ P9 R4 {; z7 A3 @, x0 \
9 }% y/ F- q9 \4 K) Y3 U" Y
6。回到游戏故意死一命后,模拟器发生中断,程式停在000cc086 6400000e BCC $cc096一行,用笔纸记下。如图3:) }# @7 z, ^2 B; V
! L+ l3 `7 Z& ~
) ^2 q' _& I7 I+ Z7。进入NEORAINE目录下debug目录,你会看到模拟器在发生中断同时在debug目录下生成2个文件。如图4:8 Z; A4 W6 ~" m2 H
& w, G! n$ [! A$ b. ~( \7 |1 i. K* w# W
8。用记事本之类软件有S后缀文件,查找000cc086,光标停在000cc086 6400000e BCC $cc096一行,现在来分析一下:% |3 `2 d. H# Q4 U+ }2 w% [" C
! ^; @" E- R7 r7 ^
000cc082 532e0082 SUBQ.B #1,130(A6)- W' G1 h8 P8 L+ c! Q3 f; D
000cc086 6400000e BCC $cc096! {1 V4 K* w0 T" o, ^( o
8 Q: ?; e M6 A6 C留意000cc086的前面一行000cc082 532e0082 SUBQ.B #1,130(A6),查了一下68K指令集资料,这一条指令作用是将130(A6)地址数据减1,结果存入130(A6)地址。
$ K6 Y0 ], k/ l" | I4 {1 P
3 J3 U8 d% `1 I% u; X9。回到模拟器用regs指令查一下寄存器,A6寄存器数据是001011f4,将130换算成16进制是82,再将82和A6寄存器数据相加,82+001011f4=00101276,00101276正好是1P命数存放地址。如图5:2 V/ g) A- j/ {# c4 T
, f ~0 a) t$ U9 e4 D4 O+ o, H
% h5 ?2 `5 v+ T$ B/ u10。只要将000cc082 532e0082 SUBQ.B #1,130(A6)这一行指令NOP掉就命不减,关闭模拟器,打开ZIP压缩包将MS2CD.PRG解压出来用WINHEX打开,来到cc082地址,将532e0082修改为4e714e71,保存。如图6、图7(注:4e71是NOP汇编指令机械码):
, T- ~, ]5 ^! x+ r' n* H# @' Q F' X9 E) ^# w( r
& M; t1 U) J) A. T4 X4 B9 z0 O# f# Q1 ^7 Q
11。将修改好MS2CD.PRG添加进ZIP压缩包里替换,再用NEORAINE打开加载合金弹头2 ZIP文件,测试一下是否命不减了,命不减说明修改成功。如图8:
, U+ `/ q. J/ C5 t1 N d
5 N) t4 X5 I1 v& l4 B6 J3 _# l$ H6 r
教程到此结束。" D7 {6 F) @7 ]9 D# [$ b8 R
* j0 h9 R& {4 E3 X
疾风之狼
9 M3 z) m8 S, h8 G) b+ X. v1 Z2 d6 E$ {8 T
2010.3.23 |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
评分
-
2
查看全部评分
-
|