libusb: Add transfer type filter to get correct ep
The need for this due to AICE having 3 interfaces (EP1 IN-Interrupt, EP2 OUT-Bulk, EP6 IN-Bulk). Without it, the function will choose first two endpoint as read_ep/write_ep. This filter will check transfer types when get endpoint-id. Without this patch, AICE will not get correct endpoint. Change-Id: I4da93c7de41cd19e5095b4bfb42078b21f40b678 Signed-off-by: Hellosun Wu <wujiheng.tw@gmail.com> Reviewed-on: http://openocd.zylin.com/3218 Tested-by: jenkins Reviewed-by: Hsiangkai Wang <hsiangkai@gmail.com> Reviewed-by: Freddie Chopin <freddie.chopin@gmail.com>
This commit is contained in:
parent
45f0e6d062
commit
8f3d16f4ae
|
@ -2135,10 +2135,16 @@ static int aice_usb_open(struct aice_port_param_s *param)
|
||||||
|
|
||||||
/* usb_set_configuration required under win32 */
|
/* usb_set_configuration required under win32 */
|
||||||
jtag_libusb_set_configuration(devh, 0);
|
jtag_libusb_set_configuration(devh, 0);
|
||||||
|
jtag_libusb_claim_interface(devh, 0);
|
||||||
|
|
||||||
unsigned int aice_read_ep;
|
unsigned int aice_read_ep;
|
||||||
unsigned int aice_write_ep;
|
unsigned int aice_write_ep;
|
||||||
jtag_libusb_choose_interface(devh, &aice_read_ep, &aice_write_ep, -1, -1, -1);
|
#ifdef HAVE_LIBUSB1
|
||||||
|
jtag_libusb_choose_interface(devh, &aice_read_ep, &aice_write_ep, -1, -1, -1, LIBUSB_TRANSFER_TYPE_BULK);
|
||||||
|
#else
|
||||||
|
jtag_libusb_choose_interface(devh, &aice_read_ep, &aice_write_ep, -1, -1, -1, USB_ENDPOINT_TYPE_BULK);
|
||||||
|
#endif
|
||||||
|
LOG_DEBUG("aice_read_ep=0x%x, aice_write_ep=0x%x", aice_read_ep, aice_write_ep);
|
||||||
|
|
||||||
aice_handler.usb_read_ep = aice_read_ep;
|
aice_handler.usb_read_ep = aice_read_ep;
|
||||||
aice_handler.usb_write_ep = aice_write_ep;
|
aice_handler.usb_write_ep = aice_write_ep;
|
||||||
|
|
|
@ -146,7 +146,7 @@ int jtag_libusb_set_configuration(jtag_libusb_device_handle *devh,
|
||||||
int jtag_libusb_choose_interface(struct jtag_libusb_device_handle *devh,
|
int jtag_libusb_choose_interface(struct jtag_libusb_device_handle *devh,
|
||||||
unsigned int *usb_read_ep,
|
unsigned int *usb_read_ep,
|
||||||
unsigned int *usb_write_ep,
|
unsigned int *usb_write_ep,
|
||||||
int bclass, int subclass, int protocol)
|
int bclass, int subclass, int protocol, int trans_type)
|
||||||
{
|
{
|
||||||
struct jtag_libusb_device *udev = jtag_libusb_get_device(devh);
|
struct jtag_libusb_device *udev = jtag_libusb_get_device(devh);
|
||||||
struct usb_interface *iface = udev->config->interface;
|
struct usb_interface *iface = udev->config->interface;
|
||||||
|
@ -157,7 +157,8 @@ int jtag_libusb_choose_interface(struct jtag_libusb_device_handle *devh,
|
||||||
for (int i = 0; i < desc->bNumEndpoints; i++) {
|
for (int i = 0; i < desc->bNumEndpoints; i++) {
|
||||||
if ((bclass > 0 && desc->bInterfaceClass != bclass) ||
|
if ((bclass > 0 && desc->bInterfaceClass != bclass) ||
|
||||||
(subclass > 0 && desc->bInterfaceSubClass != subclass) ||
|
(subclass > 0 && desc->bInterfaceSubClass != subclass) ||
|
||||||
(protocol > 0 && desc->bInterfaceProtocol != protocol))
|
(protocol > 0 && desc->bInterfaceProtocol != protocol) ||
|
||||||
|
(trans_type > 0 && (desc->endpoint[i].bmAttributes & 0x3) != trans_type))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
uint8_t epnum = desc->endpoint[i].bEndpointAddress;
|
uint8_t epnum = desc->endpoint[i].bEndpointAddress;
|
||||||
|
|
|
@ -67,7 +67,7 @@ int jtag_libusb_set_configuration(jtag_libusb_device_handle *devh,
|
||||||
int jtag_libusb_choose_interface(struct jtag_libusb_device_handle *devh,
|
int jtag_libusb_choose_interface(struct jtag_libusb_device_handle *devh,
|
||||||
unsigned int *usb_read_ep,
|
unsigned int *usb_read_ep,
|
||||||
unsigned int *usb_write_ep,
|
unsigned int *usb_write_ep,
|
||||||
int bclass, int subclass, int protocol);
|
int bclass, int subclass, int protocol, int trans_type);
|
||||||
int jtag_libusb_get_pid(struct jtag_libusb_device *dev, uint16_t *pid);
|
int jtag_libusb_get_pid(struct jtag_libusb_device *dev, uint16_t *pid);
|
||||||
|
|
||||||
#endif /* OPENOCD_JTAG_DRIVERS_LIBUSB0_COMMON_H */
|
#endif /* OPENOCD_JTAG_DRIVERS_LIBUSB0_COMMON_H */
|
||||||
|
|
|
@ -187,7 +187,7 @@ int jtag_libusb_set_configuration(jtag_libusb_device_handle *devh,
|
||||||
int jtag_libusb_choose_interface(struct jtag_libusb_device_handle *devh,
|
int jtag_libusb_choose_interface(struct jtag_libusb_device_handle *devh,
|
||||||
unsigned int *usb_read_ep,
|
unsigned int *usb_read_ep,
|
||||||
unsigned int *usb_write_ep,
|
unsigned int *usb_write_ep,
|
||||||
int bclass, int subclass, int protocol)
|
int bclass, int subclass, int protocol, int trans_type)
|
||||||
{
|
{
|
||||||
struct jtag_libusb_device *udev = jtag_libusb_get_device(devh);
|
struct jtag_libusb_device *udev = jtag_libusb_get_device(devh);
|
||||||
const struct libusb_interface *inter;
|
const struct libusb_interface *inter;
|
||||||
|
@ -210,6 +210,8 @@ int jtag_libusb_choose_interface(struct jtag_libusb_device_handle *devh,
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
epdesc = &interdesc->endpoint[k];
|
epdesc = &interdesc->endpoint[k];
|
||||||
|
if (trans_type > 0 && (epdesc->bmAttributes & 0x3) != trans_type)
|
||||||
|
continue;
|
||||||
|
|
||||||
uint8_t epnum = epdesc->bEndpointAddress;
|
uint8_t epnum = epdesc->bEndpointAddress;
|
||||||
bool is_input = epnum & 0x80;
|
bool is_input = epnum & 0x80;
|
||||||
|
|
|
@ -69,12 +69,13 @@ int jtag_libusb_set_configuration(jtag_libusb_device_handle *devh,
|
||||||
* @param bclass `bInterfaceClass` to match, or -1 to ignore this field.
|
* @param bclass `bInterfaceClass` to match, or -1 to ignore this field.
|
||||||
* @param subclass `bInterfaceSubClass` to match, or -1 to ignore this field.
|
* @param subclass `bInterfaceSubClass` to match, or -1 to ignore this field.
|
||||||
* @param protocol `bInterfaceProtocol` to match, or -1 to ignore this field.
|
* @param protocol `bInterfaceProtocol` to match, or -1 to ignore this field.
|
||||||
|
* @param trans_type `bmAttributes Bits 0..1 Transfer type` to match, or -1 to ignore this field.
|
||||||
* @returns Returns ERROR_OK on success, ERROR_FAIL otherwise.
|
* @returns Returns ERROR_OK on success, ERROR_FAIL otherwise.
|
||||||
*/
|
*/
|
||||||
int jtag_libusb_choose_interface(struct jtag_libusb_device_handle *devh,
|
int jtag_libusb_choose_interface(struct jtag_libusb_device_handle *devh,
|
||||||
unsigned int *usb_read_ep,
|
unsigned int *usb_read_ep,
|
||||||
unsigned int *usb_write_ep,
|
unsigned int *usb_write_ep,
|
||||||
int bclass, int subclass, int protocol);
|
int bclass, int subclass, int protocol, int trans_type);
|
||||||
int jtag_libusb_get_pid(struct jtag_libusb_device *dev, uint16_t *pid);
|
int jtag_libusb_get_pid(struct jtag_libusb_device *dev, uint16_t *pid);
|
||||||
|
|
||||||
#endif /* OPENOCD_JTAG_DRIVERS_LIBUSB1_COMMON_H */
|
#endif /* OPENOCD_JTAG_DRIVERS_LIBUSB1_COMMON_H */
|
||||||
|
|
|
@ -459,7 +459,7 @@ static int openjtag_init_cy7c65215(void)
|
||||||
|
|
||||||
ret = jtag_libusb_choose_interface(usbh, &ep_in, &ep_out,
|
ret = jtag_libusb_choose_interface(usbh, &ep_in, &ep_out,
|
||||||
CY7C65215_JTAG_CLASS,
|
CY7C65215_JTAG_CLASS,
|
||||||
CY7C65215_JTAG_SUBCLASS, -1);
|
CY7C65215_JTAG_SUBCLASS, -1, LIBUSB_TRANSFER_TYPE_BULK);
|
||||||
if (ret != ERROR_OK) {
|
if (ret != ERROR_OK) {
|
||||||
LOG_ERROR("unable to claim JTAG interface");
|
LOG_ERROR("unable to claim JTAG interface");
|
||||||
goto err;
|
goto err;
|
||||||
|
|
Loading…
Reference in New Issue