diff options
| -rw-r--r-- | include/osmocom/core/counter.h | 21 | ||||
| -rw-r--r-- | src/counter.c | 18 | 
2 files changed, 23 insertions, 16 deletions
diff --git a/include/osmocom/core/counter.h b/include/osmocom/core/counter.h index f4429cdb..e692f7e6 100644 --- a/include/osmocom/core/counter.h +++ b/include/osmocom/core/counter.h @@ -3,7 +3,7 @@  /*! \file counter.h   *  Common routines regarding counter handling */ -/*! structure representing a single counter */ +/*! Structure representing a single counter */  struct osmo_counter {  	struct llist_head list;		/*!< internal list head */  	const char *name;		/*!< human-readable name */ @@ -12,13 +12,15 @@ struct osmo_counter {  	unsigned long previous;		/*!< previous value */  }; -/*! Decrement counter */ +/*! Decrement given counter by one + *  \param[in] ctr Counter that's to be decremented */  static inline void osmo_counter_dec(struct osmo_counter *ctr)  {  	ctr->value--;  } -/*! Increment counter */ +/*! Increment counter by one. + *  \param[in] Counter that's to be incremented */  static inline void osmo_counter_inc(struct osmo_counter *ctr)  {  	ctr->value++; @@ -36,25 +38,12 @@ static inline void osmo_counter_reset(struct osmo_counter *ctr)  	ctr->value = 0;  } -/*! Allocate a new counter */  struct osmo_counter *osmo_counter_alloc(const char *name); -/*! Free the specified counter - *  \param[in] ctr Counter - */  void osmo_counter_free(struct osmo_counter *ctr); -/*! Iterate over all counters - *  \param[in] handle_counter Call-back function, aborts if rc < 0 - *  \param[in] data Private dtata handed through to \a handle_counter - */  int osmo_counters_for_each(int (*handle_counter)(struct osmo_counter *, void *), void *data); -/*! Resolve counter by human-readable name - *  \param[in] name human-readable name of counter - *  \returns pointer to counter (\ref osmo_counter) or NULL otherwise - */  struct osmo_counter *osmo_counter_get_by_name(const char *name); -/*! Return the counter difference since the last call to this function */  int osmo_counter_difference(struct osmo_counter *ctr); diff --git a/src/counter.c b/src/counter.c index 6fa87ba3..29637779 100644 --- a/src/counter.c +++ b/src/counter.c @@ -29,8 +29,12 @@  static LLIST_HEAD(counters); +/*! Global talloc context for all osmo_counter allocations. */  void *tall_ctr_ctx; +/*! Allocate a new counter with given name. Allocates from tall_ctr_ctx + *  \param[in] name Human-readable string name for the counter + *  \returns Allocated counter on success; NULL on error */  struct osmo_counter *osmo_counter_alloc(const char *name)  {  	struct osmo_counter *ctr = talloc_zero(tall_ctr_ctx, struct osmo_counter); @@ -44,12 +48,18 @@ struct osmo_counter *osmo_counter_alloc(const char *name)  	return ctr;  } +/*! Release/Destroy a given counter + *  \param[in] ctr Counter to be destroyed */  void osmo_counter_free(struct osmo_counter *ctr)  {  	llist_del(&ctr->list);  	talloc_free(ctr);  } +/*! Iterate over all counters; call \a handle_cunter call-back for each. + *  \param[in] handle_counter Call-back to be called for each counter; aborts if rc < 0 + *  \param[in] data Opaque data passed through to \a handle_counter function + *  \returns 0 if all \a handle_counter calls successfull; negative on error */  int osmo_counters_for_each(int (*handle_counter)(struct osmo_counter *, void *),  			   void *data)  { @@ -65,6 +75,9 @@ int osmo_counters_for_each(int (*handle_counter)(struct osmo_counter *, void *),  	return rc;  } +/*! Find a counter by its name. + *  \param[in] name Name used to look-up/search counter + *  \returns Counter on success; NULL if not found */  struct osmo_counter *osmo_counter_get_by_name(const char *name)  {  	struct osmo_counter *ctr; @@ -76,6 +89,11 @@ struct osmo_counter *osmo_counter_get_by_name(const char *name)  	return NULL;  } +/*! Compute difference between current and previous counter value. + *  \param[in] ctr Counter of which the difference is to be computed + *  \returns Delta value between current counter and previous counter. Please + *	     note that the actual counter values are unsigned long, while the + *	     difference is computed as signed integer! */  int osmo_counter_difference(struct osmo_counter *ctr)  {  	int delta = ctr->value - ctr->previous;  | 
