eadm.h 2.0 KB

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