菜鸟30分钟调通VXD

菜鸟30分钟调通VXD
作者: 二三子
其实你不是一只菜鸟,你对VC已经很熟悉了。只是想尽快向VXD进军。想写VXD驱动程序的捷径是用Verio公司的VtoolsD,不用写汇编,而且很多种操作被很好的封装成了类。

一. 以下我们首先介绍用VtoolsD进行VXD开发的开发环境的准备。
1) 首先你的机器上已经安装了VC5以上的VC版本;
2) 安装Masm611以上版本的汇编编译环境,一般网上找到的是带路径的ZIP压缩文件,而不是安装文件,将其解压到适当目录,如C:/Masm/;
3) 安装SoftIce,这不是调试时必须的,而是在编译时要SoftIce的支持;
4) 安装VtoolsD,
a. 先是显示版权和选择安装路径;
b. 选择编译器为Microsoft VC++;
c. 选择VC版本为4.x
d. 指定VC的路径(我的机器上为C:/msdn/vc98/,你的机器上可能为C:/Program Files/Microsorft VisualStudio/vc98/ ,即VC6的根目录)
e. 选择需要Masm6.11.
f. 指定Masm6.11 的路径(我的机器上为C:/masm/bin/,即Masm611的Bin子目录)
g. 下一个选项选择Yes将VtoolsD Help加入VC Help扩展
h. 再下一项选择NeMega Soft-Ice 为Debugger
i. 接着选择SoftIce的路径(我的机器上为C:/Siw95/util16,即SoftIce的util16子目录)
j. 再下一项选择可选DDK组件,两样都不选;
k. 接着确认选项后安装;
l. 安装完成后提示是否在环境变量中自动加入VtoosD = "你的VtoolsD路径",当然选Yes;
m. 最后确认安装完成。
5) 事情还没有完呢,还要到VtoolsD的include 子目录下找到User.mak文件,并将里面的长文件名都该为文件别名,如Program Files/Microsoft Visual Studio/ 改为 Progra~1/Micros~1等;
6) 到C:盘的根目录下找到autoexec.bat,看它是否增加了一项:SET VTOOLSD = 你的VToolsD路径,(如SET VTOOLSD = d:/vtoolsd),如果没有请加上;
7) 最后重新启动你的计算机,就可以用VC编译VXD的程序了;

二. 接下来我们介绍用VC编译VXD驱动程序
其实应该先用VToolD自动生成源代码。但是这里有我已经写好的代码,和VtoolsD自动生成的代码差不多,区别是注释很详细,并经过精心裁减,关于如何用VToolsD自动生成源代码,我们以后再讨论吧。
您只需将本文附带的程序用VC编译即可使用,程序中有较详细的注释。
程序有两个,分别为VXD程序:VxdDrv

用户程序:UseVxd
程序功能说明如下:
VXD程序:
1. 由用户程序调用DeviceIoControl传递相应的参数触发OnW32DeviceIoControl函数,在OnW32DeviceIoControl函数特定分支中向调试终端打印字符串"Hello devdrv.qzone.com"
2. 响应鼠标中断,并在中断中读打印并口的值,然后加1再向打印并口输出,(打印并口不是一个数据双向口,它只能把输出的数据锁存,以便回读检查刚才输出的数据是否正确,我们利用这个特点,就可以在不增加硬件的条件下调试一个最简单的I/O程序)
3. 由用户程序调用DeviceIoControl 传递相应的参数触发OnW32DeviceIoControl函数,在OnW32DeviceIoControl函数特定分支中回送并口的值,使应用程序能监视到打印并口的值在循环增加。
用户程序:
1. 动态加载和卸载VXD程序
2. 按钮调用DeviceIoControl传递相应的参数使VXD程序向调试终端打印字符串"Hello devdrv.qzone.com"
3. OnTimer事件调用DeviceIoControl 传递相应的参数使VXD传回并口的值,从而监视到打印并口的值在循环增加。

在你的机器上编译以上两个程序,就可以看到VXD程序在干活了。提示你请用DEBUG VIEW 监测调试输出,这样会很方便。用VtoolsD带的工具VxdView可看到你是否成功的加载或卸载了VXD程序。

以下为编译VXD文件的步骤:
1. 打开工程文件VxdDrv.mak 提示是否建立VC工程,回答Yes
2. 选择支持平台 Win32 ,回答OK
3. VC自动生成工作组vxdDrv1.dsp,确认
4. 在Workspace(工作区)的File View中的VxdDrv1 files中加入文件VxdDrv.CPP 和VxdDrv.H
5. 在VC菜单Project(工程)|Setting…(设置…) 中将Output File Name(输出文件名)由vxdDrv1.exe改为vxdDrv1.vxd
6. 用VC菜单Compile(编译)|Rebuild All(重建全部),构建VxdDrv.vxd

关于UseVxd的编译我就不多废话了。
再补充一句,经本人测试,只要没有其它应用程序干扰,在中断频率为10K时还没有漏失现象。如果您要中断程序工作在基本实时的情况下,不要在工作中访问硬盘,关掉屏幕保护等。
请继续支持作者网站: http://devdrv.qzone.com

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Windows95是一个运行在最高级特权,第0层级别的多线程操作系统。所有的应用程序都运行在最低级特权,第3层级别上。这样就限制了 应用程序对系统的操作。它们不能使用cpu特权指令,不能直接访问I/O端口,等等。你对gdi32,kernal32和user32这三个大的系统组件一 定很熟悉。你肯定会认为这样重要的代码段一定是在第0层级别下运行的。但是实际上,它们和其他的应用程序一样,是在第三层级别下运行的。这就是说它们并不比Windows计算器,或者扫雷游戏有更多的权限。系统的控制实权掌握在虚拟级管理器(VMM) 和虚拟设备驱动程序(VxD)手中。 这一切都是由dos引起的。在Window 3.x的时代,在市场上有很多成功的dos软件。Windows 3.x必须同时运行普通的Windows程序和dos程序,否则,它就会失去市场。 这个局面是很难处理的,因为dos程序和Windows程序有本质的不同。dos程序认为它们拥有系统的一切:键盘,cpu,内存,硬盘等等。dos程序不知道怎样和其他程序合作,而Windows程序(从那时候起)是可靠的多任务合作系统。也就是每个Windows程序都必须通过GetMessage或PeekMessage来和其他程序进行交流。 解决办法就是,在一个8086虚拟机上运行所有的dos程序,而在另一个叫做系统虚拟机的虚拟机上运行其他所有的Windows程序。Windows负责把cpu运算时间轮流的分给每个虚拟机。这样,在Windows 3.x里。Windows程序之间用的是合作多任务,而虚拟机之间用的是优先级多任务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值