X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=src%2Fhardware%2Fikalogic-scanalogic2%2Fprotocol.c;h=c58050bbb102e316c3d580108793405f81415f8c;hb=093e1cba6b7bf14cfb77fa36f59b0c16e6fca7cc;hp=c26b32a68de9f53dc565b7ad89a1b04b5cc5861f;hpb=4f840ce965b1c30c5ab75afecc56193cbaf5c1b3;p=libsigrok.git diff --git a/src/hardware/ikalogic-scanalogic2/protocol.c b/src/hardware/ikalogic-scanalogic2/protocol.c index c26b32a6..c58050bb 100644 --- a/src/hardware/ikalogic-scanalogic2/protocol.c +++ b/src/hardware/ikalogic-scanalogic2/protocol.c @@ -17,44 +17,31 @@ * along with this program. If not, see . */ +#include #include "protocol.h" -extern struct sr_dev_driver 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 dev_context *devc; - struct sr_datafeed_packet packet; - - devc = sdi->priv; + struct drv_context *drvc = sdi->driver->context; - /* Remove USB file descriptors from polling. */ usb_source_remove(sdi->session, drvc->sr_ctx); - packet.type = SR_DF_END; - sr_session_send(devc->cb_data, &packet); + std_session_send_df_end(sdi); sdi->status = SR_ST_ACTIVE; } static void abort_acquisition(struct sr_dev_inst *sdi) { - struct drv_context *drvc = sdi->driver->priv; - struct dev_context *devc; - struct sr_datafeed_packet packet; - - devc = sdi->priv; + struct drv_context *drvc = sdi->driver->context; - /* Remove USB file descriptors from polling. */ usb_source_remove(sdi->session, drvc->sr_ctx); - packet.type = SR_DF_END; - sr_session_send(devc->cb_data, &packet); + std_session_send_df_end(sdi); - sdi->driver->dev_close(sdi); + sr_dev_close(sdi); } static void buffer_sample_data(const struct sr_dev_inst *sdi) @@ -137,7 +124,7 @@ static void process_sample_data(const struct sr_dev_inst *sdi) if (devc->trigger_type != TRIGGER_TYPE_NONE && devc->pre_trigger_samples == 0) { packet.type = SR_DF_TRIGGER; - sr_session_send(devc->cb_data, &packet); + sr_session_send(sdi, &packet); } } @@ -175,10 +162,10 @@ static void process_sample_data(const struct sr_dev_inst *sdi) logic.length = n; logic.unitsize = 1; logic.data = buffer; - sr_session_send(devc->cb_data, &packet); + sr_session_send(sdi, &packet); packet.type = SR_DF_TRIGGER; - sr_session_send(devc->cb_data, &packet); + sr_session_send(sdi, &packet); n = 0; } @@ -191,7 +178,7 @@ static void process_sample_data(const struct sr_dev_inst *sdi) logic.length = n; logic.unitsize = 1; logic.data = buffer; - sr_session_send(devc->cb_data, &packet); + sr_session_send(sdi, &packet); } } @@ -215,7 +202,7 @@ SR_PRIV int ikalogic_scanalogic2_receive_data(int fd, int revents, void *cb_data return TRUE; di = sdi->driver; - drvc = di->priv; + drvc = di->context; current_time = g_get_monotonic_time(); if (devc->state == STATE_WAIT_DATA_READY && @@ -258,7 +245,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; @@ -269,7 +256,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; } @@ -389,7 +377,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; @@ -399,7 +387,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; } @@ -636,14 +625,14 @@ SR_PRIV void sl2_calculate_trigger_samples(const struct sr_dev_inst *sdi) devc->post_trigger_bytes = post_trigger_bytes; } -SR_PRIV int sl2_get_device_info(struct sr_usb_dev_inst usb, - struct device_info *dev_info) +SR_PRIV int sl2_get_device_info(struct sr_dev_driver *di, + struct sr_usb_dev_inst usb, struct device_info *dev_info) { struct drv_context *drvc; uint8_t buffer[PACKET_LENGTH]; int ret; - drvc = ikalogic_scanalogic2_driver_info.priv; + drvc = di->context; if (!dev_info) return SR_ERR_ARG; @@ -754,12 +743,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); }