1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- #ifndef S390_CMB_H
- #define S390_CMB_H
- /**
- * struct cmbdata -- channel measurement block data for user space
- *
- * @size: size of the stored data
- * @ssch_rsch_count: XXX
- * @sample_count:
- * @device_connect_time:
- * @function_pending_time:
- * @device_disconnect_time:
- * @control_unit_queuing_time:
- * @device_active_only_time:
- * @device_busy_time:
- * @initial_command_response_time:
- *
- * all values are stored as 64 bit for simplicity, especially
- * in 32 bit emulation mode. All time values are normalized to
- * nanoseconds.
- * Currently, two formats are known, which differ by the size of
- * this structure, i.e. the last two members are only set when
- * the extended channel measurement facility (first shipped in
- * z990 machines) is activated.
- * Potentially, more fields could be added, which results in a
- * new ioctl number.
- **/
- struct cmbdata {
- __u64 size;
- __u64 elapsed_time;
- /* basic and exended format: */
- __u64 ssch_rsch_count;
- __u64 sample_count;
- __u64 device_connect_time;
- __u64 function_pending_time;
- __u64 device_disconnect_time;
- __u64 control_unit_queuing_time;
- __u64 device_active_only_time;
- /* extended format only: */
- __u64 device_busy_time;
- __u64 initial_command_response_time;
- };
- /* enable channel measurement */
- #define BIODASDCMFENABLE _IO(DASD_IOCTL_LETTER,32)
- /* enable channel measurement */
- #define BIODASDCMFDISABLE _IO(DASD_IOCTL_LETTER,33)
- /* reset channel measurement block */
- #define BIODASDRESETCMB _IO(DASD_IOCTL_LETTER,34)
- /* read channel measurement data */
- #define BIODASDREADCMB _IOWR(DASD_IOCTL_LETTER,32,u64)
- /* read channel measurement data */
- #define BIODASDREADALLCMB _IOWR(DASD_IOCTL_LETTER,33,struct cmbdata)
- #ifdef __KERNEL__
- struct ccw_device;
- /**
- * enable_cmf() - switch on the channel measurement for a specific device
- * @cdev: The ccw device to be enabled
- * returns 0 for success or a negative error value.
- *
- * Context:
- * non-atomic
- **/
- extern int enable_cmf(struct ccw_device *cdev);
- /**
- * disable_cmf() - switch off the channel measurement for a specific device
- * @cdev: The ccw device to be disabled
- * returns 0 for success or a negative error value.
- *
- * Context:
- * non-atomic
- **/
- extern int disable_cmf(struct ccw_device *cdev);
- /**
- * cmf_read() - read one value from the current channel measurement block
- * @cmf: the channel to be read
- * @index: the name of the value that is read
- *
- * Context:
- * any
- **/
- extern u64 cmf_read(struct ccw_device *cdev, int index);
- /**
- * cmf_readall() - read one value from the current channel measurement block
- * @cmf: the channel to be read
- * @data: a pointer to a data block that will be filled
- *
- * Context:
- * any
- **/
- extern int cmf_readall(struct ccw_device *cdev, struct cmbdata*data);
- extern void cmf_reset(struct ccw_device *cdev);
- #endif /* __KERNEL__ */
- #endif /* S390_CMB_H */
|