EMU618社区

 找回密码
 立即注册
搜索
查看: 1211|回复: 5

[求助] GBA游戏修改問題??

[复制链接]

该用户从未签到

发表于 2010-1-9 09:09:07 | 显示全部楼层 |阅读模式
在下正在學修改gba,一開始就有問題出現啦......有人可以幫我嗎?
) ~2 c5 N4 ~* L$ I+ M/ A0 n$ N8 ^我正在學BL指令来跳转,問題是這樣的....
* o' q# w& l3 I% T- Y# L* K2 I6 q. P! e( {7 {
[把R0-R2入栈]                   push r0-r2        <-----這句無問題6 e! z8 G* F: S+ m7 Z8 ^4 {+ u+ c
[R0=修改地址]                   ldr r0,=03000fa8  <-----這句有問題出現了,我寫入ldr r0,=03000fa8 後,電腦出現[parameter fail] [參數失敗]是我寫錯了嗎?
, o9 v  [7 W8 V, A8 J' m[把0x63放入寄存器R1]             mov r1,#0x63      <-----這句一樣[parameter fail]
% f1 B$ G8 h$ H; F8 `8 W[R0的值作为地址把R1的值放入该地址] strb r1,[r0]      , G, \0 `6 U- k4 H! R$ l, R* h. ~
[出栈]                          pop r0-r2
) y) n# `( T3 o[返回]                          bx r14
/ N! m4 U3 n: ?: u6 _" `0 I2 |% _9 c  O  ^" w  }
希望有人可以寫一個,長細[图文教程]!!因為我搵了很多網都唔明點樣寫跳转,希望有人好心幫下忙啦!!:(
) i7 g- {% _3 i- G% P( z% i
$ g1 h7 @; `$ ^! w; h/ f% I4 O- M[ 本帖最后由 adrianking 于 2010-1-9 09:10 编辑 ]

签到天数: 712 天

[LV.9]以坛为家II

发表于 2010-1-9 13:27:52 | 显示全部楼层
[R0=修改地址] ldr r0,=03000fa8 <-----這句有問題出現了,我寫入ldr r0,=03000fa8 後,電腦出現[parameter fail] [參數失敗]是我寫錯了嗎?" I, p) I/ B7 t1 L. ^! M+ G$ Q9 \; q/ }5 `
[把0x63放入寄存器R1] mov r1,#0x63 <-----這句一樣[parameter fail]. R7
! j( _( y" l6 f7 p这个应该不能直接写ldr r0,=03000fa8  而是在其内存处写上机器码 48 0X(X表示某一个数值)
: f' B" |6 x9 ?1 |! X% ^最后在你的Bx r14后 (即 47 70后),找地方写上r0的地址,这样就行了。
6 q7 F* n/ ~5 K2 U' v* @! `, g3 D4 z* SGBA没怎么研究过,具体的细节问题也不会,有些东西也记不清了,LZ可以求助其他有研究过的人。

签到天数: 1 天

[LV.1]初来乍到

发表于 2010-1-9 21:29:44 | 显示全部楼层
ldr r0,=03000fa8 的语句原型应该是 ldr r0,[pc,x]    这个语句的意思是 把当前PC地址加上X的值作为地址 然后读取这个地址的值到 r0
5 L% k& G  s: i! p至于这个X应该写多少,得看你自己定了,数字越大 你那03000FA8的地址数值就要写在越后面,03000FA8写进内存的话要写A8 0F 00 03 9 o7 a" a6 @: s( w* h) k( Y" E( X: O

8 l  S4 P3 B& C' q5 @在调试器里会显示ldr r0,=03000fa8 但是写程序的时候这样写是不行的
4 Q: H0 r5 D, k" r! z4 Z- Q$ @; T$ G  o6 r+ a
你写机器码也可以 先写0048 之后等你的程序全部写完了之后 在你的最后一条指令 BX R14 之后 写上机器码 A8 0F 00 03 然后去改
, ~/ B2 L- s- k5 L' o" |0048的 那个00  从00一直加1 加1 往上试 知道 调试器里显示ldr r0,=03000fa8 为止 当然了 这个办法是比较笨的了 其实这个值是可以计算出来的 X每加1 偏移加4  所以结果就是 PC + X*4  PC就是下一条指令所在的地址 假设PC=08000000,你的程序最后一条指令在08000100 那么你那A8 0F 00 03 就得写在 08000104的地方 然后 0048 就要写4148 指令也可以写 ldr r0,[pc,#0x41]( {6 _3 W! ^4 Z8 u4 T

: E7 n9 P: E2 @; V  v5 B至于mov r1,#0x63会出错我就不明白了 要不你写 mov r1,63 试试6 ~- u( u& v& F1 M& D) U
% Y4 ?1 u$ R+ \: p$ w0 ]' x
[ 本帖最后由 shinwa 于 2010-1-9 21:46 编辑 ]

评分

1

查看全部评分

该用户从未签到

 楼主| 发表于 2010-1-10 05:16:05 | 显示全部楼层
多謝各位熱心的回復!!:victory:

签到天数: 6 天

[LV.2]偶尔看看I

发表于 2010-1-10 20:13:02 | 显示全部楼层
期待另一个超级赛亚人的诞生:victory:

签到天数: 2050 天

[LV.Master]伴坛终老

发表于 2010-1-11 13:25:40 | 显示全部楼层
mov r1,#0x63出错?可以这样写试试:mov r1,63h
- m9 _3 w9 K0 |$ A+ @; c; f/ a. ]5 V3 H6 k; L. @0 {0 ~/ `1 k( ?
期待3楼进化成超级赛亚人3......:)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2025-8-25 13:17 , Processed in 1.073242 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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