~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/locking/seqlock.rst

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /Documentation/locking/seqlock.rst (Version linux-6.12-rc7) and /Documentation/locking/seqlock.rst (Version unix-v6-master)


  1 ======================================            
  2 Sequence counters and sequential locks            
  3 ======================================            
  4                                                   
  5 Introduction                                      
  6 ============                                      
  7                                                   
  8 Sequence counters are a reader-writer consiste    
  9 lockless readers (read-only retry loops), and     
 10 are used for data that's rarely written to (e.    
 11 reader wants a consistent set of information a    
 12 that information changes.                         
 13                                                   
 14 A data set is consistent when the sequence cou    
 15 read side critical section is even and the sam    
 16 read again at the end of the critical section.    
 17 be copied out inside the read side critical se    
 18 count has changed between the start and the en    
 19 the reader must retry.                            
 20                                                   
 21 Writers increment the sequence count at the st    
 22 critical section. After starting the critical     
 23 is odd and indicates to the readers that an up    
 24 the end of the write side critical section the    
 25 even again which lets readers make progress.      
 26                                                   
 27 A sequence counter write side critical section    
 28 or interrupted by read side sections. Otherwis    
 29 the entire scheduler tick due to the odd seque    
 30 interrupted writer. If that reader belongs to     
 31 class, it can spin forever and the kernel will    
 32                                                   
 33 This mechanism cannot be used if the protected    
 34 as the writer can invalidate a pointer that th    
 35                                                   
 36                                                   
 37 .. _seqcount_t:                                   
 38                                                   
 39 Sequence counters (``seqcount_t``)                
 40 ==================================                
 41                                                   
 42 This is the raw counting mechanism, which does    
 43 multiple writers.  Write side critical section    
 44 by an external lock.                              
 45                                                   
 46 If the write serialization primitive is not im    
 47 preemption, preemption must be explicitly disa    
 48 write side section. If the read section can be    
 49 softirq contexts, interrupts or bottom halves     
 50 disabled before entering the write section.       
 51                                                   
 52 If it's desired to automatically handle the se    
 53 requirements of writer serialization and non-p    
 54 :ref:`seqlock_t` instead.                         
 55                                                   
 56 Initialization::                                  
 57                                                   
 58         /* dynamic */                             
 59         seqcount_t foo_seqcount;                  
 60         seqcount_init(&foo_seqcount);             
 61                                                   
 62         /* static */                              
 63         static seqcount_t foo_seqcount = SEQCN    
 64                                                   
 65         /* C99 struct init */                     
 66         struct {                                  
 67                 .seq   = SEQCNT_ZERO(foo.seq),    
 68         } foo;                                    
 69                                                   
 70 Write path::                                      
 71                                                   
 72         /* Serialized context with disabled pr    
 73                                                   
 74         write_seqcount_begin(&foo_seqcount);      
 75                                                   
 76         /* ... [[write-side critical section]]    
 77                                                   
 78         write_seqcount_end(&foo_seqcount);        
 79                                                   
 80 Read path::                                       
 81                                                   
 82         do {                                      
 83                 seq = read_seqcount_begin(&foo    
 84                                                   
 85                 /* ... [[read-side critical se    
 86                                                   
 87         } while (read_seqcount_retry(&foo_seqc    
 88                                                   
 89                                                   
 90 .. _seqcount_locktype_t:                          
 91                                                   
 92 Sequence counters with associated locks (``seq    
 93 ----------------------------------------------    
 94                                                   
 95 As discussed at :ref:`seqcount_t`, sequence co    
 96 sections must be serialized and non-preemptibl    
 97 sequence counters associate the lock used for     
 98 initialization time, which enables lockdep to     
 99 side critical sections are properly serialized    
100                                                   
101 This lock association is a NOOP if lockdep is     
102 storage nor runtime overhead. If lockdep is en    
103 stored in struct seqcount and lockdep's "lock     
104 injected at the beginning of the write side cr    
105 that it is properly protected.                    
106                                                   
107 For lock types which do not implicitly disable    
108 protection is enforced in the write side funct    
109                                                   
110 The following sequence counters with associate    
111                                                   
112   - ``seqcount_spinlock_t``                       
113   - ``seqcount_raw_spinlock_t``                   
114   - ``seqcount_rwlock_t``                         
115   - ``seqcount_mutex_t``                          
116   - ``seqcount_ww_mutex_t``                       
117                                                   
118 The sequence counter read and write APIs can t    
119 seqcount_t or any of the seqcount_LOCKNAME_t v    
120                                                   
121 Initialization (replace "LOCKNAME" with one of    
122                                                   
123         /* dynamic */                             
124         seqcount_LOCKNAME_t foo_seqcount;         
125         seqcount_LOCKNAME_init(&foo_seqcount,     
126                                                   
127         /* static */                              
128         static seqcount_LOCKNAME_t foo_seqcoun    
129                 SEQCNT_LOCKNAME_ZERO(foo_seqco    
130                                                   
131         /* C99 struct init */                     
132         struct {                                  
133                 .seq   = SEQCNT_LOCKNAME_ZERO(    
134         } foo;                                    
135                                                   
136 Write path: same as in :ref:`seqcount_t`, whil    
137 with the associated write serialization lock a    
138                                                   
139 Read path: same as in :ref:`seqcount_t`.          
140                                                   
141                                                   
142 .. _seqcount_latch_t:                             
143                                                   
144 Latch sequence counters (``seqcount_latch_t``)    
145 ----------------------------------------------    
146                                                   
147 Latch sequence counters are a multiversion con    
148 where the embedded seqcount_t counter even/odd    
149 between two copies of protected data. This all    
150 read path to safely interrupt its own write si    
151                                                   
152 Use seqcount_latch_t when the write side secti    
153 from interruption by readers. This is typicall    
154 side can be invoked from NMI handlers.            
155                                                   
156 Check `raw_write_seqcount_latch()` for more in    
157                                                   
158                                                   
159 .. _seqlock_t:                                    
160                                                   
161 Sequential locks (``seqlock_t``)                  
162 ================================                  
163                                                   
164 This contains the :ref:`seqcount_t` mechanism     
165 embedded spinlock for writer serialization and    
166                                                   
167 If the read side section can be invoked from h    
168 use the write side function variants which dis    
169 halves respectively.                              
170                                                   
171 Initialization::                                  
172                                                   
173         /* dynamic */                             
174         seqlock_t foo_seqlock;                    
175         seqlock_init(&foo_seqlock);               
176                                                   
177         /* static */                              
178         static DEFINE_SEQLOCK(foo_seqlock);       
179                                                   
180         /* C99 struct init */                     
181         struct {                                  
182                 .seql   = __SEQLOCK_UNLOCKED(f    
183         } foo;                                    
184                                                   
185 Write path::                                      
186                                                   
187         write_seqlock(&foo_seqlock);              
188                                                   
189         /* ... [[write-side critical section]]    
190                                                   
191         write_sequnlock(&foo_seqlock);            
192                                                   
193 Read path, three categories:                      
194                                                   
195 1. Normal Sequence readers which never block a    
196    retry if a writer is in progress by detecti    
197    number.  Writers do not wait for a sequence    
198                                                   
199         do {                                      
200                 seq = read_seqbegin(&foo_seqlo    
201                                                   
202                 /* ... [[read-side critical se    
203                                                   
204         } while (read_seqretry(&foo_seqlock, s    
205                                                   
206 2. Locking readers which will wait if a writer    
207    is in progress. A locking reader in progres    
208    from entering its critical section. This re    
209    exclusive. Unlike rwlock_t, only one lockin    
210                                                   
211         read_seqlock_excl(&foo_seqlock);          
212                                                   
213         /* ... [[read-side critical section]]     
214                                                   
215         read_sequnlock_excl(&foo_seqlock);        
216                                                   
217 3. Conditional lockless reader (as in 1), or l    
218    according to a passed marker. This is used     
219    starvation (too much retry loops) in case o    
220    activity. First, a lockless read is tried (    
221    that trial fails (odd sequence counter is r    
222    the next iteration marker), the lockless re    
223    full locking read and no retry loop is nece    
224                                                   
225         /* marker; even initialization */         
226         int seq = 0;                              
227         do {                                      
228                 read_seqbegin_or_lock(&foo_seq    
229                                                   
230                 /* ... [[read-side critical se    
231                                                   
232         } while (need_seqretry(&foo_seqlock, s    
233         done_seqretry(&foo_seqlock, seq);         
234                                                   
235                                                   
236 API documentation                                 
237 =================                                 
238                                                   
239 .. kernel-doc:: include/linux/seqlock.h           
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php