From 2eb1612d463e9232af437d9a6c1b3897da2367e9 Mon Sep 17 00:00:00 2001 From: Bert Vermeulen Date: Mon, 6 Oct 2014 12:12:13 +0200 Subject: [PATCH] atten-pps3xxx: Use serial_timeout(). --- src/hardware/atten-pps3xxx/api.c | 17 ++++------------- src/hardware/atten-pps3xxx/protocol.c | 3 +-- src/hardware/atten-pps3xxx/protocol.h | 3 ++- 3 files changed, 7 insertions(+), 16 deletions(-) diff --git a/src/hardware/atten-pps3xxx/api.c b/src/hardware/atten-pps3xxx/api.c index 68dec6b0..5bbafca8 100644 --- a/src/hardware/atten-pps3xxx/api.c +++ b/src/hardware/atten-pps3xxx/api.c @@ -92,10 +92,9 @@ static GSList *scan(GSList *options, int modelid) struct sr_serial_dev_inst *serial; GSList *l, *devices; struct pps_model *model; - float byte_delay_ms; uint8_t packet[PACKET_SIZE]; unsigned int i; - int ret; + int delay_ms, ret; const char *conn, *serialcomm; char channel[10]; @@ -127,20 +126,12 @@ static GSList *scan(GSList *options, int modelid) return NULL; serial_flush(serial); - /* How long it takes for a byte to transfer over the serial port. */ - if (sp_get_port_transport(serial->data) == SP_TRANSPORT_NATIVE) - /* 11 bits at 9600 bps. */ - byte_delay_ms = 1.15; - else - /* Emulated serial over USB or bluetooth is just enqueueing. */ - byte_delay_ms = 0; - /* This is how the vendor software scans for hardware. */ memset(packet, 0, PACKET_SIZE); packet[0] = 0xaa; packet[1] = 0xaa; - if (serial_write_blocking(serial, packet, PACKET_SIZE, - byte_delay_ms * PACKET_SIZE + 1) < PACKET_SIZE) { + delay_ms = serial_timeout(serial, PACKET_SIZE); + if (serial_write_blocking(serial, packet, PACKET_SIZE, delay_ms) < PACKET_SIZE) { sr_err("Unable to write while probing for hardware."); return NULL; } @@ -188,7 +179,7 @@ static GSList *scan(GSList *options, int modelid) devc = g_malloc0(sizeof(struct dev_context)); devc->model = model; devc->config = g_malloc0(sizeof(struct per_channel_config) * model->num_channels); - devc->byte_delay_ms = byte_delay_ms; + devc->delay_ms = delay_ms; sdi->priv = devc; drvc->instances = g_slist_append(drvc->instances, sdi); devices = g_slist_append(devices, sdi); diff --git a/src/hardware/atten-pps3xxx/protocol.c b/src/hardware/atten-pps3xxx/protocol.c index 98838b65..e7d9d810 100644 --- a/src/hardware/atten-pps3xxx/protocol.c +++ b/src/hardware/atten-pps3xxx/protocol.c @@ -88,8 +88,7 @@ SR_PRIV void send_packet(const struct sr_dev_inst *sdi, uint8_t *packet) devc = sdi->priv; serial = sdi->conn; - if (serial_write_blocking(serial, packet, PACKET_SIZE, - devc->byte_delay_ms * PACKET_SIZE + 1) < PACKET_SIZE) + if (serial_write_blocking(serial, packet, PACKET_SIZE, devc->delay_ms) < PACKET_SIZE) sr_dbg("Failed to send packet."); dump_packet("sent", packet); } diff --git a/src/hardware/atten-pps3xxx/protocol.h b/src/hardware/atten-pps3xxx/protocol.h index 2ad9e857..36ee281a 100644 --- a/src/hardware/atten-pps3xxx/protocol.h +++ b/src/hardware/atten-pps3xxx/protocol.h @@ -82,7 +82,8 @@ struct dev_context { /* Operational state */ gboolean config_dirty; struct per_channel_config *config; - float byte_delay_ms; + /* Blocking write timeout for packet. */ + int delay_ms; /* Received from device. */ int channel_mode; gboolean over_current_protection;