HI , is it possible to add these ioctls to hidraw interface ? 1) ioctl with which application can get input / output feature report and size . 2) ioctl which sets a flag so that when device sends a report , report id & report type is prefixed to output of read() . i mean when application calls read , it gets input report as <report id ><report type ><payload > right now we get <payload > only . this kind of read() output helps in situation where a application specific payload is dispersed across multiple input reports but using same report id . the functionality which is desired above is same as provided by HIDDEV_FLAG_REPORT for hiddev interface . Thanx & Regards Amit Nagal On Wed, Jun 30, 2010 at 2:26 AM, Jiri Kosina <jkosina@xxxxxxx> wrote: > On Tue, 29 Jun 2010, Alan Ott wrote: > >> > i am trying to send a vendor specific HID report from a userspace host >> > program to vendor usb hid device >> > using HIDRAW interface . >> > >> > >> > but when i send report in the format< "Report ID "(0th byte )> >> > <Report ID (1st byte )> < "data payload"> >> > i am getting perfect report response from usb device . >> > where we use usb_control_msg as : >> > >> > ret = usb_control_msg(dev, usb_sndctrlpipe(dev, 0), >> > HID_REQ_SET_REPORT, >> > USB_DIR_OUT | USB_TYPE_CLASS | USB_RECIP_INTERFACE, >> > cpu_to_le16(((HID_OUTPUT_REPORT + 1)<< 8) | *buf), >> > interface->desc.bInterfaceNumber, buf + 1, count - 1, >> > USB_CTRL_SET_TIMEOUT); >> > >> > >> >> I thought I'd be able to just go check the HID specification and be able to >> say that the report number is not sent as part of the payload for Set_Report >> devices, since it would be redundant because the Report ID is sent over in the >> wValue field. >> >> Unfortunately, I was not able to see that clearly laid out in the HID >> specification in the section on Set_Report. I did however find language saying >> "if a Report ID tag was used in the Report descriptor, all reports include a >> single byte ID prefix," in section 8.1, Report Types. >> >> I did some tests with the Windows implementation, and indeed, when numbered >> reports are used in the HID descriptor, the Windows implementation will send >> the report ID as the first byte of the payload. >> >> Based on the language in the HID spec, and the behavior of Windows, I believe >> the buf+1, count-1 to be a bug. >> >> Jiri, what do you think? Can you confirm? > > Correct, it is a bug indeed. > > Does any of you guys already have a patch handy which I could apply? > Otherwise I'll fix it myself. > > Thanks for spotting it, > > -- > Jiri Kosina > SUSE Labs, Novell Inc. > -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html