004-mtd-spi-nor-from-3.20.patch 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. --- a/drivers/mtd/spi-nor/spi-nor.c
  2. +++ b/drivers/mtd/spi-nor/spi-nor.c
  3. @@ -538,6 +538,7 @@ static const struct spi_device_id spi_no
  4. /* GigaDevice */
  5. { "gd25q32", INFO(0xc84016, 0, 64 * 1024, 64, SECT_4K) },
  6. { "gd25q64", INFO(0xc84017, 0, 64 * 1024, 128, SECT_4K) },
  7. + { "gd25q128", INFO(0xc84018, 0, 64 * 1024, 256, SECT_4K) },
  8. /* Intel/Numonyx -- xxxs33b */
  9. { "160s33b", INFO(0x898911, 0, 64 * 1024, 32, 0) },
  10. @@ -564,14 +565,14 @@ static const struct spi_device_id spi_no
  11. { "mx66l1g55g", INFO(0xc2261b, 0, 64 * 1024, 2048, SPI_NOR_QUAD_READ) },
  12. /* Micron */
  13. - { "n25q032", INFO(0x20ba16, 0, 64 * 1024, 64, 0) },
  14. - { "n25q064", INFO(0x20ba17, 0, 64 * 1024, 128, 0) },
  15. - { "n25q128a11", INFO(0x20bb18, 0, 64 * 1024, 256, 0) },
  16. - { "n25q128a13", INFO(0x20ba18, 0, 64 * 1024, 256, 0) },
  17. - { "n25q256a", INFO(0x20ba19, 0, 64 * 1024, 512, SECT_4K) },
  18. - { "n25q512a", INFO(0x20bb20, 0, 64 * 1024, 1024, SECT_4K) },
  19. - { "n25q512ax3", INFO(0x20ba20, 0, 64 * 1024, 1024, USE_FSR) },
  20. - { "n25q00", INFO(0x20ba21, 0, 64 * 1024, 2048, USE_FSR) },
  21. + { "n25q032", INFO(0x20ba16, 0, 64 * 1024, 64, SPI_NOR_QUAD_READ) },
  22. + { "n25q064", INFO(0x20ba17, 0, 64 * 1024, 128, SPI_NOR_QUAD_READ) },
  23. + { "n25q128a11", INFO(0x20bb18, 0, 64 * 1024, 256, SPI_NOR_QUAD_READ) },
  24. + { "n25q128a13", INFO(0x20ba18, 0, 64 * 1024, 256, SPI_NOR_QUAD_READ) },
  25. + { "n25q256a", INFO(0x20ba19, 0, 64 * 1024, 512, SECT_4K | SPI_NOR_QUAD_READ) },
  26. + { "n25q512a", INFO(0x20bb20, 0, 64 * 1024, 1024, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ) },
  27. + { "n25q512ax3", INFO(0x20ba20, 0, 64 * 1024, 1024, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ) },
  28. + { "n25q00", INFO(0x20ba21, 0, 64 * 1024, 2048, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ) },
  29. /* PMC */
  30. { "pm25lv512", INFO(0, 0, 32 * 1024, 2, SECT_4K_PMC) },
  31. @@ -895,6 +896,45 @@ static int spansion_quad_enable(struct s
  32. return 0;
  33. }
  34. +static int micron_quad_enable(struct spi_nor *nor)
  35. +{
  36. + int ret;
  37. + u8 val;
  38. +
  39. + ret = nor->read_reg(nor, SPINOR_OP_RD_EVCR, &val, 1);
  40. + if (ret < 0) {
  41. + dev_err(nor->dev, "error %d reading EVCR\n", ret);
  42. + return ret;
  43. + }
  44. +
  45. + write_enable(nor);
  46. +
  47. + /* set EVCR, enable quad I/O */
  48. + nor->cmd_buf[0] = val & ~EVCR_QUAD_EN_MICRON;
  49. + ret = nor->write_reg(nor, SPINOR_OP_WD_EVCR, nor->cmd_buf, 1, 0);
  50. + if (ret < 0) {
  51. + dev_err(nor->dev, "error while writing EVCR register\n");
  52. + return ret;
  53. + }
  54. +
  55. + ret = spi_nor_wait_till_ready(nor);
  56. + if (ret)
  57. + return ret;
  58. +
  59. + /* read EVCR and check it */
  60. + ret = nor->read_reg(nor, SPINOR_OP_RD_EVCR, &val, 1);
  61. + if (ret < 0) {
  62. + dev_err(nor->dev, "error %d reading EVCR\n", ret);
  63. + return ret;
  64. + }
  65. + if (val & EVCR_QUAD_EN_MICRON) {
  66. + dev_err(nor->dev, "Micron EVCR Quad bit not clear\n");
  67. + return -EINVAL;
  68. + }
  69. +
  70. + return 0;
  71. +}
  72. +
  73. static int set_quad_mode(struct spi_nor *nor, struct flash_info *info)
  74. {
  75. int status;
  76. @@ -907,6 +947,13 @@ static int set_quad_mode(struct spi_nor
  77. return -EINVAL;
  78. }
  79. return status;
  80. + case CFI_MFR_ST:
  81. + status = micron_quad_enable(nor);
  82. + if (status) {
  83. + dev_err(nor->dev, "Micron quad-read not enabled\n");
  84. + return -EINVAL;
  85. + }
  86. + return status;
  87. default:
  88. status = spansion_quad_enable(nor);
  89. if (status) {
  90. --- a/include/linux/mtd/spi-nor.h
  91. +++ b/include/linux/mtd/spi-nor.h
  92. @@ -56,6 +56,10 @@
  93. /* Used for Spansion flashes only. */
  94. #define SPINOR_OP_BRWR 0x17 /* Bank register write */
  95. +/* Used for Micron flashes only. */
  96. +#define SPINOR_OP_RD_EVCR 0x65 /* Read EVCR register */
  97. +#define SPINOR_OP_WD_EVCR 0x61 /* Write EVCR register */
  98. +
  99. /* Status Register bits. */
  100. #define SR_WIP 1 /* Write in progress */
  101. #define SR_WEL 2 /* Write enable latch */
  102. @@ -67,6 +71,9 @@
  103. #define SR_QUAD_EN_MX 0x40 /* Macronix Quad I/O */
  104. +/* Enhanced Volatile Configuration Register bits */
  105. +#define EVCR_QUAD_EN_MICRON 0x80 /* Micron Quad I/O */
  106. +
  107. /* Flag Status Register bits */
  108. #define FSR_READY 0x80