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

TOMOYO Linux Cross Reference
Linux/Documentation/admin-guide/device-mapper/statistics.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/admin-guide/device-mapper/statistics.rst (Version linux-6.12-rc7) and /Documentation/admin-guide/device-mapper/statistics.rst (Version linux-4.17.19)


  1 =============                                     
  2 DM statistics                                     
  3 =============                                     
  4                                                   
  5 Device Mapper supports the collection of I/O s    
  6 regions of a DM device.  If no regions are def    
  7 collected so there isn't any performance impac    
  8 devices are currently supported.                  
  9                                                   
 10 Each user-defined region specifies a starting     
 11 Individual statistics will be collected for ea    
 12 the range specified.                              
 13                                                   
 14 The I/O statistics counters for each step-size    
 15 in the same format as `/sys/block/*/stat` or `    
 16 Documentation/admin-guide/iostats.rst).  But t    
 17 provided: total time spent reading and writing    
 18 argument is used, the 14th parameter is report    
 19 histogram of latencies.  All these counters ma    
 20 the @stats_print message to the appropriate DM    
 21                                                   
 22 The reported times are in milliseconds and the    
 23 the kernel ticks.  When the option precise_tim    
 24 reported times are in nanoseconds.                
 25                                                   
 26 Each region has a corresponding unique identif    
 27 region_id, that is assigned when the region is    
 28 must be supplied when querying statistics abou    
 29 region, etc.  Unique region_ids enable multipl    
 30 request and process statistics for the same DM    
 31 on each other's data.                             
 32                                                   
 33 The creation of DM statistics will allocate me    
 34 fallback to using vmalloc space.  At most, 1/4    
 35 memory may be allocated by DM statistics.  The    
 36 memory is used by reading:                        
 37                                                   
 38         /sys/module/dm_mod/parameters/stats_cu    
 39                                                   
 40 Messages                                          
 41 ========                                          
 42                                                   
 43     @stats_create <range> <step> [<number_of_o    
 44         Create a new region and return the reg    
 45                                                   
 46         <range>                                   
 47           "-"                                     
 48                 whole device                      
 49           "<start_sector>+<length>"               
 50                 a range of <length> 512-byte s    
 51                 starting with <start_sector>.     
 52                                                   
 53         <step>                                    
 54           "<area_size>"                           
 55                 the range is subdivided into a    
 56                 <area_size> sectors.              
 57           "/<number_of_areas>"                    
 58                 the range is subdivided into t    
 59                 number of areas.                  
 60                                                   
 61         <number_of_optional_arguments>            
 62           The number of optional arguments        
 63                                                   
 64         <optional_arguments>                      
 65           The following optional arguments are    
 66                                                   
 67           precise_timestamps                      
 68                 use precise timer with nanosec    
 69                 instead of the "jiffies" varia    
 70                 used, the resulting times are     
 71                 milliseconds.  Precise timesta    
 72                 to obtain than jiffies-based t    
 73           histogram:n1,n2,n3,n4,...               
 74                 collect histogram of latencies    
 75                 numbers n1, n2, etc are times     
 76                 of the histogram.  If precise_    
 77                 times are in milliseconds, oth    
 78                 nanoseconds.  For each range,     
 79                 number of requests that comple    
 80                 example, if we use "histogram:    
 81                 report four numbers a:b:c:d. a    
 82                 that took 0-10 ms to complete,    
 83                 that took 10-20 ms to complete    
 84                 that took 20-30 ms to complete    
 85                 requests that took more than 3    
 86                                                   
 87         <program_id>                              
 88           An optional parameter.  A name that     
 89           the userspace owner of the range.  T    
 90           so that userspace programs can ident    
 91           created and ignore those created by     
 92           The kernel returns this string back     
 93           @stats_list message, but it doesn't     
 94           If we omit the number of optional ar    
 95           be a number, otherwise it would be i    
 96           optional arguments.                     
 97                                                   
 98         <aux_data>                                
 99           An optional parameter.  A word that     
100           that is useful to the client program    
101           The kernel returns this string back     
102           @stats_list message, but it doesn't     
103                                                   
104     @stats_delete <region_id>                     
105         Delete the region with the specified i    
106                                                   
107         <region_id>                               
108           region_id returned from @stats_creat    
109                                                   
110     @stats_clear <region_id>                      
111         Clear all the counters except the in-f    
112                                                   
113         <region_id>                               
114           region_id returned from @stats_creat    
115                                                   
116     @stats_list [<program_id>]                    
117         List all regions registered with @stat    
118                                                   
119         <program_id>                              
120           An optional parameter.                  
121           If this parameter is specified, only    
122           are returned.                           
123           If it is not specified, all regions     
124                                                   
125         Output format:                            
126           <region_id>: <start_sector>+<length>    
127                 precise_timestamps histogram:n    
128                                                   
129         The strings "precise_timestamps" and "    
130         if they were specified when creating t    
131                                                   
132     @stats_print <region_id> [<starting_line>     
133         Print counters for each step-sized are    
134                                                   
135         <region_id>                               
136           region_id returned from @stats_creat    
137                                                   
138         <starting_line>                           
139           The index of the starting line in th    
140           If omitted, all lines are returned.     
141                                                   
142         <number_of_lines>                         
143           The number of lines to include in th    
144           If omitted, all lines are returned.     
145                                                   
146         Output format for each step-sized area    
147                                                   
148           <start_sector>+<length>                 
149                 counters                          
150                                                   
151           The first 11 counters have the same     
152           `/sys/block/*/stat or /proc/diskstat    
153                                                   
154           Please refer to Documentation/admin-    
155                                                   
156           1. the number of reads completed        
157           2. the number of reads merged           
158           3. the number of sectors read           
159           4. the number of milliseconds spent     
160           5. the number of writes completed       
161           6. the number of writes merged          
162           7. the number of sectors written        
163           8. the number of milliseconds spent     
164           9. the number of I/Os currently in p    
165           10. the number of milliseconds spent    
166           11. the weighted number of milliseco    
167                                                   
168           Additional counters:                    
169                                                   
170           12. the total time spent reading in     
171           13. the total time spent writing in     
172                                                   
173     @stats_print_clear <region_id> [<starting_    
174         Atomically print and then clear all th    
175         in-flight i/o counters.  Useful when t    
176         statistics does not want to lose any s    
177         between printing and clearing).           
178                                                   
179         <region_id>                               
180           region_id returned from @stats_creat    
181                                                   
182         <starting_line>                           
183           The index of the starting line in th    
184           If omitted, all lines are printed an    
185                                                   
186         <number_of_lines>                         
187           The number of lines to process.         
188           If omitted, all lines are printed an    
189                                                   
190     @stats_set_aux <region_id> <aux_data>         
191         Store auxiliary data aux_data for the     
192                                                   
193         <region_id>                               
194           region_id returned from @stats_creat    
195                                                   
196         <aux_data>                                
197           The string that identifies data whic    
198           program that created the range.  The    
199           string back in the output of @stats_    
200           doesn't use this value for anything.    
201                                                   
202 Examples                                          
203 ========                                          
204                                                   
205 Subdivide the DM device 'vol' into 100 pieces     
206 statistics on them::                              
207                                                   
208   dmsetup message vol 0 @stats_create - /100      
209                                                   
210 Set the auxiliary data string to "foo bar baz"    
211 space must also be escaped, otherwise the shel    
212                                                   
213   dmsetup message vol 0 @stats_set_aux 0 foo\\    
214                                                   
215 List the statistics::                             
216                                                   
217   dmsetup message vol 0 @stats_list               
218                                                   
219 Print the statistics::                            
220                                                   
221   dmsetup message vol 0 @stats_print 0            
222                                                   
223 Delete the statistics::                           
224                                                   
225   dmsetup message vol 0 @stats_delete 0           
                                                      

~ [ 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