X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=src%2Fhardware%2Fikalogic-scanalogic2%2Fprotocol.c;h=03d5d1bf32df778c0f824b29a8fb5fbc672d1933;hb=9cfc695ffe5f04622f61acb98ea4ac91c3f4ffc3;hp=663ff527a75c42c2851448a3dd716cd983393489;hpb=155b680da482cea2381becb73c51cfb838bff31e;p=libsigrok.git diff --git a/src/hardware/ikalogic-scanalogic2/protocol.c b/src/hardware/ikalogic-scanalogic2/protocol.c index 663ff527..03d5d1bf 100644 --- a/src/hardware/ikalogic-scanalogic2/protocol.c +++ b/src/hardware/ikalogic-scanalogic2/protocol.c @@ -17,16 +17,16 @@ * along with this program. If not, see . */ +#include #include "protocol.h" extern struct sr_dev_driver ikalogic_scanalogic2_driver_info; -static struct sr_dev_driver *di = &ikalogic_scanalogic2_driver_info; extern uint64_t sl2_samplerates[NUM_SAMPLERATES]; static void stop_acquisition(struct sr_dev_inst *sdi) { - struct drv_context *drvc = sdi->driver->priv; + struct drv_context *drvc = sdi->driver->context; struct dev_context *devc; struct sr_datafeed_packet packet; @@ -43,7 +43,7 @@ static void stop_acquisition(struct sr_dev_inst *sdi) static void abort_acquisition(struct sr_dev_inst *sdi) { - struct drv_context *drvc = sdi->driver->priv; + struct drv_context *drvc = sdi->driver->context; struct dev_context *devc; struct sr_datafeed_packet packet; @@ -199,6 +199,7 @@ static void process_sample_data(const struct sr_dev_inst *sdi) SR_PRIV int ikalogic_scanalogic2_receive_data(int fd, int revents, void *cb_data) { struct sr_dev_inst *sdi; + struct sr_dev_driver *di; struct dev_context *devc; struct drv_context *drvc; struct timeval tv; @@ -214,7 +215,8 @@ SR_PRIV int ikalogic_scanalogic2_receive_data(int fd, int revents, void *cb_data if (!(devc = sdi->priv)) return TRUE; - drvc = di->priv; + di = sdi->driver; + drvc = di->context; current_time = g_get_monotonic_time(); if (devc->state == STATE_WAIT_DATA_READY && @@ -257,7 +259,7 @@ SR_PRIV int ikalogic_scanalogic2_receive_data(int fd, int revents, void *cb_data return TRUE; } -SR_PRIV void sl2_receive_transfer_in( struct libusb_transfer *transfer) +SR_PRIV void LIBUSB_CALL sl2_receive_transfer_in( struct libusb_transfer *transfer) { struct sr_dev_inst *sdi; struct dev_context *devc; @@ -268,7 +270,8 @@ SR_PRIV void sl2_receive_transfer_in( struct libusb_transfer *transfer) devc = sdi->priv; if (transfer->status != LIBUSB_TRANSFER_COMPLETED) { - sr_err("Transfer to device failed: %i.", transfer->status); + sr_err("Transfer to device failed: %s.", + libusb_error_name(transfer->status)); devc->transfer_error = TRUE; return; } @@ -388,7 +391,7 @@ SR_PRIV void sl2_receive_transfer_in( struct libusb_transfer *transfer) } } -SR_PRIV void sl2_receive_transfer_out( struct libusb_transfer *transfer) +SR_PRIV void LIBUSB_CALL sl2_receive_transfer_out( struct libusb_transfer *transfer) { struct sr_dev_inst *sdi; struct dev_context *devc; @@ -398,7 +401,8 @@ SR_PRIV void sl2_receive_transfer_out( struct libusb_transfer *transfer) devc = sdi->priv; if (transfer->status != LIBUSB_TRANSFER_COMPLETED) { - sr_err("Transfer to device failed: %i.", transfer->status); + sr_err("Transfer to device failed: %s.", + libusb_error_name(transfer->status)); devc->transfer_error = TRUE; return; } @@ -642,7 +646,7 @@ SR_PRIV int sl2_get_device_info(struct sr_usb_dev_inst usb, uint8_t buffer[PACKET_LENGTH]; int ret; - drvc = di->priv; + drvc = ikalogic_scanalogic2_driver_info.context; if (!dev_info) return SR_ERR_ARG; @@ -753,12 +757,12 @@ SR_PRIV int sl2_transfer_in(libusb_device_handle *dev_handle, uint8_t *data) { return libusb_control_transfer(dev_handle, USB_REQUEST_TYPE_IN, USB_HID_GET_REPORT, USB_HID_REPORT_TYPE_FEATURE, USB_INTERFACE, - (unsigned char *)data, PACKET_LENGTH, USB_TIMEOUT); + (unsigned char *)data, PACKET_LENGTH, USB_TIMEOUT_MS); } SR_PRIV int sl2_transfer_out(libusb_device_handle *dev_handle, uint8_t *data) { return libusb_control_transfer(dev_handle, USB_REQUEST_TYPE_OUT, USB_HID_SET_REPORT, USB_HID_REPORT_TYPE_FEATURE, USB_INTERFACE, - (unsigned char *)data, PACKET_LENGTH, USB_TIMEOUT); + (unsigned char *)data, PACKET_LENGTH, USB_TIMEOUT_MS); }