summaryrefslogtreecommitdiff
path: root/session.c
diff options
context:
space:
mode:
authorGerhard Sittig <gerhard.sittig@gmx.net>2017-12-17 18:55:46 +0100
committerUwe Hermann <uwe@hermann-uwe.de>2018-03-31 20:44:21 +0200
commit9553e9622bb26dfbe6296ef6f330b1cf0f5b40e6 (patch)
tree54229df143c86283ff1aca2db86ae337d9b6413e /session.c
parent7d82e3c1ec96ac8a9ef358de1e9c87715dcb8f43 (diff)
downloadlibsigrokdecode-9553e9622bb26dfbe6296ef6f330b1cf0f5b40e6.tar.gz
libsigrokdecode-9553e9622bb26dfbe6296ef6f330b1cf0f5b40e6.zip
session: add "terminate and reset" support for protocol stacks
Implement routines which terminate currently pending decoder operations and reset internal state (on the C and Python sides) for instances as well as sessions. This allows to re-use previously created stacks for new input data.
Diffstat (limited to 'session.c')
-rw-r--r--session.c39
1 files changed, 39 insertions, 0 deletions
diff --git a/session.c b/session.c
index 0c1ef82..4d794df 100644
--- a/session.c
+++ b/session.c
@@ -298,6 +298,45 @@ SRD_API int srd_session_send(struct srd_session *sess,
}
/**
+ * Terminate currently executing decoders in a session, reset internal state.
+ *
+ * All decoder instances have their .wait() method terminated, which
+ * shall terminate .decode() as well. Afterwards the decoders' optional
+ * .reset() method gets executed.
+ *
+ * This routine allows callers to abort pending expensive operations,
+ * when they are no longer interested in the decoders' results. Note
+ * that the decoder state is lost and aborted work cannot resume.
+ *
+ * This routine also allows callers to re-use previously created decoder
+ * stacks to process new input data which is not related to previously
+ * processed input data. This avoids the necessity to re-construct the
+ * decoder stack.
+ *
+ * @param sess The session in which to terminate decoders.
+ * @return SRD_OK upon success, a (negative) error code otherwise.
+ *
+ * @since 0.6.0
+ */
+SRD_API int srd_session_terminate_reset(struct srd_session *sess)
+{
+ GSList *d;
+ int ret;
+
+ if (session_is_valid(sess) != SRD_OK) {
+ srd_err("Invalid session.");
+ return SRD_ERR_ARG;
+ }
+
+ for (d = sess->di_list; d; d = d->next) {
+ ret = srd_inst_terminate_reset(d->data);
+ if (ret != SRD_OK)
+ return ret;
+ }
+ return SRD_OK;
+}
+
+/**
* Destroy a decoding session.
*
* All decoder instances and output callbacks are properly released.