IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 嵌入式 -> alarm函数在pwn中的一些利用 -> 正文阅读

[嵌入式]alarm函数在pwn中的一些利用

文本整理了alarm函数在pwn中的一些应用

利用alarm函数获取syscall

在一些题目里,可以利用alarm直接获取到syscall的地址
找个libc文件,然后反汇编看一下alarm的汇编代码

/ (fcn) sym.alarm 33
|   sym.alarm ();
|           ; XREFS(26)
|           0x000cc200      b825000000     mov eax, 0x25               ; '%'
|           0x000cc205      0f05           syscall										 ; syscall = sym.alarm + 0x5
|           0x000cc207      483d01f0ffff   cmp rax, -0xfff
|       ,=< 0x000cc20d      7301           jae 0xcc210
|       |   0x000cc20f      c3             ret
|       |   ; CODE XREF from sym.alarm @ 0xcc20d
|       `-> 0x000cc210      488b0d617c2f.  mov rcx, qword [0x003c3e78] ; [0x3c3e78:8]=0
|           0x000cc217      f7d8           neg eax
|           0x000cc219      648901         mov dword fs:[rcx], eax
|           0x000cc21c      4883c8ff       or rax, 0xffffffffffffffff
\           0x000cc220      c3             ret

? 发现alarm中就有一个syscall指令,而syscall和alarm的偏移地址是0x000cc205 - 0x000cc200 = 0x5。因此我们可以得到syscall的实际地址 = alarm的实际地址 + 0x5

利用题目可以参考XCTF-008-Recho

利用alarm给eax赋值

alarm()用来设置信号SIGALRM 在经过参数seconds 指定的秒数后传送给目前的进程. 如果参数seconds 为0, 则之前设置的闹钟会被取消, 并将剩下的时间返回。利用这个特性,我们可以给eax赋值,例如第一次调用时alarm(10),隔了五秒后调用alarm(0)时,就会返回5,即给eax赋值5。之后可以利用int80的gadgets调用fopen函数。

利用的题目可以参考2016 CTF warmup

  嵌入式 最新文章
基于高精度单片机开发红外测温仪方案
89C51单片机与DAC0832
基于51单片机宠物自动投料喂食器控制系统仿
《痞子衡嵌入式半月刊》 第 68 期
多思计组实验实验七 简单模型机实验
CSC7720
启明智显分享| ESP32学习笔记参考--PWM(脉冲
STM32初探
STM32 总结
【STM32】CubeMX例程四---定时器中断(附工
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 21:07:25  更:2022-03-21 21:08:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 6:36:40-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码