反编译实例2:温度转换

后续我们会首先显示*.o的汇编,然后使用反编译后的C语言再比较最后的汇编结果。

通过IDA打开的汇编语言如下图:

接下来我们通过汇编来进行一步步的分析:

1、我们不能通过开始给R6,R5,R4的赋值操作确定其具体的含义,但是大致上可以判定为变量的初始化或是数据常量;

2、我们看到有一个标示符loc_10,如果你看过《IDA使用指南》的话会发现,这是IDA工具自己生成的,代表了一个跳转位置,符号只是为了阅读代码时起到一定的辅助作用,通过下面的汇编指令BLE loc_10跳转到该位置,而跳转的结果是根据上面的汇编语句CMP R4, R5来进行判断的,意思是如果R4小于等于R5则跳转到loc_10,整个过程R4在调用完_printf后发生了递增R6大小而R5则完全没有变化,从这个大致的框架分析得出这基本上是一个for语句或者while do语句或者do while语句,甚至你可以认为是if goto语句;

3、ADD R0, R4, R4, LSL#2语句,使用C语言来描述:R0 = R4 + R4<<4 = R4 + R4*4 = R4*5;

4、SUB R1, R0, #0XA0语句,上句的执行结果减上0XA0,也就是R4*5 - 0XA0,通过紧接着的语句MOV R0, #9可以看出R0实际上只是一个临时的值,也就不需要定义一个变量来表示;

5、接下来就是BL __rt_sdiv以及_printf的调用,__rt_sdiv是有符号的除法实现(__rt_udiv是无符号除法实现),而

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值