• <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)  編輯 收藏 引用

            導航

            <2008年12月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            統計

            常用鏈接

            留言簿(19)

            隨筆檔案

            文章檔案

            收藏夾

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久亚洲AV成人无码电影| 亚洲国产精品高清久久久| 久久久av波多野一区二区| 99久久这里只精品国产免费| 国产福利电影一区二区三区久久久久成人精品综合 | 国产精品伊人久久伊人电影 | 亚洲精品乱码久久久久久按摩| 欧美麻豆久久久久久中文| 日本精品久久久久影院日本| 久久九九免费高清视频| 久久久青草青青国产亚洲免观| 国产精品综合久久第一页| 久久这里只有精品视频99| 思思久久好好热精品国产| 少妇人妻综合久久中文字幕| 少妇熟女久久综合网色欲| 无码人妻少妇久久中文字幕蜜桃 | 婷婷国产天堂久久综合五月| 欧美亚洲国产精品久久| 亚洲日本va中文字幕久久| 久久91精品国产91久久麻豆| 国产高潮久久免费观看| 香蕉久久夜色精品国产尤物| 亚洲级αV无码毛片久久精品| 国产精品99久久99久久久| yellow中文字幕久久网| 三级韩国一区久久二区综合| 亚洲精品乱码久久久久久中文字幕| 成人综合伊人五月婷久久| 久久久久亚洲av成人无码电影| 久久久久久精品久久久久| 久久国产精品99久久久久久老狼 | 久久精品国产亚洲AV影院| 国产精品久久国产精麻豆99网站 | 亚洲国产精品无码久久久久久曰| 97精品国产97久久久久久免费| 久久精品人人做人人爽电影蜜月| 成人精品一区二区久久| 无遮挡粉嫩小泬久久久久久久| 久久e热在这里只有国产中文精品99| 久久AV高潮AV无码AV|