From: Dave Barach Date: Mon, 8 Jul 2019 18:47:44 +0000 (-0400) Subject: vppinfra: bihash add-but-do-not-overwrite semantics X-Git-Tag: v20.01-rc0~201 X-Git-Url: https://gerrit.fd.io/r/gitweb?a=commitdiff_plain;h=9e4946b324a8480b35c861e96199881b314ea825;hp=39040a619af4e8750349edba2e93eecb8ce4538b;p=vpp.git vppinfra: bihash add-but-do-not-overwrite semantics If is_add=2, fail w/ return value -2 if the key exists instead of overwriting the (key,value) pair. Type: feature Change-Id: I00a3c194a381c68090369c31d6c6f9870cfe0a62 Signed-off-by: Dave Barach --- diff --git a/src/vppinfra/bihash_template.c b/src/vppinfra/bihash_template.c index bf6be83b2e0..cd75a7a9be9 100644 --- a/src/vppinfra/bihash_template.c +++ b/src/vppinfra/bihash_template.c @@ -519,6 +519,13 @@ static inline int BV (clib_bihash_add_del_inline) { if (BV (clib_bihash_key_compare) (v->kvp[i].key, add_v->key)) { + /* Add but do not overwrite? */ + if (is_add == 2) + { + BV (clib_bihash_unlock_bucket) (b); + return (-2); + } + CLIB_MEMORY_BARRIER (); /* Add a delay */ clib_memcpy_fast (&(v->kvp[i]), add_v, sizeof (*add_v)); BV (clib_bihash_unlock_bucket) (b);