| 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
| 2 | #ifndef DM_STATS_H |
| 3 | #define DM_STATS_H |
| 4 | |
| 5 | #include <linux/types.h> |
| 6 | #include <linux/mutex.h> |
| 7 | #include <linux/list.h> |
| 8 | |
| 9 | int dm_statistics_init(void); |
| 10 | void dm_statistics_exit(void); |
| 11 | |
| 12 | struct dm_stats { |
| 13 | struct mutex mutex; |
| 14 | struct list_head list; /* list of struct dm_stat */ |
| 15 | struct dm_stats_last_position __percpu *last; |
| 16 | bool precise_timestamps; |
| 17 | }; |
| 18 | |
| 19 | struct dm_stats_aux { |
| 20 | bool merged; |
| 21 | unsigned long long duration_ns; |
| 22 | }; |
| 23 | |
| 24 | int dm_stats_init(struct dm_stats *st); |
| 25 | void dm_stats_cleanup(struct dm_stats *st); |
| 26 | |
| 27 | struct mapped_device; |
| 28 | |
| 29 | int dm_stats_message(struct mapped_device *md, unsigned int argc, char **argv, |
| 30 | char *result, unsigned int maxlen); |
| 31 | |
| 32 | void dm_stats_account_io(struct dm_stats *stats, unsigned long bi_rw, |
| 33 | sector_t bi_sector, unsigned int bi_sectors, bool end, |
| 34 | unsigned long start_time, |
| 35 | struct dm_stats_aux *aux); |
| 36 | |
| 37 | static inline bool dm_stats_used(struct dm_stats *st) |
| 38 | { |
| 39 | return !list_empty(head: &st->list); |
| 40 | } |
| 41 | |
| 42 | static inline void dm_stats_record_start(struct dm_stats *stats, struct dm_stats_aux *aux) |
| 43 | { |
| 44 | if (unlikely(stats->precise_timestamps)) |
| 45 | aux->duration_ns = ktime_to_ns(kt: ktime_get()); |
| 46 | } |
| 47 | |
| 48 | #endif |
| 49 | |