基础汇编指令

start:

mov  sp,  #4096

bl  c  main

halt

b  8

mov  ip,  sp

stmdb   sp!,  {fp,ip,lr,pc}

sub   fp,  ip  ,#4;  0x4

sub   sp,  sp,  #8  0x8

mov  r3,#1442840576  0x56000000

add  r3,  r3,  #80;  0x50

str  r3,  [fp,#-16

mov  r3,  #1442840576  0x56000000

add  r3,  r3,  #84 ;  0x54

str  r3,  [fp, #-20]

ldr  r2,  [fp, #-16]

mov  r3,  #256

str  r3,  [r2]

ldr  r2,  [fp,#-20]

mov  r3,  #0

str  r3,  [r2]

mov  r3,  #0

mov  r0,  r3

sub  sp,  fp,  #12

ldmia  sp,{fp,sp,pc}

解析:

  stmdb  sp!,{fp,ip,lr,pc}

db含义:decrement  before  先减,后存。

  sp‘ = sp -4 = 4092,如果布加感叹号,sp为原值,并不会被减。

  高编号寄存器存在高地址,4092到4095存放PC的值,sp‘ = sp - 4 = 4088.

              4088到4091存放lr寄存器的值

              4084到4087存放ip的值

              4080到4083存放fp的值。

stmdb最常用

ldmia  sp,  {fp,sp,pc}

  先读4080到4083的值 = 原来的fp的值  低地址对应低编号。

  

  

  

    

时间: 2024-08-29 16:02:41

基础汇编指令的相关文章

<<ASM>> x86汇编指令浅析

学习研究系统/软件底层机制的朋友,汇编是必修课之一.由于汇编具有低级语言固有的特性,使得前期的学习掌握异常困难.本文将着重介绍一些常用而又关键的汇编指令,借此提携那些还在苦苦攀援的“初学者”们. 目前市场上主流的汇编教材中,王爽所著的<汇编语言(第二版)>比较受读者的青睐.笔者自学汇编所选的汇编教材则是杨继文所著的<80x86汇编语言程序设计教程>和<汇编语言程序设计——从DOS到Windows>张雪兰/谭毓安:根据书的厚度就可知其难易程度.读者若初次接触汇编,可以考虑

Assembly instructions 汇编指令解析 A&amp;AT

Assembly instructions 汇编初步学习 汇编0基础的戳上面,刷一遍,包治百病 %eax寄存器的值与C语言的return的值相对应 (%esp)地址处储存的是函数的返回地址 return address %esp 栈顶寄存器 保存栈顶指针. %ebp = boundary between parameters and local variable 函数执行时不要改变这个寄存器的值! pushl 指令究竟都干了什么: pushl x 等价于 subl $4, %esp; movl

汇编指令及其特点

基础知识 指令与伪指令 汇编指令:CPU机器指令的助记符,编译后得到1和0组成的机器码,由CPU读取执行 伪指令:本质上不是指令,由编译环境提供,谜底在于知道编译过程,最终不会生成机器码 不同的ARM风格 ARM官方汇编风格:指令一般大写,windows IDE开发环境常用.(譬如:LDR.STR) GNU风格的ARM汇编:指令一般小写,linux中常用.(譬如:ldr.str) ARM汇编的特点 ARM汇编特点1:LDR和STR架构 ARM采用RISC架构,CPU不能直接读取内存,需要将内存内

用机器指令和汇编指令编程(修改版)

实验名称 用机器指令和汇编指令编程(1) 实验日期   2018.10.22 学院:计软院 专业:计算机科学与技术 年级:2017级 班次:5班 姓名:陈奕明 学号 20171308194 一.实验目的 1. 掌握使用debug工具编写和调试汇编命令的方法 2. 掌握第1-2章所学的关于CPU.寄存器.内存的基础知识 3. 掌握第1-2章涉及的几条指令mov, add, sub, jmp的用法 二.实验准备 1. 复习教材第1~2章内容,完成教材内相关检测点 2. 结合教材实验1 (P35)及公

ARM体系结构和汇编指令

第一节 可编程器件的编程原理 1. 可编程器件的特点 1 . CPU在固定频率的时钟控制下节奏运行 2 . CPU可以通过总线读取外部存储设备中的二进制指令集,然后解码执行 3 . 这些可以被CPU解码执行的二进制指令集是CPU设计的时候确定的,是CPU的设计者(ARM公司)定义的,本质上是一串由1和0组成的数字.这就是CPU的汇编指令集 2. 从源代码到cpu执行过程 第二节 指令集对cpu的意义 1. 汇编语言与C等高级语言的差异 汇编无移植性,c语言有一定可移植性,jave等更高级的语言移

函数调用与汇编指令的关系

写一段简单的C代码分析其背后与汇编指令的关系 最近在看hotspot的代码,hotspot解释器会将字节码翻译成汇编指令,所以要先复习下这个基础 C代码 #include <stdio.h> int main(int args, char** argv){ printf("%d", add1(100, 200, 500, 600)); } int add1(int i, int j, int k, int m){ return i + j + k + m; } gcc编译验

汇编指令解析

X86架构 [原创]X86汇编之指令格式解析 [原创]汇编指令之OpCode快速入门 [原创]X64汇编之指令格式解析 ARM架构:

Android 图解逆向工程中ARM常用汇编指令(一)

我们走得太快,灵魂都跟不上了. 微小的幸福就在身边,容易满足就是天堂. 在逆向和爆破中我们经常会在IDA中接触到汇编,一般做安卓的不会太了解VB回编等,不太了解的同学可以先查看上篇文章<Android ARM常用的汇编指令合集> 再来继续我们的学习,我们先来看张图. 这个view里面有 PUSH/LDR/SUB/MOVS/BLX/SUBS/BEQ/CMP ,这些差不多都是常见的,不过也不需要看得懂,理解这个指令即可,接下来我们就来分析下这些指令分别有什么作用吧. 先引入 概念性 东西,免得大家

如何实现对ARM汇编指令的调试?

学习ARM汇编语言时,少不了对ARM汇编指令的调试.作为支持多语言的调试器,gdb自然是较好的选择.调试器工作时,一般通过修改代码段的内容构造trap软中断指令,实现程序的暂停和程序执行状态的监控.为了在x86平台上执行ARM指令,可以使用qemu模拟器执行ARM汇编指令,具体的调试方法,一起来看看吧. 一.准备ARM汇编程序 首先,我们构造一段简单的ARM汇编程序作为测试代码main.s. .globl _start _start: mov R0,#0 swi 0x00900001 以上汇编指