[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