[lttng-dev] [RFC] Deprecating RCU signal flavor
Paul E. McKenney
paulmck at kernel.org
Wed Aug 23 10:47:47 EDT 2023
On Mon, Aug 21, 2023 at 11:43:32AM -0400, Mathieu Desnoyers wrote:
> On 8/15/23 08:38, Mathieu Desnoyers via lttng-dev wrote:
> > On 8/14/23 17:05, Olivier Dion via lttng-dev wrote:
> > >
> > > After discussing it with Mathieu, we agree on the following 3 phases for
> > > deprecating the signal flavor:
> > >
> > > 1) liburcu-signal will be implemented in term of liburcu-mb. The only
> > > difference between the two flavors will be the public header files,
> > > linked symbols and library name. Note that this add a regression in
> > > term of performance, since the implementation of liburcu-mb adds memory
> > > barriers on the reader side which are not present in the original
> > > liburcu-signal implementation.
> > >
> > > 2) Adding the deprecated attribute to every public functions exposed by
> > > the liburcu-signal flavor. At this point, tests for liburcu-signal
> > > will also be removed from the project. There will be no more support
> > > for this flavor.
> > >
> > > 3) Removing the liburcu-signal flavor completely from the project.
> > >
> > > Finally, here is a tentative versions release of mine for each phase:
> > >
> > > 1) 0.15.0 [October 2023] (also TSAN support yay!)
> > >
> > > 2) 0.15.1
> > >
> > > 3) 0.16.0 || 1.0.0 (maybe a major bump since this is an API breaking
> > > change)
> >
> > There is a distinction between the version number of the liburcu project
> > (0.14) and the ABI soname for the shared objects. We may be able to do
> > step (3) without going to 1.0.0 (I don't see removal of the urcu-signal
> > flavor a strong enough motivation for hitting 1.0.0 yet).
> >
> > Technically speaking, given that we would be removing the entire
> > liburcu-signal.so shared object, we would not be changing _symbols_
> > within an existing shared object, therefore I'm not even sure we need to
> > bump the soname for all the other remaining shared objects.
>
> So after merging this commit:
>
> Phase 1 of deprecating liburcu-signal
> The first phase of liburcu-signal deprecation consists of implementing
> it in term of liburcu-mb. In other words, liburcu-signal is identical to
> liburcu-mb at the exception of the function symbols and public header
> files.
> This is done by:
> 1) Removing the RCU_SIGNAL specific code in urcu.c
> 2) Making the RCU_MB specific code also specific to RCU_SIGNAL in
> urcu.c
> 3) Rewriting _urcu_signal_read_unlock_update_and_wakeup to use a
> atomic store with CMM_SEQ_CST instead of a store CMM_RELAXED with
> cmm_barrier() around it. We could keep the explicit barriers, but that
> would require to add some cmm_annotate annotations. Therefore, to be
> less intrusive in a public header file, simply use the CMM_SEQ_CST
> like for the mb flavor.
>
> I notice that an application previously built against urcu-signal with
> _LGPL_SOURCE defined would have to be rebuilt, which would require a
> soname bump of urcu-signal.
>
> So considering that this phase 1 is not really a "drop in" replacement,
> I favor removing the urcu-signal flavor entirely before the next release.
>
> Thoughts ?
The replacement is liburcu-mb, correct?
I will need to change perfbook, but that should be an easy change,
plus sys_membarrier() is widely available by now.
Thanx, Paul
More information about the lttng-dev
mailing list