ARM软件逆向工程入门 00

这篇具有很好参考价值的文章主要介绍了ARM软件逆向工程入门 00。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

ARM指令集特点

ARM指令集是一种低功耗、小尺寸和低成本的指令集,它具有以下特点:

  • ARM指令集具有良好的可移植性,可以在不同的架构上运行;
  • ARM指令集支持32位和64位,减少指令的数量,提高运行效率;
  • ARM指令集支持硬件加速,可以更有效的利用处理器的资源;
  • ARM指令集可以节省系统资源,改善系统性能;

学习ARM软件逆向工程的意义

学习ARM软件逆向工程有着重要的意义:

  • 可以帮助开发人员更好的理解软件的内部结构;
  • 有助于开发人员分析代码的功能,查找bug,提高程序的可靠性和安全性;
  • 可以帮助开发人员更好的优化代码,提高软件的性能;
  • 可以帮助开发人员更好的了解系统底层实现,为系统开发提供参考。

ARM 主流版本

  • ARMv7架构:提供安全模式
  • ARMv8架构:增加了64位架构,支持更高级的应用

ARMv7 寄存器

ARMv7 架构的r0-r15寄存器包括:

  • r0:一般用于存储函数调用时的参数和返回值。
  • r1:用于存储当前函数的局部变量。
  • r2-r12:一般用于存储函数调用时的参数和返回值。
  • r13:栈指针,用于指向栈顶地址,也称作SP。
  • r14:链接寄存器,存储函数返回地址,也称作LR。
  • r15:存储当前执行指令的地址,也称作PC。

ARMv8 寄存器

ARMv8 架构的x0-x31寄存器包括:

  • x0:一般用于存储函数调用时的参数和返回值。
  • x1:用于存储当前函数的局部变量。
  • x2-x30:一般用于存储函数调用时的参数和返回值。
  • x29:寄存器用于存储栈指针,也称作SP;
  • x30:寄存器用于存储函数返回地址,也称作LR。
  • x31:存储当前执行指令的地址,也称作PC。
  • xzr:ARMv8架构的zero寄存器xzr是一个特殊的寄存器,它总是存储0值,不能被修改。使用zero寄存器可以减少指令的数量,提高运行效率。

安装及使用binutils

binutils是一套软件工具,用于对ARM执行程序进行反汇编。它包括一系列的可执行程序,如ld,as,objdump等等,可以用来生成,调试和管理可执行程序和共享库。

为了安装binutils,首先需要从官方网站下载源代码,然后使用./configure命令进行配置,接着使用make命令编译源代码,最后使用make install命令安装binutils。

要使用binutils,可以使用objdump命令对ARM程序进行反汇编,比如:objdump -d <程序文件>。此外,还可以使用readelf命令查看ELF文件的信息,使用nm命令查看符号表信息,以及使用strings命令查看程序中的字符串等等。

当然,也可以通过apt-get 命令直接进行安装。

通过apt-get 安装 aarch64版本binutil:

sudo apt-get install binutils-aarch64-linux-gnu

通过apt-get 安装 arm版本binutil:

sudo apt-get install binutils-arm-linux-gnueabi

逆向工程工具介绍

目前主流的逆向工程工具主要有:

  • IDA Pro:一款专业的反汇编器,支持多种CPU架构,包括ARM架构。
  • Ghidra:一款免费的反汇编器,由美国国家安全局提供,支持多种CPU架构,包括ARM架构。
  • Binary Ninja:一款独特的反汇编器,支持多种CPU架构,包括ARM架构。
  • Radare2:一款开源的反汇编器,支持多种CPU架构,包括ARM架构。

其中IDA Pro和Binary Ninja是收费的,这里就不推荐了。

Ghidra和Radare2都提供了丰富的分析功能,可以用于查看汇编代码的调试信息,搜索加密函数,查找漏洞等等。Ghidra还提供了一个交互式图形用户界面,可以帮助用户更好的理解和分析汇编代码,Radare2则提供了一个命令行用户界面,可以方便快捷的进行分析。

这两个软件的下载地址分别为:文章来源地址https://www.toymoban.com/news/detail-728107.html

  • Ghidra
  • Radare2

到了这里,关于ARM软件逆向工程入门 00的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Mybatis之逆向工程

    目录 一、逆向工程概述 二、逆向工程的实现 1、创建一个java工程 2、 第一步:mapper生成配置文件: 3、第二步:使用java类生成mapper文件:   4、第三步:拷贝生成的mapper文件到工程中指定的目录中 5、第四步Mapper接口测试 mybatis是一个ORM框架,ORM对象映射数据库,通过使用对

    2024年02月02日
    浏览(31)
  • MyBatis的逆向工程

    正向工程:先创建Java实体类,由框架负责根据实体类生成数据库表。Hibernate是支持正向工程的 逆向工程:先创建数据库表,由框架负责根据数据库表,反向生成如下资源: Java实体类 Mapper接口 Mapper映射文件 添加依赖和插件 创建MyBatis的核心配置文件 创建逆向工程的配置文件

    2024年02月09日
    浏览(24)
  • 解决xorm逆向工程问题

    问题 xorm : 无法将“xorm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。 今天在用xorm做逆向工程的时候碰到了一个普遍问题,xorm : 无法将“xorm”项识别为 cmdlet、函数、脚本文件或可运行程序的名

    2024年02月05日
    浏览(34)
  • Android 逆向工程,反编译心得

    apk的反编译是我们在Android开发中绕不开的一个坎,对于反编译这门技术,我们应该抱着学习的态度,学的越多,也越能防备别人反编译我们,这就是所谓的知己知彼吧,哈哈 Apktool ,解包和重新打包都需要它 dex-tools ,可以直接把apk中的classes.dex文件反编译为.jar文件 jd-gui ,

    2024年02月06日
    浏览(126)
  • NO.08 MyBatis创建逆向工程

    目录 1、前言 2、添加依赖和插件  3、创建MyBatis的核心配置文件  4、创建逆向工程的配置文件  5、执行MBG插件的generate目标 工程的创建有正向工程和逆向工程之分。正向工程:先创建Java实体类,由框架负责根据实体类生成数据库表,如Hibernate是支持正向工程的。 逆向工程:

    2024年02月11日
    浏览(28)
  • MyBatis --- 缓存、逆向工程、分页插件

    一级缓存是SqlSession级别的,通过同一个SqlSession查询的数据会被缓存,下次查询相同的数据,就会从缓存中直接获取,不会从数据库重新访问 使一级缓存失效的四种情况: 1、不同的SqlSession对应不同的一级缓存 2、同一个SqlSession但是查询条件不同 3、同一个SqlSession两次查询期

    2023年04月09日
    浏览(28)
  • SpringBoot项目中使用mybatis逆向工程

    mybatis逆向工程,即利用现有的数据表结构,生成对应的model实体类、dao层接口,以及对应的mapper.xml映射文件。借助mybatis逆向工程,我们无需手动去创建这些文件。 下面是使用Java代码的方式来实现逆向工程,生成文件(也可以使用插件来生成): 首先,导入需要的依赖包:

    2024年02月08日
    浏览(36)
  • AIGC:Prompt逆向工程简介及使用

    很多同学都会写爬虫。但如果想把爬虫写得好,那一定要掌握一些逆向技术,对网页的JavaScript和安卓App进行逆向,从而突破签名或者绕过反爬虫限制。最近半年,大语言模型异军突起,越来越多的公司基于GPT3.5、GPT-4或者其他大语言模型实现了各种高级功能。在使用大语言模

    2024年02月11日
    浏览(29)
  • 小程序逆向工程:这个开源的小程序逆向工具真不错,2023年亲测成功

    安全部门的大哥又双叒叕报了一个小程序的高危漏洞,他使用逆向工程破解了加密信心,用抓包修改了请求参数。又是头疼的一天… 想成为一名微信小程序的开发者,前端思路的学习和安全意识是非常有必要的,故务必掌握小程序反编译技能。 这里用到了2个工具《解密》与

    2023年04月19日
    浏览(41)
  • 【MyBatis】五、MyBatis的缓存机制与逆向工程

    MyBatis的一级缓存是默认开启的,是基于SqlSession级别的缓存,也就是说,只要是同一个sqlSession,只要执行的语句相同,则不会去数据库中进行查找,而是会从缓存中找到对应的结果。 使用了不同的sqlsession对象 同一个sqlsession对象,但查询条件不同 两次查询之间进行了增删改

    2024年02月09日
    浏览(27)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包