小巧的驱动测试工具

首先使用QuickSys向导一个驱动框架hellodrv,然后在DeviceControl例程里写入以下代码:
NTSTATUS
HellodrvDispatchDeviceControl(
 IN PDEVICE_OBJECT DeviceObject,
 IN PIRP Irp
 )
{
 NTSTATUS ntStatus;
    PIO_STACK_LOCATION IrpStack = IoGetCurrentIrpStackLocation(Irp);
    PDEVICE_EXTENSION DeviceExtension = (PDEVICE_EXTENSION)DeviceObject->DeviceExtension;
    PVOID lpInOutBuffer;
    ULONG nInBufferSize, nOutBufferSize, dwIoControlCode;
 UCHAR uBuffer[256]={0};

    Irp->IoStatus.Status = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;

    //
    // Get the pointer to the input/output buffer and it's length
    //

    lpInOutBuffer = Irp->AssociatedIrp.SystemBuffer;
    nInBufferSize = IrpStack->Parameters.DeviceIoControl.InputBufferLength;
    nOutBufferSize = IrpStack->Parameters.DeviceIoControl.OutputBufferLength;

    dprintf("[HelloDrv] IRP_MJ_DEVICE_CONTROL/n");

    dwIoControlCode = IrpStack->Parameters.DeviceIoControl.IoControlCode;

    switch (dwIoControlCode)
    {
 case IOCTL_HELLODRV_HELLO:
  {
   __try
   {
    strncpy(uBuffer,lpInOutBuffer,256);
    dprintf(uBuffer);

    {
     int iLen=strlen("Hi! I Got it!");
     strncpy(lpInOutBuffer,"Hi! I Got it!",nOutBufferSize);
     
     Irp->IoStatus.Information=iLen;
    }
    
   }
   __except(1)
   {
    dprintf("Excpetion during strncpy");
   }
   break;
  }

    default:
        Irp->IoStatus.Status = STATUS_INVALID_PARAMETER;

        dprintf("[HelloDrv] unknown IRP_MJ_DEVICE_CONTROL/n");

        break;
 }

    //
    // DON'T get cute and try to use the status field of
    // the irp in the return status.  That IRP IS GONE as
    // soon as you call IoCompleteRequest.
    //

    ntStatus = Irp->IoStatus.Status;
    IoCompleteRequest(Irp, IO_NO_INCREMENT);

    //
    // We never have pending operation so always return the status code.
    //

    return ntStatus;
}

编译生成一个sys后,使用Driver Testter测试它。


装载驱动:设置好参数后点Load按钮完成驱动装载.

进行IO测试,在这里可以通过Driver Tester程序传递最长256字节数据给驱动。
点Content按钮,设置参数,可以在左边使用16进制设置数据包值,比如某种特别的包结构内容,也可以使用右边的ASIIC视图输入字符,我在这里只敲了个了字符串"can you see it?"

参数设置好后,点IoControl按钮

可以看到驱动已收到了我们的数据,再看看驱动返回的数据,按Content按钮

我们也以收到驱动返回的数据,后面的那个t?是因为驱动返回的数据没有我们输入的长,所以没有被覆盖掉。

卸载驱动:最后点击Unload按钮,卸载驱动同时删除服务,不会在系统留下干什么痕迹,我不喜欢什么东东都在注册表写东东,自所不欲,勿所于人!这一点我很明白,所以在停止Driver的Kernel类型服务后,我就将服务删除。


一个小问题:
就是输入输出缓冲最大只支持256字节,为什么只支持这么小的数据Buffer,因为我只是要写一个小的驱动来研究系统,而不是要搞大数据量的东东,而且在对驱动进行一次DeviceIoControl也不宜用过大的数据,特别是在Buffered方式时IO管理器会把数据copy到内核态空间,此前IO管理器会分配一块内存,在驱动处理完后IO管理器再将数据从内核心态空间copy回ring3的Buffer里,这样会使效率所低,会占用很多我们很宝贵的内存啊!所以我建议的做法是驱动只完成很小的动作,比如要dump什么数据,驱动一次只负责dump一块出来,由Ring3程序进行多次DeviceIoControl请求来完成大量数据的dump操作,这样的效率也许会高一些,也就是驱动只完成一些"原子操作",而应用逻辑由Ring3程序进行包装实现。

Driver Logical Tester不是一个Debug工具,更不能防止BSOD出现,它所能做的是在你已经对你的驱动Debug后,对驱动的输入输出做一些逻辑测试,所以我给它起的名称叫Driver Logical Tester,也许没有什么大不了,但对我来说很有用,呵呵!

程序介绍:


关于DeviceID,ControlCode和Method不要问我是什么意思,怎么取值!!!具体的取值也根据你自己定义的来设置,界面里的Notes已经说明了它们的关系。需要这个小东东的朋友可以到http://kruglinski.ys168.com/下载。

wings是一款用于单元测试测试用例驱动框架自动生成工具,这款工具主要是全自动生成单元测试驱动代码与测试数据。解决做单元测试耗时耗力,编写难度大等问题。提升开发和测试效率。 特点: (1) 程序参数深度分析问题 Wings通过编译器底层技术,将输入的源文件,按照函数为单位,形成模块对象。对象中包含函数的输入参数,返回值类型等信息,供驱动函数模块和测试用例模块使用。每个文件作为一个单元,针对其中的每个函数的每个参数进行深度解析,对于嵌套类型,复杂类型等都可以实现精确的解析和分解,将复杂类型逐层讲解为基础数据类型,并产生参数结构的描述文件(PSD)。 (2) 函数驱动自动生成模块 依据PSD文件的格式信息,自动生成被测源程序的所有驱动函数,单元测试过程不再依赖开发人员手动编写测试函数,只需将生成的驱动函数和被测源文件一起编译,即可执行测试并查看测试结果。测试驱动自动生成程序基于PSD描述,全自动构建驱动被测程序运行的所有参数,必须的全局变量,并可根据复杂变量的层级结构产生结构化的测试驱动程序,可以节省大量的单元测试用例的编写时间。 (3) 测试数据自动生成与管理 用于自动生成测试数据,测试数据与被测函数提取的信息相互对应,数据以一定的层次逻辑关系存储在json文件中。数据和经过分解和展开后的数据类型是一一对应的。这些数据用户可以根据业务要求随意边际,并且用json文件进行结构化,层次化展示,非常的清晰。其中的测试数据包括全局变量值、被测函数调用时的参数值。 优点: 1. 可以为任意复杂参数结构C语言开发的系统全自动生成测试驱动程序 2. 可完成对于被测试函数的参数进行多层编译解析,并完成复杂参数赋值的代码的自动生成。 3. 支持被测函数引用的全局变量的分析和自动赋值程序的生成。 4. 能够区分系统变量和用户变量,对于复杂的系统变量可由用户自定义赋值模板。 例如File类型,而不是把复杂的系统变量全部展开。 5. 支持多层次的可视化的数据表格来对变量进行赋值,而无需关注驱动程序本身。 数据表格可以表达任意深度和多层次的数据关系,用户只需要对表格数据进行编辑,自动生成的驱动程序会自动完成表格数据的读取和参数赋值的构造过程。 6. Wings支持所有C语言的数据类型(基础类型,结构体,指针,数组,枚举等)以及高层级数据结构。 例如链表的分析和对应的驱动和数据表格框架的生成。 7. Wings生成的代码与人工写的非常相近,可读性强,自带注释和按照层次的缩进和代·码编排。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值