From 0455c435af501889de51c79a223883b3c2003b20 Mon Sep 17 00:00:00 2001 From: jaszha03 Date: Wed, 12 Jun 2019 16:01:19 -0500 Subject: vppinfra: conformed spinlocks to use CLIB_PAUSE Modified test-and-set spin locks to call CLIB_PAUSE () when spinning for code consistency. Decreases the memory bandwidth consumed. Type: fix Change-Id: I1cca4f87f44f23f257c7a35466cd2e7767072f51 Signed-off-by: Jason Zhang Reviewed-by: Honnappa Nagarahalli Reviewed-by: Lijian Zhang --- src/plugins/map/map.h | 5 +++-- src/svm/ssvm.h | 5 +++-- src/vnet/classify/vnet_classify.c | 3 ++- src/vnet/dns/dns.h | 3 ++- src/vppinfra/elog.c | 3 ++- src/vppinfra/mheap.c | 3 ++- 6 files changed, 14 insertions(+), 8 deletions(-) (limited to 'src') diff --git a/src/plugins/map/map.h b/src/plugins/map/map.h index abafb4e21fe..d96c7b88cb7 100644 --- a/src/plugins/map/map.h +++ b/src/plugins/map/map.h @@ -22,6 +22,7 @@ #include #include #include "lpm.h" +#include #define MAP_SKIP_IP6_LOOKUP 1 @@ -501,7 +502,7 @@ map_ip4_reass_get(u32 src, u32 dst, u16 fragment_id, void map_ip4_reass_free(map_ip4_reass_t *r, u32 **pi_to_drop); -#define map_ip4_reass_lock() while (clib_atomic_test_and_set (map_main.ip4_reass_lock)) {} +#define map_ip4_reass_lock() while (clib_atomic_test_and_set (map_main.ip4_reass_lock)) { CLIB_PAUSE (); } #define map_ip4_reass_unlock() do {CLIB_MEMORY_BARRIER(); *map_main.ip4_reass_lock = 0;} while(0) static_always_inline void @@ -526,7 +527,7 @@ map_ip6_reass_get(ip6_address_t *src, ip6_address_t *dst, u32 fragment_id, void map_ip6_reass_free(map_ip6_reass_t *r, u32 **pi_to_drop); -#define map_ip6_reass_lock() while (clib_atomic_test_and_set (map_main.ip6_reass_lock)) {} +#define map_ip6_reass_lock() while (clib_atomic_test_and_set (map_main.ip6_reass_lock)) { CLIB_PAUSE (); } #define map_ip6_reass_unlock() do {CLIB_MEMORY_BARRIER(); *map_main.ip6_reass_lock = 0;} while(0) int diff --git a/src/svm/ssvm.h b/src/svm/ssvm.h index 1c0373f126c..6c679456bff 100644 --- a/src/svm/ssvm.h +++ b/src/svm/ssvm.h @@ -37,6 +37,7 @@ #include #include #include +#include #ifndef MMAP_PAGESIZE #define MMAP_PAGESIZE (clib_mem_get_page_size()) @@ -104,7 +105,7 @@ ssvm_lock (ssvm_shared_header_t * h, u32 my_pid, u32 tag) } while (clib_atomic_test_and_set (&h->lock)) - ; + CLIB_PAUSE (); h->owner_pid = my_pid; h->recursion_count = 1; @@ -115,7 +116,7 @@ always_inline void ssvm_lock_non_recursive (ssvm_shared_header_t * h, u32 tag) { while (clib_atomic_test_and_set (&h->lock)) - ; + CLIB_PAUSE (); h->tag = tag; } diff --git a/src/vnet/classify/vnet_classify.c b/src/vnet/classify/vnet_classify.c index 90086f0e62f..64549a6e0d5 100755 --- a/src/vnet/classify/vnet_classify.c +++ b/src/vnet/classify/vnet_classify.c @@ -18,6 +18,7 @@ #include /* for API error numbers */ #include /* for L2_INPUT_CLASSIFY_NEXT_xxx */ #include +#include vnet_classify_main_t vnet_classify_main; @@ -447,7 +448,7 @@ vnet_classify_add_del (vnet_classify_table_t * t, hash >>= t->log2_nbuckets; while (clib_atomic_test_and_set (t->writer_lock)) - ; + CLIB_PAUSE (); /* First elt in the bucket? */ if (b->offset == 0) diff --git a/src/vnet/dns/dns.h b/src/vnet/dns/dns.h index b2e3e9b90cb..19de69cc248 100644 --- a/src/vnet/dns/dns.h +++ b/src/vnet/dns/dns.h @@ -23,6 +23,7 @@ #include #include #include +#include typedef struct { @@ -196,7 +197,7 @@ dns_cache_lock (dns_main_t * dm) if (dm->cache_lock) { while (clib_atomic_test_and_set (dm->cache_lock)) - ; + CLIB_PAUSE (); } } diff --git a/src/vppinfra/elog.c b/src/vppinfra/elog.c index 12ac3a596e4..489ccf436d9 100644 --- a/src/vppinfra/elog.c +++ b/src/vppinfra/elog.c @@ -41,13 +41,14 @@ #include #include #include +#include static inline void elog_lock (elog_main_t * em) { if (PREDICT_FALSE (em->lock != 0)) while (clib_atomic_test_and_set (em->lock)) - ; + CLIB_PAUSE (); } static inline void diff --git a/src/vppinfra/mheap.c b/src/vppinfra/mheap.c index ba5bbc9b6e7..2769838d4ba 100644 --- a/src/vppinfra/mheap.c +++ b/src/vppinfra/mheap.c @@ -41,6 +41,7 @@ #include #include #include +#include #ifdef CLIB_UNIX #include @@ -64,7 +65,7 @@ mheap_maybe_lock (void *v) } while (clib_atomic_test_and_set (&h->lock)) - ; + CLIB_PAUSE (); h->owner_cpu = my_cpu; h->recursion_count = 1; -- cgit 1.2.3-korg