首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

【Android 逆向】代码调试器开发 ( ptrace 函数 | 寄存器 | 写寄存器 )

文章目录 一、寄存器 二、写寄存器 一、寄存器 ---- 调用 ptrace(PTRACE_GETREGS, m_nPid, NULL, regs) 读取进程运行时寄存器 ; 读取寄存器时 , 进程必须处于...WUNTRACED 状态 , 否则就会出错 ; 参数一设置为 PTRACE_GETREGS , 代表本次操作是读取寄存器 ; 完整代码 : int CPtrace::getRegister(REGS...PTRACE_GETREGS failed pid %d", m_nPid); return PTERR_GETREG_FAILED; } return PTERR_SUCCESS; } 二、写寄存器...---- 调用 ptrace(PTRACE_SETREGS, m_nPid, NULL, regs) 向进程运行时寄存器写入 ; 写寄存器时 , 进程必须处于 WUNTRACED 状态 , 否则就会出错...; 参数一设置为 PTRACE_SETREGS, 代表本次操作是向寄存器写入 ; int CPtrace::setRegister(const REGS* regs) { if (ptrace(PTRACE_SETREGS

42100

汇编指令-MRS()和MSR(写)指令操作CPSR寄存器和SPSR寄存器使用(1)

1.MSR和MRS指令介绍  MRS 指令:  对状态寄存器CPSR和SPSR进行操作。通过CPSR可以获得当前处理器工作状态。...SPSR寄存器可以获得进入异常前处理器状态(因为只有异常模式下有SPSR寄存器)。 MSR指令:    对状态寄存器CPSR和SPSR进行写操作。...与MRS配合使用,可以实现对CPSR或SPSR寄存器-修改-写操作,可以切换处理器模式、或者允许/禁止IRQ/FIQ中断等。...CPSR控制位、 4.使用MRS和MSR来设置2440位管理模式,实例: mrs r0,cpsr                          状态寄存器cpsr数据到r0中 bic  r0,r0...,    { r0-r12,pc }^                    //  中断返回, ^表示将spsr复制到cpsr

2.3K50

汇编调试方式之:通过串口转义输出寄存器

前两天在调试DragonOSriscv引导代码时候,想在真机上获取寄存器,就找到了这篇帖子,非常有用,就把里面的代码提取出来,在此记录。...因为在汇编里面难以对字符串进行格式化操作,因此可以考虑把寄存器转义一下,然后输出到串口,再使用一个C程序把它转义回来。...方法如下: 编码函数 首先在汇编里面定义这样一个函数: // 要打的输入到a0 __do_show_val: // todo: 为了保护寄存器,这里应当添加压栈操作, // 把函数使用到寄存器都保存一下...,就把要打印寄存器,移动到a0,然后call这个函数即可。.../show Enter:PAAAIFPDAAAAAAAA 000000003F58000F Enter: 所以我们可以看到这个寄存器就是“3F58000F“。

11710

RGMII接口调试使用VIO读取PHY寄存器

比如RGMII接口,最重要是看在哪里去做时钟和数据偏移。这时,常常需要使用VIO去读取PHY里面对应寄存器,看是否工作在正常RGMII接口时序模式。 测试场景 测试拓扑图如下 ?...经验总结:遇到RGMII接口调试时,最关键是要查看PHY芯片型号,查阅PHY芯片手册,通过MDIO读取PHY芯片寄存器,看RGMII接口上数据和时钟是否偏移2ns,再决定FPGA对应管脚约束是否进行偏移...具体测试步骤为:通过VIO配置MDIO管理模块PHY地址、寄存器地址,然后选择操作读取某一PHY芯片寄存器,结合PHY工作状态,判断该寄存器是否被正确读取。...由于执行操作时是采用先写入地址,在读取数据方式,因此只测试读操作就可以完整测试MDIO管理模块功能。以下是VIO对应调用代码。...mdc_o) ); //------------------------------------------------------------------- 通过VIO和MDIO读取相应寄存器

3.9K21

振弦采集模块配置工具VMTool生成寄存器

河北稳控科技振弦采集模块配置工具VMTool生成寄存器图片生成寄存器VMXXX 有很多按位使用寄存器, 使用 VMTool 工具可进行方便设置,当需要知道寄存器实际时,可通过以下两种方法获取...(保持【 自动读取】 复选框为非选中状态)( 1) 振弦模块与 VMTool 工具连接时在界面上进行参数设置;点击【 写入模块参数】 按钮,将当前界面显示参数写入模块;点击【 读取模块参数】 按钮,模块寄存器会自动更新到...MODBUS 显示区表格内。...( 2) 振弦模块未与 VMTool 工具连接时在界面上进行参数设置;双击【参数设置】 区标题“ 参数设置” 文字;当前界面显示参数自动更新到 MODBUS 显示区表格内;图片VMTool 扩展功能双击主界面右侧扩展工具条可实现扩展功能区显示与隐藏切换

41430

图解|Linux文件预原理

概述 本文主要阐述内核(linux-3.12)文件系统预设计和实现。...当然,这个细节对应用程序透明,应用程序可能感觉就是下次速度会更快,当然这是好事。文中我们会通过设置几个情境(顺序、随机、多线程交织)来分析预逻辑。...且是顺序),那让我们看看操作系统是如何对文件进行预。...本次预窗口起始以及大小以及预大小可根据前一次窗口计算得到,又由于本次是异步预,因此,预大小就是本次页面数量,因此将本次预第一个页面(PAGE 4)添加预标记。...,根据特定算法计算本次预大小,更新预窗口为 (12,16,16) ,新窗口如下: 对该情境简单总结下,由于三次顺序加上内核行为,文件page cache中状态当前如下图所示:

11210

值得一linux内存学习总结

: 在linux 系统中,有一个参数swappiness,这个默认为60, 可以调整为0到100之间任意。...查看zone信息知道,可以看到如下部分结果,其中free 表示该zone当前free pages, 而min, low, high 表示该zone配置,并不是当前,这些配置有一个比较专业名字叫做...cache,buffer 理解: 在古老时代,cache 就是低俗设备缓存,而buffer就是低速设备写缓存。...其实在现在linux系统kenel里面,cache和buffer意义已经发生了变化: Buffers %lu Relatively...工作中经常遇到一个问题是: linux cache 占用非常高,有如下两种参考方案: 修改kernel 参数 /proc/sys/vm/drop_caches ,从而清空cache.

40930

Linux小说「GitHub 热点速览 v.22.03」

作者:HelloGitHub-小鱼干 本周特推选取了一个画风有点意思 Linux 代码带项目 flash-linux0.11-talk,希望有趣文风能带你读完 Linux 代码。...每周当然少不了实用小工具,比如 Files 这个老牌文件管理器你可以像用浏览器一样管理你文件,还有快速构建静态站 astro 速度、性能杠杠,还有可下载一切 Hitomi-Downloader...本周特推 1.1 小说一样 Linux:flash-linux0.11-talk 本周 star 增长数:1,050+ flash-linux0.11-talk 带你 Linux 0.11 核心代码并理解背后操作系统设计思考...,按照作者宣言“你管这破玩意叫操作系统源码 — 像小说一样品读 Linux 0.11 核心代码”这是一个 Linux 代码趣项目,可以从章节(节选)感受下画风: 第 5 回 进入保护模式前最后一次折腾内存...GitHub 地址→https://github.com/sunym1993/flash-linux0.11-talk 1.2 彩色方程注释:annotated_latex_equations 本周

3.3K20

Linux下开发stm32 ③ | 寄存器工程开发

先来回顾一下前两篇 Linux下开发stm32(一) | 使用gcc-arm-none-eabi工具链编译 Linux下开发stm32(二) | 使用openocd下载与调试 前两篇我们介绍了如何创建一个空裸机工程...main文件),并编译工程生成elf文件,然后将其转为bin格式或hex格式,使用openocd下载,最后编写了一个makefile雏形,并成功点亮了一个LED~ 但是这个LED我们是通过指针直接操作寄存器地址来完成...,接下来,我们在此基础上,引入stm32头文件,其中包含了寄存器宏定义,也就是使用寄存器进行开发~ 1.创建寄存器工程 首先将上一节中创建裸机工程00-template-reg复制一份出来,改名为01...将其中空stm32f10x.h文件删掉,从固件库中复制一份,然后因为头文件中使用了core_cm3.h和system_stm32f10x.h中一些定义,包含了这两个头文件,所以将这两个文件也复制过来...,接下来开始编译~ 2.编译&下载寄存器工程 编译寄存器工程重点就在于C头文件和C源文件,启动文件编译和链接都和之前一样。

1.2K30

怎样去阅读源码,这篇文章你一

估计很多人都有这样疑惑。 我非常能理解小伙伴们痛苦,因为我也是这么痛苦着走过来。 阅读优秀源码好处想必大家都知道,学习别人优秀设计,合理抽象,简洁代码...... 总之是好处多多。...但是真的把庞大代码放到你面前,就如同一个巨大迷宫,要在其中东转西转寻出一条路来,把迷宫整个结构搞清楚,理解核心思想,真心不容易。...先去找书,找资料,了解这个软件整体设计。 都有哪些模块? 模块之间是怎么关联?怎么关联? 可能一下子理解不了,但是要建立一个整体概念,就像一个地图,防止你迷航。...,画出系统类图(不要依靠IDE给你生成), 记录下主要函数调用, 方便后续查看。 文档工作极为重要,因为代码太复杂,人大脑容量也有限,记不住所有的细节。...没有千百度上下求索,不会有瞬间顿悟和理解,衷心祝愿阅读源码朋友们都能达到这一境界。 最后一点,也是最关键一点: 要能坚持下去。

77960

汇编寄存器规则

但是,一旦函数序言(准备堆栈和寄存器函数开始部分)完成执行,这些寄存器就可能改变。生成程序集可能会覆盖存储在这些寄存器,或者在代码不再需要这些引用时丢弃这些引用。...需要注意是,该应用程序不会实时显示寄存器; 它只能在特定函数调用期间显示寄存器。...这意味着您不会看到这些寄存器有太多更改,因为在调用获取寄存器函数时它们可能具有相同(或相似)。...幸运是,只有一个指定寄存器用于返回:RAX。...了解 RAX 中返回非常重要,因为它将构成您将在后面的部分中编写调试脚本基础。 # 改变寄存器 为了巩固您对寄存器理解,您将在一个已编译应用程序中修改寄存器

2.4K50

寄存器相关知识

寄存器 寄存器是CPU中存储单元,用于存储指令和数据。寄存器具有高速存储和快速访问特点,能够提高CPU运算速度。...寄存器通常都是以他们可以保存位元数量来估量,例如一个“8位元寄存器”或“32位元寄存器”。寄存器拥有非常高读写速度,所以在寄存器之间数据传送非常快。...指针寄存器主要用于保存内存单元地址,用于间接寻址。变址寄存器主要用于保存要修改内存单元地址,用于间接寻址。 专用寄存器是专门用于特定操作寄存器,如指令指针寄存器、标志寄存器等。...指令指针寄存器用于保存下一条要执行指令地址,标志寄存器用于保存运算结果状态信息。 特殊寄存器是用于特定硬件功能寄存器,如段寄存器、控制寄存器等。...一些常用寄存器名字及其功能 寄存器功能取决于其所在硬件设备和上下文环境。 EBX基址寄存器:常用于访问内存数据,作为内存数据指针。 ECX计数器寄存器:常用于字符串和循环操作中计数。

8010
领券