罗云彬VxD教程--DeviceIoControl接口

2016-02-19 13:25 7 1 收藏

图老师小编精心整理的罗云彬VxD教程--DeviceIoControl接口希望大家喜欢,觉得好的亲们记得收藏起来哦!您的支持就是小编更新的动力~

【 tulaoshi.com - 编程语言 】


  在这一节中我们将要关于学习动态VXD,非凡是如何创建,加载和使用。
  
  VxD接口
  VxD总共提供了4种接口。
  
  l         VxD services                    VxD服务
  
  l         V86 Interface                   V86接口
  
  l         Protected-mode (PM) Interface   保护模式接口
  
  l         Win32 DeviceIoControl Interface Win32设备输入输出控制接口
  
  我们已经知道了VxD服务,V86和保护模式接口是由V86和保护模式程序调用的。因为V86和保护模式程序是16位的,我们不能在Win32应用程序中使用那两种接口。在Windows 95中,微软给Win32应用程序加了另外一个接口所以Win32应用程序可以调用VxD的服务:DeviceIoControl接口(设备输入输出控制接口)
  
  DeviceIoControl接口
  简单的说,DeviceIoControl接口是一种为Win32程序预备的调用VxD内部函数的方法。不要混淆DeviceIoControl接口调用函数和用VxD服务调用函数,这两种方法是不一样的。比如说,DeviceIoControl function1 也许和Vxd service1是不一样的。你应给把DeviceIoControl函数作为一种只为Win32应用程序提供的单独的函数。
  
  在Win32程序方面:
  首先用CreateFile来打开/加载一个VxD。假如调用成功的话,VxD将会创建/加再到内存中并且CreateFile把VxD的句柄返回到eax中。
  
  接着你调用DeviceIoControlAPI函数来选择要运行的函数。DeviceIoControl函数遵循下面的语法:
  
  DeviceIoControl PROTO  hDevice:DWord,
  
                                          dwIoControlCode:DWORD,
  
                                          lpInBuffer:DWORD,
  
                                          nInBufferSize:DWORD,
  
                                          lpOutBuffer:DWORD,
  
                                          nOutBufferSize:DWORD,
  
  
                                          lpBytesReturned:DWORD,
  
                                          lpOverlapped:DWORD
  
  l         hDevice 是从CreateFile返回的VxD句柄。
  
  l         dwIoControlCode是用来制定VxD将要进行的操作。你应该在你要选用那种操作之前得到可能的dwIoControlCode值得列表。
  
  l         lpInBuffer是包含了VxD完成dwIoControlCode所制定操作的数据的缓冲区地址。假如这个操作不需要数据,你可以传为NULL。
  
  l         nInBufferSize是由lpInBuffer所指向的缓冲区的地址的大小(byte)。
  
  l         lpOutBuffer是VxD程序在操作成功之后要将输出数据输出到的缓冲区。假如这个操作没有任何返回值,这个值可以为NULL。
  
  l         nOutBufferSize是lpOutBuffer所指向的缓冲区的大小(byte)。
  
  l         lpBytesReturned是一个dword型变量的地址。这个变量用来接收VxD在lpOutBuffer中写入数据的大小。
  
  l         假如你想要把操作设成异步的,lpOverlapped是一个OVERLAPPED结构的指针。假如你要一直等直到操作完成,这个值为NULL。
  
  在VxD方面:
  VxD程序必须处理w32_deviceIoControl消息。当VxD收到w32_deviceIoControl消息,它的寄存器是如下值:
  
  l         ebx 是VM的句柄。
  
  l         esi 是指向DIOCParams结构的指针。DIOCParams包含了从win32程序传送的信息。
  
  DIOCParams是按照如下定义的:
  
  DIOCParams STRUC
  
      Internal1          DD ?
  
      VMHandle           DD ?
  
      Internal2          DD ?
  
      dwIoControlCode    DD ?
  
      lpvInBuffer        DD ?
  
      cbInBuffer         DD ?
  
      lpvOutBuffer       DD ?
  
      cbOutBuffer        DD ?
  
      lpcbBytesReturned  DD ?
  
  
      lpoOverlapped      DD ?
  
      hDevice            DD ?
  
      tagProcess         DD ?
  
  DIOCParams ENDS
  
  l         Internal1       是指向Win32应用应用程序用户寄存器结构的指针。
  
  l         VMHandle        虚拟机句柄
  
  l         Internal2       是指向设备描述块(DDB)的句柄。
  
  l         dwIoControlCode, lpvInBuffer, cbInBuffer, lpvOutBuffer, cbOutBuffer, lpcbBytesReturned, lpOverlapped是传送到DeviceIoControl API的参数。
  
  l         hDevice是       ring-3级设备句柄。
  
  l         tagProces       是过程的标签。
  
  在DIOCParams结构中有所有从Win32应用程序传送到你的VxD的信息。
  
  你的VxD至少要处理DIOC_Open(传送到dwIoControlCode),那是当Win32程序调用CreateFile打开你的VxD时VWIN32发送给你的VxD的。假如你的VxD预备好了,它必须在eax中返回0而且CreateFile也会成功。假如你的VxD没有预备好,它必须在eas中返回一个非零值而且CreateFile也会失败。除了DIOC_Open,当Win32程序关闭这个设备句柄时

来源:http://www.tulaoshi.com/n/20160219/1604186.html

延伸阅读
三、Windows 95/98应用程序与VxD的通信 Windows 95/98应用程序与VxD的通信一般使用DeviceIoControl函数, 这里给出一个实例源程序(FHTEST.C)如下: //拦截Windows 95/98文件操作测试程序 #include #include "tchar.h" #define INSTALL_FILE_SYSTEM_API_HOOK 1 #define UNINSTALL_FILE_SYSTEM_API_HOOK 2 static TCHAR szAppName[...
Interfaces 接口 在软件工程中,由一份“契约”规定来自不同的开发小组的软件之间如何相互作用是非常常见的。每个小组都可以在不知道别的组的代码的前提下独立开发自己的代码。Java中的interface就是这样的一份“契约”。 举个例子,假设在未来社会有一种智能汽车,它可以在自动运载旅客而不需要人工操作。汽车生产商开发了软件(当然是用Java...
标签: 编织
步骤1: 将五根线对折,在一半合扣上各编一个雀头结。 步骤2: 把右边第一根线为轴拉到左边编9个斜卷结。 步骤3: 步骤二第三排的轴线都是用右边的第一根向左边拉,也就是每一排的轴线不是同一根线。编三排,如果手围大于15厘米的话再酌情增加就好。 第4: 编完第四步之后将左边第一根线拉向右边做轴线,依次编...
标签: 宠物犬
卡斯罗的品种介绍 无论何时,意大利南方的老人,只要坐在一起就长篇大论的讲述有关于卡斯罗的故事,一些故事是真实的,还有一些是次真实的,甚至有一些是幻想出来的。他们总是带着敬仰和爱戴来谈论这一伟大的犬种的创始者,他花费了一生的时间来繁育它们,照顾它们。我希望所有的人都能看到我的故事,因为这些故事是你深入了解卡斯罗的重要...

经验教程

801

收藏

8

精华推荐

罗望子

罗望子

光头去去去

金宇彬高清图集一

金宇彬高清图集一

伊达家的大叔

金宇彬高清图集二

金宇彬高清图集二

勤奋的雨墨天迹

微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部