EMU618社区

 找回密码
 立即注册
搜索
查看: 3095|回复: 6

[原创HACK教程] NEOGEO CD HACK初级教程

 关闭 [复制链接]

签到天数: 2022 天

[LV.Master]伴坛终老

发表于 2010-3-23 22:04:27 | 显示全部楼层 |阅读模式
1。准备工具和资料8 x- ?. T5 p- l! [% |4 ]/ t
(1)NEORAINE 1.2.1.0+MK68KDIS.EXE(注:官方NEORAINE模拟器是不附带MK68KDIS.EXE,你要在官方网站另外下载MK68KDIS.EXE,并放在NEORAINE模拟器目录里,下载页面:http://rainemu.swishparty.co.uk/html/download/dev.html)
5 a# h3 y' r4 ~(2)十六进制编辑器WINHEX或ULTRAEDIT
. J7 Q: E4 c- N+ Z- ]/ t+ k) v3 C+ j(3)68K指令集资料, H. s; z. k0 ~0 f' n0 x( ~
(4)笔、纸2 ]# |- E/ y4 J6 v  q# W  ]9 Q( i9 X* i* Y, H

4 t8 O. B0 g( j( w. _本人以NEOGEOCD《合金弹头2》为例,目标命不减。
0 H2 m- A3 i( w3 v! U
( X9 w0 q1 w3 E- r$ Z' _2。下载NEOGEOCD版《合金弹头2》,将ISO里面全部文件解压到任意目录下再重新打包压缩成ZIP,因NEORAINE不能提取ISO镜像里面文件出来反汇编,所以要先将ISO里文件解压出来再重新打包压缩成ZIP。, x8 r- I) k4 Z8 }

& B: J6 @8 Z/ ~+ K+ G; M4 L& ~3。首先要找到游戏命数存放地址,我已经找到,命数存放地址是:1012767 B; z# O( W, i: b) }9 `
" p0 l) R: F7 R/ h. O
4。运行NEORAINE模拟器,读取《合金弹头2》ZIP文件,进入游戏后,现在你看到生命数是2,如图1:
. h1 i: Z1 p) \. p4 D
$ I- [- d; V' h% p4 M3 ?6 t9 |( _6 t3 R  Q7 d
5。按ESC键进入NEORAINE菜单选择界面,选择Console,输入watch $101276 1 1回车,这样当有1字节数值1写入生命存放地址时就发生中断,说明一下watch指令格式,watch [read] [adr] [size] [value]! D1 y' G$ x$ u  O' s7 R! P, u' E

+ H; E( [  [3 g) p5 t: Q3 n  Hread不加的话,就是写,adr是地址,size是字节长度,value是数值,数值必须用十进制表示,监视读取101276地址2个字节数据,可以这样打:watch read $101276 2
" r* @, Y, r. o4 f  u; M
/ Z7 w+ m: j! D5 C* s要删除断点就输入watch del [n],n是断点编号
+ m+ y1 y! @. o* ~( e( B
# V6 r/ M) x$ `1 n) j, n, A* P( i9 s  o再输入watch查看一下断点是否设置好,提示"watch #0 adr:101276 size:1 read:0",说明一下,#0是断点编号,adr是地址,size是字节数,read是1的读,是0的不读。如图2:
* M. }- u0 m9 k7 I
6 d- v8 [9 @) `0 T  h( N- P& J3 a. o. D0 F
提示:关于其他NEORAINE的控制台指令用法请输入help查看。; c* g9 ?6 p5 n  q
2 d( _, Q% o6 P. Y+ `7 |4 \
6。回到游戏故意死一命后,模拟器发生中断,程式停在000cc086 6400000e BCC $cc096一行,用笔纸记下。如图3:, k% \6 S% m$ I  X  N: q
1 Q. k. @. ~8 I$ x3 X: H
$ }. g1 e2 z) ^2 B
7。进入NEORAINE目录下debug目录,你会看到模拟器在发生中断同时在debug目录下生成2个文件。如图4:
7 ]* m2 ~0 R4 H% r& C6 W& }" |5 D
7 Y* T( f+ D% Y2 C% A1 a
) \3 N- B6 V# t* M4 ?( b8。用记事本之类软件有S后缀文件,查找000cc086,光标停在000cc086 6400000e BCC $cc096一行,现在来分析一下:* o: v5 s/ L* m! B1 c
! g. B: z0 Z" v- y
000cc082   532e0082                        SUBQ.B        #1,130(A6)+ U/ V3 k, o/ A1 |0 ?
000cc086   6400000e                        BCC        $cc096
$ ]( ^1 y  h! Y0 U  i& S3 ~$ Q
6 L! N6 ]9 m: }: ~' ^6 w留意000cc086的前面一行000cc082 532e0082 SUBQ.B #1,130(A6),查了一下68K指令集资料,这一条指令作用是将130(A6)地址数据减1,结果存入130(A6)地址。
. D0 E+ r+ E2 K
" o, ~$ p: }0 Q" T9。回到模拟器用regs指令查一下寄存器,A6寄存器数据是001011f4,将130换算成16进制是82,再将82和A6寄存器数据相加,82+001011f4=00101276,00101276正好是1P命数存放地址。如图5:* y$ ^8 X  p. e* \9 c$ |) B
; `- \1 d" E$ w4 ^4 P/ c, D- ~
+ y2 p/ ~) m0 g; g# K( H
10。只要将000cc082 532e0082 SUBQ.B #1,130(A6)这一行指令NOP掉就命不减,关闭模拟器,打开ZIP压缩包将MS2CD.PRG解压出来用WINHEX打开,来到cc082地址,将532e0082修改为4e714e71,保存。如图6、图7(注:4e71是NOP汇编指令机械码):% L% M- B$ I' s, V( v

5 u/ {. G( \* k. b7 U: W2 I2 W/ G* I

- ]  d8 j. `; e  U6 Q  d, q  u11。将修改好MS2CD.PRG添加进ZIP压缩包里替换,再用NEORAINE打开加载合金弹头2 ZIP文件,测试一下是否命不减了,命不减说明修改成功。如图8:
# B  _, b8 Q9 A4 u( P: l) S# D( k* W! v( v  Z( V, j3 L) n5 u& Z
3 ^# x! R! c5 j& \; c
教程到此结束。
6 _& U. q% |+ Y: N( L: X% r- d7 @9 g. q; E
疾风之狼/ H/ Y+ {# ~, \3 T0 M: u, p+ X

$ w9 N& n) l5 E( m2010.3.23

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

评分

2

查看全部评分

签到天数: 343 天

[LV.8]以坛为家I

发表于 2010-3-24 09:45:34 | 显示全部楼层
感谢,学习一下.

该用户从未签到

发表于 2010-4-20 12:47:42 | 显示全部楼层
感谢,感谢,学习一下.学习一下.

签到天数: 1 天

[LV.1]初来乍到

发表于 2010-4-20 14:53:25 | 显示全部楼层
好耶,楼主的教程还真多啊,支持一下

签到天数: 35 天

[LV.5]常住居民I

发表于 2010-9-3 19:49:06 | 显示全部楼层
能把工具放出来下载吗

签到天数: 2022 天

[LV.Master]伴坛终老

 楼主| 发表于 2010-9-3 20:18:54 | 显示全部楼层
能把工具放出来下载吗
8 p$ u) q) y1 r孙爱孙 发表于 2010/9/3 19:49

8 Y1 J2 ?6 G6 ~1 J( E& y# j
% m. ^9 {5 c1 V) \NEORAINE模拟器:http://rainemu.swishparty.co.uk/html/download/neoraine.html" E/ c3 w: o4 D4 \( d+ ?. Q
/ q9 {+ `2 h% d- g9 m& t
MK68KDIS.EXE:http://rainemu.swishparty.co.uk/html/download/dev.html" P1 L( E7 O* i4 L2 M& `5 s1 `

. _# @3 y4 i- Y8 N# F! [! E. C& Z剩下十六进制编辑器WINHEX或ULTRAEDIT在网上很多网站有提供下载,用搜索引擎搜索一下就能找到。

签到天数: 145 天

[LV.7]常住居民III

发表于 2010-9-3 20:29:38 | 显示全部楼层
又是英文看不懂{:4_121:}
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|国治模拟精品屋 ( 沪ICP备15012945号-1 )

GMT+8, 2025-7-29 14:52 , Processed in 1.107422 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表