diff options
author | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-16 18:20:36 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-16 18:20:36 -0400 |
commit | 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 (patch) | |
tree | 0bba044c4ce775e45a88a51686b5d9f90697ea9d /include/asm-s390/cmb.h |
Linux-2.6.12-rc2v2.6.12-rc2
Initial git repository build. I'm not bothering with the full history,
even though we have it. We can create a separate "historical" git
archive of that later if we want to, and in the meantime it's about
3.2GB when imported into git - space that would just make the early
git days unnecessarily complicated, when we don't have a lot of good
infrastructure for it.
Let it rip!
Diffstat (limited to 'include/asm-s390/cmb.h')
-rw-r--r-- | include/asm-s390/cmb.h | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/include/asm-s390/cmb.h b/include/asm-s390/cmb.h new file mode 100644 index 000000000000..1bfe2bd630b5 --- /dev/null +++ b/include/asm-s390/cmb.h | |||
@@ -0,0 +1,98 @@ | |||
1 | #ifndef S390_CMB_H | ||
2 | #define S390_CMB_H | ||
3 | /** | ||
4 | * struct cmbdata -- channel measurement block data for user space | ||
5 | * | ||
6 | * @size: size of the stored data | ||
7 | * @ssch_rsch_count: XXX | ||
8 | * @sample_count: | ||
9 | * @device_connect_time: | ||
10 | * @function_pending_time: | ||
11 | * @device_disconnect_time: | ||
12 | * @control_unit_queuing_time: | ||
13 | * @device_active_only_time: | ||
14 | * @device_busy_time: | ||
15 | * @initial_command_response_time: | ||
16 | * | ||
17 | * all values are stored as 64 bit for simplicity, especially | ||
18 | * in 32 bit emulation mode. All time values are normalized to | ||
19 | * nanoseconds. | ||
20 | * Currently, two formats are known, which differ by the size of | ||
21 | * this structure, i.e. the last two members are only set when | ||
22 | * the extended channel measurement facility (first shipped in | ||
23 | * z990 machines) is activated. | ||
24 | * Potentially, more fields could be added, which results in a | ||
25 | * new ioctl number. | ||
26 | **/ | ||
27 | struct cmbdata { | ||
28 | __u64 size; | ||
29 | __u64 elapsed_time; | ||
30 | /* basic and exended format: */ | ||
31 | __u64 ssch_rsch_count; | ||
32 | __u64 sample_count; | ||
33 | __u64 device_connect_time; | ||
34 | __u64 function_pending_time; | ||
35 | __u64 device_disconnect_time; | ||
36 | __u64 control_unit_queuing_time; | ||
37 | __u64 device_active_only_time; | ||
38 | /* extended format only: */ | ||
39 | __u64 device_busy_time; | ||
40 | __u64 initial_command_response_time; | ||
41 | }; | ||
42 | |||
43 | /* enable channel measurement */ | ||
44 | #define BIODASDCMFENABLE _IO(DASD_IOCTL_LETTER,32) | ||
45 | /* enable channel measurement */ | ||
46 | #define BIODASDCMFDISABLE _IO(DASD_IOCTL_LETTER,33) | ||
47 | /* reset channel measurement block */ | ||
48 | #define BIODASDRESETCMB _IO(DASD_IOCTL_LETTER,34) | ||
49 | /* read channel measurement data */ | ||
50 | #define BIODASDREADCMB _IOWR(DASD_IOCTL_LETTER,32,u64) | ||
51 | /* read channel measurement data */ | ||
52 | #define BIODASDREADALLCMB _IOWR(DASD_IOCTL_LETTER,33,struct cmbdata) | ||
53 | |||
54 | #ifdef __KERNEL__ | ||
55 | |||
56 | /** | ||
57 | * enable_cmf() - switch on the channel measurement for a specific device | ||
58 | * @cdev: The ccw device to be enabled | ||
59 | * returns 0 for success or a negative error value. | ||
60 | * | ||
61 | * Context: | ||
62 | * non-atomic | ||
63 | **/ | ||
64 | extern int enable_cmf(struct ccw_device *cdev); | ||
65 | |||
66 | /** | ||
67 | * disable_cmf() - switch off the channel measurement for a specific device | ||
68 | * @cdev: The ccw device to be disabled | ||
69 | * returns 0 for success or a negative error value. | ||
70 | * | ||
71 | * Context: | ||
72 | * non-atomic | ||
73 | **/ | ||
74 | extern int disable_cmf(struct ccw_device *cdev); | ||
75 | |||
76 | /** | ||
77 | * cmf_read() - read one value from the current channel measurement block | ||
78 | * @cmf: the channel to be read | ||
79 | * @index: the name of the value that is read | ||
80 | * | ||
81 | * Context: | ||
82 | * any | ||
83 | **/ | ||
84 | |||
85 | extern u64 cmf_read(struct ccw_device *cdev, int index); | ||
86 | /** | ||
87 | * cmf_readall() - read one value from the current channel measurement block | ||
88 | * @cmf: the channel to be read | ||
89 | * @data: a pointer to a data block that will be filled | ||
90 | * | ||
91 | * Context: | ||
92 | * any | ||
93 | **/ | ||
94 | extern int cmf_readall(struct ccw_device *cdev, struct cmbdata*data); | ||
95 | extern void cmf_reset(struct ccw_device *cdev); | ||
96 | |||
97 | #endif /* __KERNEL__ */ | ||
98 | #endif /* S390_CMB_H */ | ||