mmcsd_host.h 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. /*
  2. * Copyright (c) 2006-2024, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2011-07-25 weety first version
  9. * 2024-05-25 HPMicro add HS400 support
  10. * 2024-05-26 HPMicro add UHS-I support
  11. */
  12. #ifndef __HOST_H__
  13. #define __HOST_H__
  14. #include <rtthread.h>
  15. #ifdef __cplusplus
  16. extern "C" {
  17. #endif
  18. struct rt_mmcsd_io_cfg
  19. {
  20. rt_uint32_t clock; /* clock rate */
  21. rt_uint16_t vdd;
  22. /* vdd stores the bit number of the selected voltage range from below. */
  23. rt_uint8_t bus_mode; /* command output mode */
  24. #define MMCSD_BUSMODE_OPENDRAIN 1
  25. #define MMCSD_BUSMODE_PUSHPULL 2
  26. rt_uint8_t chip_select; /* SPI chip select */
  27. #define MMCSD_CS_IGNORE 0
  28. #define MMCSD_CS_HIGH 1
  29. #define MMCSD_CS_LOW 2
  30. rt_uint8_t power_mode; /* power supply mode */
  31. #define MMCSD_POWER_OFF 0
  32. #define MMCSD_POWER_UP 1
  33. #define MMCSD_POWER_ON 2
  34. rt_uint8_t bus_width; /* data bus width */
  35. #define MMCSD_BUS_WIDTH_1 0
  36. #define MMCSD_BUS_WIDTH_4 2
  37. #define MMCSD_BUS_WIDTH_8 3
  38. unsigned char timing; /* timing specification used */
  39. #define MMCSD_TIMING_LEGACY 0
  40. #define MMCSD_TIMING_MMC_HS 1
  41. #define MMCSD_TIMING_SD_HS 2
  42. #define MMCSD_TIMING_UHS_SDR12 3
  43. #define MMCSD_TIMING_UHS_SDR25 4
  44. #define MMCSD_TIMING_UHS_SDR50 5
  45. #define MMCSD_TIMING_UHS_SDR104 6
  46. #define MMCSD_TIMING_UHS_DDR50 7
  47. #define MMCSD_TIMING_MMC_DDR52 8
  48. #define MMCSD_TIMING_MMC_HS200 9
  49. #define MMCSD_TIMING_MMC_HS400 10
  50. #define MMCSD_TIMING_MMC_HS400_ENH_DS 11
  51. unsigned char drv_type; /* driver type (A, B, C, D) */
  52. #define MMCSD_SET_DRIVER_TYPE_B 0
  53. #define MMCSD_SET_DRIVER_TYPE_A 1
  54. #define MMCSD_SET_DRIVER_TYPE_C 2
  55. #define MMCSD_SET_DRIVER_TYPE_D 3
  56. unsigned char signal_voltage;
  57. #define MMCSD_SIGNAL_VOLTAGE_330 0
  58. #define MMCSD_SIGNAL_VOLTAGE_180 1
  59. #define MMCSD_SIGNAL_VOLTAGE_120 2
  60. rt_bool_t enhanced_strobe;
  61. };
  62. struct rt_mmcsd_host;
  63. struct rt_mmcsd_req;
  64. struct rt_mmcsd_host_ops
  65. {
  66. void (*request)(struct rt_mmcsd_host *host, struct rt_mmcsd_req *req);
  67. void (*set_iocfg)(struct rt_mmcsd_host *host, struct rt_mmcsd_io_cfg *io_cfg);
  68. rt_int32_t (*get_card_status)(struct rt_mmcsd_host *host);
  69. void (*enable_sdio_irq)(struct rt_mmcsd_host *host, rt_int32_t en);
  70. rt_int32_t (*execute_tuning)(struct rt_mmcsd_host *host, rt_int32_t opcode);
  71. rt_bool_t (*card_busy)(struct rt_mmcsd_host *host);
  72. rt_err_t (*signal_voltage_switch)(struct rt_mmcsd_host *host, struct rt_mmcsd_io_cfg *io_cfg);
  73. };
  74. #ifdef RT_USING_REGULATOR
  75. struct rt_regulator;
  76. struct rt_mmcsd_supply
  77. {
  78. rt_bool_t vqmmc_enabled;
  79. rt_bool_t regulator_enabled;
  80. struct rt_regulator *vmmc; /* Card power supply */
  81. struct rt_regulator *vqmmc; /* Optional Vccq supply */
  82. };
  83. #endif /* RT_USING_REGULATOR */
  84. struct rt_mmcsd_host
  85. {
  86. char name[RT_NAME_MAX];
  87. struct rt_mmcsd_card *card;
  88. const struct rt_mmcsd_host_ops *ops;
  89. rt_uint32_t freq_min;
  90. rt_uint32_t freq_max;
  91. struct rt_mmcsd_io_cfg io_cfg;
  92. rt_uint32_t valid_ocr; /* current valid OCR */
  93. #define VDD_165_195 (1 << 7) /* VDD voltage 1.65 - 1.95 */
  94. #define VDD_20_21 (1 << 8) /* VDD voltage 2.0 ~ 2.1 */
  95. #define VDD_21_22 (1 << 9) /* VDD voltage 2.1 ~ 2.2 */
  96. #define VDD_22_23 (1 << 10) /* VDD voltage 2.2 ~ 2.3 */
  97. #define VDD_23_24 (1 << 11) /* VDD voltage 2.3 ~ 2.4 */
  98. #define VDD_24_25 (1 << 12) /* VDD voltage 2.4 ~ 2.5 */
  99. #define VDD_25_26 (1 << 13) /* VDD voltage 2.5 ~ 2.6 */
  100. #define VDD_26_27 (1 << 14) /* VDD voltage 2.6 ~ 2.7 */
  101. #define VDD_27_28 (1 << 15) /* VDD voltage 2.7 ~ 2.8 */
  102. #define VDD_28_29 (1 << 16) /* VDD voltage 2.8 ~ 2.9 */
  103. #define VDD_29_30 (1 << 17) /* VDD voltage 2.9 ~ 3.0 */
  104. #define VDD_30_31 (1 << 18) /* VDD voltage 3.0 ~ 3.1 */
  105. #define VDD_31_32 (1 << 19) /* VDD voltage 3.1 ~ 3.2 */
  106. #define VDD_32_33 (1 << 20) /* VDD voltage 3.2 ~ 3.3 */
  107. #define VDD_33_34 (1 << 21) /* VDD voltage 3.3 ~ 3.4 */
  108. #define VDD_34_35 (1 << 22) /* VDD voltage 3.4 ~ 3.5 */
  109. #define VDD_35_36 (1 << 23) /* VDD voltage 3.5 ~ 3.6 */
  110. #define OCR_S18R (1 << 24) /* Switch to 1V8 Request */
  111. rt_uint32_t flags; /* define device capabilities */
  112. #define MMCSD_BUSWIDTH_4 (1 << 0)
  113. #define MMCSD_BUSWIDTH_8 (1 << 1)
  114. #define MMCSD_MUTBLKWRITE (1 << 2)
  115. #define MMCSD_HOST_IS_SPI (1 << 3)
  116. #define controller_is_spi(host) (host->flags & MMCSD_HOST_IS_SPI)
  117. #define MMCSD_SUP_SDIO_IRQ (1 << 4) /* support signal pending SDIO IRQs */
  118. #define MMCSD_SUP_HIGHSPEED (1 << 5) /* support high speed SDR */
  119. #define MMCSD_SUP_DDR_3V3 (1 << 6)
  120. #define MMCSD_SUP_DDR_1V8 (1 << 7)
  121. #define MMCSD_SUP_DDR_1V2 (1 << 8)
  122. #define MMCSD_SUP_HIGHSPEED_DDR (MMCSD_SUP_DDR_3V3 | MMCSD_SUP_DDR_1V8 | MMCSD_SUP_DDR_1V2)/* HIGH SPEED DDR */
  123. #define MMCSD_SUP_HS200_1V8 (1 << 9)
  124. #define MMCSD_SUP_HS200_1V2 (1 << 10)
  125. #define MMCSD_SUP_HS200 (MMCSD_SUP_HS200_1V2 | MMCSD_SUP_HS200_1V8) /* hs200 sdr */
  126. #define MMCSD_SUP_NONREMOVABLE (1 << 11)
  127. #define controller_is_removable(host) (!(host->flags & MMCSD_SUP_NONREMOVABLE))
  128. #define MMCSD_SUP_HS400_1V8 (1 << 12)
  129. #define MMCSD_SUP_HS400_1V2 (1 << 13)
  130. #define MMCSD_SUP_HS400 (MMCSD_SUP_HS400_1V2 | MMCSD_SUP_HS400_1V8) /* hs400 ddr */
  131. #define MMCSD_SUP_ENH_DS (1 << 14)
  132. #define MMCSD_SUP_SDR50 (1 << 15)
  133. #define MMCSD_SUP_SDR104 (1 << 16)
  134. #define MMCSD_SUP_DDR50 (1 << 17)
  135. rt_uint32_t max_seg_size; /* maximum size of one dma segment */
  136. rt_uint32_t max_dma_segs; /* maximum number of dma segments in one request */
  137. rt_uint32_t max_blk_size; /* maximum block size */
  138. rt_uint32_t max_blk_count; /* maximum block count */
  139. rt_uint32_t id; /* Assigned host id */
  140. rt_uint32_t spi_use_crc;
  141. struct rt_mutex bus_lock;
  142. struct rt_semaphore sem_ack;
  143. rt_uint32_t sdio_irq_num;
  144. struct rt_semaphore *sdio_irq_sem;
  145. struct rt_thread *sdio_irq_thread;
  146. #ifdef RT_USING_REGULATOR
  147. struct rt_mmcsd_supply supply;
  148. #endif
  149. #ifdef RT_USING_OFW
  150. void *ofw_node;
  151. #endif
  152. void *private_data;
  153. };
  154. #ifdef __cplusplus
  155. }
  156. #endif
  157. #endif