• <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 閱讀(3174) 評論(0)  編輯 收藏 引用

            導航

            <2011年3月>
            272812345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            統計

            常用鏈接

            留言簿(19)

            隨筆檔案

            文章檔案

            收藏夾

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            无码精品久久久天天影视| 久久久久久狠狠丁香| 国产69精品久久久久9999| 久久久久女人精品毛片| 久久精品人妻中文系列| 久久人妻少妇嫩草AV无码蜜桃| Xx性欧美肥妇精品久久久久久| 99热都是精品久久久久久| 国产伊人久久| 午夜精品久久久久9999高清| 2021国产精品久久精品| 色欲综合久久中文字幕网| 久久无码人妻一区二区三区午夜| 99久久这里只有精品| 国产精品成人无码久久久久久| 国产精品午夜久久| 久久精品国产AV一区二区三区| 久久久久久毛片免费播放| 国产精品久久久久9999| 久久婷婷五月综合97色直播| 18禁黄久久久AAA片| 国产成人久久激情91 | 日本加勒比久久精品| 亚洲精品午夜国产va久久| 伊人久久大香线蕉av不变影院| 国产午夜免费高清久久影院| 久久久久噜噜噜亚洲熟女综合| 久久久亚洲AV波多野结衣| 亚洲国产精品久久久久久| 一本大道久久东京热无码AV| 久久精品国产精品青草| 久久丝袜精品中文字幕| 久久丫精品国产亚洲av不卡| 久久久久一本毛久久久| 国产精品久久久福利| 精品伊人久久大线蕉色首页| 99久久精品九九亚洲精品| 伊人久久大香线蕉av不变影院 | 精品熟女少妇a∨免费久久| 久久露脸国产精品| 国产成人精品久久一区二区三区av |