svm: convert fifo want_deq_ntf ops to atomics
Type: improvement Signed-off-by: Florin Coras <fcoras@cisco.com> Change-Id: Iba2e4de24ff0724e31859f5d2f4ffa3cfe2cf284
This commit is contained in:

committed by
Florin Coras

parent
5aa59c7cfc
commit
81e3243c1b
@ -759,7 +759,7 @@ svm_fifo_unset_event (svm_fifo_t * f)
|
|||||||
static inline void
|
static inline void
|
||||||
svm_fifo_add_want_deq_ntf (svm_fifo_t * f, u8 ntf_type)
|
svm_fifo_add_want_deq_ntf (svm_fifo_t * f, u8 ntf_type)
|
||||||
{
|
{
|
||||||
f->shr->want_deq_ntf |= ntf_type;
|
__atomic_or_fetch (&f->shr->want_deq_ntf, ntf_type, __ATOMIC_RELEASE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -773,7 +773,21 @@ svm_fifo_add_want_deq_ntf (svm_fifo_t * f, u8 ntf_type)
|
|||||||
static inline void
|
static inline void
|
||||||
svm_fifo_del_want_deq_ntf (svm_fifo_t * f, u8 ntf_type)
|
svm_fifo_del_want_deq_ntf (svm_fifo_t * f, u8 ntf_type)
|
||||||
{
|
{
|
||||||
f->shr->want_deq_ntf &= ~ntf_type;
|
__atomic_and_fetch (&f->shr->want_deq_ntf, ~ntf_type, __ATOMIC_RELEASE);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get want notification flag
|
||||||
|
*
|
||||||
|
* Done atomically with acquire memory ordering
|
||||||
|
*
|
||||||
|
* @param f fifo
|
||||||
|
* @return value of want_deq_ntf flag
|
||||||
|
*/
|
||||||
|
static inline u32
|
||||||
|
svm_fifo_get_want_deq_ntf (svm_fifo_t *f)
|
||||||
|
{
|
||||||
|
return clib_atomic_load_acq_n (&f->shr->want_deq_ntf);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -790,12 +804,29 @@ svm_fifo_del_want_deq_ntf (svm_fifo_t * f, u8 ntf_type)
|
|||||||
static inline void
|
static inline void
|
||||||
svm_fifo_clear_deq_ntf (svm_fifo_t * f)
|
svm_fifo_clear_deq_ntf (svm_fifo_t * f)
|
||||||
{
|
{
|
||||||
/* Set the flag if want_notif_if_full was the only ntf requested */
|
u32 want_deq_ntf = svm_fifo_get_want_deq_ntf (f);
|
||||||
f->shr->has_deq_ntf =
|
/* Set the flag if want ntf if full or empty was requested */
|
||||||
f->shr->want_deq_ntf == SVM_FIFO_WANT_DEQ_NOTIF_IF_FULL;
|
if (want_deq_ntf &
|
||||||
|
(SVM_FIFO_WANT_DEQ_NOTIF_IF_FULL | SVM_FIFO_WANT_DEQ_NOTIF_IF_EMPTY))
|
||||||
|
clib_atomic_store_rel_n (&f->shr->has_deq_ntf, 1);
|
||||||
|
if (want_deq_ntf & SVM_FIFO_WANT_DEQ_NOTIF)
|
||||||
svm_fifo_del_want_deq_ntf (f, SVM_FIFO_WANT_DEQ_NOTIF);
|
svm_fifo_del_want_deq_ntf (f, SVM_FIFO_WANT_DEQ_NOTIF);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get has dequeue notification flag
|
||||||
|
*
|
||||||
|
* Done atomically with acquire memory ordering
|
||||||
|
*
|
||||||
|
* @param f fifo
|
||||||
|
* @return has_deq_ntf flag
|
||||||
|
*/
|
||||||
|
static inline u32
|
||||||
|
svm_fifo_has_deq_ntf (svm_fifo_t *f)
|
||||||
|
{
|
||||||
|
return clib_atomic_load_acq_n (&f->shr->has_deq_ntf);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Clear has notification flag
|
* Clear has notification flag
|
||||||
*
|
*
|
||||||
@ -824,9 +855,9 @@ svm_fifo_reset_has_deq_ntf (svm_fifo_t * f)
|
|||||||
static inline u8
|
static inline u8
|
||||||
svm_fifo_needs_deq_ntf (svm_fifo_t * f, u32 n_last_deq)
|
svm_fifo_needs_deq_ntf (svm_fifo_t * f, u32 n_last_deq)
|
||||||
{
|
{
|
||||||
u8 want_ntf = f->shr->want_deq_ntf;
|
u32 want_ntf = svm_fifo_get_want_deq_ntf (f);
|
||||||
|
|
||||||
if (PREDICT_TRUE (want_ntf == SVM_FIFO_NO_DEQ_NOTIF))
|
if (want_ntf == SVM_FIFO_NO_DEQ_NOTIF)
|
||||||
return 0;
|
return 0;
|
||||||
else if (want_ntf & SVM_FIFO_WANT_DEQ_NOTIF)
|
else if (want_ntf & SVM_FIFO_WANT_DEQ_NOTIF)
|
||||||
return (svm_fifo_max_enqueue (f) >= f->shr->deq_thresh);
|
return (svm_fifo_max_enqueue (f) >= f->shr->deq_thresh);
|
||||||
@ -834,13 +865,13 @@ svm_fifo_needs_deq_ntf (svm_fifo_t * f, u32 n_last_deq)
|
|||||||
{
|
{
|
||||||
u32 max_deq = svm_fifo_max_dequeue_cons (f);
|
u32 max_deq = svm_fifo_max_dequeue_cons (f);
|
||||||
u32 size = f->shr->size;
|
u32 size = f->shr->size;
|
||||||
if (!f->shr->has_deq_ntf && max_deq < size &&
|
if (max_deq < size && max_deq + n_last_deq >= size &&
|
||||||
max_deq + n_last_deq >= size)
|
!svm_fifo_has_deq_ntf (f))
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if (want_ntf & SVM_FIFO_WANT_DEQ_NOTIF_IF_EMPTY)
|
if (want_ntf & SVM_FIFO_WANT_DEQ_NOTIF_IF_EMPTY)
|
||||||
{
|
{
|
||||||
if (!f->shr->has_deq_ntf && svm_fifo_is_empty (f))
|
if (!svm_fifo_has_deq_ntf (f) && svm_fifo_is_empty (f))
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
Reference in New Issue
Block a user