spi_msd.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. /*
  2. * File : msd.h
  3. * SPI mode SD Card Driver
  4. * This file is part of RT-Thread RTOS
  5. * COPYRIGHT (C) 2006 - 2012, RT-Thread Development Team
  6. *
  7. * The license and distribution terms for this file may be
  8. * found in the file LICENSE in this distribution or at
  9. * http://www.rt-thread.org/license/LICENSE
  10. *
  11. * Change Logs:
  12. * Date Author Notes
  13. * 2009-04-17 Bernard first version.
  14. */
  15. #ifndef SPI_MSD_H_INCLUDED
  16. #define SPI_MSD_H_INCLUDED
  17. #include <stdint.h>
  18. #include <drivers/spi.h>
  19. /* SD command (SPI mode) */
  20. #define GO_IDLE_STATE 0 /* CMD0 R1 */
  21. #define SEND_OP_COND 1 /* CMD1 R1 */
  22. #define SWITCH_FUNC 6 /* CMD6 R1 */
  23. #define SEND_IF_COND 8 /* CMD8 R7 */
  24. #define SEND_CSD 9 /* CMD9 R1 */
  25. #define SEND_CID 10 /* CMD10 R1 */
  26. #define STOP_TRANSMISSION 12 /* CMD12 R1B */
  27. #define SEND_STATUS 13 /* CMD13 R2 */
  28. #define SET_BLOCKLEN 16 /* CMD16 R1 */
  29. #define READ_SINGLE_BLOCK 17 /* CMD17 R1 */
  30. #define READ_MULTIPLE_BLOCK 18 /* CMD18 R1 */
  31. #define WRITE_BLOCK 24 /* CMD24 R1 */
  32. #define WRITE_MULTIPLE_BLOCK 25 /* CMD25 R1 */
  33. #define PROGRAM_CSD 27 /* CMD27 R1 */
  34. #define SET_WRITE_PROT 28 /* CMD28 R1B */
  35. #define CLR_WRITE_PROT 29 /* CMD29 R1B */
  36. #define SEND_WRITE_PROT 30 /* CMD30 R1 */
  37. #define ERASE_WR_BLK_START_ADDR 32 /* CMD32 R1 */
  38. #define ERASE_WR_BLK_END_ADDR 33 /* CMD33 R1 */
  39. #define ERASE 38 /* CMD38 R1B */
  40. #define LOCK_UNLOCK 42 /* CMD42 R1 */
  41. #define APP_CMD 55 /* CMD55 R1 */
  42. #define GEN_CMD 56 /* CMD56 R1 */
  43. #define READ_OCR 58 /* CMD58 R3 */
  44. #define CRC_ON_OFF 59 /* CMD59 R1 */
  45. /* Application-Specific Command */
  46. #define SD_STATUS 13 /* ACMD13 R2 */
  47. #define SEND_NUM_WR_BLOCKS 22 /* ACMD22 R1 */
  48. #define SET_WR_BLK_ERASE_COUNT 23 /* ACMD23 R1 */
  49. #define SD_SEND_OP_COND 41 /* ACMD41 R1 */
  50. #define SET_CLR_CARD_DETECT 42 /* ACMD42 R1 */
  51. #define SEND_SCR 51 /* ACMD51 R1 */
  52. /* Start Data tokens */
  53. /* Tokens (necessary because at nop/idle (and CS active) only 0xff is on the data/command line) */
  54. #define MSD_TOKEN_READ_START 0xFE /* Data token start byte, Start Single Block Read */
  55. #define MSD_TOKEN_WRITE_SINGLE_START 0xFE /* Data token start byte, Start Single Block Write */
  56. #define MSD_TOKEN_WRITE_MULTIPLE_START 0xFC /* Data token start byte, Start Multiple Block Write */
  57. #define MSD_TOKEN_WRITE_MULTIPLE_STOP 0xFD /* Data toke stop byte, Stop Multiple Block Write */
  58. /* MSD reponses and error flags */
  59. #define MSD_RESPONSE_NO_ERROR 0x00
  60. #define MSD_IN_IDLE_STATE 0x01
  61. #define MSD_ERASE_RESET 0x02
  62. #define MSD_ILLEGAL_COMMAND 0x04
  63. #define MSD_COM_CRC_ERROR 0x08
  64. #define MSD_ERASE_SEQUENCE_ERROR 0x10
  65. #define MSD_ADDRESS_ERROR 0x20
  66. #define MSD_PARAMETER_ERROR 0x40
  67. #define MSD_RESPONSE_FAILURE 0xFF
  68. /* Data response error */
  69. #define MSD_DATA_OK 0x05
  70. #define MSD_DATA_CRC_ERROR 0x0B
  71. #define MSD_DATA_WRITE_ERROR 0x0D
  72. #define MSD_DATA_OTHER_ERROR 0xFF
  73. #define MSD_DATA_RESPONSE_MASK 0x1F
  74. #define MSD_GET_DATA_RESPONSE(res) (res & MSD_DATA_RESPONSE_MASK)
  75. #define MSD_CMD_LEN 6 /**< command, arg and crc. */
  76. #define MSD_RESPONSE_MAX_LEN 5 /**< response max len */
  77. #define MSD_CSD_LEN 16 /**< SD crad CSD register len */
  78. #define SECTOR_SIZE 512 /**< sector size, default 512byte */
  79. /* card try timeout, unit: ms */
  80. #define CARD_TRY_TIMES 3000
  81. #define CARD_TRY_TIMES_ACMD41 800
  82. #define CARD_WAIT_TOKEN_TIMES 800
  83. #define MSD_USE_PRE_ERASED /**< id define MSD_USE_PRE_ERASED, before CMD25, send ACMD23 */
  84. /**
  85. * SD/MMC card type
  86. */
  87. typedef enum
  88. {
  89. MSD_CARD_TYPE_UNKNOWN = 0, /**< unknown */
  90. MSD_CARD_TYPE_MMC, /**< MultiMedia Card */
  91. MSD_CARD_TYPE_SD_V1_X, /**< Ver 1.X Standard Capacity SD Memory Card */
  92. MSD_CARD_TYPE_SD_V2_X, /**< Ver 2.00 or later Standard Capacity SD Memory Card */
  93. MSD_CARD_TYPE_SD_SDHC, /**< High Capacity SD Memory Card */
  94. MSD_CARD_TYPE_SD_SDXC, /**< later Extended Capacity SD Memory Card */
  95. }msd_card_type;
  96. typedef enum
  97. {
  98. response_type_unknown = 0,
  99. response_r1,
  100. response_r1b,
  101. response_r2,
  102. response_r3,
  103. response_r4,
  104. response_r5,
  105. response_r7,
  106. }response_type;
  107. struct msd_device
  108. {
  109. struct rt_device parent; /**< RT-Thread device struct */
  110. struct rt_device_blk_geometry geometry; /**< sector size, sector count */
  111. struct rt_spi_device * spi_device; /**< SPI interface */
  112. msd_card_type card_type; /**< card type: MMC SD1.x SD2.0 SDHC SDXC */
  113. uint32_t max_clock; /**< MAX SPI clock */
  114. };
  115. extern rt_err_t msd_init(const char * sd_device_name, const char * spi_device_name);
  116. #endif // SPI_MSD_H_INCLUDED