找回密码
 注册
关于网站域名变更的通知
查看: 339|回复: 2
打印 上一主题 下一主题

在arm中执行到B指令跳转的时候,为什么内存恢复原来的数据???

[复制链接]
  • TA的每日心情
    难过
    2019-11-20 15:02
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2019-7-10 16:47 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x
    . W1 A0 I" P" Y7 v! e( x' X

    该用户从未签到

    3#
    发表于 2019-7-10 17:38 | 只看该作者
    希望对你有帮助6 p# _8 `' N; m- [2 x- p4 p* Z

    - z. ~3 X4 d. d$ e' Q4 f$ J7 v首先看看跳转指令B的指令编码情况:
    ' O: N7 k# t0 X# s+ t! O- t3 C7 D9 M9 E& o# C3 A
    9 u/ C2 V5 Y  M( T2 h

      b0 z& O# e: A- U6 cB指令的编码是这样的4 ~8 M" Q7 @" b( V# `) a
    31..28:条件码( J; t  m' ?+ H$ e, A
    27..25:101' o5 B6 O+ p2 A+ N2 B/ h
    24:是否链接标志  Z. l5 M$ o( a3 O6 h
    23..0:跳转的地址- b6 ~1 T# c& Y: `; Q# W9 z, m

    8 c8 d. x/ [; e( ?, |+ Y也就是说跳转的地址位为23:0位共24位,其中一位为符号位也就只有正负8M的跳转地址而已,32M是怎么来的呢' w0 `0 ^7 e1 n; a' M9 ^% `: {
    我是这么理解的,因为ARM中要求指令是字对齐的,也就是32位对齐,指令起始地址末尾两位1:0为00,而寄存器R15程序计数器pc每次跳转地址都要加4,保证了跳转的指令末两位为00,而23:0并不保证这个规律,所以就将这24为左移2位,也就是在末尾加两个0变成了26位,此时其中一位为符号位所能表示的跳转范围就变成了正负32M了" _/ U  U5 k* m" r, r' e( i
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-11-24 19:37 , Processed in 0.156250 second(s), 26 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

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