《ARM汇编与逆向工程 蓝狐卷 基础知识》

  大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的知识进行总结与归纳,不仅形成深入且独到的理解,而且能够帮助新手快速入门。

  本文主要介绍了《ARM汇编与逆向工程 蓝狐卷 基础知识》,希望能对学习汇编和逆向的的同学们有所帮助。

文章目录

  • 1. 前言
  • 2. 内容简介
  • 3. 作者简介
  • 4. 译者简介
  • 5. 目录

1. 前言

  与传统的CISC(Complex Instruction Set Computer,复杂指令集计算机)架构相比,Arm架构的指令集更加简洁明了,指令执行效率更高,能够在更低的功耗下完成同样的计算任务,因此在低功耗、嵌入式等领域具有广泛的应用。同时,由于ARM公司采用了开放授权的商业模式,许多芯片厂商都可以使用Arm架构进行设计和生产,因此Arm架构在移动设备、智能家居、工控等领域也得到了广泛应用。此外,Arm架构还具有可扩展性和兼容性,可以支持从单核到多核的不同规模和复杂度的处理器设计,并且可以运行各种不同的操作系统,如Linux、Android等。

  随着Arm架构的广泛应用,相关安全事件层出不穷,各类Arm设备的安全性亟待提升,设备逆向分析工作需要进一步深入,以了解设备内部实现方式和运行机制,发现潜在的安全漏洞和缺陷,从而加强设备的安全性。此外,分析黑客的攻击载荷和恶意软件,了解攻击者的攻击手段和目的,可以帮助我们及时发现并阻止攻击,从而保护系统和数据。因此,熟练掌握Arm逆向分析技术十分重要。

2. 内容简介

  《ARM汇编与逆向工程 蓝狐卷 基础知识》分为12章,从基础的字节和字符编码到操作系统原理、Arm架构和指令,再到静态和动态分析、逆向工程实践,循序渐进地讲解Arm逆向工程的方方面面,而且每一章都包含许多实际的案例,可以帮助读者更好地理解和掌握相关知识。同时,书中也介绍了许多工具和技术,如IDA Pro、Radare2、Binary Ninja、Ghidra、GDB等,这些工具在实际逆向工程中都有着广泛的应用。此外,本书还介绍了Arm环境的构建和使用,可以帮助读者快速搭建自己的Arm环境。

  总的来说,本书对逆向工程的各个方面都进行了较为全面的介绍,对于想要学习Arm逆向工程的读者来说是一本很好的入门书籍,可以帮助读者建立起Arm逆向分析技术的知识体系。同时,由于逆向工程领域的不断更新和变化,读者也需要不断学习和探索,才能在实践中获得更多的经验和技能。需要注意的是,在学习逆向工程时要遵守相关法律法规和道德规范,不能侵犯他人的知识产权和隐私权。

3. 作者简介

Maria Markstedter是全球著名的ARM逆向工程专家,2018年入选“福布斯30岁以下科技精英”榜单,2020年获得“福布斯网络安全年度人物”奖。

4. 译者简介

ChaMd5安全团队

国内老牌CTF战队,成立于2016年,旨在维护企业安全和培养安全人才,为各大企业提供安全服务,著有《CTF实战:技术、解题与进阶》

5. 目录

译者序前言致谢作者简介第一部分 Arm汇编内部机制第1章 逆向工程简介    21.1 汇编简介    21.1.1 位和字节    21.1.2 字符编码    31.1.3 机器码和汇编    41.1.4 汇编    61.2 高级语言    111.3 反汇编    121.4 反编译    13第2章 ELF文件格式的内部结构    152.1 程序结构    152.2 高级语言与低级语言    162.3 编译过程    172.3.1 不同架构的交叉编译    182.3.2 汇编和链接     202.4 ELF文件概述    222.5 ELF文件头    232.5.1 ELF文件头信息字段    242.5.2 目标平台字段    242.5.3 程序入口点字段    252.5.4 表位置字段    252.6 ELF程序头     262.6.1 PHDR 程序头    272.6.2 INTERP程序头    272.6.3 LOAD程序头    272.6.4 DYNAMIC程序头    282.6.5 NOTE程序头    282.6.6 TLS程序头    292.6.7 GNU\_EH\_FRAME程序头    292.6.8 GNU_STACK程序头    292.6.9 GNU_RELRO程序头    312.7 ELF节头    332.7.1 ELF meta节    352.7.2 主要的ELF节    362.7.3 ELF符号    372.8 .dynamic节和动态加载    402.8.1 依赖项加载    412.8.2 程序重定位    412.8.3 ELF程序的初始化和终止节    442.9 线程本地存储    472.9.1 local-exec TLS访问模型    502.9.2 initial-exec TLS访问模型    502.9.3 general-dynamic TLS访问模型    512.9.4 local-dynamic TLS访问模型    52第3章 操作系统基本原理    543.1 操作系统架构概述    543.1.1 用户模式与内核模式    543.1.2 进程    553.1.3 系统调用    563.1.4 线程    623.2 进程内存管理    633.2.1 内存页    643.2.2 内存保护    653.2.3 匿名内存和内存映射    653.2.4 地址空间布局随机化    693.2.5 栈的实现    713.2.6 共享内存    72第4章 Arm架构    744.1 架构和配置文件    744.2 Armv8-A架构    754.2.1 异常级别    764.2.2 Armv8-A执行状态    814.3 AArch64执行状态    824.3.1 A64指令集    824.3.2 AArch64寄存器    834.3.3 PSTATE    894.4 AArch32执行状态    904.4.1 A32和T32指令集    914.4.2 AArch32寄存器    944.4.3 当前程序状态寄存器    964.4.4 执行状态寄存器    99第5章 数据处理指令    1035.1 移位和循环移位    1055.1.1 逻辑左移    1055.1.2 逻辑右移    1065.1.3 算术右移    1065.1.4 循环右移    1075.1.5 带扩展的循环右移    1075.1.6 指令形式    1075.1.7 位域操作    1125.2 逻辑运算    1205.2.1 位与    1215.2.2 位或    1225.2.3 位异或    1245.3 算术运算    1255.3.1 加法和减法    1255.3.2 比较    1275.4 乘法运算    1305.4.1 A64中的乘法运算    1305.4.2 A32/T32中的乘法运算    1315.5 除法运算    1455.6 移动操作    1465.6.1 移动常量立即数    1465.6.2 移动寄存器    1495.6.3 移动取反    150第6章 内存访问指令    1516.1 指令概述    1516.2 寻址模式和偏移形式    1526.2.1 偏移寻址    1556.2.2 前索引寻址    1626.2.3 后索引寻址    1646.2.4 字面值寻址    1666.3 加载和存储指令    1726.3.1 加载和存储字或双字    1726.3.2 加载和存储半字或字节    1746.3.3 A32多重加载和存储    1776.3.4 A64加载和存储对    186第7章 条件执行    1897.1 条件执行概述    1897.2 条件码    1907.2.1 NZCV条件标志    1907.2.2 条件码    1937.3 条件指令    1947.4 标志设置指令    1977.4.1 指令的S后缀    1977.4.2 测试和比较指令    2017.5 条件选择指令    2077.6 条件比较指令    2097.6.1 使用CCMP的布尔与条件    2107.6.2 使用CCMP的布尔或条件    212第8章 控制流    2158.1 分支指令    2158.1.1 条件分支和循环    2168.1.2 测试和比较分支    2198.1.3 表分支    2208.1.4 分支和切换    2228.1.5 子程序分支    2258.2 函数和子程序    2278.2.1 程序调用标准    2278.2.2 易失性和非易失性寄存器    2288.2.3 参数和返回值    2298.2.4 传递较大值    2308.2.5 叶子函数和非叶子函数    233第二部分 逆向工程第9章 Arm环境    2409.1 Arm板    2419.2 使用QEMU模拟虚拟环境    2429.2.1 QEMU用户模式模拟    2439.2.2 QEMU系统模式模拟    246第10章 静态分析    25210.1 静态分析工具    25210.1.1 命令行工具    25310.1.2 反汇编器和反编译器    25310.1.3 Binary Ninja Cloud    25410.2 引用调用示例    25810.3 控制流分析    26310.3.1 main函数    26410.3.2 子程序    26510.3.3 转换为字符    26910.3.4 if语句    27010.3.5 商除法    27210.3.6 for循环    27310.4 算法分析    275第11章 动态分析    28811.1 命令行调试    28911.1.1 GDB命令    28911.1.2 GDB多用户模式    29011.1.3 GDB扩展:GEF     29211.1.4 Radare2     30311.2 远程调试    30811.2.1 Radare2    30911.2.2 IDA Pro    30911.3 调试内存损坏    31111.4 使用GDB调试进程    319第12章 逆向arm64架构的macOS恶意软件    32512.1 背景    32612.1.1 macOS arm64二进制文件    32612.1.2 macOS Hello World(arm64)    32912.2 寻找恶意arm64二进制文件    33112.3 分析arm64恶意软件    33712.3.1 反分析技术    33812.3.2 反调试逻辑(通过ptrace)    33912.3.3 反调试逻辑(通过sysctl)    34212.3.4 反虚拟机逻辑(通过SIP状态和VM遗留物检测)    34612.4 总结    351

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/543382.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker的常用指令

docker的常用指令 从docker镜像仓库,搜索所有和mysql有关的镜像 docker search mysql 从docker仓库拉取mysql docker pull mysql这里的mysql是指使用search搜索出来的所有容器的NAME 如果和我一样遇到以下问题: 我可以登录阿里云的官网,找…

[嵌入式系统-39]:龙芯1B 开发学习套件 -10-PMON启动过程Sstart.S详解

目录 一、龙芯向量表与启动程序的入口(复位向量) 1.1 复位向量: 1.2 代码执行流程 1.3 计算机的南桥 VS 北桥 二、PMON代码执行流程 三、Start.S详解 3.1 CPU初始化时所需要的宏定义 (1)与CPU相关的一些宏定义…

【商业|数据科学主题会议推荐】2024年商业分析与数据科学国际学术会议(ICBADS 2024)

【商业|数据科学主题会议推荐】2024年商业分析与数据科学国际学术会议(ICBADS 2024) 征稿主题 (以下主题包括但不限于) 多媒体决策 决策理论与决策科学 数字市场设计与运营 降维 电子商务 道德决策 财务分析 群体决策与软件 医疗保…

19、python:文件概述

一、文件的类型 (1).文本文件 一般由单一特定编码的字符组成,如Unicode编码,内容容易统一展示和阅读,由于文本文件存在编码,可以看作是存储在磁盘上的长字符串,如一个txt格式的文本文件。 &am…

如何在Windows11上通过PHPStudy小皮面板快速大家MySQL环境

首先,下载小皮面板:https://www.xp.cn/ 点Windows版本: 开始下载: 或者直接从百度网盘下载: 链接:https://pan.baidu.com/s/1gcaiK54yW7DcrYld22V06A 提取码:4oj8 –来自百度网盘超级会员V9…

地理数据 vs. 3D数据

在表示我们周围的物理世界时,地理空间数据和 3D 建筑数据是两个最常见的选择。 他们在各个行业和项目中发挥着至关重要的作用。 从构建数字孪生到可视化城市景观和创建沉浸式应用程序。 尽管地理空间和 3D 建筑数据有相似之处,但它们不可互换。 虽然地…

ideaSSM失物招领管理系统网页模式开发mysql数据库web结构java编程计算机网页源码maven项目

一、源码特点 idea ssm 失物招领管理系统是一套完善的完整信息管理系统,结合SSM框架完成本系统SpringMVC spring mybatis ,对理解JSP java编程开发语言有帮助系统采用SSM框架(MVC模式开发),系统具有完整的源代码和数…

【海贼王的数据航海】排序——直接选择排序|堆排序

目录 1 -> 选择排序 1.1 -> 基本思想 1.2 -> 直接选择排序 1.2.1 -> 代码实现 1.3 -> 堆排序 1.3.1 -> 代码实现 1 -> 选择排序 1.1 -> 基本思想 每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置&…

Cesium 获取 3dtileset的包围盒各顶点坐标

Cesium 获取 3dtileset的包围盒各顶点坐标 /*** 获取 3dtileset的包围盒各顶点坐标, z 方向取高度最低的位置* param {*} tileset* param {*} options* returns* ref https://blog.csdn.net/STANDBYF/article/details/135012273* ref https://community.cesium.com/t/accurate-…

Java学习笔记------常用API

Math类 常用方法: 1. publicb static int abs(int a) 获取参数绝对值 2. publicb static double ceil(double a) 向上取整 3. publicb static floor(double a) 向下取整 4.public static int round(float a) 四舍五入 5. publicb static int max…

Android 地图SDK 绘制点 删除 指定

问题 Android 地图SDK 删除指定绘制点 详细问题 笔者进行Android 项目开发&#xff0c;对于已标记的绘制点&#xff0c;提供撤回按钮&#xff0c;即删除绘制点&#xff0c;如何实现。 解决方案 新增绘制点 private List<Marker> markerList new ArrayList<>…

element-plus 完成下拉切换功能

项目场景&#xff1a; element-plus element-plus 完成下拉切换功能&#xff0c;选用了popover 组件去进行样式修改&#xff0c;本来大概是要实现下面这样的样式效果&#xff0c;没想到调整的时候&#xff0c;这个选择的高亮模块总是超出。 实现效果&#xff1a; 解决方案&am…