汇编指令学习(1)
本文最后更新于 842 天前,其中的信息可能已经有所发展或是发生改变。

先来一个 汇编指令在线转换的网站

https://defuse.ca/online-x86-assembler.htm#disassembly

可以通过这个网站来辅助学习

先了解一下基础的知识:

https://zhuanlan.zhihu.com/p/388683540

ARM 汇编的格式

基础知识中有说:

<opcode> {<cond>} {S} <Rd>,<Rn>,<shifter_operand>

这个是很重要的,要读懂汇编必须要明白一个指令是怎么组成的

例如:

PUSH {LR}

LR 寄存器入栈

SUB SP,SP,#0xc

基础学习中可以知道 , SP 是用来保存栈顶地址,栈是自顶向下,当栈指针向下移动 0xc 个字节,就代表开辟了 0xc 个字节的空间。

MOV R12 , #0

MOV 指令就是移动,这里理解很简单,就是把 R12 寄存器初始化为0

STR R12 ,[SP,#0x10+var_10]

这里的 var_10 是 ida 为了方便理解定义的,我们可以理解为 STR R12,[SP,#0]

那就是把 R12 中的内容存到 SP 寄存器偏移 0 个字节的位置

R12 的 内容上面的 MOV 指令给了是 0 ,那现在 SP 这个栈顶指针就是 0

BL luaL_loadbufferx

arm 指令中 BL 代表 无条件跳转, 后面的符号是 luaL_loadbufferx ,理解起来就是 跳转到 lual_loadbufferx 符号所在的偏移执行

ADD SP,SP,#0xc

栈顶指针 向上移动 0xc 个 字节,代表 释放栈空间

POP {PC}

PC 寄存器出栈

暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇