On Fri, Apr 08, 2022 at 12:29:36AM +0900, Akira Yokosawa wrote: > Hi Paul, > > Let me make a suggestion regarding Hao's poor experience as a first-time > reader of Section 4.3. > > On Tue, 5 Apr 2022 08:31:20 -0700, > Paul E. McKenney wrote: > > On Tue, Apr 05, 2022 at 09:52:23PM +0800, Hao Lee wrote: > >> Hi, Paul > >> > >> I'm currently reading perfbook, but I often get stuck in some concepts > >> which are not explained. Does this book need some prior knowledge? > >> Or all these concepts are explained later and I just need to keep > >> reading patiently? > >> > >> For example, on page 67 in v2021.12.22a: > >> > >> For example, a write memory barrier (Linux kernel smp_wmb()) would > >> order the store, but not the load. This situation might suggest use > >> of smp_store_release() over smp_wmb(). > > So this is in Section 4.3.4.1 "Shared-Variable Shenanigans". > > I think one of the purpose of Chapter 4 is an introduction to various > constructs which are used/discussed in later chapters and CodeSamples. > > If I were a first-time reader, I'd find Section 4.3.4 out-of-place > because other sections in this chapter explain APIs and their usages > in a brief manner. > > My suggestion is to move hard parts of Section 4.3.4 to a later > chapter/appendix and to leave a brief introduction in Chapter 4 around > the discussion of READ_ONCE() and WRITE_ONCE(). > > And I believe you have intentionally avoided discussing memory ordering > and memory barriers in Chapter 4, as they are pretty "advanced" topic. > > So a brief introduction to them in Chapter 4 would also be helpful. > > I think "data race" and "battle with compiler optimizations" in > accessing shared memory from C are also "advanced" topics in that > they are not intuitive for those who is willing to learn parallel > programming. > > Thoughts? One approach would be to make 4.3.4 "Accessing Shared Variables" be much smaller and more directive. ("Don't access concurrently modified shared variables using plain C-language loads and stores.") Also describe READ_ONCE() and WRITE_ONCE(). Then move 4.3.4 to be a section in the "Advanced Synchronization" chapter, and probably the first chapter. Forward-reference this section from the reworked 4.3.4 ("If you don't believe me, go read this new section!"). Expand 4.3.5 "Atomic Operations" to give more detail on what these operations do. Or maybe rely on additions to the Glossary? Add a 4.3.x section on memory barriers, saying that they provide ordering, and also saying that both thread's accesses must be ordered for anything useful to happen. Forward-reference the memory-ordering chapter. Would this help, or is there a better way? > >> Unfortunately, although I have some knowledge about Linux kernel, I'm not > >> familiar with the concepts such as store_release, smp_wmb, etc. I don't > >> know if I should keep reading this book until all these concepts are > >> explained or stop reading the book and learn some prior knowledge.> > > Good point. On the one hand, this book is rather advanced, but on the > > other hand, it needs to be as accessible as is reasonably possible. > > Expanding general Index and API Index might be helpful here. > At the moment, they are "work in progress". Somehow, there is no entry > related to memory barriers in the general Index, and very limited memory > barrier primitives in API Index. This may be due to the lack of > "memory barrier" and related terms in Glossary. I need to add at least the following to the glossary: o Acquire load. o Release store. o Memory barrier. o Read memory barrier. o Write memory barrier. Any others? Thanx, Paul