eadm.h 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. #ifndef _ASM_S390_EADM_H
  2. #define _ASM_S390_EADM_H
  3. #include <linux/types.h>
  4. #include <linux/device.h>
  5. struct arqb {
  6. u64 data;
  7. u16 fmt:4;
  8. u16:12;
  9. u16 cmd_code;
  10. u16:16;
  11. u16 msb_count;
  12. u32 reserved[12];
  13. } __packed;
  14. #define ARQB_CMD_MOVE 1
  15. struct arsb {
  16. u16 fmt:4;
  17. u32:28;
  18. u8 ef;
  19. u8:8;
  20. u8 ecbi;
  21. u8:8;
  22. u8 fvf;
  23. u16:16;
  24. u8 eqc;
  25. u32:32;
  26. u64 fail_msb;
  27. u64 fail_aidaw;
  28. u64 fail_ms;
  29. u64 fail_scm;
  30. u32 reserved[4];
  31. } __packed;
  32. struct msb {
  33. u8 fmt:4;
  34. u8 oc:4;
  35. u8 flags;
  36. u16:12;
  37. u16 bs:4;
  38. u32 blk_count;
  39. u64 data_addr;
  40. u64 scm_addr;
  41. u64:64;
  42. } __packed;
  43. struct aidaw {
  44. u8 flags;
  45. u32 :24;
  46. u32 :32;
  47. u64 data_addr;
  48. } __packed;
  49. #define MSB_OC_CLEAR 0
  50. #define MSB_OC_READ 1
  51. #define MSB_OC_WRITE 2
  52. #define MSB_OC_RELEASE 3
  53. #define MSB_FLAG_BNM 0x80
  54. #define MSB_FLAG_IDA 0x40
  55. #define MSB_BS_4K 0
  56. #define MSB_BS_1M 1
  57. #define AOB_NR_MSB 124
  58. struct aob {
  59. struct arqb request;
  60. struct arsb response;
  61. struct msb msb[AOB_NR_MSB];
  62. } __packed __aligned(PAGE_SIZE);
  63. struct aob_rq_header {
  64. struct scm_device *scmdev;
  65. char data[0];
  66. };
  67. struct scm_device {
  68. u64 address;
  69. u64 size;
  70. unsigned int nr_max_block;
  71. struct device dev;
  72. struct {
  73. unsigned int persistence:4;
  74. unsigned int oper_state:4;
  75. unsigned int data_state:4;
  76. unsigned int rank:4;
  77. unsigned int release:1;
  78. unsigned int res_id:8;
  79. } __packed attrs;
  80. };
  81. #define OP_STATE_GOOD 1
  82. #define OP_STATE_TEMP_ERR 2
  83. #define OP_STATE_PERM_ERR 3
  84. struct scm_driver {
  85. struct device_driver drv;
  86. int (*probe) (struct scm_device *scmdev);
  87. int (*remove) (struct scm_device *scmdev);
  88. void (*notify) (struct scm_device *scmdev);
  89. void (*handler) (struct scm_device *scmdev, void *data, int error);
  90. };
  91. int scm_driver_register(struct scm_driver *scmdrv);
  92. void scm_driver_unregister(struct scm_driver *scmdrv);
  93. int scm_start_aob(struct aob *aob);
  94. void scm_irq_handler(struct aob *aob, int error);
  95. struct eadm_ops {
  96. int (*eadm_start) (struct aob *aob);
  97. struct module *owner;
  98. };
  99. int scm_get_ref(void);
  100. void scm_put_ref(void);
  101. void register_eadm_ops(struct eadm_ops *ops);
  102. void unregister_eadm_ops(struct eadm_ops *ops);
  103. #endif /* _ASM_S390_EADM_H */