summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUwe Hermann <uwe@hermann-uwe.de>2018-05-18 01:02:13 +0200
committerUwe Hermann <uwe@hermann-uwe.de>2018-05-18 16:48:56 +0200
commit4ccebbd355fb53177dcc46476a5e5105f4859410 (patch)
tree26f57cf8291e22d64212c17daa4fa39b9e6583f5
parentec31b9821dbfad0283a56c6d2b5e7d819c59ba51 (diff)
downloadlibsigrokdecode-4ccebbd355fb53177dcc46476a5e5105f4859410.tar.gz
libsigrokdecode-4ccebbd355fb53177dcc46476a5e5105f4859410.zip
Simplify code by dropping session_is_valid().
A simple NULL check is sufficient here, max_session_id is being properly handled by srd_init(), srd_exit(), srd_session_new(). This might also have a small performance benefit.
-rw-r--r--instance.c23
-rw-r--r--libsigrokdecode-internal.h1
-rw-r--r--session.c55
3 files changed, 24 insertions, 55 deletions
diff --git a/instance.c b/instance.c
index c28ede9..ab1e0a2 100644
--- a/instance.c
+++ b/instance.c
@@ -294,6 +294,7 @@ SRD_API int srd_inst_channel_set_all(struct srd_decoder_inst *di,
* Create a new protocol decoder instance.
*
* @param sess The session holding the protocol decoder instance.
+ * Must not be NULL.
* @param decoder_id Decoder 'id' field.
* @param options GHashtable of options which override the defaults set in
* the decoder class. May be NULL.
@@ -315,10 +316,8 @@ SRD_API struct srd_decoder_inst *srd_inst_new(struct srd_session *sess,
i = 1;
srd_dbg("Creating new %s instance.", decoder_id);
- if (session_is_valid(sess) != SRD_OK) {
- srd_err("Invalid session.");
+ if (!sess)
return NULL;
- }
if (!(dec = srd_decoder_get_by_id(decoder_id))) {
srd_err("Protocol decoder %s not found.", decoder_id);
@@ -479,6 +478,7 @@ static void srd_inst_reset_state(struct srd_decoder_inst *di)
* Stack a decoder instance on top of another.
*
* @param sess The session holding the protocol decoder instances.
+ * Must not be NULL.
* @param di_bottom The instance on top of which di_top will be stacked.
* @param di_top The instance to go on top.
*
@@ -490,10 +490,8 @@ SRD_API int srd_inst_stack(struct srd_session *sess,
struct srd_decoder_inst *di_bottom,
struct srd_decoder_inst *di_top)
{
- if (session_is_valid(sess) != SRD_OK) {
- srd_err("Invalid session.");
+ if (!sess)
return SRD_ERR_ARG;
- }
if (!di_bottom || !di_top) {
srd_err("Invalid from/to instance pair.");
@@ -552,6 +550,7 @@ static struct srd_decoder_inst *srd_inst_find_by_id_stack(const char *inst_id,
* given session.
*
* @param sess The session holding the protocol decoder instance.
+ * Must not be NULL.
* @param inst_id The instance ID to be found.
*
* @return Pointer to struct srd_decoder_inst, or NULL if not found.
@@ -564,10 +563,8 @@ SRD_API struct srd_decoder_inst *srd_inst_find_by_id(struct srd_session *sess,
GSList *l;
struct srd_decoder_inst *tmp, *di;
- if (session_is_valid(sess) != SRD_OK) {
- srd_err("Invalid session.");
+ if (!sess)
return NULL;
- }
di = NULL;
for (l = sess->di_list; l; l = l->next) {
@@ -586,10 +583,8 @@ static struct srd_decoder_inst *srd_sess_inst_find_by_obj(
const GSList *l;
struct srd_decoder_inst *tmp, *di;
- if (session_is_valid(sess) != SRD_OK) {
- srd_err("Invalid session.");
+ if (!sess)
return NULL;
- }
di = NULL;
for (l = stack ? stack : sess->di_list; di == NULL && l != NULL; l = l->next) {
@@ -1368,10 +1363,8 @@ SRD_PRIV void srd_inst_free(struct srd_decoder_inst *di)
/** @private */
SRD_PRIV void srd_inst_free_all(struct srd_session *sess)
{
- if (session_is_valid(sess) != SRD_OK) {
- srd_err("Invalid session.");
+ if (!sess)
return;
- }
g_slist_free_full(sess->di_list, (GDestroyNotify)srd_inst_free);
}
diff --git a/libsigrokdecode-internal.h b/libsigrokdecode-internal.h
index 6fb590c..f1f8e18 100644
--- a/libsigrokdecode-internal.h
+++ b/libsigrokdecode-internal.h
@@ -70,7 +70,6 @@ struct srd_session {
SRD_PRIV int srd_decoder_searchpath_add(const char *path);
/* session.c */
-SRD_PRIV int session_is_valid(struct srd_session *sess);
SRD_PRIV struct srd_pd_callback *srd_pd_output_callback_find(struct srd_session *sess,
int output_type);
diff --git a/session.c b/session.c
index cec97cf..36b5005 100644
--- a/session.c
+++ b/session.c
@@ -45,15 +45,6 @@ SRD_PRIV int max_session_id = -1;
/** @endcond */
-/** @private */
-SRD_PRIV int session_is_valid(struct srd_session *sess)
-{
- if (!sess || sess->session_id < 1)
- return SRD_ERR;
-
- return SRD_OK;
-}
-
/**
* Create a decoding session.
*
@@ -61,7 +52,7 @@ SRD_PRIV int session_is_valid(struct srd_session *sess)
* output callbacks.
*
* @param sess A pointer which will hold a pointer to a newly
- * initialized session on return.
+ * initialized session on return. Must not be NULL.
*
* @return SRD_OK upon success, a (negative) error code otherwise.
*
@@ -69,10 +60,8 @@ SRD_PRIV int session_is_valid(struct srd_session *sess)
*/
SRD_API int srd_session_new(struct srd_session **sess)
{
- if (!sess) {
- srd_err("Invalid session pointer.");
+ if (!sess)
return SRD_ERR_ARG;
- }
*sess = g_malloc(sizeof(struct srd_session));
(*sess)->session_id = ++max_session_id;
@@ -92,7 +81,7 @@ SRD_API int srd_session_new(struct srd_session **sess)
* Decoders, instances and stack must have been prepared beforehand,
* and all SRD_CONF parameters set.
*
- * @param sess The session to start.
+ * @param sess The session to start. Must not be NULL.
*
* @return SRD_OK upon success, a (negative) error code otherwise.
*
@@ -104,10 +93,8 @@ SRD_API int srd_session_start(struct srd_session *sess)
struct srd_decoder_inst *di;
int ret;
- if (session_is_valid(sess) != SRD_OK) {
- srd_err("Invalid session pointer.");
- return SRD_ERR;
- }
+ if (!sess)
+ return SRD_ERR_ARG;
srd_dbg("Calling start() on all instances in session %d.", sess->session_id);
@@ -159,7 +146,7 @@ static int srd_inst_send_meta(struct srd_decoder_inst *di, int key,
/**
* Set a metadata configuration key in a session.
*
- * @param sess The session to configure.
+ * @param sess The session to configure. Must not be NULL.
* @param key The configuration key (SRD_CONF_*).
* @param data The new value for the key, as a GVariant with GVariantType
* appropriate to that key. A floating reference can be passed
@@ -175,10 +162,8 @@ SRD_API int srd_session_metadata_set(struct srd_session *sess, int key,
GSList *l;
int ret;
- if (session_is_valid(sess) != SRD_OK) {
- srd_err("Invalid session.");
+ if (!sess)
return SRD_ERR_ARG;
- }
if (!key) {
srd_err("Invalid key.");
@@ -281,10 +266,8 @@ SRD_API int srd_session_send(struct srd_session *sess,
GSList *d;
int ret;
- if (session_is_valid(sess) != SRD_OK) {
- srd_err("Invalid session.");
+ if (!sess)
return SRD_ERR_ARG;
- }
for (d = sess->di_list; d; d = d->next) {
if ((ret = srd_inst_decode(d->data, abs_start_samplenum,
@@ -311,7 +294,8 @@ SRD_API int srd_session_send(struct srd_session *sess,
* processed input data. This avoids the necessity to re-construct the
* decoder stack.
*
- * @param sess The session in which to terminate decoders.
+ * @param sess The session in which to terminate decoders. Must not be NULL.
+ *
* @return SRD_OK upon success, a (negative) error code otherwise.
*
* @since 0.6.0
@@ -321,10 +305,8 @@ 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.");
+ if (!sess)
return SRD_ERR_ARG;
- }
for (d = sess->di_list; d; d = d->next) {
ret = srd_inst_terminate_reset(d->data);
@@ -340,7 +322,7 @@ SRD_API int srd_session_terminate_reset(struct srd_session *sess)
*
* All decoder instances and output callbacks are properly released.
*
- * @param sess The session to be destroyed.
+ * @param sess The session to be destroyed. Must not be NULL.
*
* @return SRD_OK upon success, a (negative) error code otherwise.
*
@@ -350,10 +332,8 @@ SRD_API int srd_session_destroy(struct srd_session *sess)
{
int session_id;
- if (!sess) {
- srd_err("Invalid session.");
+ if (!sess)
return SRD_ERR_ARG;
- }
session_id = sess->session_id;
if (sess->di_list)
@@ -376,6 +356,7 @@ SRD_API int srd_session_destroy(struct srd_session *sess)
* stack).
*
* @param sess The output session in which to register the callback.
+ * Must not be NULL.
* @param output_type The output type this callback will receive. Only one
* callback per output type can be registered.
* @param cb The function to call. Must not be NULL.
@@ -388,10 +369,8 @@ SRD_API int srd_pd_output_callback_add(struct srd_session *sess,
{
struct srd_pd_callback *pd_cb;
- if (session_is_valid(sess) != SRD_OK) {
- srd_err("Invalid session.");
+ if (!sess)
return SRD_ERR_ARG;
- }
srd_dbg("Registering new callback for output type %d.", output_type);
@@ -411,10 +390,8 @@ SRD_PRIV struct srd_pd_callback *srd_pd_output_callback_find(
GSList *l;
struct srd_pd_callback *tmp, *pd_cb;
- if (session_is_valid(sess) != SRD_OK) {
- srd_err("Invalid session.");
+ if (!sess)
return NULL;
- }
pd_cb = NULL;
for (l = sess->callbacks; l; l = l->next) {