sd.h 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /*
  2. * include/linux/mmc/sd.h
  3. *
  4. * Copyright (C) 2005-2007 Pierre Ossman, All Rights Reserved.
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or (at
  9. * your option) any later version.
  10. */
  11. #ifndef MMC_SD_H
  12. #define MMC_SD_H
  13. /* SD commands type argument response */
  14. /* class 0 */
  15. /* This is basically the same command as for MMC with some quirks. */
  16. #define SD_SEND_RELATIVE_ADDR 3 /* bcr R6 */
  17. #define SD_SEND_IF_COND 8 /* bcr [11:0] See below R7 */
  18. /* class 10 */
  19. #define SD_SWITCH 6 /* adtc [31:0] See below R1 */
  20. /* class 5 */
  21. #define SD_ERASE_WR_BLK_START 32 /* ac [31:0] data addr R1 */
  22. #define SD_ERASE_WR_BLK_END 33 /* ac [31:0] data addr R1 */
  23. /* Application commands */
  24. #define SD_APP_SET_BUS_WIDTH 6 /* ac [1:0] bus width R1 */
  25. #define SD_APP_SD_STATUS 13 /* adtc R1 */
  26. #define SD_APP_SEND_NUM_WR_BLKS 22 /* adtc R1 */
  27. #define SD_APP_OP_COND 41 /* bcr [31:0] OCR R3 */
  28. #define SD_APP_SEND_SCR 51 /* adtc R1 */
  29. /*
  30. * SD_SWITCH argument format:
  31. *
  32. * [31] Check (0) or switch (1)
  33. * [30:24] Reserved (0)
  34. * [23:20] Function group 6
  35. * [19:16] Function group 5
  36. * [15:12] Function group 4
  37. * [11:8] Function group 3
  38. * [7:4] Function group 2
  39. * [3:0] Function group 1
  40. */
  41. /*
  42. * SD_SEND_IF_COND argument format:
  43. *
  44. * [31:12] Reserved (0)
  45. * [11:8] Host Voltage Supply Flags
  46. * [7:0] Check Pattern (0xAA)
  47. */
  48. /*
  49. * SCR field definitions
  50. */
  51. #define SCR_SPEC_VER_0 0 /* Implements system specification 1.0 - 1.01 */
  52. #define SCR_SPEC_VER_1 1 /* Implements system specification 1.10 */
  53. #define SCR_SPEC_VER_2 2 /* Implements system specification 2.00 */
  54. /*
  55. * SD bus widths
  56. */
  57. #define SD_BUS_WIDTH_1 0
  58. #define SD_BUS_WIDTH_4 2
  59. /*
  60. * SD_SWITCH mode
  61. */
  62. #define SD_SWITCH_CHECK 0
  63. #define SD_SWITCH_SET 1
  64. /*
  65. * SD_SWITCH function groups
  66. */
  67. #define SD_SWITCH_GRP_ACCESS 0
  68. /*
  69. * SD_SWITCH access modes
  70. */
  71. #define SD_SWITCH_ACCESS_DEF 0
  72. #define SD_SWITCH_ACCESS_HS 1
  73. #endif