Re: Question about volatile usage

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

 



Hi Akira & Paul,

Thanks very much for your time and explanation!

Best Regards
Nan Xiao

On Mon, Oct 28, 2019 at 1:11 AM Paul E. McKenney <paulmck@xxxxxxxxxx> wrote:
>
> On Sun, Oct 27, 2019 at 11:45:07AM +0900, Akira Yokosawa wrote:
> > (Added explicit CC: to Paul)
> >
> > Hello!
> >
> > On Fri, 25 Oct 2019 21:32:35 +0800, Nan Xiao wrote:
> > > Hi Paul and perfbook members,
> > >
> > > Greetings from me!
> > >
> > > I have a question about 4.3.4.2 A Volatile Solution:
> > >
> > >> To summarize, the volatile keyword can prevent load tearing and store tearing in cases where the loads and stores are machine-sized and properly aligned. It can also prevent load fusing, store fusing, invented loads, and invented stores. However, although it does prevent the compiler from reordering volatile accesses with each other, it does nothing to prevent the CPU from reordering these accesses. Furthermore, it does nothing to prevent either compiler or CPU from reordering non-volatile accesses with each other or with volatile accesses. Preventing these types of reordering requires the techniques described in the next section.
> > >
> > > Does this summary apply for both C and C++? Or C only?
> >
> > IIUC, it applies to both C and C++.
> >
> > There is an article on LWN (Linux Weekly News) based on this section at:
> >
> >     https://lwn.net/Articles/793253/
> >
> > The article and comments from readers there might be of your interest.
> >
> > If your main concern is application code developed on modern C/C++ compilers
> > (C11/C++11 or later), it might be a good idea to use standard language
> > features which support concurrent code rather than to use volatile/volatile
> > casting.  (There can be changes in C/C++ standards in future, though.)
> >
> > Annotation of racy accesses by READ_ONCE()/WRITE_ONCE() to prevent
> > compiler optimizations can be seen as abusing of volatile from the
> > view point of compiler developers. But it survives generations of
> > compilers (with occasional regression reported as bugs in compiler
> > optimization).
>
> All good points!
>
> And one reason that volatile survives is that it absolutely must have
> certain properties in order for device drivers to work, and none of our
> modern computing infrastructure will work without device drivers.
>
>                                                         Thanx, Paul
>
> >         Thanks, Akira
> >
> > >
> > > Thanks very much in advance!
> > >
> > > Best Regards
> > > Nan Xiao
> > >
> >




[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