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