yaozhenyu2008 2017-01-23 08:48 采纳率: 0%
浏览 1464

powerpc 跳转指令问题

在powerpc下,我想自己计算出 跳转到函数C的 指令16进制代码。目的是为了修改代码段,实现

原先:函数A调用B。
修改后: 函数A调用函数C

代码段如下,即需要修改0xa284c地址指令。

0xa2840 9421fff0 stwu r1,-16(r1)
0xa2844 7c0802a6 mfspr r0,LR
0xa2848 90010014 stw r0,20(r1)
0xa284c 487976b5 bl 0x839f00 # funcB

NIA = CIA+EXTS(LI || 0b00)
branch instruction:

bl target_addr

18 | LI | AA| LK|
0 6 30 31
BIT0 --BIT5 是bx的操作码 18 LI 为BIT6 到BIT29 共24位。

我 按照上边的公式计算,但是funcC的地址比较大为0x0839e000
这样我计算LI时 就超出了24位。还望大神指点迷津。谢谢

ps: funcC 是编译出来的内核模块动态加载到Vxworks system中去的。

  • 写回答

1条回答 默认 最新

报告相同问题?

悬赏问题

  • ¥15 树莓派与pix飞控通信
  • ¥15 自动转发微信群信息到另外一个微信群
  • ¥15 outlook无法配置成功
  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题