mmcsd_host.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. #ifndef _MMCSD_HOST_H
  2. #define _MMCSD_HOST_H
  3. #include "FreeRTOS.h"
  4. #include "semphr.h"
  5. #include "task.h"
  6. #ifdef __cplusplus
  7. extern "C" {
  8. #endif
  9. struct mmcsd_io_cfg {
  10. uint32_t clock; /* clock rate */
  11. uint16_t vdd;
  12. /* vdd stores the bit number of the selected voltage range from below. */
  13. uint8_t bus_mode; /* command output mode */
  14. #define MMCSD_BUSMODE_OPENDRAIN 1
  15. #define MMCSD_BUSMODE_PUSHPULL 2
  16. uint8_t chip_select; /* SPI chip select */
  17. #define MMCSD_CS_IGNORE 0
  18. #define MMCSD_CS_HIGH 1
  19. #define MMCSD_CS_LOW 2
  20. uint8_t power_mode; /* power supply mode */
  21. #define MMCSD_POWER_OFF 0
  22. #define MMCSD_POWER_UP 1
  23. #define MMCSD_POWER_ON 2
  24. uint8_t bus_width; /* data bus width */
  25. #define MMCSD_BUS_WIDTH_1 0
  26. #define MMCSD_BUS_WIDTH_4 2
  27. #define MMCSD_BUS_WIDTH_8 3
  28. };
  29. struct mmcsd_host;
  30. struct mmcsd_req;
  31. struct mmcsd_host_ops {
  32. void (*request)(struct mmcsd_host *host, struct mmcsd_req *req);
  33. void (*set_iocfg)(struct mmcsd_host *host, struct mmcsd_io_cfg *io_cfg);
  34. int32_t (*get_card_status)(struct mmcsd_host *host);
  35. void (*enable_sdio_irq)(struct mmcsd_host *host, int32_t en);
  36. };
  37. struct mmcsd_host {
  38. struct mmcsd_card *card;
  39. const struct mmcsd_host_ops *ops;
  40. uint32_t freq_min;
  41. uint32_t freq_max;
  42. struct mmcsd_io_cfg io_cfg;
  43. uint32_t valid_ocr; /* current valid OCR */
  44. #define VDD_165_195 (1 << 7) /* VDD voltage 1.65 - 1.95 */
  45. #define VDD_20_21 (1 << 8) /* VDD voltage 2.0 ~ 2.1 */
  46. #define VDD_21_22 (1 << 9) /* VDD voltage 2.1 ~ 2.2 */
  47. #define VDD_22_23 (1 << 10) /* VDD voltage 2.2 ~ 2.3 */
  48. #define VDD_23_24 (1 << 11) /* VDD voltage 2.3 ~ 2.4 */
  49. #define VDD_24_25 (1 << 12) /* VDD voltage 2.4 ~ 2.5 */
  50. #define VDD_25_26 (1 << 13) /* VDD voltage 2.5 ~ 2.6 */
  51. #define VDD_26_27 (1 << 14) /* VDD voltage 2.6 ~ 2.7 */
  52. #define VDD_27_28 (1 << 15) /* VDD voltage 2.7 ~ 2.8 */
  53. #define VDD_28_29 (1 << 16) /* VDD voltage 2.8 ~ 2.9 */
  54. #define VDD_29_30 (1 << 17) /* VDD voltage 2.9 ~ 3.0 */
  55. #define VDD_30_31 (1 << 18) /* VDD voltage 3.0 ~ 3.1 */
  56. #define VDD_31_32 (1 << 19) /* VDD voltage 3.1 ~ 3.2 */
  57. #define VDD_32_33 (1 << 20) /* VDD voltage 3.2 ~ 3.3 */
  58. #define VDD_33_34 (1 << 21) /* VDD voltage 3.3 ~ 3.4 */
  59. #define VDD_34_35 (1 << 22) /* VDD voltage 3.4 ~ 3.5 */
  60. #define VDD_35_36 (1 << 23) /* VDD voltage 3.5 ~ 3.6 */
  61. uint32_t flags; /* define device capabilities */
  62. #define MMCSD_BUSWIDTH_4 (1 << 0)
  63. #define MMCSD_BUSWIDTH_8 (1 << 1)
  64. #define MMCSD_MUTBLKWRITE (1 << 2)
  65. #define MMCSD_HOST_IS_SPI (1 << 3)
  66. #define controller_is_spi(host) (host->flags & MMCSD_HOST_IS_SPI)
  67. #define MMCSD_SUP_SDIO_IRQ (1 << 4) /* support signal pending SDIO IRQs */
  68. #define MMCSD_SUP_HIGHSPEED (1 << 5) /* support high speed */
  69. uint32_t max_seg_size; /* maximum size of one dma segment */
  70. uint32_t max_dma_segs; /* maximum number of dma segments in one request */
  71. uint32_t max_blk_size; /* maximum block size */
  72. uint32_t max_blk_count; /* maximum block count */
  73. /* host specific block data */
  74. unsigned short max_segs; /* see blk_queue_max_segments */
  75. unsigned int max_req_size; /* maximum number of bytes in one req */
  76. // unsigned int ring_size;
  77. uint32_t spi_use_crc;
  78. SemaphoreHandle_t bus_lock;
  79. SemaphoreHandle_t sem_ack;
  80. uint32_t sdio_irq_num;
  81. SemaphoreHandle_t sdio_irq_sem;
  82. TaskHandle_t sdio_irq_thread;
  83. void *private_data;
  84. };
  85. static inline void mmcsd_delay_ms(uint32_t ms)
  86. {
  87. if (ms < 1000 / configTICK_RATE_HZ)
  88. {
  89. vTaskDelay(1);
  90. }
  91. else
  92. {
  93. vTaskDelay(ms/(1000 / configTICK_RATE_HZ));
  94. }
  95. }
  96. #ifdef __cplusplus
  97. }
  98. #endif
  99. #endif