int transferred = 0;
ret = libusb_bulk_transfer(dev->usb_device, 0x81, buffer, len, &transferred, 0);
- if (ret != 0 || (unsigned int)transferred != len) {
+ if (ret < 0) {
+ error(dev->ctx, "USB bulk transfer failed (%s)\n", libusb_error_name(ret));
+ return ret;
+ } else if (ret != 0 || (unsigned int)transferred != len) {
error(dev->ctx, "ret: %d\ttransferred: %d (expected %u)\n",
ret, transferred, len);
return ret;
trace_dump_buffer(dev->ctx, "sending -->", buffer, len);
ret = libusb_bulk_transfer(dev->usb_device, 0x1, buffer, len, &transferred, 0);
- if (ret != 0 || (unsigned int)transferred != len) {
+ if (ret < 0) {
+ error(dev->ctx, "USB bulk transfer failed (%s)\n", libusb_error_name(ret));
+ return ret;
+ } else if (ret != 0 || (unsigned int)transferred != len) {
error(dev->ctx, "ret: %d\ttransferred: %d (expected %u)\n",
ret, transferred, len);
return ret;
num_devices = libusb_get_device_list(ctx->usb_context, &list);
if (num_devices < 0) {
+ error(ctx, "USB get device list failed (%s)\n", libusb_error_name(num_devices));
ret = -ENODEV;
goto out;
}
unsigned int j;
ret = libusb_get_device_descriptor(list[i], &desc);
- if (ret < 0)
+ if (ret < 0) {
+ debug(ctx, "USB get device descriptor failed (%s)\n", libusb_error_name(ret));
continue;
+ }
for (j = 0; j < ARRAY_SIZE(supported_devices); j++) {
if (desc.idVendor == supported_devices[j].vendor_id
ret = libusb_open(list[i], &((*dev)->usb_device));
if (ret < 0) {
- debug(ctx, "libusb_open failed\n");
+ debug(ctx, "libusb_open failed (%s)\n", libusb_error_name(ret));
goto out;
}
(*ctx)->log_level = AM7XXX_LOG_TRACE;
ret = libusb_init(&((*ctx)->usb_context));
- if (ret < 0)
+ if (ret < 0) {
+ fatal("USB initialization failed (%s)\n", libusb_error_name(ret));
goto out_free_context;
+ }
libusb_set_debug((*ctx)->usb_context, 3);
return send_data(dev, image, image_size);
}
-AM7XXX_PUBLIC int am7xxx_set_power_mode(am7xxx_device *dev, am7xxx_power_mode mode)
+AM7XXX_PUBLIC int am7xxx_set_power_mode(am7xxx_device *dev, am7xxx_power_mode power)
{
int ret;
struct am7xxx_header h = {
.unknown3 = 0x10,
};
- switch(mode) {
+ switch(power) {
case AM7XXX_POWER_OFF:
h.header_data.power.bit2 = 0;
h.header_data.power.bit1 = 0;
break;
default:
- error(dev->ctx, "Power mode not supported!\n");
+ error(dev->ctx, "Unsupported power mode.\n");
return -EINVAL;
};