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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? irp.c

?? ReactOS是一些高手根據(jù)Windows XP的內(nèi)核編寫出的類XP。內(nèi)核實(shí)現(xiàn)機(jī)理和API函數(shù)調(diào)用幾乎相同。甚至可以兼容XP的程序。喜歡研究系統(tǒng)內(nèi)核的人可以看一看。
?? C
字號(hào):
/*
 * COPYRIGHT:       See COPYING in the top level directory
 * PROJECT:         ReactOS
 * FILE:            drivers/multimedia/portcls/irp.c
 * PURPOSE:         Port Class driver / IRP Handling
 * PROGRAMMER:      Andrew Greenwood
 *
 * HISTORY:
 *                  27 Jan 07   Created
 */


#include "private.h"
#include <portcls.h>

/*
    A safe place for IRPs to be bounced to, if no handler has been
    set. Whether this is a good idea or not...?
*/
#if 0
static
NTSTATUS
NTAPI
IrpStub(
    IN  PDEVICE_OBJECT DeviceObject,
    IN  PIRP Irp)
{
    NTSTATUS status = STATUS_NOT_SUPPORTED;

    Irp->IoStatus.Status = STATUS_NOT_SUPPORTED;
    Irp->IoStatus.Information = 0;
    IoCompleteRequest(Irp, IO_NO_INCREMENT);

    DPRINT1("IRP Stub called\n");

    return status;
}
#endif

/*
    Handles IRP_MJ_CREATE, which occurs when someone wants to make use of
    a device.
*/
NTSTATUS
NTAPI
PortClsCreate(
    IN  PDEVICE_OBJECT DeviceObject,
    IN  PIRP Irp)
{
    DPRINT1("PortClsCreate called\n");

    /* TODO */

    Irp->IoStatus.Status = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;
    IoCompleteRequest(Irp, IO_NO_INCREMENT);

    return STATUS_SUCCESS;
}


/*
    IRP_MJ_PNP handler
    Used for things like IRP_MN_START_DEVICE
*/
NTSTATUS
NTAPI
PortClsPnp(
    IN  PDEVICE_OBJECT DeviceObject,
    IN  PIRP Irp)
{
    NTSTATUS status;
    PCExtension* portcls_ext;
    PIO_STACK_LOCATION irp_stack;

    DPRINT1("PortClsPnp called\n");

    portcls_ext = (PCExtension*) DeviceObject->DeviceExtension;
    irp_stack = IoGetCurrentIrpStackLocation(Irp);

    ASSERT(portcls_ext);

    /*
        if IRP_MN_START_DEVICE, call the driver's customer start device routine.
        Before we do so, we must create a ResourceList to pass to the Start
        routine.
    */
    if ( irp_stack->MinorFunction == IRP_MN_START_DEVICE )
    {
        IResourceList* resource_list;
        DPRINT("IRP_MN_START_DEVICE\n");

        /* Create the resource list */
        status = PcNewResourceList(
                    &resource_list,
                    NULL,
                    PagedPool,
                    irp_stack->Parameters.StartDevice.AllocatedResourcesTranslated,
                    irp_stack->Parameters.StartDevice.AllocatedResources);

        if ( ! NT_SUCCESS(status) )
        {
            DPRINT("PcNewResourceList failed [0x%8x]\n", status);
            Irp->IoStatus.Status = status;
            IoCompleteRequest(Irp, IO_NO_INCREMENT);

            return status;
        }

        /* Assign the resource list to our extension */
        portcls_ext->resources = resource_list;

        ASSERT(portcls_ext->StartDevice);

        /* Call the StartDevice routine */
        DPRINT("Calling StartDevice at 0x%8p\n", portcls_ext->StartDevice);
        status = portcls_ext->StartDevice(DeviceObject, Irp, resource_list);

        if ( ! NT_SUCCESS(status) )
        {
            DPRINT("StartDevice returned a failure code [0x%8x]\n", status);
            resource_list->lpVtbl->Release(resource_list);

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

            return status;
        }

        Irp->IoStatus.Status = STATUS_SUCCESS;
        IoCompleteRequest(Irp, IO_NO_INCREMENT);
    }
    else if ( irp_stack->MinorFunction == IRP_MN_REMOVE_DEVICE )
    {
        DPRINT("IRP_MN_REMOVE_DEVICE\n");
        /* Clean up */
        portcls_ext->resources->lpVtbl->Release(portcls_ext->resources);

        IoDeleteDevice(DeviceObject);

        /* Do not complete? */
        Irp->IoStatus.Status = STATUS_SUCCESS;
    }

    return STATUS_SUCCESS;
}

/*
    Power management. Handles IRP_MJ_POWER
    (not implemented)
*/
NTSTATUS
NTAPI
PortClsPower(
    IN  PDEVICE_OBJECT DeviceObject,
    IN  PIRP Irp)
{
    DPRINT1("PortClsPower called\n");

    /* TODO */

    Irp->IoStatus.Status = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;
    IoCompleteRequest(Irp, IO_NO_INCREMENT);

    return STATUS_SUCCESS;
}

/*
    System control. Handles IRP_MJ_SYSTEM_CONTROL
    (not implemented)
*/
NTSTATUS
NTAPI
PortClsSysControl(
    IN  PDEVICE_OBJECT DeviceObject,
    IN  PIRP Irp)
{
    DPRINT1("PortClsSysControl called\n");

    /* TODO */

    Irp->IoStatus.Status = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;
    IoCompleteRequest(Irp, IO_NO_INCREMENT);

    return STATUS_SUCCESS;
}


/*
    ==========================================================================
    API EXPORTS
    ==========================================================================
*/

/*
    Drivers may implement their own IRP handlers. If a driver decides to let
    PortCls handle the IRP, it can do so by calling this.
*/
NTSTATUS NTAPI
PcDispatchIrp(
    IN  PDEVICE_OBJECT DeviceObject,
    IN  PIRP Irp)
{
    PIO_STACK_LOCATION irp_stack;

    DPRINT("PcDispatchIrp called - handling IRP in PortCls\n");

    irp_stack = IoGetCurrentIrpStackLocation(Irp);

    switch ( irp_stack->MajorFunction )
    {
        /* PortCls */
        case IRP_MJ_CREATE :
            return PortClsCreate(DeviceObject, Irp);

        case IRP_MJ_PNP :
            return PortClsPnp(DeviceObject, Irp);

        case IRP_MJ_POWER :
            return PortClsPower(DeviceObject, Irp);

        case IRP_MJ_SYSTEM_CONTROL :
            return PortClsSysControl(DeviceObject, Irp);

        /* KS - TODO */

#if 0
    KsSetMajorFunctionHandler(DriverObject, IRP_MJ_CLOSE);
    KsSetMajorFunctionHandler(DriverObject, IRP_MJ_DEVICE_CONTROL);
    KsSetMajorFunctionHandler(DriverObject, IRP_MJ_FLUSH_BUFFERS);
    KsSetMajorFunctionHandler(DriverObject, IRP_MJ_QUERY_SECURITY);
    KsSetMajorFunctionHandler(DriverObject, IRP_MJ_READ);
    KsSetMajorFunctionHandler(DriverObject, IRP_MJ_SET_SECURITY);
    KsSetMajorFunctionHandler(DriverObject, IRP_MJ_WRITE);
#endif

        default :
            break;
    };

    /* If we reach here, we just complete the IRP */
    Irp->IoStatus.Status = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;
    IoCompleteRequest(Irp, IO_NO_INCREMENT);

    return STATUS_SUCCESS;
}

/*
 * @unimplemented
 */
NTSTATUS NTAPI
PcCompleteIrp(
    IN  PDEVICE_OBJECT DeviceObject,
    IN  PIRP Irp,
    IN  NTSTATUS Status)
{
    UNIMPLEMENTED;
    return STATUS_UNSUCCESSFUL;
}

/*
 * @unimplemented
 */
NTSTATUS NTAPI
PcForwardIrpSynchronous(
    IN  PDEVICE_OBJECT DeviceObject,
    IN  PIRP Irp)
{
    UNIMPLEMENTED;
    return STATUS_UNSUCCESSFUL;
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲综合男人的天堂| 国产精品传媒入口麻豆| 日韩精品一卡二卡三卡四卡无卡| 色8久久精品久久久久久蜜| 亚洲欧美日韩电影| 91精品福利视频| 舔着乳尖日韩一区| 日韩精品在线一区| 国产成人午夜视频| 国产精品二三区| 欧美日韩午夜精品| 日本三级亚洲精品| 久久免费视频一区| 99视频精品在线| 亚洲va欧美va人人爽| 精品国免费一区二区三区| 高清在线观看日韩| 一区二区三区四区激情| 欧美一区二区日韩一区二区| 激情综合网av| 一区二区三区四区激情| 日韩精品中文字幕一区二区三区| 国产精品一区免费在线观看| 亚洲少妇屁股交4| 欧美一区永久视频免费观看| 国产精品综合一区二区| 一区二区三区四区在线| 精品久久一区二区三区| 色国产综合视频| 精品无码三级在线观看视频| 综合激情网...| 日韩欧美国产综合在线一区二区三区| 丁香桃色午夜亚洲一区二区三区| 亚洲欧美日韩一区| 精品福利一二区| 在线观看一区二区精品视频| 久久er99精品| 午夜伦理一区二区| 国产精品美女久久久久av爽李琼| 欧美日本免费一区二区三区| 成人av资源站| 久久不见久久见免费视频1| 亚洲一区二区三区在线| 欧美激情一区二区| 欧美一二三区在线观看| 91美女蜜桃在线| 国产精品正在播放| 美腿丝袜亚洲综合| 亚洲亚洲人成综合网络| 亚洲国产高清在线观看视频| 日韩欧美一区二区视频| 欧美性做爰猛烈叫床潮| 成人性生交大片免费| 国产一区二区三区蝌蚪| 五月综合激情婷婷六月色窝| 国产精品毛片a∨一区二区三区| 欧美sm极限捆绑bd| 欧美电影影音先锋| 在线免费观看日韩欧美| 94-欧美-setu| 成人午夜视频网站| 国产成人午夜精品5599| 加勒比av一区二区| 久久国产麻豆精品| 免费国产亚洲视频| 青青草原综合久久大伊人精品优势| 亚洲一线二线三线视频| 亚洲三级视频在线观看| 亚洲欧洲av一区二区三区久久| 久久久久99精品国产片| 欧美videofree性高清杂交| 日韩三级.com| 欧美日韩一级二级三级| 欧美在线播放高清精品| 欧洲视频一区二区| 欧美日韩亚洲综合在线| 欧美日韩在线免费视频| 欧美精品视频www在线观看 | 国产自产高清不卡| 免费在线成人网| 全部av―极品视觉盛宴亚洲| 天天影视涩香欲综合网| 三级久久三级久久久| 日本最新不卡在线| 久草在线在线精品观看| 国产盗摄一区二区| av电影在线观看一区| 色综合欧美在线| 色综合久久天天综合网| 欧美在线免费播放| 欧美一区二区三区免费观看视频 | 欧美精品一区二区在线观看| 久久婷婷色综合| 国产精品毛片久久久久久久| 亚洲人123区| 亚洲国产综合色| 蜜桃在线一区二区三区| 国产一区二区三区免费观看| a级高清视频欧美日韩| 91精品91久久久中77777| 日韩一区二区免费在线观看| 欧美精品一区视频| 亚洲色图在线视频| 性做久久久久久| 国产麻豆91精品| 色婷婷一区二区| 日韩一区二区免费在线电影| 中国av一区二区三区| 亚洲一二三区不卡| 国产精品99久久久| 91福利资源站| 精品人伦一区二区色婷婷| 国产精品入口麻豆原神| 亚洲一区二区三区影院| 极品美女销魂一区二区三区| 91网上在线视频| 日韩午夜av电影| 最新热久久免费视频| 视频在线观看91| 97久久精品人人做人人爽| 欧美精品精品一区| 国产精品丝袜91| 日本午夜一本久久久综合| 99re热视频这里只精品| 日韩女优毛片在线| 亚洲精品一卡二卡| 国产精品888| 日韩一区二区三区观看| 国产精品国产三级国产| 蜜桃久久久久久| 欧日韩精品视频| 亚洲国产精品精华液ab| 日韩av高清在线观看| 色哦色哦哦色天天综合| 久久免费美女视频| 日韩成人一级大片| 欧洲精品一区二区| 亚洲欧美综合网| 国产精品18久久久久久久久| 欧美日韩国产在线观看| 椎名由奈av一区二区三区| 国内偷窥港台综合视频在线播放| 欧美在线三级电影| 亚洲免费av在线| 不卡av免费在线观看| 久久综合久久综合亚洲| 奇米一区二区三区| 欧美日韩国产三级| 亚洲一区二区欧美| 色菇凉天天综合网| 最新国产成人在线观看| 粉嫩在线一区二区三区视频| 精品美女被调教视频大全网站| 日日欢夜夜爽一区| 欧美日本国产视频| 一区二区欧美在线观看| 色综合视频一区二区三区高清| 国产欧美日本一区视频| 国产精品中文字幕日韩精品| 久久久亚洲精品石原莉奈| 看国产成人h片视频| 日韩美女视频在线| 精品亚洲欧美一区| 国产三级精品三级| 国产成人综合在线观看| 久久久国产精华| 国产成人精品免费看| 欧美激情一区二区三区蜜桃视频 | 91视频你懂的| 亚洲色图一区二区三区| 色偷偷88欧美精品久久久| 1024精品合集| 欧美性猛交xxxx黑人交| 亚洲1区2区3区4区| 4438x亚洲最大成人网| 日本不卡不码高清免费观看| 日韩一区和二区| 韩国成人精品a∨在线观看| 国产欧美日韩精品在线| 99久久国产综合精品麻豆| 亚洲理论在线观看| 在线亚洲一区观看| 视频一区视频二区在线观看| 日韩欧美久久久| 国产mv日韩mv欧美| 亚洲精品免费电影| 欧美日韩黄视频| 国产伦精品一区二区三区在线观看 | 欧美视频在线不卡| 久久精品噜噜噜成人88aⅴ| 久久综合精品国产一区二区三区| 国产精品系列在线播放| 亚洲欧美激情小说另类| 欧美日韩免费视频| 狠狠色狠狠色综合日日91app| 中文字幕精品一区二区三区精品 | 亚洲午夜精品17c| 91精品国产综合久久精品| 国产精品资源网站| 玉足女爽爽91|