已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
雨伞ATAPI系列读写硬盘被大量穿透还原的恶意代码应用从而导致ATAPI读写磁盘已经不靠谱了,所以需要一种新方法如果喜欢请关注小站 用IDA打开HAL我们发现一组新的导出call不过有操作系统限制,而且使用起来有操作系统限制(不过随着win7,win8的普及应该没啥问题了)不过也是很犀利的详情见代码:代码:typedef struct _X86BIOS_REGISTERS / invented names ULONG Eax; ULONG Ecx; ULONG Edx; ULONG Ebx; ULONG Ebp; ULONG Esi; ULONG Edi; USHORT SegDs; USHORT SegEs; X86BIOS_REGISTERS, *PX86BIOS_REGISTERS;NTHALAPI BOOLEAN x86BiosCall (ULONG, PX86BIOS_REGISTERS);NTHALAPI NTSTATUS x86BiosAllocateBuffer (ULONG *, USHORT *, USHORT *);NTHALAPI NTSTATUS x86BiosFreeBuffer (USHORT, USHORT);NTHALAPI NTSTATUS x86BiosReadMemory (USHORT, USHORT, PVOID, ULONG);NTHALAPI NTSTATUS x86BiosWriteMemory (USHORT, USHORT, PVOID, ULONG);#pragma pack(1)typedef struct _X86DISK_PACKET_ USHORT Size; USHORT Sectors; USHORT Addr; USHORT Segment; ULONG64 StartSectorNumber; ULONG64 L_BufferAddr;X86DISK_PACKET,*PX86DISK_PACKET;#pragma pack()BOOL ReadDiskByInt13Ext(ULONG64 sector,USHORT numbers,PVOID *OutBuffer,UINT *nSize) ULONG cb = 0; BOOL bRet=FALSE; USHORT bufSeg=0,bufAddr=0; USHORT dpSeg=0,dpAddr=0; BOOL bBuf=FALSE; BOOL bDp =FALSE; NTSTATUS ns; X86DISK_PACKET dp; X86BIOS_REGISTERS regs; _try if (!OutBuffer|!nSize) _leave; cb = numbers*512;/默认512一个sec这样看起来还行,其实应该好好计算的 ns = x86BiosAllocateBuffer(&cb,&bufSeg,&bufAddr); if (!NT_SUCCESS(ns) _leave; bBuf =TRUE; cb = sizeof(X86DISK_PACKET); ns = x86BiosAllocateBuffer(&cb,&dpSeg,&dpAddr); if (!NT_SUCCESS(ns) _leave; bDp =TRUE; dp.Size = 0x10; dp.Sectors = numbers; dp.StartSectorNumber = sector; dp.Segment = bufSeg; dp.Addr = bufAddr; dp.L_BufferAddr=0; ns = x86BiosWriteMemory(dpSeg,dpAddr,&dp,sizeof(X86DISK_PACKET); if(!NT_SUCCESS(ns) _leave; RtlZeroMemory(®s,sizeof(X86BIOS_REGISTERS); regs.Eax = 0x4200;/AH=0x42 regs.Edx = 0x0080;/DL=0x80 /第一个磁盘 regs.SegDs = dpSeg; regs.Esi=dpAddr; if (x86BiosCall(0x13,®s) UINT iSize = numbers*512; PVOID Buffer = ExAllocatePool(NonPagedPool,iSize); if (Buffer) ns = x86BiosReadMemory(bufSeg,bufAddr,Buffer,iSize); if (NT_SUCCESS(ns) *OutBuffer = Buffer; *nSize=iSize; bRet =TRUE; else ExFreePool(Buffer); _except(EXCEPTION_EXECUTE_HANDLER) DbgPrint(Exception From Read); if (bBuf) x86BiosFreeBuffer(bufSeg,bufAddr); if (bDp) x86BiosFreeBuffer(dpSeg,dpAddr); return bRet;BOOL WriteDiskInt13Ext(ULONG64 Sector,PVOID InBuffer,INT nInBuffSize) ULONG cb = 0; BOOL bRet=FALSE; USHORT bufSeg=0,bufAddr=0; USHORT dpSeg=0,dpAddr=0; BOOL bBuf=FALSE; BOOL bDp =FALSE; NTSTATUS ns; X86DISK_PACKET dp; X86BIOS_REGISTERS regs; USHORT numbers =0; _try if (!InBuffer|!nInBuffSize) _leave; numbers = nInBuffSize/512; cb = nInBuffSize;/默认512一个sec这样看起来还行,其实应该好好计算的 ns = x86BiosAllocateBuffer(&cb,&bufSeg,&bufAddr); if (!NT_SUCCESS(ns) _leave; bBuf =TRUE; cb = sizeof(X86DISK_PACKET); ns = x86BiosAllocateBuffer(&cb,&dpSeg,&dpAddr); if (!NT_SUCCESS(ns) _leave; bDp =TRUE; dp.Size = 0x10; dp.Sectors = numbers; dp.StartSectorNumber = Sector; dp.Segment = bufSeg; dp.Addr = bufAddr; dp.L_BufferAddr=0; ns = x86BiosWriteMemory(bufSeg,bufAddr,InBuffer,nInBuffSize); ns = x86BiosWriteMemory(dpSeg,dpAddr,&dp,sizeof(X86DISK_PACKET); if(!NT_SUCCESS(ns) _leave; RtlZeroMemory(®s,sizeof(X86BIOS_REGISTERS); regs.Eax = 0x4300;/AH=0x42 regs.Edx = 0x0080;/DL=0x80 /第一个磁盘 regs.SegDs = dpSeg; regs.Esi=dpAddr; if (x86BiosCall(0x13,®s) bRet =TRUE; _except(EXCEPTION_EXECUTE_HANDLER) DbgPrint(Exception From Read); if (bBuf) x86BiosFreeBuffer(bufSeg,bufAddr); if (bDp) x86BiosFreeBuffer(dpSeg,dpAddr); return bRet;注意部分系统下要注册一个KeRegisterBugCheckCallBack然后通过自己调用BugCheck在自己的CallBack里才能随心所欲的使用这个代码囧最后,这个代码只是个POC真正想要可用于各位的伟大事业必须继续努力修改和做很多处理,亲(伸手党必然被砍手)求捐助,求赞助,求投资,有意者欢迎联系QQ:86879759欲购买 AntiGameProtect或UltraGameProt
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 全员线上安全培训通知模板课件
- 全员安全培训内容记录课件
- 北辰职业规划发展指南
- 职业生涯规划与发展指南
- 食品博士女生就业指南
- 职业规划与路径设计
- 全体教职工安全培训课件
- 车辆安全用品清单讲解
- 人工智能利弊深度剖析报告
- 光电效应课件介绍
- 2025山东省人民检察院公开招聘聘用制书记员(40名)备考考试题库及答案解析
- 2026届新高考历史冲刺备考复习第一次世界大战与战后国际秩序
- 消防设施操作员基础知识
- 2025天津大学管理岗位集中招聘15人参考笔试题库及答案解析
- T-CAQ 10201-2024《质量管理小组活动准则》解读与实践指南
- 2025年江苏省《保安员资格证考试》考试题库含答案
- 发展心理学-终结性考核-国开(GS)-参考资料
- 员工喝酒合同协议书
- 2025陕西三秦环保科技股份有限公司经理层成员市场化选聘工作5人考试笔试参考题库附答案解析
- 白蛋白肽的课件
- 棉花生理学课件
评论
0/150
提交评论