cmb.h 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  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. /* enable channel measurement */
  43. #define BIODASDCMFENABLE _IO(DASD_IOCTL_LETTER,32)
  44. /* enable channel measurement */
  45. #define BIODASDCMFDISABLE _IO(DASD_IOCTL_LETTER,33)
  46. /* read channel measurement data */
  47. #define BIODASDREADALLCMB _IOWR(DASD_IOCTL_LETTER,33,struct cmbdata)
  48. #ifdef __KERNEL__
  49. struct ccw_device;
  50. /**
  51. * enable_cmf() - switch on the channel measurement for a specific device
  52. * @cdev: The ccw device to be enabled
  53. * returns 0 for success or a negative error value.
  54. *
  55. * Context:
  56. * non-atomic
  57. **/
  58. extern int enable_cmf(struct ccw_device *cdev);
  59. /**
  60. * disable_cmf() - switch off the channel measurement for a specific device
  61. * @cdev: The ccw device to be disabled
  62. * returns 0 for success or a negative error value.
  63. *
  64. * Context:
  65. * non-atomic
  66. **/
  67. extern int disable_cmf(struct ccw_device *cdev);
  68. /**
  69. * cmf_read() - read one value from the current channel measurement block
  70. * @cmf: the channel to be read
  71. * @index: the name of the value that is read
  72. *
  73. * Context:
  74. * any
  75. **/
  76. extern u64 cmf_read(struct ccw_device *cdev, int index);
  77. /**
  78. * cmf_readall() - read one value from the current channel measurement block
  79. * @cmf: the channel to be read
  80. * @data: a pointer to a data block that will be filled
  81. *
  82. * Context:
  83. * any
  84. **/
  85. extern int cmf_readall(struct ccw_device *cdev, struct cmbdata*data);
  86. extern void cmf_reset(struct ccw_device *cdev);
  87. #endif /* __KERNEL__ */
  88. #endif /* S390_CMB_H */