EMU618社区

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

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

 关闭 [复制链接]

签到天数: 2113 天

[LV.Master]伴坛终老

发表于 2010-3-23 22:04:27 | 显示全部楼层 |阅读模式
1。准备工具和资料
6 @; R6 r6 _, B1 A9 z(1)NEORAINE 1.2.1.0+MK68KDIS.EXE(注:官方NEORAINE模拟器是不附带MK68KDIS.EXE,你要在官方网站另外下载MK68KDIS.EXE,并放在NEORAINE模拟器目录里,下载页面:http://rainemu.swishparty.co.uk/html/download/dev.html)
6 ]$ ?$ ^& ]) q( C(2)十六进制编辑器WINHEX或ULTRAEDIT
' H+ ?4 l3 m& J* a" p, w; u7 s(3)68K指令集资料
1 X" d% R1 W5 a5 c' i& n1 I(4)笔、纸
8 Y; r; o0 F+ x5 L4 n' r" z
3 b) T6 n& ^" J9 o本人以NEOGEOCD《合金弹头2》为例,目标命不减。! Z8 S- L  m6 L! c. V- k) B

. P1 ]9 M, e, q2。下载NEOGEOCD版《合金弹头2》,将ISO里面全部文件解压到任意目录下再重新打包压缩成ZIP,因NEORAINE不能提取ISO镜像里面文件出来反汇编,所以要先将ISO里文件解压出来再重新打包压缩成ZIP。" x) q% Y  f1 Q+ I0 D
) o3 T* y6 b  h
3。首先要找到游戏命数存放地址,我已经找到,命数存放地址是:101276
* b) D/ z& p4 J, i& v- B# m' \1 i6 F1 L, O& ]- M1 D
4。运行NEORAINE模拟器,读取《合金弹头2》ZIP文件,进入游戏后,现在你看到生命数是2,如图1:* |5 L. p( e5 l: q8 q4 v7 C
" ]" v& O% ]9 p" _# V0 `) ]. [

$ l: X# d7 `4 Z  t0 F1 p1 `3 @4 ~  Z7 y5。按ESC键进入NEORAINE菜单选择界面,选择Console,输入watch $101276 1 1回车,这样当有1字节数值1写入生命存放地址时就发生中断,说明一下watch指令格式,watch [read] [adr] [size] [value]
8 l  K$ J7 y9 T: E# z2 U8 C, Z. E+ `* V" L6 J" a: {
read不加的话,就是写,adr是地址,size是字节长度,value是数值,数值必须用十进制表示,监视读取101276地址2个字节数据,可以这样打:watch read $101276 2
# E0 J' }9 c2 H% D
& W" W; t2 @$ k7 y9 K: U要删除断点就输入watch del [n],n是断点编号& L# n$ g  n8 e3 _5 s& N. {
7 \( v% b0 Z! \! D1 ?+ d! l
再输入watch查看一下断点是否设置好,提示"watch #0 adr:101276 size:1 read:0",说明一下,#0是断点编号,adr是地址,size是字节数,read是1的读,是0的不读。如图2:0 s, r' n4 R9 h( c' J9 u" D

& K  n7 @' G: c5 X0 ^1 f% c
, ?6 q# f# w7 o. R8 Y) l+ j/ {提示:关于其他NEORAINE的控制台指令用法请输入help查看。! B- p4 k  B/ T

, T8 g2 x- {9 e' i9 f! {6。回到游戏故意死一命后,模拟器发生中断,程式停在000cc086 6400000e BCC $cc096一行,用笔纸记下。如图3:
" ~) [8 N0 M& F/ T! F1 \% _% P3 i% o
: \- N% p- V! G  F2 I7 x
7。进入NEORAINE目录下debug目录,你会看到模拟器在发生中断同时在debug目录下生成2个文件。如图4:! x9 p' D: H( C

8 c/ |. S4 W- J) D! l7 J2 _
* S$ m8 ^3 c3 {* b# E8。用记事本之类软件有S后缀文件,查找000cc086,光标停在000cc086 6400000e BCC $cc096一行,现在来分析一下:' h' x8 q5 R& U
! D- T' I. s9 J* P
000cc082   532e0082                        SUBQ.B        #1,130(A6)
" `& i  {6 \; `: k0 `000cc086   6400000e                        BCC        $cc096
- G) |+ K& U/ `1 R
- b$ `" Y" _& X! Y留意000cc086的前面一行000cc082 532e0082 SUBQ.B #1,130(A6),查了一下68K指令集资料,这一条指令作用是将130(A6)地址数据减1,结果存入130(A6)地址。
' a6 o, f8 Q, o$ w" E! R8 _* i# ]* V/ s
9。回到模拟器用regs指令查一下寄存器,A6寄存器数据是001011f4,将130换算成16进制是82,再将82和A6寄存器数据相加,82+001011f4=00101276,00101276正好是1P命数存放地址。如图5:
+ B) v' E3 d# q2 O" L3 F
! e8 l( _: Y7 Y/ E9 I0 m3 r* f& _  e! x
10。只要将000cc082 532e0082 SUBQ.B #1,130(A6)这一行指令NOP掉就命不减,关闭模拟器,打开ZIP压缩包将MS2CD.PRG解压出来用WINHEX打开,来到cc082地址,将532e0082修改为4e714e71,保存。如图6、图7(注:4e71是NOP汇编指令机械码):
6 H/ Z$ H1 o5 n  L
2 ]8 z( I* o, Q3 u' ]0 a. M( @- X
) @) g5 [: N* ?' R- ^# K; q( s  S# D
11。将修改好MS2CD.PRG添加进ZIP压缩包里替换,再用NEORAINE打开加载合金弹头2 ZIP文件,测试一下是否命不减了,命不减说明修改成功。如图8:& V# g! m- K% M5 E) R6 F8 l

6 g% g( A3 x3 \. E5 e4 n0 |4 j& ^0 I& m
教程到此结束。
- E6 E- m! t+ x1 u
# b0 k% g; l) D6 C/ \疾风之狼
, _+ S" B  Z+ \8 C, Y8 h  R; j- w4 G; o/ r. y( F0 V
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 | 显示全部楼层
能把工具放出来下载吗

签到天数: 2113 天

[LV.Master]伴坛终老

 楼主| 发表于 2010-9-3 20:18:54 | 显示全部楼层
能把工具放出来下载吗
( N: p4 H2 _8 A) n; p  l  x8 m孙爱孙 发表于 2010/9/3 19:49
( }% i, }  [- r, }/ n- I

3 E# K7 j  h* k& uNEORAINE模拟器:http://rainemu.swishparty.co.uk/html/download/neoraine.html$ G) G5 q& K7 H& g5 G+ N* K1 a
7 N0 |, t; E- F: G) o/ M- |4 Q
MK68KDIS.EXE:http://rainemu.swishparty.co.uk/html/download/dev.html$ D* b& l5 Z' Z( [1 U8 D

6 S% c: F1 f% s剩下十六进制编辑器WINHEX或ULTRAEDIT在网上很多网站有提供下载,用搜索引擎搜索一下就能找到。

签到天数: 145 天

[LV.7]常住居民III

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

本版积分规则

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

GMT+8, 2025-10-27 18:19 , Processed in 1.064454 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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