[EXTERNAL] Re: [PATCH] net/mana: use mana_local_data for tracking usage data for primary process
Long Li
longli at microsoft.com
Sat Feb 8 02:40:47 CET 2025
> On Fri, 7 Feb 2025 15:21:45 -0800
> longli at linuxonhyperv.com wrote:
>
> > + /* At least one eth_dev is probed, init shared data */
> > + if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
> > + rte_spinlock_lock(&mana_shared_data_lock);
> > + mana_local_data.primary_cnt++;
> > + rte_spinlock_unlock(&mana_shared_data_lock);
> > + } else {
> > + rte_spinlock_lock(&mana_shared_data_lock);
> > + mana_local_data.secondary_cnt++;
> > + rte_spinlock_unlock(&mana_shared_data_lock);
> > +
> > + rte_spinlock_lock(&mana_shared_data->lock);
> > + mana_shared_data->secondary_cnt++;
> > + rte_spinlock_unlock(&mana_shared_data->lock);
>
> If all you are doing is wanting a MP safe counter, use atomic operations instead of
> the overhead of a spin lock.
mana_shared_data_lock is also used to protect init_done, mana_shared_mz and mana_shared_data. That's why I'm reusing it for primary_cnt and secondary_cnt as those values are initialized in locked context at the beginning for the local process. I think this will make the code look clean.
I can remove mana_shared_data->lock and use atomic for mana_shared_data->secondary_cnt.
Will send v2.
Thanks,
Long
More information about the stable
mailing list