原文链接:抢先DriverStudio夺取机器控制权(下篇)

上篇仅仅说到如何抢先DriverStudio,并在结尾留给大家一个遐想。现在我进一步拓展这个遐想,从而给大家更多的遐想。: ) 那么现在我要给这个驱动增加新的功能,不但抢先DriverStudio启动,而且给用户显示几行提示,并等待用户的输入,如果用户输入B 键则发生蓝屏,如果用户按任意其他键则继续往下执行,SoDriverStudio可以正常执行下去。

要完成这个功能必须解决两个问题:

0 如何在系统引导时显示字符串;

1 如何捕获用户输入并延时等待。

那么从哪入手呢?我首先想到直接写Video Buffer和直接捕获键盘寄存器,但是这个方法可行吗?我们不妨看一下DriverStudio的bootcfg.sys 是如何做的。

照例用IDA载入bootcfg.sys,按照DriverStudio初始化显示的字符串来到驱动的DriverEntry,如图0

图0

通过查找字符串的引用很快就找到对应的指令点,全文只有一个引用,如图1所示:

图1

为了确认这一点,我将地址0x107dd - 0x107e6中的指令全部nop掉,

图2

这时的确原先应该显示"Press ESC ..."这段话的地方没有显示,而是直接跳到Config 对话框那里去了。既然找对了地方下一步就好办了,通过进一步反汇编bootcfg.sys的代码片断,印证了我先前的想法!下面简单说说DriverStudio是如何做的:

a. 使用 MmMapIoSpace 完成物理地址到虚拟地址的映射,因为内核已经进入保护模式,并且开了分页。要想读写物理地址必须做这样的映射(本猫的《Windows 核心编程研究系列之二:读取指定物理内存地址中的内容 》一篇中有更为详细的说明)。该函数原形如下:

 PVOID
MmMapIoSpace(
IN PHYSICAL_ADDRESS PhysicalAddress,
IN ULONG NumberOfBytes,
IN MEMORY_CACHING_TYPE CacheType

参数含义都比较明显,其中CacheType选择NoCache类型。

b. 使用类似于bios中断字符显示的规则,一个字符占一个word,低位为字符的ascii码,高位为显示属性。我这里显示闪烁的红色字体所以属性为 84h。与bios中断不同的是,我们是直接写视频缓冲,其物理地址为 0b8000h 。我写了一个显示函数,包含两个参数:第一个是字符串地址,第二个是显示的位置。为了美观,我将2行字符串显示在屏幕的倒数最后两行上:

 Screen_W equ 50h
Screen_H equ 19h ;1ch
Show_Pos_Line0 equ (Screen_W * (Screen_H - ) + ) *
Show_Pos_Line1 equ (Screen_W * (Screen_H - ) + ) * 函数内容如下: ;*************************************************************************
_DisplayString proc _lpstr,_pos
local pa:qword
local lpvmem:dword ;mov dword ptr [pa+1],Video_Addr
;mov dword ptr [pa+5],0 mov dword ptr [pa],Video_Addr
mov dword ptr [pa+], push ;MmNonCached
push 8000h ;NumberOfBytes
;push dword ptr [pa+5]
;push dword ptr [pa+1]
push dword ptr [pa+]
push dword ptr [pa]
call MmMapIoSpace mov lpvmem,eax
mov esi,_lpstr
mov edi,lpvmem
add edi,_pos
mov bh,84h ;char show_attribute .while TRUE
.if byte ptr [esi] !=
mov bl,byte ptr [esi]
mov word ptr [edi],bx
inc esi
inc edi
inc edi
.else
.break
.endif
.endw invoke MmUnmapIoSpace,lpvmem,8000h ret _DisplayString endp
最后不要忘了用MmUnmapIoSpace取消映射。

c. 为了达到延时的效果调用ntoskrnl.exe中的apiKeDelayExecutionThread,其原形如下:

 NTSTATUS
KeDelayExecutionThread(
IN KPROCESSOR_MODE WaitMode,
IN BOOLEAN Alertable,
IN PLARGE_INTEGER Interval
);

其中 WaitMode选择KernelMode,将可报警置为FALSE.值得注意的是第3个参数Interval,这个参数说明如下:

Interval

Specifies the absolute or relative time, in units of 100 nanoseconds, for which the wait is to occur. A negative value indicates relative time. Absolute expiration times track any changes in system time; relative expiration times are not affected by system time changes.

我们最好是用相对时间的延时方式,这就需要写成负数的形式将前导位全部置1。为了达到捕获键盘输入,需要直接访问IO端口64h和60h,这在ring0种都不成问题 。我同样写了一个子函数方便使用,代码如下:

 ;*************************************************************************
_WaitForInput proc
local al_tmp:byte
local interval:LARGE_INTEGER
local turnsNow:dword mov dword ptr [interval],0ffffe000h
mov dword ptr [interval+],0ffffffffh mov turnsNow, .while TRUE
.if turnsNow == Turns
.break
.else
inc turnsNow in al,64h
test al,
jz Delay in al,60h
mov al_tmp,al
movzx eax,al_tmp
cmp eax,
jz ExitWhile cmp eax,1eh
jz ExitWhile cmp eax,0b0h
jz ExitWhile cmp eax,1ch
jnz Delay ExitWhile:
.break Delay:
invoke KeDelayExecutionThread,,,addr interval
.endif
.endw xor eax,eax
mov al,al_tmp
ret _WaitForInput endp ;************************************************************************* d. 剩下来做的事就是在Main中判断用户输入的键码: invoke _DisplayString,addr szhopysay,Show_Pos_Line0
invoke _DisplayString,addr szchoose,Show_Pos_Line1
invoke _WaitForInput .if al == 01h
;do nothing
.elseif al == 0b0h
invoke _TryBS
.else
;do nothing
.endif

运行的效果如图3所示:

图3

蓝屏的代码就不给出了,因为相信每个人都能写出不同的花样来。写续篇的原因是因为正好看到驱网(www.driverdevelop.com)的一篇逆向的文章,想现学现卖一番,呵呵。暂时到这里吧(以前预告的第3篇文章因为要结合VB的界面而且又有了新的想法,所以还要等一段时间,呼呼),准备去看女足啦,哇咔咔.......(无语了,这不是我...不是我....不是我 ... ...)

侯佩|hopy

写于2007.09.18

[原创]抢先DriverStudio夺取机器控制权(下篇)的更多相关文章

  1. [原创]抢先DriverStudio夺取机器控制权(上篇)

    原文链接:抢先DriverStudio夺取机器控制权 废话不谈,言归正传!大家都知道,装了DriverStudio软件(我使用的是v3.2版)的系统在启动时会显示其配置画面,(如图0所示) 图 0 这 ...

  2. 【百度SEO优化】如何让蜘蛛爬行你的网站

    大家都知道,现在做网站简单,但是推广就比较困难了,可能一些商家引入投资,直接烧钱做广告来推广,但是对于一些小站长,是没有那么多资金的.因此我们就要懂得一些SEO优化的知识了,简单介绍一下: 怎么让百度 ...

  3. Hacker(25)----病毒攻防之认识病毒

    Internet中,计算机病毒是威胁计算机安全的程序.对于计算机病毒,用户不仅需要掌握其基础知识,还要认识常见的病毒及简单病毒制作方法.无论病毒基础还是制作简单病毒,用户需要掌握防御病毒的有效措施和专 ...

  4. Hacker(十一)----黑客常用入侵方法

    Internet中,为了防止黑客入侵自己的电脑,就必须了解黑客入侵目标计算机的常用方法.黑客常用的入侵方法有数据驱动攻击.系统文件非法利用.伪造信息攻击.远端操纵等. 一.数据驱动攻击 数据驱动攻击是 ...

  5. 用Delphi实现Windows的鼠标钩子函数

    Delphi是基于PASCAL语言的Windows编程工具,功能十分强大.然而在Delphi的帮助文件中,对Windows API函数的说明沿袭了 VC 的格式,和VC一样,对很多API函数的用法没有 ...

  6. (转) 深度强化学习综述:从AlphaGo背后的力量到学习资源分享(附论文)

    本文转自:http://mp.weixin.qq.com/s/aAHbybdbs_GtY8OyU6h5WA 专题 | 深度强化学习综述:从AlphaGo背后的力量到学习资源分享(附论文) 原创 201 ...

  7. Linux内核分析方法谈

    本文来自 http://blog.csdn.net/ouyang_linux007/article/details/7422346 Linux的最大的好处之一就是它的源码公开.同时,公开的核心源码也吸 ...

  8. [原创]Oracle 12c 抢先安装手迹

    [前言] Oracle 12c 终于投放市场了,唉,等了很久了.据官方说这是一个为云计算平台量身定做的版本....且不管真的假的,先让我们把它装上再说. 注:笔者在安装的过程中发现12c的安装过程,较 ...

  9. [原创] zabbix学习之旅七:如何远程操作被监控机器

    虽然我们已经创建了一个报警系统,但在实际场景中,运维人员从得到报警到实际解决问题有一定的时差,若业务系统没有做高可用,那业务不得不中断,对于某些要求严格的企业级环境,这是不可容忍的,那有没有方法能让z ...

随机推荐

  1. GitBook是一个命令行工具(Node.js库),我们可以借用该工具使用Github/Git和Markdown来制作精美的图书,但它并不是一本关于Git的教程哟。

    GitBook是一个命令行工具(Node.js库),我们可以借用该工具使用Github/Git和Markdown来制作精美的图书,但它并不是一本关于Git的教程哟. 支持输出多种格式 GitBook支 ...

  2. pagination jquery最简单的分页【无刷新和刷新都通用】

    参数说明 参数名 描述 参数值 maxentries 总条目数                           必选参数,整数 items_per_page 每页显示的条目数            ...

  3. javascript 压缩空格代码演示

          压缩空格代码演示 主要是讲解 压缩一个字符串两段空格          例如:javascript函数里的空格不论是这样     var s = "Hello World     ...

  4. 【学习笔记03】Javascript数组学习

    数组定义的方法一: var Myarr=new Array(); //先声明一维 for(var i=0;i<2;i++){ //一维长度2 Myarr[i]=new Array(); //再声 ...

  5. Linux08--Shell程序设计03 shell script

    第一个Shell脚本——HelloWorld [root@localhost ~]# vi sh01.sh #!/bin/bash #!表明使用哪种shell # this is my first s ...

  6. poj1484---判断保险丝是否烧断

    题目输入要求: 2 2 10 //设备数n  接下来的操作数m   保险丝能承受最大电流c5 //电器1的电流7 //2的电流1 //反转开关12 //反转开关2 思路:设置一个flag数组,记得每次 ...

  7. Linux Makefile文件编写详细步骤与实践

    Linux Makefile文件编写详细步骤与实践 1.makefile概述 Windows环境下IDE会帮你完成makefile文件的编写,但在UNIX环境下你就必须自己写makefile了,会不会 ...

  8. c++犯过的严重错误

    1.if(num == 0)写成了if(num = 0)导致软件运行一直崩溃且找不到原因,浪费了很大的代价,以后我写这种语法的时候一直写if(0 == num) 2.if (sting.find(&q ...

  9. Unity CCTween UGUI 动画插件

    在这简单的介绍一下 CCTween 动画插件的使用 因为GIF 制作软件不太好(网上随便下载的)所以导致效果不太好,有时间我重新制作一下 这是一下简单的效果 下面介绍怎么使用 首先 先下载 CCTwe ...

  10. C++ STL 一般总结

    以下内容来源网上 经过整合而成(转载) 一.一般介绍 STL(Standard Template Library),即标准模板库,是一个具有工业强度的,高效的C++程序库.它被容纳于C++标准程序库( ...