Re: [PATCH] count: Switch from GCC to C11 thread-local storage

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



That sounds good, thank you!

There are quite a few people on projects for which C11 is not yet a
thing.  Or that need to look at old code.

But yes, some years hence, perhaps all mention of __thread is dropped
from this book.  Not today, though.  ;-)

						Thanx, Paul

On Sat, Aug 13, 2022 at 07:12:48PM -0400, Elad Lahav wrote:
> Yes, I thought about a footnote along the lines of "previous versions
> of this book used GCC extensions..." but wasn't sure if you'd approve.
> I can certainly add that.
> 
> --Elad
> 
> On Sat, 13 Aug 2022 at 19:08, Paul E. McKenney <paulmck@xxxxxxxxxx> wrote:
> >
> > On Sat, Aug 13, 2022 at 07:45:59AM -0400, Elad Lahav wrote:
> > > Signed-off-by: Elad Lahav <e2lahav@xxxxxxxxx>
> >
> > Nice, thank you!
> >
> > But did you verify that none of the text describing count_end.c needed
> > changing?  (It seems unlikely that any would, but could you please check?)
> >
> > > ---
> > >  CodeSamples/count/count_end.c | 12 ++++++------
> > >  count/count.tex               |  4 ++--
> > >  2 files changed, 8 insertions(+), 8 deletions(-)
> > >
> > > diff --git a/CodeSamples/count/count_end.c b/CodeSamples/count/count_end.c
> > > index 722ad2f7..5e7b9ee1 100644
> > > --- a/CodeSamples/count/count_end.c
> > > +++ b/CodeSamples/count/count_end.c
> > > @@ -1,6 +1,6 @@
> > >  /*
> > >   * count_end.c: Per-thread statistical counters that provide sum at end.
> > > - *   Uses __thread for each thread's counter.
> > > + *   Uses _Thread_local for each thread's counter.
> > >   *
> > >   * This program is free software; you can redistribute it and/or modify
> > >   * it under the terms of the GNU General Public License as published by
> > > @@ -23,17 +23,17 @@
> > >  #include "../api.h"
> > >
> > >  //\begin{snippet}[labelbase=ln:count:count_end:whole,commandchars=\\\@\$]
> > > -unsigned long __thread counter = 0;          //\lnlbl{var:b}
> > > +unsigned long _Thread_local counter = 0;             //\lnlbl{var:b}
> > >  unsigned long *counterp[NR_THREADS] = { NULL };
> > >  unsigned long finalcount = 0;
> > >  DEFINE_SPINLOCK(final_mutex);                        //\lnlbl{var:e}
> > >
> > > -static __inline__ void inc_count(void)               //\lnlbl{inc:b}
> > > +static inline void inc_count(void)           //\lnlbl{inc:b}
> > >  {
> > >       WRITE_ONCE(counter, counter + 1);
> > >  }                                            //\lnlbl{inc:e}
> > >
> > > -static __inline__ unsigned long read_count(void)
> > > +static inline unsigned long read_count(void)
> > >  {
> > >       int t;
> > >       unsigned long sum;
> > > @@ -48,7 +48,7 @@ static __inline__ unsigned long read_count(void)
> > >  }
> > >
> > >  #ifndef FCV_SNIPPET
> > > -__inline__ void count_init(void)
> > > +inline void count_init(void)
> > >  {
> > >  }
> > >  #endif /* FCV_SNIPPET */
> > > @@ -73,7 +73,7 @@ void count_unregister_thread(int nthreadsexpected)  //\lnlbl{unreg:b}
> > >  }                                                    //\lnlbl{unreg:e}
> > >  //\end{snippet}
> > >
> > > -__inline__ void count_cleanup(void)
> > > +inline void count_cleanup(void)
> > >  {
> > >  }
> > >
> > > diff --git a/count/count.tex b/count/count.tex
> > > index 523789e2..173b964c 100644
> > > --- a/count/count.tex
> > > +++ b/count/count.tex
> > > @@ -721,8 +721,8 @@ This is the topic of the next section.
> > >  \subsection{Per-Thread-Variable-Based Implementation}
> > >  \label{sec:count:Per-Thread-Variable-Based Implementation}
> > >
> > > -\GCC\ provides an \apig{__thread} storage class that provides
> > > -per-thread storage.
> > > +The C language, since C11, features a \apig{_Thread_local} storage class that
> > > +provides per-thread storage.
> >
> > Could you please mention __thread as the old way?  Either in the text
> > directly, in parentheses, as a footnote, or as a quick quiz, your choice.
> >
> >                                                         Thanx, Paul
> >
> > >  This can be used as shown in
> > >  \cref{lst:count:Per-Thread Statistical Counters} (\path{count_end.c})
> > >  to implement
> > > --
> > > 2.25.1
> > >



[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux