]> sigrok.org Git - libsigrok.git/commitdiff
Add a void *cb_data parameter to datafeed callbacks.
authorMartin Ling <redacted>
Mon, 15 Apr 2013 20:08:55 +0000 (21:08 +0100)
committerBert Vermeulen <redacted>
Tue, 16 Apr 2013 09:13:18 +0000 (11:13 +0200)
libsigrok.h
proto.h
session.c

index 294bb15d7d3ba0a5fd7827ddf89b9640dfaead1a..6c34c384cf6fc14e7c50af718edc6f8e61ce2aca 100644 (file)
@@ -761,7 +761,7 @@ struct sr_dev_driver {
 struct sr_session {
        /** List of struct sr_dev pointers. */
        GSList *devs;
-       /** List of sr_receive_data_callback_t items. */
+       /** List of struct datafeed_callback pointers. */
        GSList *datafeed_callbacks;
        GTimeVal starttime;
 
diff --git a/proto.h b/proto.h
index 2ca1eaf91f4b7c6e9c30504eb69cb4cebb42d49c..8504bfa4481abae976d2656165c91f7d524d1140 100644 (file)
--- a/proto.h
+++ b/proto.h
@@ -80,7 +80,7 @@ SR_API const struct sr_config_info *sr_config_info_name_get(const char *optname)
 /*--- session.c -------------------------------------------------------------*/
 
 typedef void (*sr_datafeed_callback_t)(const struct sr_dev_inst *sdi,
-               const struct sr_datafeed_packet *packet);
+               const struct sr_datafeed_packet *packet, void *cb_data);
 
 /* Session setup */
 SR_API int sr_session_load(const char *filename);
@@ -91,7 +91,8 @@ SR_API int sr_session_dev_add(const struct sr_dev_inst *sdi);
 
 /* Datafeed setup */
 SR_API int sr_session_datafeed_callback_remove_all(void);
-SR_API int sr_session_datafeed_callback_add(sr_datafeed_callback_t cb);
+SR_API int sr_session_datafeed_callback_add(sr_datafeed_callback_t cb,
+               void *cb_data);
 
 /* Session control */
 SR_API int sr_session_start(void);
index acf1158b4e3ad0e75061c4aa9ab831f5c5aadbd1..21bd3d4d814f7ee5a867ae5179d6cc0ae5627ffe 100644 (file)
--- a/session.c
+++ b/session.c
@@ -59,6 +59,11 @@ struct source {
        gintptr poll_object;
 };
 
+struct datafeed_callback {
+       sr_datafeed_callback_t cb;
+       void *cb_data;
+};
+
 /* There can only be one session at a time. */
 /* 'session' is not static, it's used elsewhere (via 'extern'). */
 struct sr_session *session;
@@ -234,7 +239,7 @@ SR_API int sr_session_datafeed_callback_remove_all(void)
                return SR_ERR_BUG;
        }
 
-       g_slist_free(session->datafeed_callbacks);
+       g_slist_free_full(session->datafeed_callbacks, g_free);
        session->datafeed_callbacks = NULL;
 
        return SR_OK;
@@ -248,8 +253,10 @@ SR_API int sr_session_datafeed_callback_remove_all(void)
  *
  * @return SR_OK upon success, SR_ERR_BUG if no session exists.
  */
-SR_API int sr_session_datafeed_callback_add(sr_datafeed_callback_t cb)
+SR_API int sr_session_datafeed_callback_add(sr_datafeed_callback_t cb, void *cb_data)
 {
+       struct datafeed_callback *cb_struct;
+
        if (!session) {
                sr_err("%s: session was NULL", __func__);
                return SR_ERR_BUG;
@@ -260,8 +267,14 @@ SR_API int sr_session_datafeed_callback_add(sr_datafeed_callback_t cb)
                return SR_ERR_ARG;
        }
 
+       if (!(cb_struct = g_try_malloc0(sizeof(struct datafeed_callback))))
+               return SR_ERR_MALLOC;
+
+       cb_struct->cb = cb;
+       cb_struct->cb_data = cb_data;
+
        session->datafeed_callbacks =
-           g_slist_append(session->datafeed_callbacks, cb);
+           g_slist_append(session->datafeed_callbacks, cb_struct);
 
        return SR_OK;
 }
@@ -511,7 +524,7 @@ SR_PRIV int sr_session_send(const struct sr_dev_inst *sdi,
                            const struct sr_datafeed_packet *packet)
 {
        GSList *l;
-       sr_datafeed_callback_t cb;
+       struct datafeed_callback *cb_struct;
 
        if (!sdi) {
                sr_err("%s: sdi was NULL", __func__);
@@ -526,8 +539,8 @@ SR_PRIV int sr_session_send(const struct sr_dev_inst *sdi,
        for (l = session->datafeed_callbacks; l; l = l->next) {
                if (sr_log_loglevel_get() >= SR_LOG_DBG)
                        datafeed_dump(packet);
-               cb = l->data;
-               cb(sdi, packet);
+               cb_struct = l->data;
+               cb_struct->cb(sdi, packet, cb_struct->cb_data);
        }
 
        return SR_OK;