亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? simpldrv.c

?? 驅動開發Wizard
?? C
字號:
/*++

Copyright (c) 1993  Microsoft Corporation

Module Name:

    $$safe_root$$.c

Abstract:

    A simple kernel-mode driver sample.

Environment:

    kernel mode only

Notes:

    See readme.txt

Revision History:

    06-25-93 : created

--*/

#include "ntddk.h"
#include "stdarg.h"
#include "stdio.h"
//#include "$$safe_root$$.h"
#include "$$safe_root$$.h"



//
// The following is the debug print macro- when we are building checked
// drivers "DBG" will be defined (by the \ddk\setenv.cmd script), and we
// will see debug messages appearing on the KD screen on the host debug
// machine. When we build free drivers "DBG" is not defined, and calls
// to $$safe_root$$KdPrint are removed.
//

#ifdef DBG
#define $$safe_root$$KdPrint(arg) DbgPrint arg
#else
#define $$safe_root$$KdPrint(arg)
#endif



NTSTATUS
$$safe_root$$Dispatch(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    );

VOID
$$safe_root$$Unload(
    IN PDRIVER_OBJECT DriverObject
    );



NTSTATUS
DriverEntry(
    IN PDRIVER_OBJECT  DriverObject,
    IN PUNICODE_STRING RegistryPath
    )
/*++

Routine Description:

    Installable driver initialization entry point.
    This entry point is called directly by the I/O system.

Arguments:

    DriverObject - pointer to the driver object

    RegistryPath - pointer to a unicode string representing the path
                   to driver-specific key in the registry

Return Value:

    STATUS_SUCCESS if successful,
    STATUS_UNSUCCESSFUL otherwise

--*/
{

    PDEVICE_OBJECT         deviceObject        = NULL;
    NTSTATUS               ntStatus;
    WCHAR                  deviceNameBuffer[]  = L"\\Device\\$$safe_root$$";
    UNICODE_STRING         deviceNameUnicodeString;
    PDEVICE_EXTENSION      deviceExtension;
    WCHAR                  deviceLinkBuffer[]  = L"\\DosDevices\\$$safe_root$$";
    UNICODE_STRING         deviceLinkUnicodeString;


    $$safe_root$$KdPrint (("$$safe_root$$.SYS: entering DriverEntry\n"));



    //
    // A real driver would:
    //
    //     1. Report it's resources (IoReportResourceUsage)
    //
    //     2. Attempt to locate the device(s) it supports



    //
    // OK, we've claimed our resources & found our h/w, so create
    // a device and initialize stuff...
    //

    RtlInitUnicodeString (&deviceNameUnicodeString,
                          deviceNameBuffer
                          );



    //
    // Create an EXCLUSIVE device, i.e. only 1 thread at a time can send
    // i/o requests.
    //

    ntStatus = IoCreateDevice (DriverObject,
                               sizeof (DEVICE_EXTENSION),
                               &deviceNameUnicodeString,
                               FILE_DEVICE_$$safe_root$$,
                               0,
                               TRUE,
                               &deviceObject
                               );

    if (NT_SUCCESS(ntStatus))
    {
        deviceExtension = (PDEVICE_EXTENSION) deviceObject->DeviceExtension;



        //
        // Set up synchronization objects, state info,, etc.
        //



        //
        // Create a symbolic link that Win32 apps can specify to gain access
        // to this driver/device
        //

        RtlInitUnicodeString (&deviceLinkUnicodeString,
                              deviceLinkBuffer
                              );

        ntStatus = IoCreateSymbolicLink (&deviceLinkUnicodeString,
                                         &deviceNameUnicodeString
                                         );


        if (!NT_SUCCESS(ntStatus))
        {
            $$safe_root$$KdPrint (("$$safe_root$$.SYS: IoCreateSymbolicLink failed\n"));
        }



        //
        // Create dispatch points for device control, create, close.
        //

        DriverObject->MajorFunction[IRP_MJ_CREATE]         =
        DriverObject->MajorFunction[IRP_MJ_CLOSE]          =
        DriverObject->MajorFunction[IRP_MJ_DEVICE_CONTROL] = $$safe_root$$Dispatch;
        DriverObject->DriverUnload                         = $$safe_root$$Unload;
    }


//done_DriverEntry:

    if (!NT_SUCCESS(ntStatus))
    {
        //
        // Something went wrong, so clean up (free resources, etc.)
        //

        if (deviceObject)

            IoDeleteDevice (deviceObject);
    }

    return ntStatus;
}



NTSTATUS
$$safe_root$$Dispatch(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    )
/*++

Routine Description:

    Process the IRPs sent to this device.

Arguments:

    DeviceObject - pointer to a device object

    Irp          - pointer to an I/O Request Packet

Return Value:


--*/
{

    PIO_STACK_LOCATION  irpStack;
    PDEVICE_EXTENSION   deviceExtension;
    PVOID               ioBuffer;
    ULONG               inputBufferLength;
    ULONG               outputBufferLength;
    ULONG               ioControlCode;
    NTSTATUS            ntStatus;



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


    //
    // Get a pointer to the current location in the Irp. This is where
    //     the function codes and parameters are located.
    //

    irpStack = IoGetCurrentIrpStackLocation (Irp);



    //
    // Get a pointer to the device extension
    //

    deviceExtension = DeviceObject->DeviceExtension;



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

    ioBuffer           = Irp->AssociatedIrp.SystemBuffer;
    inputBufferLength  = irpStack->Parameters.DeviceIoControl.InputBufferLength;
    outputBufferLength = irpStack->Parameters.DeviceIoControl.OutputBufferLength;



    switch (irpStack->MajorFunction)
    {
    case IRP_MJ_CREATE:

        $$safe_root$$KdPrint (("$$safe_root$$.SYS: IRP_MJ_CREATE\n"));

        break;

    case IRP_MJ_CLOSE:

        $$safe_root$$KdPrint (("$$safe_root$$.SYS: IRP_MJ_CLOSE\n"));

        break;

    case IRP_MJ_DEVICE_CONTROL:

        $$safe_root$$KdPrint (("$$safe_root$$.SYS: IRP_MJ_DEVICE_CONTROL\n"));

        ioControlCode = irpStack->Parameters.DeviceIoControl.IoControlCode;

        switch (ioControlCode)
        {

        case IOCTL_$$safe_root$$_HELLO:
        {
            //
            // Some app is saying hello
            //

            break;
        }

        default:

            Irp->IoStatus.Status = STATUS_INVALID_PARAMETER;

            $$safe_root$$KdPrint (("$$safe_root$$.SYS: unknown IRP_MJ_DEVICE_CONTROL\n"));

            break;

        }

        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;
}



VOID
$$safe_root$$Unload(
    IN PDRIVER_OBJECT DriverObject
    )
/*++

Routine Description:

    Free all the allocated resources, etc.

Arguments:

    DriverObject - pointer to a driver object

Return Value:


--*/
{
    WCHAR                  deviceLinkBuffer[]  = L"\\DosDevices\\$$safe_root$$";
    UNICODE_STRING         deviceLinkUnicodeString;



    //
    // Free any resources
    //



    //
    // Delete the symbolic link
    //

    RtlInitUnicodeString (&deviceLinkUnicodeString,
                          deviceLinkBuffer
                          );

    IoDeleteSymbolicLink (&deviceLinkUnicodeString);



    //
    // Delete the device object
    //

    IoDeleteDevice (DriverObject->DeviceObject);

    $$safe_root$$KdPrint (("$$safe_root$$.SYS: unloading\n"));
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩二区三区在线观看| 狠狠色2019综合网| 欧美成人vr18sexvr| gogo大胆日本视频一区| 日本女优在线视频一区二区| √…a在线天堂一区| 日韩欧美国产综合| 在线国产电影不卡| 日本一区中文字幕| 亚洲日穴在线视频| 国产欧美一二三区| 日韩免费视频线观看| 欧美三级视频在线观看| 不卡欧美aaaaa| 国产乱色国产精品免费视频| 亚洲国产欧美日韩另类综合 | 久久久国产一区二区三区四区小说 | 国产成人99久久亚洲综合精品| 国产午夜一区二区三区| 91国产免费看| 成人sese在线| 国产一区二区电影| 久久国产乱子精品免费女| 亚洲3atv精品一区二区三区| 国产精品卡一卡二卡三| 久久精品一区二区三区av| 欧美一区永久视频免费观看| 欧美三级欧美一级| 日本高清不卡视频| 91在线无精精品入口| 成人性生交大片免费看中文| 国产呦精品一区二区三区网站| 日本成人在线电影网| 亚洲成人你懂的| 一区二区三区四区国产精品| 亚洲欧美视频在线观看| 亚洲欧洲精品成人久久奇米网| 欧美极品aⅴ影院| 欧美韩国日本综合| 欧美激情在线一区二区| 中文字幕精品在线不卡| 中文文精品字幕一区二区| 国产日韩欧美综合在线| 国产女人aaa级久久久级| 欧美国产禁国产网站cc| 中文字幕精品三区| 国产精品久久久久久久久搜平片| 中文字幕免费观看一区| 中文字幕一区在线观看视频| 国产精品美女视频| 亚洲人成电影网站色mp4| 亚洲男人电影天堂| 亚洲国产成人91porn| 亚洲成人激情av| 日本在线不卡视频| 精品亚洲成a人在线观看| 国产成人亚洲综合a∨婷婷图片| 国产剧情一区在线| 成人av在线影院| 欧洲亚洲国产日韩| 69堂成人精品免费视频| 日韩美女主播在线视频一区二区三区| 日韩欧美国产1| 久久久精品黄色| 中文字幕日本乱码精品影院| 亚洲无人区一区| 毛片一区二区三区| 国产成人免费视频| 日本高清不卡一区| 欧美不卡视频一区| 国产欧美一区二区精品性色 | 日韩精品色哟哟| 国产精品亚洲专一区二区三区| aa级大片欧美| 91精品麻豆日日躁夜夜躁| 国产视频一区不卡| 一区二区三区不卡在线观看 | 972aa.com艺术欧美| 欧美日韩一区二区三区在线看| 日韩视频免费观看高清在线视频| 欧美激情一区二区在线| 一区二区成人在线| 国产一区欧美一区| 91黄色免费网站| 精品国产1区二区| 亚洲色图色小说| 免费成人小视频| caoporen国产精品视频| 欧美日韩成人综合| 国产精品色在线| 日韩国产一二三区| 东方欧美亚洲色图在线| 欧美日韩国产一级二级| 国产欧美日韩精品在线| 五月天一区二区| 成人动漫中文字幕| 欧美tickling挠脚心丨vk| 亚洲久草在线视频| 国产在线视频一区二区| 在线国产亚洲欧美| 国产人妖乱国产精品人妖| 香蕉乱码成人久久天堂爱免费| 国产91丝袜在线播放| 欧美情侣在线播放| 国产精品美女www爽爽爽| 日本不卡免费在线视频| 色欧美片视频在线观看| 久久久精品国产免大香伊| 亚洲一区二区三区四区在线| 成人永久看片免费视频天堂| 日韩一区二区免费视频| 亚洲午夜久久久久| 91色在线porny| 国产精品色噜噜| 国产一区亚洲一区| 日韩一区二区视频| 性欧美疯狂xxxxbbbb| 日本国产一区二区| 亚洲婷婷综合久久一本伊一区| 国产馆精品极品| 久久青草欧美一区二区三区| 日韩av不卡在线观看| 欧美少妇xxx| 亚洲乱码国产乱码精品精小说 | 成人avav影音| 久久久www成人免费毛片麻豆| 免费欧美在线视频| 69堂亚洲精品首页| 日韩在线观看一区二区| 欧美人与性动xxxx| 丝袜亚洲另类欧美综合| 欧洲色大大久久| 亚洲高清免费一级二级三级| 欧美在线一二三四区| 亚洲蜜臀av乱码久久精品| 99久久婷婷国产综合精品电影| 中文字幕精品在线不卡| 成人99免费视频| 中文字幕在线不卡| 91视频一区二区| 亚洲一本大道在线| 在线观看中文字幕不卡| 亚洲6080在线| 日韩丝袜情趣美女图片| 国产一区在线不卡| 中文字幕国产精品一区二区| av亚洲精华国产精华| **性色生活片久久毛片| 91免费在线播放| 亚洲国产另类精品专区| 91精品国产aⅴ一区二区| 免费av成人在线| 久久影院午夜论| 夫妻av一区二区| 成人欧美一区二区三区小说| 一本久道久久综合中文字幕| 亚洲国产精品久久艾草纯爱| 欧美一区二区成人6969| 国产一区二区调教| 中文字幕一区二区不卡 | av亚洲精华国产精华精| 亚洲黄色免费电影| 欧美日韩成人一区二区| 麻豆一区二区在线| 久久久精品国产免大香伊| 一本色道久久综合精品竹菊| 婷婷国产v国产偷v亚洲高清| 精品成a人在线观看| 成人激情视频网站| 一二三四社区欧美黄| 日韩亚洲电影在线| 丰满放荡岳乱妇91ww| 亚洲线精品一区二区三区八戒| 欧美日韩国产一二三| 精品一二三四区| 亚洲欧美日韩一区二区三区在线观看| 欧美日韩在线三区| 国产精品一区二区在线观看不卡 | 日韩精品成人一区二区在线| 久久久久国产成人精品亚洲午夜| 成人黄色综合网站| 日日夜夜精品视频天天综合网| 精品国产乱码久久久久久图片| 成人理论电影网| 日韩精品成人一区二区在线| 日本一区二区三区国色天香| 欧美系列在线观看| 国产精品一区二区三区四区| 一区二区三区毛片| 久久精品免费在线观看| 欧美午夜精品免费| 国产一区二区在线影院| 亚洲成a人片综合在线| 欧美国产成人精品| 日韩精品一区二| 欧美视频一区二区三区| 国产成人精品亚洲日本在线桃色| 午夜精品一区在线观看| 欧美高清在线视频| 欧美变态tickle挠乳网站|