diff options
author | dimitri staessens <dimitri.staessens@ugent.be> | 2017-03-21 14:25:51 +0000 |
---|---|---|
committer | Sander Vrijders <sander.vrijders@ugent.be> | 2017-03-21 14:25:51 +0000 |
commit | d4e80d41197b75d2c351659c7e8d4546270e677d (patch) | |
tree | 75f499a09782dd03b9d61e69166b659f9d09f698 /src/lib/shm_rbuff.c | |
parent | 5a001d5a386af24ee25734e9195f4eb1641ad38c (diff) | |
parent | 0c8d8e419f7c9052d88bb9765bf43b01187977d0 (diff) | |
download | ouroboros-d4e80d41197b75d2c351659c7e8d4546270e677d.tar.gz ouroboros-d4e80d41197b75d2c351659c7e8d4546270e677d.zip |
Merged in dstaesse/ouroboros/be-lib-flowset (pull request #405)
lib: Add queued SDUs when adding fd to flow_set
Diffstat (limited to 'src/lib/shm_rbuff.c')
-rw-r--r-- | src/lib/shm_rbuff.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/lib/shm_rbuff.c b/src/lib/shm_rbuff.c index a206a019..b8db7c19 100644 --- a/src/lib/shm_rbuff.c +++ b/src/lib/shm_rbuff.c @@ -384,3 +384,23 @@ void shm_rbuff_fini(struct shm_rbuff * rb) #endif pthread_cleanup_pop(true); } + +size_t shm_rbuff_queued(struct shm_rbuff * rb) +{ + size_t ret; + + assert(rb); + +#ifdef __APPLE__ + pthread_mutex_lock(rb->lock); +#else + if (pthread_mutex_lock(rb->lock) == EOWNERDEAD) + pthread_mutex_consistent(rb->lock); +#endif + + ret = shm_rbuff_used(rb); + + pthread_mutex_unlock(rb->lock); + + return ret; +} |