diff options
| author | Eric Dumazet <eric.dumazet@gmail.com> | 2010-06-23 20:04:38 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2010-06-29 02:24:29 -0400 |
| commit | b6b3ecc71a0664d44ed8d087d583aee98fbf492a (patch) | |
| tree | 078e92d78578d3a8833dd225f71a6b2a982ea5be /include/linux | |
| parent | a095cfc40ec7ebe63e9532383c5b5c2a27b14075 (diff) | |
net: u64_stats_sync improvements
- Add a comment about interrupts:
6) If counter might be written by an interrupt, readers should block
interrupts.
- Fix a typo in sample of use.
Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/u64_stats_sync.h | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/include/linux/u64_stats_sync.h b/include/linux/u64_stats_sync.h index d0505156ed52..b38e3a58de83 100644 --- a/include/linux/u64_stats_sync.h +++ b/include/linux/u64_stats_sync.h | |||
| @@ -23,6 +23,10 @@ | |||
| 23 | * pure reads. But if they have to fetch many values, it's better to not allow | 23 | * pure reads. But if they have to fetch many values, it's better to not allow |
| 24 | * preemptions/interruptions to avoid many retries. | 24 | * preemptions/interruptions to avoid many retries. |
| 25 | * | 25 | * |
| 26 | * 6) If counter might be written by an interrupt, readers should block interrupts. | ||
| 27 | * (On UP, there is no seqcount_t protection, a reader allowing interrupts could | ||
| 28 | * read partial values) | ||
| 29 | * | ||
| 26 | * Usage : | 30 | * Usage : |
| 27 | * | 31 | * |
| 28 | * Stats producer (writer) should use following template granted it already got | 32 | * Stats producer (writer) should use following template granted it already got |
| @@ -46,7 +50,7 @@ | |||
| 46 | * start = u64_stats_fetch_begin(&stats->syncp); | 50 | * start = u64_stats_fetch_begin(&stats->syncp); |
| 47 | * tbytes = stats->bytes64; // non atomic operation | 51 | * tbytes = stats->bytes64; // non atomic operation |
| 48 | * tpackets = stats->packets64; // non atomic operation | 52 | * tpackets = stats->packets64; // non atomic operation |
| 49 | * } while (u64_stats_fetch_retry(&stats->lock, syncp)); | 53 | * } while (u64_stats_fetch_retry(&stats->syncp, start)); |
| 50 | * | 54 | * |
| 51 | * | 55 | * |
| 52 | * Example of use in drivers/net/loopback.c, using per_cpu containers, | 56 | * Example of use in drivers/net/loopback.c, using per_cpu containers, |
