[dpdk-dev] [PATCH 3/4] hash: fix rw concurrency while moving keys
Honnappa Nagarahalli
Honnappa.Nagarahalli at arm.com
Mon Oct 1 00:33:14 CEST 2018
> > > >
> > > >Reader-writer concurrency issue, caused by moving the keys to their
> > > >alternative locations during key insert, is solved by introducing a
> > > >global counter(tbl_chng_cnt) indicating a change in table.
>
> <snip>
>
> > > > /**
> > > >@@ -200,7 +200,7 @@ rte_hash_add_key_with_hash_data(const struct
> > > >rte_hash
> > *h, const void *key,
> > > > * array of user data. This value is unique for this key.
> > > > */
> > > > int32_t
> > > >-rte_hash_add_key(const struct rte_hash *h, const void *key);
> > > >+rte_hash_add_key(struct rte_hash *h, const void *key);
> > > >
> > > > /**
> > > > * Add a key to an existing hash table.
> > > >@@ -222,7 +222,7 @@ rte_hash_add_key(const struct rte_hash *h,
> > > >const void
> > *key);
> > > > * array of user data. This value is unique for this key.
> > > > */
> > > > int32_t
> > > >-rte_hash_add_key_with_hash(const struct rte_hash *h, const void
> > > >*key,
> > hash_sig_t sig);
> > > >+rte_hash_add_key_with_hash(struct rte_hash *h, const void *key,
> > hash_sig_t sig);
> > > >
> > > > /
> > >
> > > I think the above changes will break ABI by changing the parameter type?
> > Other people may know better on this.
> >
> > Just removing a const should not change the ABI, I believe, since the
> > const is just advisory hint to the compiler. Actual parameter size and
> > count remains unchanged so I don't believe there is an issue.
> > [ABI experts, please correct me if I'm wrong on this]
>
>
> [Certainly no ABI expert, but...]
>
> I think this is an API break, not ABI break.
>
> Given application code as follows, it will fail to compile - even though running
> the new code as a .so wouldn't cause any issues (AFAIK).
>
> void do_hash_stuff(const struct rte_hash *h, ...) {
> /* parameter passed in is const, but updated function prototype is non-
> const */
> rte_hash_add_key_with_hash(h, ...);
> }
>
> This means that we can't recompile apps against latest patch without
> application code changes, if the app was passing a const rte_hash struct as
> the first parameter.
>
Agree. Do we need to do anything for this?
>
> -Harry
More information about the dev
mailing list