EMU618社区

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

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

 关闭 [复制链接]

签到天数: 2163 天

[LV.Master]伴坛终老

发表于 2010-3-23 22:04:27 | 显示全部楼层 |阅读模式
1。准备工具和资料
" H9 L9 B+ M/ P  c- t1 A2 o(1)NEORAINE 1.2.1.0+MK68KDIS.EXE(注:官方NEORAINE模拟器是不附带MK68KDIS.EXE,你要在官方网站另外下载MK68KDIS.EXE,并放在NEORAINE模拟器目录里,下载页面:http://rainemu.swishparty.co.uk/html/download/dev.html)
0 j& o8 P9 l9 J(2)十六进制编辑器WINHEX或ULTRAEDIT
+ d7 u& q. \! r/ j) r(3)68K指令集资料
' g  E( }# Z6 Y8 u2 K0 M(4)笔、纸: ^* d; J0 J( p

- P6 O" S) w0 E$ f7 u: Y本人以NEOGEOCD《合金弹头2》为例,目标命不减。
# A# z+ x2 f" m- D
1 _! X" \% F2 N( G% C2。下载NEOGEOCD版《合金弹头2》,将ISO里面全部文件解压到任意目录下再重新打包压缩成ZIP,因NEORAINE不能提取ISO镜像里面文件出来反汇编,所以要先将ISO里文件解压出来再重新打包压缩成ZIP。5 Y+ ~! I3 T2 h, b3 c

3 H1 j6 X# @5 H% v8 T3。首先要找到游戏命数存放地址,我已经找到,命数存放地址是:101276( m+ ^3 R; i6 u" D# i

- _  n6 `! Y9 k6 a4。运行NEORAINE模拟器,读取《合金弹头2》ZIP文件,进入游戏后,现在你看到生命数是2,如图1:
/ `. {* V/ \# k9 n5 I: `9 l8 m
# E) q; i( ^7 ]0 f7 [
/ e7 m. z+ i* E/ `5。按ESC键进入NEORAINE菜单选择界面,选择Console,输入watch $101276 1 1回车,这样当有1字节数值1写入生命存放地址时就发生中断,说明一下watch指令格式,watch [read] [adr] [size] [value]
# S" W1 \; b- U( p; S5 x5 F+ |/ e* ~9 X0 N( L
read不加的话,就是写,adr是地址,size是字节长度,value是数值,数值必须用十进制表示,监视读取101276地址2个字节数据,可以这样打:watch read $101276 2
3 ~, I1 O4 _5 F+ t+ k* x8 h) {/ ^) @; A/ b
要删除断点就输入watch del [n],n是断点编号
' [1 l* E& K! }/ u
* ^! h$ T% W5 e再输入watch查看一下断点是否设置好,提示"watch #0 adr:101276 size:1 read:0",说明一下,#0是断点编号,adr是地址,size是字节数,read是1的读,是0的不读。如图2:
3 Q2 Y) c- [3 m" ^; q8 h% y' b# n- N) c- }& w
, m, @6 v/ w; J0 W% \3 k8 |
提示:关于其他NEORAINE的控制台指令用法请输入help查看。: B4 Z" W; R% T) \# e* Z
1 k; {: ]# P% m1 b
6。回到游戏故意死一命后,模拟器发生中断,程式停在000cc086 6400000e BCC $cc096一行,用笔纸记下。如图3:  N. Y; B! R2 r2 O# d6 a1 m

# x" M$ n9 p4 p0 q5 K$ Z/ d6 Z+ `
, g; q7 A' g7 @4 {  I1 s7。进入NEORAINE目录下debug目录,你会看到模拟器在发生中断同时在debug目录下生成2个文件。如图4:
; t: S  d- d9 y9 W
, x* n9 W1 H7 y( q* U, f/ K; w* J/ `. S% t1 Y1 b9 R8 ^: J
8。用记事本之类软件有S后缀文件,查找000cc086,光标停在000cc086 6400000e BCC $cc096一行,现在来分析一下:; ~3 B; S2 ]: V
: B6 ]$ g2 Z* T6 [, `: n6 _
000cc082   532e0082                        SUBQ.B        #1,130(A6)" `# N# l5 \9 T2 ^  V' I
000cc086   6400000e                        BCC        $cc096) a2 S+ i+ U. l9 y  O
  J; P# x( o; O- I. C5 [% K
留意000cc086的前面一行000cc082 532e0082 SUBQ.B #1,130(A6),查了一下68K指令集资料,这一条指令作用是将130(A6)地址数据减1,结果存入130(A6)地址。$ ~* K, Y  [+ p. I. A
3 E. ~0 K( [+ M3 V6 e3 X
9。回到模拟器用regs指令查一下寄存器,A6寄存器数据是001011f4,将130换算成16进制是82,再将82和A6寄存器数据相加,82+001011f4=00101276,00101276正好是1P命数存放地址。如图5:5 n1 v% y0 |( M$ L: ]

" e# g6 j7 G  p3 v/ l: W
+ h4 t  s& d/ h10。只要将000cc082 532e0082 SUBQ.B #1,130(A6)这一行指令NOP掉就命不减,关闭模拟器,打开ZIP压缩包将MS2CD.PRG解压出来用WINHEX打开,来到cc082地址,将532e0082修改为4e714e71,保存。如图6、图7(注:4e71是NOP汇编指令机械码):/ a% F3 ~# w  [# L$ }

2 ^+ V5 |+ ?2 U4 Z/ I' j4 V6 x+ R; t  b5 F

4 U1 T* M; t. P& Y2 t. s11。将修改好MS2CD.PRG添加进ZIP压缩包里替换,再用NEORAINE打开加载合金弹头2 ZIP文件,测试一下是否命不减了,命不减说明修改成功。如图8:
+ H! U/ ~1 ], a; }% w
" _& V/ o; b6 m$ [! ]' j, d. ?/ a, _- I
教程到此结束。. G! l$ p8 s/ j" b$ D7 ^
" r7 a4 A+ Y9 e, ~; o# E
疾风之狼
" O$ m  [2 o* B- p/ v: b/ J! z9 D8 v" r' o- N& C7 h3 F! U
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 | 显示全部楼层
能把工具放出来下载吗

签到天数: 2163 天

[LV.Master]伴坛终老

 楼主| 发表于 2010-9-3 20:18:54 | 显示全部楼层
能把工具放出来下载吗
' r; C; K" ^1 N) _孙爱孙 发表于 2010/9/3 19:49

/ F/ A+ O6 ^- M6 b7 M0 |2 w9 U/ V4 G1 J( ~" j4 l8 U
NEORAINE模拟器:http://rainemu.swishparty.co.uk/html/download/neoraine.html
( ]* X3 }' M! x, h) l: P; t5 Q/ M7 d; u# k1 }$ _" V  f
MK68KDIS.EXE:http://rainemu.swishparty.co.uk/html/download/dev.html- A6 \: K# Y" L0 M$ F4 ~

+ y5 g- [: c( B3 s5 u剩下十六进制编辑器WINHEX或ULTRAEDIT在网上很多网站有提供下载,用搜索引擎搜索一下就能找到。

签到天数: 145 天

[LV.7]常住居民III

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

本版积分规则

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

GMT+8, 2025-12-17 08:25 , Processed in 1.086914 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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