eon.c 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. * (C) Copyright 2010, ucRobotics Inc.
  3. * Author: Chong Huang <chuang@ucrobotics.com>
  4. * Licensed under the GPL-2 or later.
  5. */
  6. #include <common.h>
  7. #include <malloc.h>
  8. #include <spi_flash.h>
  9. #include "spi_flash_internal.h"
  10. /* EN25Q128-specific commands */
  11. #define CMD_EN25Q128_SE 0x20 /* Sector Erase */
  12. #define CMD_EN25Q128_BE 0xd8 /* Block Erase */
  13. struct eon_spi_flash_params {
  14. u8 idcode1;
  15. u16 page_size;
  16. u16 pages_per_sector;
  17. u16 sectors_per_block;
  18. u16 nr_sectors;
  19. const char *name;
  20. };
  21. static const struct eon_spi_flash_params eon_spi_flash_table[] = {
  22. {
  23. .idcode1 = 0x16,
  24. .page_size = 256,
  25. .pages_per_sector = 16,
  26. .sectors_per_block = 16,
  27. .nr_sectors = 1024,
  28. .name = "EN25Q32B",
  29. },
  30. {
  31. .idcode1 = 0x18,
  32. .page_size = 256,
  33. .pages_per_sector = 16,
  34. .sectors_per_block = 16,
  35. .nr_sectors = 4096,
  36. .name = "EN25Q128",
  37. },
  38. {
  39. .idcode1 = 0x16,
  40. .page_size = 256,
  41. .pages_per_sector = 16,
  42. .sectors_per_block = 16,
  43. .nr_sectors = 1024,
  44. .name = "EN25Q32B",
  45. },
  46. };
  47. static int eon_erase(struct spi_flash *flash, u32 offset, size_t len)
  48. {
  49. return spi_flash_cmd_erase(flash, CMD_EN25Q128_BE, offset, len);
  50. }
  51. struct spi_flash *spi_flash_probe_eon(struct spi_slave *spi, u8 *idcode)
  52. {
  53. const struct eon_spi_flash_params *params;
  54. struct spi_flash *flash;
  55. unsigned int i;
  56. for (i = 0; i < ARRAY_SIZE(eon_spi_flash_table); ++i) {
  57. params = &eon_spi_flash_table[i];
  58. if (params->idcode1 == idcode[2])
  59. break;
  60. }
  61. if (i == ARRAY_SIZE(eon_spi_flash_table)) {
  62. debug("SF: Unsupported EON ID %02x\n", idcode[1]);
  63. return NULL;
  64. }
  65. flash = malloc(sizeof(*flash));
  66. if (!flash) {
  67. debug("SF: Failed to allocate memory\n");
  68. return NULL;
  69. }
  70. flash->spi = spi;
  71. flash->name = params->name;
  72. flash->write = spi_flash_cmd_write_multi;
  73. flash->erase = eon_erase;
  74. flash->read = spi_flash_cmd_read_fast;
  75. flash->page_size = params->page_size;
  76. flash->sector_size = params->page_size * params->pages_per_sector
  77. * params->sectors_per_block;
  78. flash->size = params->page_size * params->pages_per_sector
  79. * params->nr_sectors;
  80. return flash;
  81. }