EMU618社区

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

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

 关闭 [复制链接]

签到天数: 2189 天

[LV.Master]伴坛终老

发表于 2010-3-23 22:04:27 | 显示全部楼层 |阅读模式
1。准备工具和资料6 B" ?6 Q' W" F* z
(1)NEORAINE 1.2.1.0+MK68KDIS.EXE(注:官方NEORAINE模拟器是不附带MK68KDIS.EXE,你要在官方网站另外下载MK68KDIS.EXE,并放在NEORAINE模拟器目录里,下载页面:http://rainemu.swishparty.co.uk/html/download/dev.html)
; O+ ]2 z9 G$ a0 o(2)十六进制编辑器WINHEX或ULTRAEDIT
" H6 |5 k9 @. P% X, q, T4 E(3)68K指令集资料
, f! B2 \" c& I, t5 }; m$ P4 W(4)笔、纸
* s2 x0 A0 B$ V: h$ P* u+ o0 P" p0 |+ R5 U
本人以NEOGEOCD《合金弹头2》为例,目标命不减。3 B; O; ~8 w) ^. ^! A: j
; {1 L; z+ W( }9 q* D3 `! X2 T7 ]
2。下载NEOGEOCD版《合金弹头2》,将ISO里面全部文件解压到任意目录下再重新打包压缩成ZIP,因NEORAINE不能提取ISO镜像里面文件出来反汇编,所以要先将ISO里文件解压出来再重新打包压缩成ZIP。
* \$ |6 V0 a$ o( b2 N( k! p1 g( w$ n1 ?% ?' M% `6 i0 F1 n  S' ^" M
3。首先要找到游戏命数存放地址,我已经找到,命数存放地址是:101276  S* \& ~* _" ~  |4 I
; ^2 G$ D0 b' T) Z6 e
4。运行NEORAINE模拟器,读取《合金弹头2》ZIP文件,进入游戏后,现在你看到生命数是2,如图1:: h4 R; L. V0 _4 a( t

5 P5 s2 p7 i- ^( V3 n  l7 n4 e
5。按ESC键进入NEORAINE菜单选择界面,选择Console,输入watch $101276 1 1回车,这样当有1字节数值1写入生命存放地址时就发生中断,说明一下watch指令格式,watch [read] [adr] [size] [value]
) f1 [" G, Z* g! V* [7 T7 J- A! ~
1 P, o! [1 K7 kread不加的话,就是写,adr是地址,size是字节长度,value是数值,数值必须用十进制表示,监视读取101276地址2个字节数据,可以这样打:watch read $101276 2* B( Z" j( R# K9 a7 a
' j, O) S7 u  K3 F, r: _
要删除断点就输入watch del [n],n是断点编号
( x& `+ D: C9 h: M. `
2 J/ c0 M# N6 H9 ~% u再输入watch查看一下断点是否设置好,提示"watch #0 adr:101276 size:1 read:0",说明一下,#0是断点编号,adr是地址,size是字节数,read是1的读,是0的不读。如图2:
* D3 u  x! J! y/ G* n) J; q# S. p1 Z0 F/ g7 F! j& T; d0 s
" ^- S& P) a; o' L: l2 D5 b
提示:关于其他NEORAINE的控制台指令用法请输入help查看。& ^0 @9 E& a4 i  a
# W) W$ o+ `  G1 E/ s$ `/ E$ i
6。回到游戏故意死一命后,模拟器发生中断,程式停在000cc086 6400000e BCC $cc096一行,用笔纸记下。如图3:
; v! \/ z/ L7 q4 R* C1 H+ o. P$ n2 o1 h- {  N. S7 R+ q. j/ T6 U! B$ |  C
) v, s% R( T) F) L3 J& @
7。进入NEORAINE目录下debug目录,你会看到模拟器在发生中断同时在debug目录下生成2个文件。如图4:
7 A& [) x. Y$ T$ k5 L  o
5 @& [- L6 s  \' U  Q9 h
+ S4 Y- J5 F: c& y8。用记事本之类软件有S后缀文件,查找000cc086,光标停在000cc086 6400000e BCC $cc096一行,现在来分析一下:
1 a0 E: B0 v* Z" M* J. _7 m2 ~+ F# z3 Y/ k( a" R, W
000cc082   532e0082                        SUBQ.B        #1,130(A6)2 A( u! |, ^/ Q' _4 @$ K- j3 H& [
000cc086   6400000e                        BCC        $cc096  T* K5 m4 B7 @- E

* p# I' t0 V6 z$ e留意000cc086的前面一行000cc082 532e0082 SUBQ.B #1,130(A6),查了一下68K指令集资料,这一条指令作用是将130(A6)地址数据减1,结果存入130(A6)地址。' l/ m: [- A/ }2 s# f) y

% \8 e% g. S! D" e9。回到模拟器用regs指令查一下寄存器,A6寄存器数据是001011f4,将130换算成16进制是82,再将82和A6寄存器数据相加,82+001011f4=00101276,00101276正好是1P命数存放地址。如图5:5 g; q; k& ^, ~6 g+ N1 S% ~3 b

1 E0 E# R2 X; g; E1 V7 W. [8 O. u
8 o/ S9 Y( M& Y, ~/ s10。只要将000cc082 532e0082 SUBQ.B #1,130(A6)这一行指令NOP掉就命不减,关闭模拟器,打开ZIP压缩包将MS2CD.PRG解压出来用WINHEX打开,来到cc082地址,将532e0082修改为4e714e71,保存。如图6、图7(注:4e71是NOP汇编指令机械码):$ d* B0 R9 F0 w3 s4 y2 h8 Y# g) W

8 p& Y- V  j8 u! f3 i, T% h, g
# L3 d3 Q6 ?/ n0 X" S
0 f5 G* f0 Q- Y11。将修改好MS2CD.PRG添加进ZIP压缩包里替换,再用NEORAINE打开加载合金弹头2 ZIP文件,测试一下是否命不减了,命不减说明修改成功。如图8:$ J% t8 f9 p9 y6 ]8 {; q1 R5 M) {8 m9 c
: u  D8 i; ~6 F) H8 e, F
# ?  }7 M4 c& E7 y/ ]% s; h
教程到此结束。
+ y: G) [7 f4 i- [( e) V, K: D& Q! F  Z7 M
疾风之狼  i7 b  _8 Z9 ]8 y) Q

6 U. p3 X+ e$ ?2010.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 | 显示全部楼层
能把工具放出来下载吗

签到天数: 2189 天

[LV.Master]伴坛终老

 楼主| 发表于 2010-9-3 20:18:54 | 显示全部楼层
能把工具放出来下载吗
9 C$ o* P( ^1 k9 X2 J0 ~孙爱孙 发表于 2010/9/3 19:49
3 g8 S8 }6 N% u' X: U

+ ^3 ~2 r/ O  G+ Y' Y- P: CNEORAINE模拟器:http://rainemu.swishparty.co.uk/html/download/neoraine.html, W" ~/ G7 l5 W' P0 L# J5 G$ A- C
3 O: ^" F- U3 H' L: y0 n: X
MK68KDIS.EXE:http://rainemu.swishparty.co.uk/html/download/dev.html* E# a0 n7 ]' z, d- a/ A3 [7 A
2 ]5 n# n, _+ E/ p% V
剩下十六进制编辑器WINHEX或ULTRAEDIT在网上很多网站有提供下载,用搜索引擎搜索一下就能找到。

签到天数: 145 天

[LV.7]常住居民III

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

本版积分规则

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

GMT+8, 2026-1-12 07:47 , Processed in 1.083008 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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