อุปกรณ์ USB HID เริ่มทำงานเพียง 1 เหตุการณ์


11

ฉันมี eDIO USB Multi Remote Controller (ตัวรับสัญญาณอินฟราเรด) ที่มาพร้อมกับ ASUS PSR 2000 Web Surfing Remote Control

ฉันกำลังพยายามเชื่อมต่อตัวควบคุมระยะไกลกับไพของฉันเพื่อที่จะได้รับการกดแป้นที่ส่งมาจากระยะไกล

ตรวจพบคอนโทรลเลอร์เป็นอุปกรณ์ HID นี่คือรายละเอียดจากคำสั่ง lsusb -v

    Bus 001 Device 007: ID 147a:e001 Formosa Industrial Computing, Inc.
    Couldn't open device, some information will be missing
    Device Descriptor:
    bLength                18
    bDescriptorType         1
    bcdUSB               1.10
    bDeviceClass            0 (Defined at Interface level)
   bDeviceSubClass         0
   bDeviceProtocol         0
   bMaxPacketSize0         8
   idVendor           0x147a Formosa Industrial Computing, Inc.
   idProduct          0xe001
   bcdDevice            1.22
   iManufacturer           1
   iProduct                2
   iSerial                 0
   bNumConfigurations      1
  Configuration Descriptor:
  bLength                 9
  bDescriptorType         2
wTotalLength           34
bNumInterfaces          1
bConfigurationValue     1
iConfiguration          4
bmAttributes         0xa0
  (Bus Powered)
  Remote Wakeup
MaxPower              300mA
Interface Descriptor:
  bLength                 9
  bDescriptorType         4
  bInterfaceNumber        0
  bAlternateSetting       0
  bNumEndpoints           1
  bInterfaceClass         3 Human Interface Device
  bInterfaceSubClass      1 Boot Interface Subclass
  bInterfaceProtocol      2 Mouse
  iInterface              0
    HID Device Descriptor:
      bLength                 9
      bDescriptorType        33
      bcdHID               1.10
      bCountryCode            0 Not supported
      bNumDescriptors         1
      bDescriptorType        34 Report
      wDescriptorLength      20
     Report Descriptors:
       ** UNAVAILABLE **
  Endpoint Descriptor:
    bLength                 7
    bDescriptorType         5
    bEndpointAddress     0x81  EP 1 IN
    bmAttributes            3
      Transfer Type            Interrupt
      Synch Type               None
      Usage Type               Data
    wMaxPacketSize     0x0004  1x 4 bytes
    bInterval              10

ฉันยังสามารถดูอุปกรณ์เป้าหมายในโฟลเดอร์ dev ด้วยเหตุการณ์ที่สร้างขึ้น

    pi@raspberrypi /dev/input/by-id $ dir
    usb-Cypress_Semiconductor_eDio_USB_Multi_Remote_Controlle-event-if00

ตัวจัดการเหตุการณ์เชื่อมโยงกับเหตุการณ์ดังต่อไปนี้ตามที่เห็นจากคำสั่งต่อไปนี้

pi@raspberrypi /proc/bus/input $ cat devices
I: Bus=0003 Vendor=147a Product=e001 Version=0110
N: Name="Cypress Semiconductor eDio USB Multi Remote Controlle"
P: Phys=usb-bcm2708_usb-1.2/input0
S: Sysfs=/devices/platform/bcm2708_usb/usb1/1-1/1-1.2/1-1.2:1.0/input/input2
U: Uniq=
H: Handlers=event0
B: PROP=0
B: EV=1

ปัญหาคือเมื่อฉันพยายามอ่านผลลัพธ์จากตัวจัดการเหตุการณ์ที่สร้างขึ้นสำหรับอุปกรณ์การกดแป้นแรกถูกลงทะเบียน แต่การกดแป้นครั้งต่อไปจะไม่แสดงโดยคำสั่ง CAT

 pi@raspberrypi /dev/input $ cat event0 | xxd
 0000000: e007 9450 9476 0900 0000 0000 0000 0000  ...P.v..........

โปรดแนะนำฉันฉันจะทำอย่างไรเพื่อให้อุปกรณ์ทำงานได้ การกดปุ่มใด ๆ หลังจากการกดแป้นครั้งแรกจะไม่ส่งคืนสิ่งใดนอกจากว่ามีการเสียบอุปกรณ์

โปรดแนะนำสิ่งที่ต้องทำเพื่อแก้ไขปัญหา


อะไรก็ได้ ??? ฉันไม่รู้จะทำยังไงกับอุปกรณ์ บางทีผู้ดำเนินรายการสามารถช่วยฉันวางกรอบคำถามได้ดีกว่านี้หากมีปัญหาที่นี่
SteveIrwin

คำถามที่ดี อย่างไรก็ตามมันค่อนข้างเป็นภาษาท้องถิ่นดังนั้นฉันจึงมั่นใจว่ามีคนไม่มากที่จะมีปัญหาเดียวกัน มันอาจทำให้คุณสงบใจที่จะรู้ว่าฉันได้เห็นสิ่งที่คล้ายกันมากที่เรือพูดของ Chris Wallace ใช้เพื่อให้คุณสามารถดูได้ สิ่งแรกที่ฉันจะถามเพื่อวินิจฉัยปัญหาคือ คุณกำลังใช้ฮับขับเคลื่อนด้วยตนเองเพราะอาจเป็นปัญหาพลังงาน
Jivings

คุณเคยลอง|xxdไหม มันบัฟเฟอร์เอาต์พุต ฉันใช้irwจากแพ็คเกจlircเพื่อรับรหัสที่ส่งโดยรีโมทของฉัน
macrojames

ไดรเวอร์ที่กำหนดเองจะหมายถึง Linux Kernel Patch ตัวเลือกที่ง่ายกว่าคือการใช้ libusb เนื่องจาก libusb ให้การเข้าถึง USB Endpoint โดยตรง
Lars Pötter

คำตอบ:


5

ดูเหมือนว่าปัญหาจะเป็นตัวให้บริการ USB ที่ไม่สมบูรณ์:

  Couldn't open device, some information will be missing
  Report Descriptors:
  ** UNAVAILABLE **

Descriptor ที่สามารถอ่านได้บอกว่านี่คือเม้าส์

  bInterfaceProtocol      2 Mouse

และจะมี Descriptor ขนาด 20 Bytes ที่อธิบายรูปแบบข้อมูล:

  bDescriptorType        34 Report
  wDescriptorLength      20

แต่คนนั้นหายไป

มีปัญหาแปลก ๆ กับการรวมกันของฮาร์ดแวร์และซอฟต์แวร์หรือโปรแกรมเมอร์เป็นคนขี้เกียจและไม่ได้ใช้ Report Descriptor เนื่องจาก Driver ของพวกเขาอาจไม่ต้องการมัน แต่ส่วนใหญ่อาจทำให้ไดร์เวอร์ที่สร้างอุปกรณ์อินพุตสับสน

คุณสามารถลองใช้ libusb เพื่ออ่าน 4 ไบต์จากจุดปลาย บางทีการสำรวจอาจใช้งานได้ หรือดูที่การสื่อสาร USB เมื่อคุณใช้อุปกรณ์กับไดรเวอร์ดั้งเดิม และใช่นี่เป็นเรื่องยากมากหากคุณไม่ได้มีหนึ่งใน Loggers USB ราคาแพงวางอยู่รอบ ๆ แต่ Linux Kernel นั้นรองรับ Software USB Logging และมีซอฟต์แวร์ Loggers สำหรับ Windows


4

ในที่สุดฉันก็ได้เวลาเขียนการใช้งานของฉันเองโดยใช้ห้องสมุด PyUSB ซึ่งเป็นเสื้อคลุมสำหรับ Libusb

ฉันกำลังโพสต์รหัสที่นี่อาจช่วยใครบางคน

ฉันมีโค้ดอีกชิ้นหนึ่งที่สร้างไฟล์กำหนดค่าซึ่งใช้ที่นี่ฉันไม่ได้แมปรีโมตคีย์ทั้งหมดเนื่องจากฉันไม่ต้องการทั้งหมด

import usb.core
import usb.util
import ConfigParser 
import shlex
import subprocess
import logging

# find our device
diction={
  6402315641282315:'1',
  6402415641282415:'2',
  6402515641282515:'3',
  6402615641282615:'4',
  6402715641282715:'5',
  6402815641282815:'6',
  6402915641282915:'7',
  6403015641283015:'8',
  6403115641283115:'9',
  }



def load_config():
    dict={}
    config = ConfigParser.RawConfigParser()
    config.read('/codes/remote/remote.cfg')

    dict['vendor']=config.getint('Settings','idVendor')

    dict['product']=config.getint('Settings','idProduct')

    dict['interface']=config.getint('Settings', 'interface')

    r=config.options('Key Mappings')

    for item in r:
        if config.get('Key Mappings',item)!='': 
            dict[item]=config.get('Key Mappings',item)
            #print config.get('Key Mappings',item)
    return dict

def pyus():

    try:
        load_log()
        dict=load_config()
        join_int = lambda nums: int(''.join(str(i) for i in nums))
        #print dict

        dev = usb.core.find(idVendor=dict['vendor'], idProduct=dict['product'])
        interface=dict['interface']

        if dev is None:
            raise ValueError('Device not found')

        if dev.is_kernel_driver_active(interface) is True:
                #print "but we need to detach kernel driver"
                dev.detach_kernel_driver(interface)
        #dev.detatch_kernel_driver(interface) 
        # set the active configuration. With no arguments, the first
        # configuration will be the active one
        dev.set_configuration()

        # get an endpoint instance
        cfg = dev.get_active_configuration()
        interface_number = cfg[(0,0)].bInterfaceNumber
        alternate_setting = usb.control.get_interface(dev,interface_number)
        intf = usb.util.find_descriptor(
            cfg, bInterfaceNumber = interface_number,
            bAlternateSetting = alternate_setting
        )

        ep = usb.util.find_descriptor(
            intf,
            # match the first IN endpoint
            custom_match = \
            lambda e: \
                usb.util.endpoint_direction(e.bEndpointAddress) == \
                usb.util.ENDPOINT_IN
        )

        assert ep is not None
        #print 'packet details',ep.bEndpointAddress , ep.wMaxPacketSize

        while 1:
            try:
                data = dev.read(ep.bEndpointAddress, ep.wMaxPacketSize*2,interface,1000)
                data=data.tolist()
                key=join_int(data)
                #print "Key is " , key
                if  key in diction:

                    try:
                        args=shlex.split(dict[diction[key]])
                        #print args
                        p=subprocess.Popen(args, stderr=subprocess.STDOUT, stdout=subprocess.PIPE)
                        #print "Pressed key is ",diction[key]
                    except:
                        pass


            except usb.core.USBError as e:
                pass
    except:
        pass

pyus()
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.