diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/lib/dev.c | 6 | ||||
| -rw-r--r-- | src/lib/shm_rbuff.c | 20 | 
2 files changed, 26 insertions, 0 deletions
| diff --git a/src/lib/dev.c b/src/lib/dev.c index 9ddc5b84..bd706dc8 100644 --- a/src/lib/dev.c +++ b/src/lib/dev.c @@ -1029,6 +1029,8 @@ int flow_set_add(struct flow_set * set,                   int               fd)  {          int ret; +        size_t sdus; +        size_t i;          if (set == NULL)                  return -EINVAL; @@ -1038,6 +1040,10 @@ int flow_set_add(struct flow_set * set,          ret = shm_flow_set_add(ai.fqset, set->idx, ai.flows[fd].port_id); +        sdus = shm_rbuff_queued(ai.flows[fd].rx_rb); +        for (i = 0; i < sdus; i++) +                shm_flow_set_notify(ai.fqset, ai.flows[fd].port_id); +          pthread_rwlock_unlock(&ai.flows_lock);          pthread_rwlock_unlock(&ai.data_lock); 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; +} | 
