From 1bd9e678ac2c00c4b6336ed2506c28cdcfe3a25c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?poljar=20=28Damir=20Jeli=C4=87=29?= Date: Fri, 25 Oct 2013 18:13:20 +0200 Subject: [PATCH] serial: Add function to extract serial options. This patch adds a function for a common operation of all serial based drivers. It extracts the serial options from the options linked list that is passed down to every hardware driver. --- hardware/common/serial.c | 42 ++++++++++++++++++++++++++++++++++++++++ libsigrok-internal.h | 2 ++ 2 files changed, 44 insertions(+) diff --git a/hardware/common/serial.c b/hardware/common/serial.c index c131b38a..e181f233 100644 --- a/hardware/common/serial.c +++ b/hardware/common/serial.c @@ -596,3 +596,45 @@ SR_PRIV int serial_stream_detect(struct sr_serial_dev_inst *serial, return SR_ERR; } + +/** + * Extract the serial device and options from the options linked list. + * + * @param options List of options passed from the command line. + * @param serial_device Pointer where to store the exctracted serial device. + * @param serial_options Pointer where to store the optional extracted serial + * options. + * + * @return SR_OK if a serial_device is found, SR_ERR if no device is found. The + * returned string should not be freed by the caller. + */ +SR_PRIV int sr_serial_extract_options(GSList *options, const char **serial_device, + const char **serial_options) +{ + GSList *l; + struct sr_config *src; + + *serial_device = NULL; + + for (l = options; l; l = l->next) { + src = l->data; + switch (src->key) { + case SR_CONF_CONN: + *serial_device = g_variant_get_string(src->data, NULL); + sr_dbg("Parsed serial device: %s", *serial_device); + break; + + case SR_CONF_SERIALCOMM: + *serial_options = g_variant_get_string(src->data, NULL); + sr_dbg("Parsed serial options: %s", *serial_options); + break; + } + } + + if (!*serial_device) { + sr_dbg("No serial device specified"); + return SR_ERR; + } + + return SR_OK; +} diff --git a/libsigrok-internal.h b/libsigrok-internal.h index e36f3165..970c799f 100644 --- a/libsigrok-internal.h +++ b/libsigrok-internal.h @@ -219,6 +219,8 @@ SR_PRIV int serial_stream_detect(struct sr_serial_dev_inst *serial, uint8_t *buf, size_t *buflen, size_t packet_size, packet_valid_t is_valid, uint64_t timeout_ms, int baudrate); +SR_PRIV int sr_serial_extract_options(GSList *options, const char **serial_device, + const char **serial_options); #endif /*--- hardware/common/ezusb.c -----------------------------------------------*/