atten-pps3xxx: Use serial_timeout().

This commit is contained in:
Bert Vermeulen 2014-10-06 12:12:13 +02:00
parent c5cfc735e5
commit 2eb1612d46
3 changed files with 7 additions and 16 deletions

View File

@ -92,10 +92,9 @@ static GSList *scan(GSList *options, int modelid)
struct sr_serial_dev_inst *serial; struct sr_serial_dev_inst *serial;
GSList *l, *devices; GSList *l, *devices;
struct pps_model *model; struct pps_model *model;
float byte_delay_ms;
uint8_t packet[PACKET_SIZE]; uint8_t packet[PACKET_SIZE];
unsigned int i; unsigned int i;
int ret; int delay_ms, ret;
const char *conn, *serialcomm; const char *conn, *serialcomm;
char channel[10]; char channel[10];
@ -127,20 +126,12 @@ static GSList *scan(GSList *options, int modelid)
return NULL; return NULL;
serial_flush(serial); 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. */ /* This is how the vendor software scans for hardware. */
memset(packet, 0, PACKET_SIZE); memset(packet, 0, PACKET_SIZE);
packet[0] = 0xaa; packet[0] = 0xaa;
packet[1] = 0xaa; packet[1] = 0xaa;
if (serial_write_blocking(serial, packet, PACKET_SIZE, delay_ms = serial_timeout(serial, PACKET_SIZE);
byte_delay_ms * PACKET_SIZE + 1) < PACKET_SIZE) { if (serial_write_blocking(serial, packet, PACKET_SIZE, delay_ms) < PACKET_SIZE) {
sr_err("Unable to write while probing for hardware."); sr_err("Unable to write while probing for hardware.");
return NULL; return NULL;
} }
@ -188,7 +179,7 @@ static GSList *scan(GSList *options, int modelid)
devc = g_malloc0(sizeof(struct dev_context)); devc = g_malloc0(sizeof(struct dev_context));
devc->model = model; devc->model = model;
devc->config = g_malloc0(sizeof(struct per_channel_config) * model->num_channels); 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; sdi->priv = devc;
drvc->instances = g_slist_append(drvc->instances, sdi); drvc->instances = g_slist_append(drvc->instances, sdi);
devices = g_slist_append(devices, sdi); devices = g_slist_append(devices, sdi);

View File

@ -88,8 +88,7 @@ SR_PRIV void send_packet(const struct sr_dev_inst *sdi, uint8_t *packet)
devc = sdi->priv; devc = sdi->priv;
serial = sdi->conn; serial = sdi->conn;
if (serial_write_blocking(serial, packet, PACKET_SIZE, if (serial_write_blocking(serial, packet, PACKET_SIZE, devc->delay_ms) < PACKET_SIZE)
devc->byte_delay_ms * PACKET_SIZE + 1) < PACKET_SIZE)
sr_dbg("Failed to send packet."); sr_dbg("Failed to send packet.");
dump_packet("sent", packet); dump_packet("sent", packet);
} }

View File

@ -82,7 +82,8 @@ struct dev_context {
/* Operational state */ /* Operational state */
gboolean config_dirty; gboolean config_dirty;
struct per_channel_config *config; struct per_channel_config *config;
float byte_delay_ms; /* Blocking write timeout for packet. */
int delay_ms;
/* Received from device. */ /* Received from device. */
int channel_mode; int channel_mode;
gboolean over_current_protection; gboolean over_current_protection;