精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

使用同步接口讀取鼠標數據的方法

麥辣雞腿堡 ? 來源:嵌入式Linux系統開發 ? 作者:韋東山老師驅動大 ? 2023-07-17 17:42 ? 次閱讀

編寫源碼

#include < errno.h >
#include < signal.h >
#include < stdio.h >
#include < stdlib.h >
#include < string.h >

#include < libusb-1.0/libusb.h >

int main(int argc, char **argv)
{
    int err;
    libusb_device *dev, **devs;
    int num_devices;
    int endpoint;
    int interface_num;
    int found = 0;
    int transferred;
    int count = 0;
    unsigned char buffer[16];
    struct libusb_config_descriptor *config_desc;
    struct libusb_device_handle *dev_handle = NULL;
    
    /* libusb_init */
    err = libusb_init(NULL);
    if (err < 0) {
        fprintf(stderr, "failed to initialise libusb %d - %sn", err, libusb_strerror(err));
        exit(1);
    }

    /* get device list */
    if ((num_devices = libusb_get_device_list(NULL, &devs)) < 0) {
        fprintf(stderr, "libusb_get_device_list() failedn");
        libusb_exit(NULL);
        exit(1);
    }
    fprintf(stdout, "libusb_get_device_list() okn");

    /* for each device, get config descriptor */
    for (int i = 0; i < num_devices; i++) {
        dev = devs[i];

        /* parse interface descriptor, find usb mouse */        
        err = libusb_get_config_descriptor(dev, 0, &config_desc);
        if (err) {
            fprintf(stderr, "could not get configuration descriptorn");
            continue;
        }
        fprintf(stdout, "libusb_get_config_descriptor() okn");

        for (int interface = 0; interface < config_desc- >bNumInterfaces; interface++) {
            const struct libusb_interface_descriptor *intf_desc = &config_desc- >interface[interface].altsetting[0];
            interface_num = intf_desc- >bInterfaceNumber;

            if (intf_desc- >bInterfaceClass != 3 || intf_desc- >bInterfaceProtocol != 2)
                continue;
            else
            {
                /* 找到了USB鼠標 */
                fprintf(stdout, "find usb mouse okn");
                for (int ep = 0; ep < intf_desc- >bNumEndpoints; ep++)
                {
                    if ((intf_desc- >endpoint[ep].bmAttributes & 3) == LIBUSB_TRANSFER_TYPE_INTERRUPT ||
                            (intf_desc- >endpoint[ep].bEndpointAddress & 0x80) == LIBUSB_ENDPOINT_IN) {
                        /* 找到了輸入的中斷端點 */
                        fprintf(stdout, "find in int endpointn");
                        endpoint = intf_desc- >endpoint[ep].bEndpointAddress;
                        found = 1;
                        break;
                    }
                    
                }
            }

            if (found)
                break;
        }

        libusb_free_config_descriptor(config_desc);
        
        if (found)
            break;        
    }

    if (!found)
    {
        /* free device list */
        libusb_free_device_list(devs, 1);
        libusb_exit(NULL);
        exit(1);
    }

    if (found)
    {
        /* libusb_open */
        err = libusb_open(dev, &dev_handle);
        if (err)
        {
            fprintf(stderr, "failed to open usb mousen");
            exit(1);
        }
        fprintf(stdout, "libusb_open okn");
    }

    /* free device list */
    libusb_free_device_list(devs, 1);

    /* claim interface */
    libusb_set_auto_detach_kernel_driver(dev_handle, 1);  
    err = libusb_claim_interface(dev_handle, interface_num);
    if (err)
    {
        fprintf(stderr, "failed to libusb_claim_interfacen");
        exit(1);
    }
    fprintf(stdout, "libusb_claim_interface okn");

    /* libusb_interrupt_transfer */
    while (1)
    {
        err = libusb_interrupt_transfer(dev_handle, endpoint, buffer, 16, &transferred, 5000);
        if (!err) {
            /* parser data */
            printf("%04d datas: ", count++);
            for (int i = 0; i < transferred; i++)
            {
                printf("%02x ", buffer[i]);
            }
            printf("n");
        } else if (err == LIBUSB_ERROR_TIMEOUT){
            fprintf(stderr, "libusb_interrupt_transfer timoutn");
        } else {
            fprintf(stderr, "libusb_interrupt_transfer err : %dn", err);
            //exit(1);
        }
        
    }

    /* libusb_close */
    libusb_release_interface(dev_handle, interface_num);
    libusb_close(dev_handle);
    libusb_exit(NULL);
}

2.2 上機實驗

2.2.1 在 Ubuntu 上實驗

// 1. 安裝開發包
$ sudo apt install libusb-1.0-0-dev
    
// 2. 修改源碼,包含libusb.h 頭文件時用如下代碼
#include < libusb-1.0/libusb.h >

// 3. 編譯程序指定庫
gcc -o readmouse readmouse.c -lusb-1.0

2.2.2 在 IMX6ULL 開發板上實驗

  • 交叉編譯 libusb
    sudo apt-get install libtool
    
    unzip libusb-1.0.26.zip
    cd libusb-1.0.26
    ./autogen.sh
    
    ./configure --host=arm-buildroot-linux-gnueabihf --prefix=$PWD/tmp
    
    make
    
    make install
    
    ls tmp/
    include  lib
    
  • 安裝庫、頭文件到工具鏈的目錄里
    libusb-1.0.26/tmp/lib$ cp * -rfd /home/book/100ask_imx6ull-sdk/ToolChain/arm-buildroot-linux-gnueabihf_sdk-buildroot/arm-buildroot-linux-gnueabihf/sysroot/usr/lib/
    
    libusb-1.0.26/tmp/include$ cp libusb-1.0 -rf /home/book/100ask_imx6ull-sdk/ToolChain/arm-buildroot-linux-gnueabihf_sdk-buildroot/arm-buildroot-linux-gnueabihf/sysroot/usr/include/
    
  • 交叉編譯 app
    arm-buildroot-linux-gnueabihf-gcc -o  readmouse.c -lusb-1.0
    
  • 在開發板上插入 USB 鼠標,執行命令
    ./readmouse
    
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 接口
    +關注

    關注

    33

    文章

    8504

    瀏覽量

    150840
  • usb
    usb
    +關注

    關注

    60

    文章

    7900

    瀏覽量

    264006
  • 鼠標
    +關注

    關注

    6

    文章

    589

    瀏覽量

    39727
收藏 人收藏

    評論

    相關推薦

    STM32讀取鼠標芯片<原相的PAN3204>移動數據的問題

    不能讀取到移動的數據(不管怎么動鼠標讀取數據就是不動,從紅色LED可以看出芯片檢測到移動了),找了很久的問題還是不行,所以來這個論壇找找
    發表于 02-28 13:35

    PS2鼠標使用USB接口的轉換器

    鼠標與控制器間履行一種雙向同步串行數據幀協議,每幀為11~12Bit,如圖3所示。按照標準的三鍵鼠標數據包有效
    發表于 12-06 10:14

    嵌入式設備鼠標接口的設計與實現

    接口采用一種雙向同步串行協議。即每在時鐘線上發一個脈沖,就在數據線上發送一位數據。在相互傳輸中,主機擁有總線控制權,即它可以在任何時候抑制鼠標
    發表于 12-14 10:58

    PS/2鼠標和單片機的接口

    鼠標有RS232串口和PS/2二種接口,在單片機應用中,由于PS/2鼠標是1yrL電平,和單片接口更方便,通常PS/2鼠標控制芯片采用TP8
    發表于 10-22 23:00 ?121次下載
    PS/2<b class='flag-5'>鼠標</b>和單片機的<b class='flag-5'>接口</b>

    鼠標接口

    鼠標接口7.1   鼠標的工作原理1.  鼠標分機械式鼠標和光電式鼠標
    發表于 06-12 22:18 ?43次下載

    基于PS/2鼠標接口單片機輸入設備的實現

    基于PS/2鼠標接口單片機輸入設備的實現:詳細介紹了PS/2鼠標/鍵盤接口的工作原理.提出了基于PS/2接口的三鍵
    發表于 10-27 18:30 ?82次下載

    PS 2鼠標接口轉串行鼠標轉接器

    PS 2鼠標接口轉串行鼠標轉接器 本轉換口把一個串行鼠標接到 PS/2 鼠標口上,到鼠
    發表于 11-27 20:08 ?909次閱讀
    PS 2<b class='flag-5'>鼠標</b><b class='flag-5'>接口</b>轉串行<b class='flag-5'>鼠標</b>轉接器

    計算機鼠標接口

    計算機鼠標接口 目前,市場中的多
    發表于 07-25 08:15 ?2604次閱讀

    鼠標接口類型

    鼠標接口類型 接口類型是指鼠標與電腦主機之間相連接的接口方式或類型。目前常見的鼠標
    發表于 12-28 11:26 ?2118次閱讀

    什么是主板PS/2鼠標接口

    什么是主板PS/2鼠標接口  PS/2鼠標接口:現今的一些流行的Pentium
    發表于 02-05 11:46 ?1544次閱讀

    通過I2C兼容接口讀取ADC數據

    本應用筆記討論了通過I2C兼容接口讀取多字節數據時需要特別注意的地方。介紹了每次讀取一個字節時容易出現的問題,并給出了幾個具體示例。本文也描述了進行
    發表于 08-26 22:13 ?877次閱讀
    通過I2C兼容<b class='flag-5'>接口</b><b class='flag-5'>讀取</b>ADC<b class='flag-5'>數據</b>

    KVM遠程鼠標同步方法

    提出一種基于高速USB2.0-HID 類規范的鼠標同步方法。在傳統相對鼠標同步方法中加入自適應殘
    發表于 05-10 11:50 ?6664次閱讀
    KVM遠程<b class='flag-5'>鼠標</b><b class='flag-5'>同步</b><b class='flag-5'>方法</b>

    鼠標PS2接口改USB方法

    現在,大多數最新的筆記本電腦已經放棄了PS2接口,但是很多用戶都是要外接鼠標的,特別是要求效率高的或者是作圖用途的用戶更是如此。這就有一個問題了,以前買的PS2接口鼠標用不上了,一個
    的頭像 發表于 09-17 10:47 ?8.4w次閱讀

    使用鼠標失靈時的解決方法

    步驟一:出現問題的鼠標一般以USB接口鼠標居多,原因當然不外乎鼠標自身和USB接口問題了,首先我們來看看是否是
    的頭像 發表于 07-04 11:21 ?3610次閱讀

    關于從I2C接口上的ADC讀取數據及處理方法

    本應用筆記討論了通過I2C兼容接口讀取多字節數據時需要注意的問題。討論了一次讀取一個字節的陷阱,并提供了一些具體示例。本文還介紹了處理此類數據
    的頭像 發表于 01-29 15:53 ?2007次閱讀
    關于從I2C<b class='flag-5'>接口</b>上的ADC<b class='flag-5'>讀取</b><b class='flag-5'>數據</b>及處理<b class='flag-5'>方法</b>