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

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

?? intwmi.c

?? This document provides information that supplements the Silicon Labs Interrupt Driver, which includ
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
        so the irp should be completed with the buffer needed.        
            
    OutBufferSize has the maximum size available to write the data
        block.

    Buffer on return is filled with the returned data block


Return Value:

    status

--*/
{
    PDEVICE_EXTENSION deviceExtension;
    NTSTATUS          ntStatus;
    ULONG             size;
    WCHAR             modelName[] = L"Aishverya\0\0";
    USHORT            modelNameLen;

    PAGED_CODE();

    KdPrint( ("IntUsb_QueryWmiDataBlock - begins\n"));

    size = 0;
    modelNameLen = (wcslen(modelName) + 1) * sizeof(WCHAR);

    //
    // Only ever registers 1 instance per guid
    //

    ASSERT((InstanceIndex == 0) &&
           (InstanceCount == 1));
    
    deviceExtension = (PDEVICE_EXTENSION) DeviceObject->DeviceExtension;

    switch (GuidIndex) {

    case WMI_INTUSB_DRIVER_INFORMATION:

        size = sizeof(ULONG) + modelNameLen + sizeof(USHORT);

        if (OutBufferSize < size ) {

            KdPrint( ("OutBuffer too small\n"));

            ntStatus = STATUS_BUFFER_TOO_SMALL;

            break;
        }

        * (PULONG) Buffer = DebugLevel;

        Buffer += sizeof(ULONG);

        //
        // put length of string ahead of string
        //

        *((PUSHORT)Buffer) = modelNameLen;

        Buffer = (PUCHAR)Buffer + sizeof(USHORT);

        RtlCopyBytes((PVOID)Buffer, (PVOID)modelName, modelNameLen);

        *InstanceLengthArray = size ;

        ntStatus = STATUS_SUCCESS;

        break;

    default:

        ntStatus = STATUS_WMI_GUID_NOT_FOUND;
    }

    ntStatus = WmiCompleteRequest(DeviceObject,
                                Irp,
                                ntStatus,
                                size,
                                IO_NO_INCREMENT);

    KdPrint( ("IntUsb_QueryWmiDataBlock - ends\n"));

    return ntStatus;
}


NTSTATUS
IntUsb_SetWmiDataItem(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp,
    IN ULONG          GuidIndex,
    IN ULONG          InstanceIndex,
    IN ULONG          DataItemId,
    IN ULONG          BufferSize,
    IN PUCHAR         Buffer
    )
/*++

Routine Description:

    This routine is a callback into the driver to set for the contents of
    a data block. When the driver has finished filling the data block it
    must call WmiCompleteRequest to complete the irp. The driver can
    return STATUS_PENDING if the irp cannot be completed immediately.

Arguments:

    DeviceObject is the device whose data block is being queried

    Irp is the Irp that makes this request

    GuidIndex is the index into the list of guids provided when the
        device registered

    InstanceIndex is the index that denotes which instance of the data block
        is being queried.
            
    DataItemId has the id of the data item being set

    BufferSize has the size of the data item passed

    Buffer has the new values for the data item


Return Value:

    status

--*/
{
    PDEVICE_EXTENSION deviceExtension;
    NTSTATUS          ntStatus;
    ULONG             info;
    
    PAGED_CODE();

    KdPrint( ("IntUsb_SetWmiDataItem - begins\n"));

    deviceExtension = (PDEVICE_EXTENSION) DeviceObject->DeviceExtension;
    info = 0;

    switch(GuidIndex) {
    
    case WMI_INTUSB_DRIVER_INFORMATION:

        if(DataItemId == 1) {

            if(BufferSize == sizeof(ULONG)) {

                DebugLevel = *((PULONG)Buffer);

                ntStatus = STATUS_SUCCESS;

                info = sizeof(ULONG);
            }
            else {

                ntStatus = STATUS_INFO_LENGTH_MISMATCH;
            }
        }
        else {

            ntStatus = STATUS_WMI_READ_ONLY;
        }

        break;

    default:

        ntStatus = STATUS_WMI_GUID_NOT_FOUND;
    }

    ntStatus = WmiCompleteRequest(DeviceObject,
                                Irp,
                                ntStatus,
                                info,
                                IO_NO_INCREMENT);

    KdPrint( ("IntUsb_SetWmiDataItem - ends\n"));

    return ntStatus;
}

NTSTATUS
IntUsb_SetWmiDataBlock(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp,
    IN ULONG          GuidIndex,
    IN ULONG          InstanceIndex,
    IN ULONG          BufferSize,
    IN PUCHAR         Buffer
    )
/*++

Routine Description:

    This routine is a callback into the driver to set the contents of
    a data block. When the driver has finished filling the data block it
    must call WmiCompleteRequest to complete the irp. The driver can
    return STATUS_PENDING if the irp cannot be completed immediately.

Arguments:

    DeviceObject is the device whose data block is being queried

    Irp is the Irp that makes this request

    GuidIndex is the index into the list of guids provided when the
        device registered

    InstanceIndex is the index that denotes which instance of the data block
        is being queried.
            
    BufferSize has the size of the data block passed

    Buffer has the new values for the data block


Return Value:

    status

--*/
{
    PDEVICE_EXTENSION deviceExtension;
    NTSTATUS          ntStatus;
    ULONG             info;

    PAGED_CODE();

    deviceExtension = (PDEVICE_EXTENSION) DeviceObject->DeviceExtension;
    info = 0;

    KdPrint( ("IntUsb_SetWmiDataBlock - begins\n"));

    switch(GuidIndex) {
    
    case WMI_INTUSB_DRIVER_INFORMATION:

        if(BufferSize == sizeof(ULONG)) {

            DebugLevel = *(PULONG) Buffer;
                    
            ntStatus = STATUS_SUCCESS;

            info = sizeof(ULONG);
        }
        else {

            ntStatus = STATUS_INFO_LENGTH_MISMATCH;
        }

        break;

    default:

        ntStatus = STATUS_WMI_GUID_NOT_FOUND;
    }

    ntStatus = WmiCompleteRequest(DeviceObject,
                                Irp,
                                ntStatus,
                                info,
                                IO_NO_INCREMENT);

    KdPrint( ("IntUsb_SetWmiDataBlock - ends\n"));

    return ntStatus;
}

PCHAR
WMIMinorFunctionString (
    UCHAR MinorFunction
    )
/*++
 
Routine Description:

Arguments:

Return Value:

--*/
{
    switch (MinorFunction) {

        case IRP_MN_CHANGE_SINGLE_INSTANCE:
            return "IRP_MN_CHANGE_SINGLE_INSTANCE\n";

        case IRP_MN_CHANGE_SINGLE_ITEM:
            return "IRP_MN_CHANGE_SINGLE_ITEM\n";

        case IRP_MN_DISABLE_COLLECTION:
            return "IRP_MN_DISABLE_COLLECTION\n";

        case IRP_MN_DISABLE_EVENTS:
            return "IRP_MN_DISABLE_EVENTS\n";

        case IRP_MN_ENABLE_COLLECTION:
            return "IRP_MN_ENABLE_COLLECTION\n";

        case IRP_MN_ENABLE_EVENTS:
            return "IRP_MN_ENABLE_EVENTS\n";

        case IRP_MN_EXECUTE_METHOD:
            return "IRP_MN_EXECUTE_METHOD\n";

        case IRP_MN_QUERY_ALL_DATA:
            return "IRP_MN_QUERY_ALL_DATA\n";

        case IRP_MN_QUERY_SINGLE_INSTANCE:
            return "IRP_MN_QUERY_SINGLE_INSTANCE\n";

        case IRP_MN_REGINFO:
            return "IRP_MN_REGINFO\n";

        default:
            return "IRP_MN_?????\n";
    }
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91.xcao| 欧美久久久久中文字幕| 亚洲夂夂婷婷色拍ww47| 日韩一级片在线播放| 色婷婷av一区二区三区大白胸 | 欧美伦理电影网| 国产精品香蕉一区二区三区| 亚洲一区二区三区美女| 中文字幕欧美日韩一区| 91精品国产综合久久福利软件| 91婷婷韩国欧美一区二区| 国产美女视频91| 日本亚洲免费观看| 一区二区三区 在线观看视频| 国产婷婷色一区二区三区四区 | 蜜臀久久久久久久| 亚洲一区在线视频观看| 成人欧美一区二区三区1314 | 欧美一卡二卡三卡| 欧美亚洲动漫制服丝袜| av色综合久久天堂av综合| 国产一区二区三区av电影 | 偷窥少妇高潮呻吟av久久免费| 中文字幕+乱码+中文字幕一区| 精品国产乱码久久久久久1区2区| 欧美日韩在线播| 色偷偷久久人人79超碰人人澡| 成人永久看片免费视频天堂| 激情亚洲综合在线| 日韩精品成人一区二区在线| 一区二区三区免费看视频| 亚洲色图欧洲色图| 亚洲婷婷在线视频| 亚洲色欲色欲www| 国产欧美一区二区在线观看| 久久亚洲综合色| 欧美大胆人体bbbb| 日韩一区二区电影| 337p日本欧洲亚洲大胆色噜噜| 欧美sm美女调教| 日韩你懂的在线观看| 日韩精品一区二区三区在线观看| 91精品国产黑色紧身裤美女| 51午夜精品国产| 欧美一区二区三区免费观看视频 | 国产一本一道久久香蕉| 国产精品1区2区| 懂色av中文字幕一区二区三区| 国产精品18久久久久久久网站| 国产一区二区视频在线| 国产高清成人在线| www.日韩精品| 欧美专区亚洲专区| 欧美日本高清视频在线观看| 91精品国产免费| 欧美videos中文字幕| 久久综合久久综合亚洲| 国产日韩三级在线| 亚洲日本在线观看| 午夜欧美在线一二页| 日日骚欧美日韩| 国产一区二区精品在线观看| 成人国产视频在线观看| 在线精品视频免费观看| 欧美一区二区福利在线| 欧美国产欧美综合| 亚洲线精品一区二区三区| 免费一级片91| 粉嫩高潮美女一区二区三区| 91久久线看在观草草青青| 欧美日本在线观看| 久久久久久久久久久久久女国产乱| 国产欧美一区二区三区鸳鸯浴 | 手机精品视频在线观看| 国产精品一级二级三级| 色综合久久久久| 欧美一级日韩一级| 国产精品另类一区| 性做久久久久久| 国产精品中文字幕一区二区三区| 91免费看片在线观看| 日韩欧美国产1| 日韩一区中文字幕| 久久精品国产一区二区三| 99国产精品国产精品毛片| 日韩一区二区电影| 亚洲精品免费一二三区| 久久成人精品无人区| 91免费版在线看| 欧美电影免费观看完整版| 亚洲视频狠狠干| 久久99精品久久久久婷婷| 91在线国产观看| www久久精品| 五月激情综合婷婷| 99精品欧美一区| 2023国产精品| 日韩av在线播放中文字幕| www.在线欧美| 国产日韩欧美一区二区三区乱码| 亚洲一区二区三区四区的| 成人av在线播放网址| 日韩欧美一区二区不卡| 夜夜嗨av一区二区三区中文字幕 | 91免费看`日韩一区二区| 久久婷婷成人综合色| 亚洲电影一级片| 色天天综合久久久久综合片| 日本一区二区视频在线观看| 青娱乐精品在线视频| 欧美综合天天夜夜久久| 亚洲视频精选在线| 成人av在线资源网| 久久久青草青青国产亚洲免观| 日韩av在线发布| 欧美日韩视频第一区| 亚洲综合激情另类小说区| www.欧美亚洲| 国产精品丝袜久久久久久app| 久久国产尿小便嘘嘘尿| 欧美疯狂性受xxxxx喷水图片| 亚洲免费av观看| av资源站一区| 国产精品丝袜91| 成人免费不卡视频| 国产精品素人视频| 成人精品小蝌蚪| 国产精品久久久久久户外露出| 国产伦精品一区二区三区在线观看 | 精品国产免费久久| 久久精品72免费观看| 欧美电影免费观看高清完整版 | 国产a区久久久| 欧美国产欧美综合| 成人精品小蝌蚪| 1区2区3区精品视频| 99国产精品国产精品久久| 国产精品视频你懂的| 不卡大黄网站免费看| 亚洲欧洲精品天堂一级| 91啪亚洲精品| 亚洲国产aⅴ成人精品无吗| 欧美天天综合网| 青青草视频一区| 精品欧美一区二区在线观看| 国产中文字幕一区| 国产精品乱码久久久久久| 波多野结衣亚洲| 一区二区三区国产精品| 91黄色激情网站| 日韩电影免费一区| 亚洲精品一区二区在线观看| 国产二区国产一区在线观看| 国产精品视频在线看| 在线中文字幕不卡| 强制捆绑调教一区二区| 26uuu国产一区二区三区| 国产不卡高清在线观看视频| 国产精品麻豆网站| 欧美日韩一区国产| 黑人巨大精品欧美一区| 中文字幕免费不卡在线| 91麻豆成人久久精品二区三区| 亚洲午夜视频在线| 欧美videos大乳护士334| 不卡av在线免费观看| 洋洋成人永久网站入口| 日韩一卡二卡三卡| caoporen国产精品视频| 亚洲18女电影在线观看| 久久久国产精品不卡| 在线精品亚洲一区二区不卡| 久久99精品国产91久久来源| 国产精品大尺度| 欧美一区二区福利在线| 波多野洁衣一区| 日韩激情一区二区| 国产精品第四页| 日韩欧美中文一区| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 中文字幕制服丝袜成人av| 欧美精品色综合| 成人午夜伦理影院| 日韩av电影免费观看高清完整版 | 免费看日韩a级影片| 国产精品网曝门| 欧美区一区二区三区| 成人黄色综合网站| 蜜桃视频在线观看一区二区| 国产精品福利一区二区| 日韩精品一区二区三区蜜臀 | 国产欧美一区二区三区在线看蜜臀| 欧美日韩精品一区二区三区蜜桃| 国产精品一区不卡| 日韩电影在线一区二区三区| 亚洲视频一区二区免费在线观看| 精品国产百合女同互慰| 欧美日韩精品系列| 91视频com| 国产福利一区在线观看|