EMU618社区

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

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

 关闭 [复制链接]

签到天数: 1895 天

[LV.Master]伴坛终老

发表于 2010-3-23 22:04:27 | 显示全部楼层 |阅读模式
1。准备工具和资料0 J; e9 p% L! u* e
(1)NEORAINE 1.2.1.0+MK68KDIS.EXE(注:官方NEORAINE模拟器是不附带MK68KDIS.EXE,你要在官方网站另外下载MK68KDIS.EXE,并放在NEORAINE模拟器目录里,下载页面:http://rainemu.swishparty.co.uk/html/download/dev.html)+ R9 i+ u; n2 a0 R
(2)十六进制编辑器WINHEX或ULTRAEDIT$ |3 ^+ D1 h- ?' x
(3)68K指令集资料/ w3 @. h' }& z7 p
(4)笔、纸
0 l7 v" q7 J  L3 Q% w% z$ K
- [2 ?0 r6 Q4 Q) o本人以NEOGEOCD《合金弹头2》为例,目标命不减。; ^% `: Z+ O0 u9 J, @, {+ q
  ?* Q4 T: x4 n# r0 z+ Q3 J
2。下载NEOGEOCD版《合金弹头2》,将ISO里面全部文件解压到任意目录下再重新打包压缩成ZIP,因NEORAINE不能提取ISO镜像里面文件出来反汇编,所以要先将ISO里文件解压出来再重新打包压缩成ZIP。
. i# {# R. f, L  e! \& \, [1 t! G  X) c: {; P# }
3。首先要找到游戏命数存放地址,我已经找到,命数存放地址是:101276
3 o9 N2 \! c0 p7 |3 E' E' ~
* q) @' F3 F% W& X% i' ^0 _4。运行NEORAINE模拟器,读取《合金弹头2》ZIP文件,进入游戏后,现在你看到生命数是2,如图1:, I* z+ a$ a& {% I; _

0 E- ]7 s! s3 S& _2 N! K* R9 u# p6 }+ B' ]# `* \, b
5。按ESC键进入NEORAINE菜单选择界面,选择Console,输入watch $101276 1 1回车,这样当有1字节数值1写入生命存放地址时就发生中断,说明一下watch指令格式,watch [read] [adr] [size] [value]
9 I% Z, e" W9 L4 M( ^" t2 g, L0 p7 T+ l9 M! t' b
read不加的话,就是写,adr是地址,size是字节长度,value是数值,数值必须用十进制表示,监视读取101276地址2个字节数据,可以这样打:watch read $101276 2" K5 C) S! o, n) Q" @' ?/ K

7 T1 D" T0 {: ?2 M要删除断点就输入watch del [n],n是断点编号" \( f/ e" x( {  y. N7 i( B
: _, X' P' j, D8 Y8 M
再输入watch查看一下断点是否设置好,提示"watch #0 adr:101276 size:1 read:0",说明一下,#0是断点编号,adr是地址,size是字节数,read是1的读,是0的不读。如图2:
) ]" G1 A! N/ W* ?$ x/ ^9 t  L6 Y! C/ ~3 Q

  a. J: Q7 F3 B9 k1 M( F提示:关于其他NEORAINE的控制台指令用法请输入help查看。8 H6 A  M5 x; P. c( M8 ]

$ y  g5 N3 y& q$ b7 x6。回到游戏故意死一命后,模拟器发生中断,程式停在000cc086 6400000e BCC $cc096一行,用笔纸记下。如图3:
* {/ v: i, _. o9 `! c: U+ }" q  V, E9 o2 a
' v, {3 g- d  D1 V0 Z$ p# m
7。进入NEORAINE目录下debug目录,你会看到模拟器在发生中断同时在debug目录下生成2个文件。如图4:
/ i1 J4 s) j6 ^6 ~/ D( L
* V/ r7 @+ Y( w7 N# q6 F% V: y4 \' o& R0 M& {% \
8。用记事本之类软件有S后缀文件,查找000cc086,光标停在000cc086 6400000e BCC $cc096一行,现在来分析一下:
8 s2 p2 U: h6 A5 }- J+ m. m' p6 l5 [7 a( b: w% K8 P
000cc082   532e0082                        SUBQ.B        #1,130(A6)7 w# B3 b" Z8 S; ~2 a# C5 X2 a
000cc086   6400000e                        BCC        $cc096. Q+ T0 s& ?2 W1 _2 }/ b
0 Q) B) G: k+ u1 m0 o) j- A
留意000cc086的前面一行000cc082 532e0082 SUBQ.B #1,130(A6),查了一下68K指令集资料,这一条指令作用是将130(A6)地址数据减1,结果存入130(A6)地址。
1 Q: _' O1 F' V6 {$ X# z" r8 A7 D6 u
9。回到模拟器用regs指令查一下寄存器,A6寄存器数据是001011f4,将130换算成16进制是82,再将82和A6寄存器数据相加,82+001011f4=00101276,00101276正好是1P命数存放地址。如图5:: Z" ?! |- }4 n5 [
6 J$ s5 B3 A- Z& N2 F. b

& D! C+ C+ b1 Q/ \  J) k+ ^10。只要将000cc082 532e0082 SUBQ.B #1,130(A6)这一行指令NOP掉就命不减,关闭模拟器,打开ZIP压缩包将MS2CD.PRG解压出来用WINHEX打开,来到cc082地址,将532e0082修改为4e714e71,保存。如图6、图7(注:4e71是NOP汇编指令机械码):: y. @& p4 {( X; F1 A, W# a

6 Y5 E3 z+ S: y& X9 w
/ w" i5 q* q% a0 e7 x1 j0 M' e8 v  z6 M7 p
11。将修改好MS2CD.PRG添加进ZIP压缩包里替换,再用NEORAINE打开加载合金弹头2 ZIP文件,测试一下是否命不减了,命不减说明修改成功。如图8:
- Y/ P) `, l; W" l1 V
* L: O, K* k/ a, Z( C, i7 s
; k1 L% @! Y1 \$ g1 m, ]* ?教程到此结束。, X9 s3 O, r6 P  @/ `' @- j7 V

+ u" i1 `1 {+ x疾风之狼* q. B& W. |  X+ {. D
0 ?. w% I% q; p5 s5 n
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 | 显示全部楼层
能把工具放出来下载吗

签到天数: 1895 天

[LV.Master]伴坛终老

 楼主| 发表于 2010-9-3 20:18:54 | 显示全部楼层
能把工具放出来下载吗5 [+ M& R+ z3 i
孙爱孙 发表于 2010/9/3 19:49

2 Q  M& t( r$ W2 m, g7 S8 Z2 Q' D! m
2 J: ?5 d5 m# ?- zNEORAINE模拟器:http://rainemu.swishparty.co.uk/html/download/neoraine.html5 r3 y& o9 f1 E$ V, h

8 ^" [7 p. r9 r6 T% b$ GMK68KDIS.EXE:http://rainemu.swishparty.co.uk/html/download/dev.html" a$ p* G; ^% ]5 y
3 J- S! H! j0 w2 B
剩下十六进制编辑器WINHEX或ULTRAEDIT在网上很多网站有提供下载,用搜索引擎搜索一下就能找到。

签到天数: 145 天

[LV.7]常住居民III

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

本版积分规则

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

GMT+8, 2026-2-25 04:12

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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