From: Uwe Hermann Date: Fri, 31 May 2013 13:33:58 +0000 (+0200) Subject: asix-sigma: Use std_dev_clear(). X-Git-Tag: libsigrok-0.2.1~77 X-Git-Url: https://sigrok.org/gitaction?a=commitdiff_plain;h=3678cf73fea3c7903eb8887d8bb0dec61cb09e6e;p=libsigrok.git asix-sigma: Use std_dev_clear(). --- diff --git a/hardware/asix-sigma/asix-sigma.c b/hardware/asix-sigma/asix-sigma.c index 154d154b..2ddbbea9 100644 --- a/hardware/asix-sigma/asix-sigma.c +++ b/hardware/asix-sigma/asix-sigma.c @@ -380,32 +380,18 @@ static int bin2bitbang(const char *filename, return SR_OK; } -static int clear_instances(void) +static void clear_helper(void *priv) { - GSList *l; - struct sr_dev_inst *sdi; - struct drv_context *drvc; struct dev_context *devc; + + devc = priv; - drvc = di->priv; - - /* Properly close all devices. */ - for (l = drvc->instances; l; l = l->next) { - if (!(sdi = l->data)) { - /* Log error, but continue cleaning up the rest. */ - sr_err("%s: sdi was NULL, continuing", __func__); - continue; - } - if (sdi->priv) { - devc = sdi->priv; - ftdi_deinit(&devc->ftdic); - } - sr_dev_inst_free(sdi); - } - g_slist_free(drvc->instances); - drvc->instances = NULL; + ftdi_deinit(&devc->ftdic); +} - return SR_OK; +static int clear_instances(void) +{ + return std_dev_clear(di, clear_helper); } static int init(struct sr_context *sr_ctx) @@ -755,12 +741,7 @@ static int dev_close(struct sr_dev_inst *sdi) static int cleanup(void) { - if (!di->priv) - return SR_OK; - - clear_instances(); - - return SR_OK; + return clear_instances(); } static int config_get(int id, GVariant **data, const struct sr_dev_inst *sdi)