drv_sdhi.h 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. /*
  2. * Copyright (c) 2006-2025, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2021-11-03 mazhiyuan first version
  9. */
  10. #ifndef __DRV_SDHI_H__
  11. #define __DRV_SDHI_H__
  12. #include <rtthread.h>
  13. #include <rtdevice.h>
  14. #include <rthw.h>
  15. #include <drv_common.h>
  16. #include <drv_config.h>
  17. #include <hal_data.h>
  18. #ifndef SDIO_BUFF_SIZE
  19. #define SDIO_BUFF_SIZE 4096
  20. #endif
  21. #ifndef SDIO_ALIGN_LEN
  22. #define SDIO_ALIGN_LEN (32)
  23. #endif
  24. #define SD_INFO2_CBSY_SDD0MON_IDLE_VAL 0x80
  25. #define SD_INFO2_CBSY_SDD0MON_IDLE_MASK 0x4080
  26. #define BUSY_TIMEOUT_US 5000000
  27. #define SDHI_INFO1_RESPONSE_END 1
  28. #define SDHI_INFO1_ACCESS_END (1 << 2)
  29. #define SDHI_INFO2_MASK_CMD_SEND 0x00007C80U
  30. #define SDHI_INFO2_BRE (1 << 8)
  31. #define SDHI_INFO2_BWE (1 << 9)
  32. #define SDHI_CMD_RESP_TYPE_EXT_NONE (0 << 8)
  33. #define SDHI_CMD_RESP_TYPE_EXT_R1_R5_R6_R7 (4 << 8)
  34. #define SDHI_CMD_RESP_TYPE_EXT_R1B (5 << 8)
  35. #define SDHI_CMD_RESP_TYPE_EXT_R2 (6 << 8)
  36. #define SDHI_CMD_RESP_TYPE_EXT_R3_R4 (7 << 8)
  37. #define SDHI_CMD_ADTC_EN (1 << 11)
  38. #define SDHI_CMD_DATA_DIR_READ (1 << 12)
  39. #define SDHI_BLK_TRANSFER (1 << 13)
  40. #define SDHI_BLK_NOT_AUTO_STOP (1 << 14)
  41. #if defined(SOC_SERIES_R7KA8P1)
  42. #define SDIO_MAX_FREQ (50 * 1000 * 1000)
  43. #else
  44. #define SDIO_MAX_FREQ (25 * 1000 * 1000)
  45. #endif
  46. #define HW_SDHI_ERR_CRCE (0x01U << 17)
  47. #define HW_SDHI_ERR_RTIMEOUT (0x01U << 22)
  48. #define HW_SDHI_ERR_DTIMEOUT (0x01U << 19)
  49. #define SDHI_WAIT_ACCESS_BIT 2
  50. #define SDHI_WAIT_RESPONSE_BIT 0
  51. #define SDIO_TX_RX_COMPLETE_TIMEOUT_LOOPS (1000000U)
  52. struct ra_sdhi
  53. {
  54. const sdmmc_instance_t *instance;
  55. sdmmc_device_t *media_device;
  56. rt_uint8_t bus_width; /* Store bus width (1 or 4) for each SDHI instance */
  57. };
  58. extern void sdcard_change(void);
  59. #endif