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

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

?? ioctl.c

?? 微軟的point of sale的源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*++

Copyright (c) 1999  Microsoft Corporation

Module Name:

    ioctl.c

Abstract: POS (serial) interface for USB Point-of-Sale devices

Author:

    Karan Mehra [t-karanm]

Environment:

    Kernel mode

Revision History:


--*/

#include <WDM.H>

#include <usbdi.h>
#include "usbdlib.h"
#include <usbioctl.h>

#include "escpos.h"
#include "debug.h"



NTSTATUS Ioctl(POSPDOEXT *pdoExt, PIRP irp)
{
    NTSTATUS status = STATUS_SUCCESS;
    PIO_STACK_LOCATION irpSp;
    KIRQL oldIrql;

    irp->IoStatus.Information = 0;
    irpSp = IoGetCurrentIrpStackLocation(irp);

    /* 
     *  Private Ioctls for applications to be able to get the device's pretty name and attributes.
     */
    switch (irpSp->Parameters.DeviceIoControl.IoControlCode){

        case IOCTL_SERIAL_QUERY_DEVICE_NAME:
            return QueryDeviceName(pdoExt, irp);

        case IOCTL_SERIAL_QUERY_DEVICE_ATTR: {

            if (irpSp->Parameters.DeviceIoControl.OutputBufferLength < sizeof(ULONG))
                return STATUS_BUFFER_TOO_SMALL; 

            irp->IoStatus.Information = sizeof(ULONG);

            KeAcquireSpinLock(&pdoExt->parentFdoExt->devExtSpinLock, &oldIrql);
            *(PULONG)irp->AssociatedIrp.SystemBuffer = pdoExt->parentFdoExt->posFlag;
            KeReleaseSpinLock(&pdoExt->parentFdoExt->devExtSpinLock, oldIrql);
            return status;
        }
    }
    /* 
     *  The following Ioctl calls are ONLY for Serial Emulation.
     */
    if(!(pdoExt->parentFdoExt->posFlag & SERIAL_EMULATION)) {
        DBGVERBOSE(("Serial Emulation NOT supported by this device - Ioctl Rejected."));
        return STATUS_NOT_SUPPORTED;
    }

    switch (irpSp->Parameters.DeviceIoControl.IoControlCode){

        case IOCTL_SERIAL_GET_STATS: {

            if (irpSp->Parameters.DeviceIoControl.OutputBufferLength < sizeof(SERIALPERF_STATS)) {
                status = STATUS_BUFFER_TOO_SMALL;
                break;
            }

            irp->IoStatus.Information = sizeof(SERIALPERF_STATS);
            irp->IoStatus.Status = STATUS_SUCCESS;

            KeAcquireSpinLock(&pdoExt->devExtSpinLock, &oldIrql);
            *(PSERIALPERF_STATS)irp->AssociatedIrp.SystemBuffer = pdoExt->fakePerfStats;
            KeReleaseSpinLock(&pdoExt->devExtSpinLock, oldIrql);
            break;
        }

        case IOCTL_SERIAL_CLEAR_STATS: {

            KeAcquireSpinLock(&pdoExt->devExtSpinLock, &oldIrql);
            RtlZeroMemory(&pdoExt->fakePerfStats, sizeof(SERIALPERF_STATS));
            KeReleaseSpinLock(&pdoExt->devExtSpinLock, oldIrql);
            break;
        }

        case IOCTL_SERIAL_GET_PROPERTIES: {

            PSERIAL_COMMPROP properties = (PSERIAL_COMMPROP)irp->AssociatedIrp.SystemBuffer;

            if (irpSp->Parameters.DeviceIoControl.OutputBufferLength < sizeof(SERIAL_COMMPROP)) {
                status = STATUS_BUFFER_TOO_SMALL; 
                break;
            }
		
            irp->IoStatus.Information = sizeof(SERIAL_COMMPROP);
            irp->IoStatus.Status = STATUS_SUCCESS;

            RtlZeroMemory(properties, sizeof(SERIAL_COMMPROP)); 

            properties->PacketLength   = sizeof(SERIAL_COMMPROP);
            properties->PacketVersion  = 2;
            properties->ServiceMask    = SERIAL_SP_SERIALCOMM;
            properties->MaxTxQueue     = 0;
            properties->MaxRxQueue     = 0;

            properties->MaxBaud        = SERIAL_BAUD_115200;
            properties->SettableBaud   = pdoExt->supportedBauds;
            properties->ProvSubType    = SERIAL_SP_MODEM;

            properties->ProvCapabilities = SERIAL_PCF_DTRDSR        | SERIAL_PCF_RTSCTS
              	                         | SERIAL_PCF_SPECIALCHARS  | SERIAL_PCF_PARITY_CHECK
                                         | SERIAL_PCF_TOTALTIMEOUTS | SERIAL_PCF_INTTIMEOUTS;

            properties->SettableParams = SERIAL_SP_PARITY       | SERIAL_SP_BAUD        | SERIAL_SP_DATABITS
                                       | SERIAL_SP_STOPBITS     | SERIAL_SP_HANDSHAKING | SERIAL_SP_PARITY_CHECK 
                                       | SERIAL_SP_CARRIER_DETECT;

            properties->SettableData  = SERIAL_DATABITS_5 | SERIAL_DATABITS_6
                                      | SERIAL_DATABITS_7 | SERIAL_DATABITS_8;

            properties->SettableStopParity = SERIAL_STOPBITS_10 | SERIAL_STOPBITS_15 | SERIAL_STOPBITS_20 
                                           | SERIAL_PARITY_NONE | SERIAL_PARITY_ODD  | SERIAL_PARITY_EVEN 
                                           | SERIAL_PARITY_MARK | SERIAL_PARITY_SPACE;

            properties->CurrentTxQueue = 0;

            KeAcquireSpinLock(&pdoExt->devExtSpinLock, &oldIrql);
            properties->CurrentRxQueue = pdoExt->fakeRxSize;
            KeReleaseSpinLock(&pdoExt->devExtSpinLock, oldIrql);
            break;
        }

        case IOCTL_SERIAL_GET_MODEMSTATUS: {

            if (irpSp->Parameters.DeviceIoControl.OutputBufferLength < sizeof(ULONG)) {
                status = STATUS_BUFFER_TOO_SMALL; 
                break;
            }

            irp->IoStatus.Information = sizeof(ULONG);
            irp->IoStatus.Status = STATUS_SUCCESS;

            KeAcquireSpinLock(&pdoExt->devExtSpinLock, &oldIrql);
            *(PULONG)irp->AssociatedIrp.SystemBuffer = pdoExt->fakeModemStatus;
            KeReleaseSpinLock(&pdoExt->devExtSpinLock, oldIrql);
            break;
        }
 
        case IOCTL_SERIAL_GET_COMMSTATUS: {

            PSERIAL_STATUS commStatus = (PSERIAL_STATUS)irp->AssociatedIrp.SystemBuffer;

            if (irpSp->Parameters.DeviceIoControl.OutputBufferLength < sizeof(SERIAL_STATUS)) {
                status = STATUS_BUFFER_TOO_SMALL; 
                break;
            }

            irp->IoStatus.Information = sizeof(SERIAL_STATUS);
            irp->IoStatus.Status = STATUS_SUCCESS;

            commStatus->Errors            = 0;
            commStatus->HoldReasons       = 0;
            commStatus->AmountInInQueue   = 100;
            commStatus->AmountInOutQueue  = 0;
            commStatus->EofReceived       = FALSE;
            commStatus->WaitForImmediate  = 0;
            break;
        }

        case IOCTL_SERIAL_RESET_DEVICE: {

            break;								
        }
	    
        case IOCTL_SERIAL_GET_BAUD_RATE: {

            if (irpSp->Parameters.DeviceIoControl.OutputBufferLength < sizeof(SERIAL_BAUD_RATE)) {
                status = STATUS_BUFFER_TOO_SMALL;
                break;
            }

            irp->IoStatus.Information = sizeof(SERIAL_BAUD_RATE);
            irp->IoStatus.Status = STATUS_SUCCESS;

            KeAcquireSpinLock(&pdoExt->devExtSpinLock, &oldIrql);
            ((PSERIAL_BAUD_RATE)irp->AssociatedIrp.SystemBuffer)->BaudRate = pdoExt->baudRate;
            KeReleaseSpinLock(&pdoExt->devExtSpinLock, oldIrql);
            break;
        }

        case IOCTL_SERIAL_SET_BAUD_RATE: {

            if (irpSp->Parameters.DeviceIoControl.InputBufferLength < sizeof(SERIAL_BAUD_RATE)) {
                status = STATUS_BUFFER_TOO_SMALL; 
                break;
            }

            irp->IoStatus.Status = STATUS_SUCCESS;

            KeAcquireSpinLock(&pdoExt->devExtSpinLock, &oldIrql);
            pdoExt->baudRate = ((PSERIAL_BAUD_RATE)irp->AssociatedIrp.SystemBuffer)->BaudRate;
            KeReleaseSpinLock(&pdoExt->devExtSpinLock, oldIrql);
            break;
        }

        case IOCTL_SERIAL_GET_LINE_CONTROL: {

            if (irpSp->Parameters.DeviceIoControl.OutputBufferLength < sizeof(SERIAL_LINE_CONTROL)) {
                status = STATUS_BUFFER_TOO_SMALL; 
                break;
            }

            irp->IoStatus.Information = sizeof(SERIAL_LINE_CONTROL);
            irp->IoStatus.Status = STATUS_SUCCESS;

            KeAcquireSpinLock(&pdoExt->devExtSpinLock, &oldIrql);
            *(PSERIAL_LINE_CONTROL)irp->AssociatedIrp.SystemBuffer = pdoExt->fakeLineControl;
            KeReleaseSpinLock(&pdoExt->devExtSpinLock, oldIrql);
            break;
        }

        case IOCTL_SERIAL_SET_LINE_CONTROL: {

            if (irpSp->Parameters.DeviceIoControl.InputBufferLength < sizeof(SERIAL_LINE_CONTROL)) {
                status = STATUS_BUFFER_TOO_SMALL; 
                break;
            }
	    
            irp->IoStatus.Status = STATUS_SUCCESS;

            KeAcquireSpinLock(&pdoExt->devExtSpinLock, &oldIrql);
            pdoExt->fakeLineControl = *(PSERIAL_LINE_CONTROL)irp->AssociatedIrp.SystemBuffer;
            KeReleaseSpinLock(&pdoExt->devExtSpinLock, oldIrql);
            break;
        }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本亚洲视频在线| 久久成人精品无人区| 午夜久久久久久电影| 国产在线观看一区二区| 欧美日韩精品久久久| 国产精品免费av| 日韩电影免费一区| 91高清视频在线| 中国色在线观看另类| 视频一区免费在线观看| 色哟哟一区二区| 国产精品欧美经典| 国产精一区二区三区| 在线播放视频一区| 悠悠色在线精品| 91伊人久久大香线蕉| 精品欧美久久久| 日本不卡视频在线| 欧美日韩一区高清| 亚洲男人的天堂av| 99久久er热在这里只有精品15| 精品久久人人做人人爽| 日韩黄色在线观看| 欧美欧美欧美欧美首页| 亚洲最色的网站| 91在线一区二区三区| 欧美国产国产综合| 国产成人av电影在线| 精品久久久久久久久久久久包黑料| 亚洲成a天堂v人片| 欧美丝袜丝交足nylons| 亚洲精品乱码久久久久久日本蜜臀| 高清av一区二区| 国产偷国产偷亚洲高清人白洁| 国产呦精品一区二区三区网站| 日韩精品一区二区三区四区视频 | 日韩和欧美一区二区| 在线一区二区三区| 亚洲一二三四在线观看| 欧美日韩一区三区| 日本亚洲视频在线| 日韩免费在线观看| 国产一区二区伦理| 日本一区二区三区视频视频| 成人免费高清在线观看| 国产精品久久久久三级| 99免费精品在线观看| 一区二区三区欧美视频| 欧美无砖砖区免费| 午夜精品福利久久久| 欧美日韩不卡视频| 久久99精品国产麻豆不卡| 精品久久久久久无| 粉嫩av一区二区三区粉嫩| 国产精品伦理在线| 欧美午夜精品久久久| 免费成人在线视频观看| 久久精品这里都是精品| 99精品视频中文字幕| 亚洲一区二区精品3399| 欧美电影免费观看高清完整版在线观看| 一区二区三区免费观看| 678五月天丁香亚洲综合网| 青青青爽久久午夜综合久久午夜| 久久久精品tv| 欧美最猛黑人xxxxx猛交| 美女网站色91| 国产精品久久久久国产精品日日 | 3751色影院一区二区三区| 狠狠色狠狠色综合日日91app| 欧美精彩视频一区二区三区| 在线观看欧美日本| 国产精品一区二区久久不卡| 亚洲女人的天堂| 欧美一区二区三区电影| 成人激情小说乱人伦| 亚洲综合av网| 久久久久国产免费免费| 欧美无砖砖区免费| 国产91精品欧美| 日韩中文字幕亚洲一区二区va在线| 久久综合资源网| 欧美亚洲动漫制服丝袜| 国产精品一区二区黑丝| 午夜影院在线观看欧美| 国产精品传媒视频| 精品国产99国产精品| 欧美亚洲综合久久| 成人app下载| 久久国产麻豆精品| 丝袜诱惑亚洲看片| 一区二区中文视频| 国产丝袜在线精品| 欧美xxx久久| 欧美日韩黄色影视| 色狠狠综合天天综合综合| 夫妻av一区二区| 久久精品国产成人一区二区三区 | 狠狠色综合播放一区二区| 亚洲成人动漫一区| 亚洲美女视频在线| 中文字幕 久热精品 视频在线| 日韩一区国产二区欧美三区| 色94色欧美sute亚洲线路二| 国产aⅴ综合色| 狠狠色丁香婷婷综合久久片| 三级亚洲高清视频| 天天操天天色综合| 无码av中文一区二区三区桃花岛| 亚洲天堂成人在线观看| 国产精品人成在线观看免费 | 欧美一区二区三区在线看| 欧洲亚洲国产日韩| 欧美日韩一级黄| 欧美丝袜丝交足nylons| 欧美色视频在线| 欧美日韩久久一区| 欧美日韩国产大片| 91精品免费观看| 日韩欧美亚洲另类制服综合在线| 欧美一区二区免费| 欧美va亚洲va国产综合| 久久亚洲私人国产精品va媚药| 中文字幕一区二区三区四区不卡 | 亚洲欧洲一区二区在线播放| 国产精品国产三级国产普通话99 | 欧美mv日韩mv| 久久久一区二区三区捆绑**| 久久精品日韩一区二区三区| 国产片一区二区三区| 国产精品网曝门| 国产精品国产馆在线真实露脸| 中文字幕成人网| 亚洲精品视频免费观看| 夜夜嗨av一区二区三区网页| 亚洲一二三区视频在线观看| 丝袜脚交一区二区| 看电视剧不卡顿的网站| 国产麻豆精品在线观看| 成人av综合在线| 色综合久久综合中文综合网| 在线一区二区三区| 欧美一区二区视频网站| 国产日本欧洲亚洲| 亚洲午夜日本在线观看| 国产一区中文字幕| 99热精品一区二区| 在线成人av影院| 欧美极品少妇xxxxⅹ高跟鞋| 一级日本不卡的影视| 毛片不卡一区二区| 成人性生交大片免费| 欧美精品三级在线观看| 国产婷婷一区二区| 亚洲成人动漫在线观看| 国产a精品视频| 欧美精选一区二区| 欧美激情一区二区在线| 日日摸夜夜添夜夜添精品视频| 国产精品一区一区| 欧美日韩激情一区| 中文字幕一区二区三区四区| 亚洲成人在线网站| 不卡视频一二三| 日韩免费视频一区二区| 亚洲视频你懂的| 激情久久五月天| 欧美怡红院视频| 国产精品毛片高清在线完整版| 免费看欧美女人艹b| 91极品视觉盛宴| 国产天堂亚洲国产碰碰| 日本欧美肥老太交大片| 色综合久久综合网97色综合| 亚洲欧美偷拍另类a∨色屁股| 久久er99精品| 91麻豆免费视频| 国产精品人成在线观看免费| 经典三级视频一区| 777午夜精品免费视频| 亚洲精品国产a| av影院午夜一区| 久久久精品综合| 精品中文字幕一区二区小辣椒| 91国产免费看| 亚洲女与黑人做爰| av在线播放成人| 中文字幕亚洲精品在线观看| 国产高清在线精品| 日韩精品一区在线| 欧美bbbbb| 欧美一区二区在线观看| 亚洲成av人在线观看| 91国模大尺度私拍在线视频| 日韩理论片中文av| 色丁香久综合在线久综合在线观看| 欧美国产国产综合| av资源网一区| 亚洲人精品一区| 99视频精品免费视频|