• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            windows sdk編程系列文章 ---- 遍歷USB設備,獲取掃描儀序列號之一

            理論:
                對于USB接口的設備,現在越來越多了。本篇我們就通過獲取一個USB掃描儀設備中的序列號,來介紹如何獲取usb設備的一些硬件信息。對于usb設備都是采用HCD0,HCD1,HCD2,HCD3等符號描述的。如下圖:

            因此,有了這個名字,我們就可以使用CreateFile來打開usb設備。然后使用DeviceIoControl函數與usb設備通訊了。HCD是host controller driver的簡寫。需要了解詳情的,還要仔細的閱讀usb協議。
            usb的通訊基本步驟如下圖所示:
            基本步驟:
                1)打開HCD%X
                2) 得到上面的USB root hub
                3) 遍歷usb root hub上連接的usb 設備。獲取信息
                4)如果有多個usb口,循環前3步。

            下面介紹通訊用的幾個IOCTL:
            1)USB_HCD_DRIVERKEY_NAME ,用于獲取USB設備驅動在注冊表中的鍵名。相應的一個結構體是:
            typedef struct _USB_HCD_DRIVERKEY_NAME
            {
               ULONG   ActualLength;

               WCHAR   DriverKeyName[1];

            } USB_HCD_DRIVERKEY_NAME, *PUSB_HCD_DRIVERKEY_NAME;


            2)IOCTL_USB_GET_ROOT_HUB_NAME,用于獲取root hub 鍵名。使用的結構體,跟上面一樣。
            typedef struct _USB_ROOT_HUB_NAME
            {
                ULONG ActualLength;
                WCHAR RootHubName[1];
            } USB_ROOT_HUB_NAME, *PUSB_ROOT_HUB_NAME;

            3IOCTL_USB_GET_NODE_INFORMATION,
            用于獲取連接在root hub上的節點設備信息。也就是我們接在usb口上的所有usb設備的信息,對應的結構體:
            typedef struct _USB_NODE_INFORMATION
            {
                USB_HUB_NODE NodeType;   
                union {
                    USB_HUB_INFORMATION HubInformation;
                    USB_MI_PARENT_INFORMATION MiParentInformation;
                } u;
            } USB_NODE_INFORMATION, *PUSB_NODE_INFORMATION;

            typedef struct _USB_MI_PARENT_INFORMATION
            {
                ULONG NumberOfInterfaces;
            } USB_MI_PARENT_INFORMATION, *PUSB_MI_PARENT_INFORMATION;

            typedef struct _USB_HUB_INFORMATION
            {
                USB_HUB_DESCRIPTOR HubDescriptor;

                BOOLEAN HubIsBusPowered;

            } USB_HUB_INFORMATION, *PUSB_HUB_INFORMATION;


            typedef struct _USB_HUB_DESCRIPTOR
            {
                UCHAR        bDescriptorLength;      // Length of this descriptor
                UCHAR        bDescriptorType;        // Hub configuration type
                UCHAR        bNumberOfPorts;         // number of ports on this hub
                USHORT       wHubCharacteristics;    // Hub Charateristics
                UCHAR        bPowerOnToPowerGood;    // port power on till power good in 2ms
                UCHAR        bHubControlCurrent;     // max current in mA
                //
                // room for 255 ports power control and removable bitmask
                UCHAR        bRemoveAndPowerMask[64];      
            } USB_HUB_DESCRIPTOR, *PUSB_HUB_DESCRIPTOR;


            4) IOCTL_USB_GET_NODE_CONNECTION_INFORMATION, 用于獲取接在usb口上的單個usb設備的信息,對應的結構體:

            typedef struct _USB_NODE_CONNECTION_INFORMATION
            {
                ULONG ConnectionIndex;
                USB_DEVICE_DESCRIPTOR DeviceDescriptor;
                UCHAR CurrentConfigurationValue;
                BOOLEAN LowSpeed;

                BOOLEAN DeviceIsHub;

                USHORT DeviceAddress;

                ULONG NumberOfOpenPipes;

                USB_CONNECTION_STATUS ConnectionStatus;
                USB_PIPE_INFO PipeList[0];
            } USB_NODE_CONNECTION_INFORMATION, *PUSB_NODE_CONNECTION_INFORMATION;

            4)IOCTL_USB_GET_DESCRIPTOR_FROM_NODE_CONNECTION, 用于獲取usb設備的描述信息。
            typedef struct _USB_DEVICE_DESCRIPTOR
            {
                UCHAR bLength;
                UCHAR bDescriptorType;
                USHORT bcdUSB;
                UCHAR bDeviceClass;
                UCHAR bDeviceSubClass;
                UCHAR bDeviceProtocol;
                UCHAR bMaxPacketSize0;
                USHORT idVendor;
                USHORT idProduct;
                USHORT bcdDevice;
                UCHAR iManufacturer;
                UCHAR iProduct;
                UCHAR iSerialNumber;
                UCHAR bNumConfigurations;
            } USB_DEVICE_DESCRIPTOR, *PUSB_DEVICE_DESCRIPTOR;

            typedef struct _USB_DEVICE_DESCRIPTOR
            {
                UCHAR bLength;
                UCHAR bDescriptorType;
                USHORT bcdUSB;
                UCHAR bDeviceClass;
                UCHAR bDeviceSubClass;
                UCHAR bDeviceProtocol;
                UCHAR bMaxPacketSize0;
                USHORT idVendor;
                USHORT idProduct;
                USHORT bcdDevice;
                UCHAR iManufacturer;
                UCHAR iProduct;
                UCHAR iSerialNumber;
                UCHAR bNumConfigurations;
            } USB_DEVICE_DESCRIPTOR, *PUSB_DEVICE_DESCRIPTOR;

            typedef enum _USB_CONNECTION_STATUS
            {
                NoDeviceConnected,
                DeviceConnected,

                /* failure codes, these map to fail reasons */
                DeviceFailedEnumeration,
                DeviceGeneralFailure,
                DeviceCausedOvercurrent,
                DeviceNotEnoughPower,
                DeviceNotEnoughBandwidth,
                DeviceHubNestedTooDeeply,
                DeviceInLegacyHub
            } USB_CONNECTION_STATUS, *PUSB_CONNECTION_STATUS;

            typedef struct _USB_PIPE_INFO
            {
                USB_ENDPOINT_DESCRIPTOR EndpointDescriptor;
                ULONG ScheduleOffset;
            } USB_PIPE_INFO, *PUSB_PIPE_INFO;

            typedef struct _USB_ENDPOINT_DESCRIPTOR
            {
                UCHAR bLength;
                UCHAR bDescriptorType;
                UCHAR bEndpointAddress;
                UCHAR bmAttributes;
                USHORT wMaxPacketSize;
                UCHAR bInterval;
            } USB_ENDPOINT_DESCRIPTOR, *PUSB_ENDPOINT_DESCRIPTOR;

            需要注意一點,如果要得到pid,vid,則直接從
            USB_DEVICE_DESCRIPTOR結構中取出idVendor,idProduct這兩項的值就行了。如果要得到序列號,則不是取出 iSerialNumber就可以的。這里的 iSerialNumber僅僅是一個索引值。如果想得到序列號,就需要定義一個結構,然后給設備發送個請求。請求的結構如下圖:

            代碼參照GetStringDescriptor函數。可以根據iSerialNumber偏移,取出其對應的字符串,存放在上圖USB_STRING_DESCRIPTOR結構中。

            posted on 2010-11-17 10:25 wrh 閱讀(3157) 評論(0)  編輯 收藏 引用

            導航

            <2010年11月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            統計

            常用鏈接

            留言簿(19)

            隨筆檔案

            文章檔案

            收藏夾

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产色综合久久无码有码| 久久综合久久性久99毛片| 久久99精品久久久久婷婷| 国内精品久久久久久野外| 香蕉久久夜色精品国产小说| 久久精品一区二区国产| 久久久久无码国产精品不卡| 久久亚洲sm情趣捆绑调教| 国内精品久久久人妻中文字幕| 国产午夜精品久久久久九九| 久久久无码精品亚洲日韩京东传媒| 人妻无码αv中文字幕久久 | 国产Av激情久久无码天堂| 久久天天躁狠狠躁夜夜av浪潮| 国产亚洲综合久久系列| 久久WWW免费人成—看片| 精品久久久久久久无码| 色偷偷91久久综合噜噜噜噜| 国产成人精品免费久久久久| 精品久久久久久久久免费影院| 国产精品久久久久久影院 | 亚洲国产成人久久综合一 | av色综合久久天堂av色综合在| 精品熟女少妇aⅴ免费久久| 精品久久8x国产免费观看| 天堂久久天堂AV色综合| 久久久亚洲裙底偷窥综合| 久久综合久久伊人| 久久一区二区三区免费| 国内精品久久久久久久久电影网| 国产产无码乱码精品久久鸭| 中文字幕热久久久久久久| 久久天天躁夜夜躁狠狠| 欧美亚洲日本久久精品| 无码任你躁久久久久久| 日本精品久久久久久久久免费| 久久精品国产精品亚洲下载 | 久久久久久一区国产精品| 久久天天躁狠狠躁夜夜2020| 久久天天躁狠狠躁夜夜av浪潮| 久久99精品国产麻豆蜜芽|