X-Git-Url: http://sigrok.org/gitweb/?a=blobdiff_plain;f=hwdriver.c;h=88b0006060a0de1ec53b872dbd12e60ff5de34a1;hb=b6bad47c91a7cbc19571cbe49918a0612ad2babe;hp=25d92b68a9d7b95543820e7624750e7e663ab120;hpb=8e34ca86fb54ec1c841724900006868e29b180fa;p=libsigrok.git diff --git a/hwdriver.c b/hwdriver.c index 25d92b68..88b00060 100644 --- a/hwdriver.c +++ b/hwdriver.c @@ -1,5 +1,5 @@ /* - * This file is part of the sigrok project. + * This file is part of the libsigrok project. * * Copyright (C) 2013 Bert Vermeulen * @@ -160,11 +160,15 @@ extern SR_PRIV struct sr_dev_driver radioshack_22_805_driver_info; extern SR_PRIV struct sr_dev_driver radioshack_22_812_driver_info; extern SR_PRIV struct sr_dev_driver voltcraft_vc820_ser_driver_info; extern SR_PRIV struct sr_dev_driver voltcraft_vc840_ser_driver_info; +extern SR_PRIV struct sr_dev_driver uni_t_ut61d_ser_driver_info; extern SR_PRIV struct sr_dev_driver uni_t_ut61e_ser_driver_info; #endif #ifdef HAVE_HW_UNI_T_DMM +extern SR_PRIV struct sr_dev_driver tecpel_dmm_8061_driver_info; extern SR_PRIV struct sr_dev_driver uni_t_ut61d_driver_info; +extern SR_PRIV struct sr_dev_driver uni_t_ut61e_driver_info; extern SR_PRIV struct sr_dev_driver voltcraft_vc820_driver_info; +extern SR_PRIV struct sr_dev_driver voltcraft_vc840_driver_info; #endif /** @endcond */ @@ -242,11 +246,15 @@ static struct sr_dev_driver *drivers_list[] = { &radioshack_22_812_driver_info, &voltcraft_vc820_ser_driver_info, &voltcraft_vc840_ser_driver_info, + &uni_t_ut61d_ser_driver_info, &uni_t_ut61e_ser_driver_info, #endif #ifdef HAVE_HW_UNI_T_DMM + &tecpel_dmm_8061_driver_info, &uni_t_ut61d_driver_info, + &uni_t_ut61e_driver_info, &voltcraft_vc820_driver_info, + &voltcraft_vc840_driver_info, #endif NULL, }; @@ -410,6 +418,9 @@ SR_API int sr_config_get(const struct sr_dev_driver *driver, int key, if (!driver || !data) return SR_ERR; + if (!driver->config_get) + return SR_ERR_ARG; + if ((ret = driver->config_get(key, data, sdi)) == SR_OK) { /* Got a floating reference from the driver. Sink it here, * caller will need to unref when done with it. */ @@ -474,8 +485,10 @@ SR_API int sr_config_list(const struct sr_dev_driver *driver, int key, { int ret; - if (!driver || !data || !driver->config_list) + if (!driver || !data) ret = SR_ERR; + else if (!driver->config_list) + ret = SR_ERR_ARG; else if ((ret = driver->config_list(key, data, sdi)) == SR_OK) g_variant_ref_sink(*data);