On Fri, Dec 13, 2024 at 7:58 AM Mattias Rönnblom <hof...@lysator.liu.se> wrote: > On 2024-12-12 08:57, David Marchand wrote: > > clb_multiwait, clb_pause and clb_scale_freq callbacks can only be > > reached after a successful call to > > rte_power_ethdev_pmgmt_queue_enable. > > Triggering an allocation in them means we are hiding a (internal) > > programatic error as allocation and use of a lcore variable are > > clearly separated atm. > > If we keep the lcore var api as is, I would add an assert() (maybe > > under a debug build option) in RTE_LCORE_VAR macros themselves, as > > calling with a NULL handle means the initialisation path in some > > code/RTE_LCORE_VAR API use was incorrect. > > > > Sure, that would make sense. RTE_ASSERT(), that is. RTE_VERIFY() would > be too expensive.
Yes, I'll send in next revision. > > > > > Or because you propose to add the same type of helpers in both this > > patch and the next, I am considering the other way: hide the > > allocation in the RTE_LCORE_VAR* macros. > > Checking for already allocated var in RTE_LCORE_VAR_ALLOC seems fine. > > But the "fast path" RTE_LCORE_VAR would have an unwanted branch in most > > cases. > > > > I would prefer to have the ALLOC() macro with semantics most people > expect from a macro (or function) with that name, which is, I would > argue, an unconditional allocation. > It would make sense to have another macro, which performs an allocation > only if the handle is NULL. > > RTE_LCORE_VAR_ASSURE_ALLOCATED(), or just RTE_LCORE_VAR_ASSURE() > (although the latter sounds a little like an assertion, and not an > allocation). > > RTE_LCORE_VAR_LAZY_ALLOC() > > I don't know. Something like that. - In the power libary case, allocating the lcore variable is followed by the initialisation of the lcore variable internals (per lcore tailqs). For this patch, I will rename the alloc_lcore_cfgs helper I had in v1 as: static void +init_lcore_cfgs(void) +{ + struct pmd_core_cfg *lcore_cfg; + unsigned int lcore_id; + + if (lcore_cfgs != NULL) + return; + + RTE_LCORE_VAR_ALLOC(lcore_cfgs); + + /* initialize all tailqs */ + RTE_LCORE_VAR_FOREACH(lcore_id, lcore_cfg, lcore_cfgs) + TAILQ_INIT(&lcore_cfg->head); +} and only keep those checks in the public symbols. - About more macros, I am wondering if this is needed in the end. Adding assertions in the lcore var accessor should catch incorrect initialisation path. > > > >> A somewhat unrelated question: why is pmd_core_cfg cache-line aligned? I > >> don't think it should be. > > > > Before the conversion to per lcore variable, it was probably useful > > (avoiding false sharing). > > With the conversion, indeed, it looks like a waste of space. > > It seems worth a separate fix. > > > > > > You will include it, or should I submit a separate patch? I'll send it in next revision. -- David Marchand