t/nvmept_trim: increase transfer size for some tests
[fio.git] / diskutil.h
... / ...
CommitLineData
1#ifndef FIO_DISKUTIL_H
2#define FIO_DISKUTIL_H
3#define FIO_DU_NAME_SZ 64
4
5#include <stdint.h>
6#include <limits.h>
7
8#include "helper_thread.h"
9#include "fio_sem.h"
10#include "flist.h"
11#include "lib/ieee754.h"
12
13/**
14 * @ios: Number of I/O operations that have been completed successfully.
15 * @merges: Number of I/O operations that have been merged.
16 * @sectors: I/O size in 512-byte units.
17 * @ticks: Time spent on I/O in milliseconds.
18 * @io_ticks: CPU time spent on I/O in milliseconds.
19 * @time_in_queue: Weighted time spent doing I/O in milliseconds.
20 *
21 * For the array members, index 0 refers to reads and index 1 refers to writes.
22 */
23struct disk_util_stats {
24 uint64_t ios[2];
25 uint64_t merges[2];
26 uint64_t sectors[2];
27 uint64_t ticks[2];
28 uint64_t io_ticks;
29 uint64_t time_in_queue;
30 uint64_t msec;
31};
32
33/*
34 * Disk utilization as read from /sys/block/<dev>/stat
35 */
36struct disk_util_stat {
37 uint8_t name[FIO_DU_NAME_SZ];
38 struct disk_util_stats s;
39};
40
41struct disk_util_agg {
42 uint64_t ios[2];
43 uint64_t merges[2];
44 uint64_t sectors[2];
45 uint64_t ticks[2];
46 uint64_t io_ticks;
47 uint64_t time_in_queue;
48 uint32_t slavecount;
49 uint32_t pad;
50 fio_fp64_t max_util;
51};
52
53/*
54 * Per-device disk util management
55 */
56struct disk_util {
57 struct flist_head list;
58 /* If this disk is a slave, hook it into the master's
59 * list using this head.
60 */
61 struct flist_head slavelist;
62
63 char *sysfs_root;
64 char path[PATH_MAX];
65 int major, minor;
66
67 struct disk_util_stat dus;
68 struct disk_util_stat last_dus;
69
70 struct disk_util_agg agg;
71
72 /* For software raids, this entry maintains pointers to the
73 * entries for the slave devices. The disk_util entries for
74 * the slaves devices should primarily be maintained through
75 * the disk_list list, i.e. for memory allocation and
76 * de-allocation, etc. Whereas this list should be used only
77 * for aggregating a software RAID's disk util figures.
78 */
79 struct flist_head slaves;
80
81 struct timespec time;
82
83 struct fio_sem *lock;
84 unsigned long users;
85};
86
87static inline void disk_util_mod(struct disk_util *du, int val)
88{
89 if (du) {
90 struct flist_head *n;
91
92 fio_sem_down(du->lock);
93 du->users += val;
94
95 flist_for_each(n, &du->slavelist) {
96 struct disk_util *slave;
97
98 slave = flist_entry(n, struct disk_util, slavelist);
99 slave->users += val;
100 }
101 fio_sem_up(du->lock);
102 }
103}
104static inline void disk_util_inc(struct disk_util *du)
105{
106 disk_util_mod(du, 1);
107}
108
109static inline void disk_util_dec(struct disk_util *du)
110{
111 disk_util_mod(du, -1);
112}
113
114#define DISK_UTIL_MSEC (250)
115
116extern struct flist_head disk_list;
117
118/*
119 * disk util stuff
120 */
121#ifdef FIO_HAVE_DISK_UTIL
122extern void init_disk_util(struct thread_data *);
123extern int update_io_ticks(void);
124extern void setup_disk_util(void);
125extern void disk_util_prune_entries(void);
126#else
127/* keep this as a function to avoid a warning in handle_du() */
128#define disk_util_prune_entries()
129#define init_disk_util(td)
130#define setup_disk_util()
131
132static inline int update_io_ticks(void)
133{
134 return helper_should_exit();
135}
136#endif
137
138#endif