EMU618社区

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

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

 关闭 [复制链接]

签到天数: 1772 天

[LV.Master]伴坛终老

发表于 2010-3-23 22:04:27 | 显示全部楼层 |阅读模式
1。准备工具和资料( ]! E1 o$ S. ^. G$ X$ o
(1)NEORAINE 1.2.1.0+MK68KDIS.EXE(注:官方NEORAINE模拟器是不附带MK68KDIS.EXE,你要在官方网站另外下载MK68KDIS.EXE,并放在NEORAINE模拟器目录里,下载页面:http://rainemu.swishparty.co.uk/html/download/dev.html): A* E* w1 g/ q- S7 T5 F
(2)十六进制编辑器WINHEX或ULTRAEDIT6 q  @+ g4 c6 M; c, A/ e
(3)68K指令集资料
) e  ~0 x( V9 c- F  C9 I6 b(4)笔、纸
0 A2 g( C! f' {/ A+ S0 \' o9 }+ F. H  @4 s
本人以NEOGEOCD《合金弹头2》为例,目标命不减。& @  m+ \1 R, D1 b/ m2 s, ~% `

  W& @; I4 ^' p2 [6 g+ M$ i9 Z2。下载NEOGEOCD版《合金弹头2》,将ISO里面全部文件解压到任意目录下再重新打包压缩成ZIP,因NEORAINE不能提取ISO镜像里面文件出来反汇编,所以要先将ISO里文件解压出来再重新打包压缩成ZIP。
* C( K' R! F8 }! M  A1 T
, p# N  }1 s, ~* B3。首先要找到游戏命数存放地址,我已经找到,命数存放地址是:101276
6 C! K; x# ~* L! j4 \  S5 H7 T: }2 o. s+ ^& j
4。运行NEORAINE模拟器,读取《合金弹头2》ZIP文件,进入游戏后,现在你看到生命数是2,如图1:
( ^' L% p' c4 ]0 ?/ E" }( H8 z+ r: F0 a( d  _& {/ s5 {7 H
: x* D7 s$ C' k3 I; H8 a
5。按ESC键进入NEORAINE菜单选择界面,选择Console,输入watch $101276 1 1回车,这样当有1字节数值1写入生命存放地址时就发生中断,说明一下watch指令格式,watch [read] [adr] [size] [value]
- Q5 i0 {( B5 x) ^* d+ f9 W8 ^0 W9 d" q1 g! E
read不加的话,就是写,adr是地址,size是字节长度,value是数值,数值必须用十进制表示,监视读取101276地址2个字节数据,可以这样打:watch read $101276 2
$ p* F0 K3 z. e
. r9 r1 A1 M- O- ^要删除断点就输入watch del [n],n是断点编号
; r& m+ a# u+ w8 L3 T# R
! Q6 w. Z8 D  o9 l$ r再输入watch查看一下断点是否设置好,提示"watch #0 adr:101276 size:1 read:0",说明一下,#0是断点编号,adr是地址,size是字节数,read是1的读,是0的不读。如图2:
& ]+ \7 ]3 h8 Z5 H+ W7 w5 W9 @5 p( M' y( c( M3 j
0 Q1 |$ l( J. p" G
提示:关于其他NEORAINE的控制台指令用法请输入help查看。
9 q7 v7 w& E6 i
  [# h& s, c$ Y9 ]0 g! I- I5 z  l4 E6。回到游戏故意死一命后,模拟器发生中断,程式停在000cc086 6400000e BCC $cc096一行,用笔纸记下。如图3:4 ?( F! N, X% @! X, }/ Z. K& K

4 X" j5 X+ R4 Z6 L) p9 C8 R& M0 i3 Y
7。进入NEORAINE目录下debug目录,你会看到模拟器在发生中断同时在debug目录下生成2个文件。如图4:8 h  ]6 [" f/ c6 V3 l6 B

' k2 L9 Z/ K8 I0 A. v3 y9 O$ o7 d3 B! ~  x
8。用记事本之类软件有S后缀文件,查找000cc086,光标停在000cc086 6400000e BCC $cc096一行,现在来分析一下:
8 R1 C. r4 z( i* e) v
/ o4 P9 ]7 F8 m9 M8 ^) J1 v000cc082   532e0082                        SUBQ.B        #1,130(A6)5 k; d  T3 w8 r
000cc086   6400000e                        BCC        $cc096
. ~" m8 H% k! J# J3 q
' t% |) o& C: g6 f0 r" ~6 M& L留意000cc086的前面一行000cc082 532e0082 SUBQ.B #1,130(A6),查了一下68K指令集资料,这一条指令作用是将130(A6)地址数据减1,结果存入130(A6)地址。
) y' p9 z0 G( I' B) X  G9 V1 h4 y0 r) q0 T5 }8 h
9。回到模拟器用regs指令查一下寄存器,A6寄存器数据是001011f4,将130换算成16进制是82,再将82和A6寄存器数据相加,82+001011f4=00101276,00101276正好是1P命数存放地址。如图5:
* N# U3 F$ x8 U" t" R4 t
7 o4 J6 o3 q* A: t8 m
5 ~" @5 A, C. z0 N  q/ a  _8 J10。只要将000cc082 532e0082 SUBQ.B #1,130(A6)这一行指令NOP掉就命不减,关闭模拟器,打开ZIP压缩包将MS2CD.PRG解压出来用WINHEX打开,来到cc082地址,将532e0082修改为4e714e71,保存。如图6、图7(注:4e71是NOP汇编指令机械码):
; e: u0 v) s+ A1 H
; V) \/ H4 {/ x/ X! ^2 N/ ~4 p: F5 O# {" X' W
% v& S% L5 }- q' p/ \/ {# I
11。将修改好MS2CD.PRG添加进ZIP压缩包里替换,再用NEORAINE打开加载合金弹头2 ZIP文件,测试一下是否命不减了,命不减说明修改成功。如图8:" t3 |# |- _! w- ~

, _/ |7 N5 r# u% [& s$ |3 G. @1 Y8 Y2 i5 `
教程到此结束。. p: F4 r: B: z2 [
/ r+ L' I/ C: b. d( L
疾风之狼
: X: U' Z0 e  J. w9 }: k9 I# e/ @4 C
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 | 显示全部楼层
能把工具放出来下载吗

签到天数: 1772 天

[LV.Master]伴坛终老

 楼主| 发表于 2010-9-3 20:18:54 | 显示全部楼层
能把工具放出来下载吗
7 D# o' H  F2 H, D' n孙爱孙 发表于 2010/9/3 19:49
7 K, w% l0 Z! l- h8 S

2 q6 m" O% J# M0 A0 }NEORAINE模拟器:http://rainemu.swishparty.co.uk/html/download/neoraine.html: d* }* {" X. E; F, b
6 D, y, ]! E1 q4 t1 H: N1 {
MK68KDIS.EXE:http://rainemu.swishparty.co.uk/html/download/dev.html
4 t* T' V9 V4 C# y7 h- \; k7 I* R+ `
) ~) z0 t/ w/ V/ ?  F! x6 d" k# `剩下十六进制编辑器WINHEX或ULTRAEDIT在网上很多网站有提供下载,用搜索引擎搜索一下就能找到。

签到天数: 145 天

[LV.7]常住居民III

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

本版积分规则

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

GMT+8, 2024-11-18 22:45 , Processed in 1.082031 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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