15 #define SFDP_ACCESS_PROT 0xFF
16 #define SFDP_BASIC_FLASH 0xFF00
17 #define SFDP_4BYTE_ADDR 0xFF84
65 uint32_t *ptable =
NULL;
66 unsigned int j, k, nph;
67 int retval, erase_type = 0;
72 memset(&header, 0,
sizeof(header));
82 LOG_ERROR(
"access protocol 0x%02x not implemented",
88 nph = ((header.
revision >> 16) & 0xFF) + 1;
90 pheaders = malloc(
sizeof(
struct sfdp_phdr) * nph);
95 memset(pheaders, 0,
sizeof(
struct sfdp_phdr) * nph);
97 (
sizeof(
struct sfdp_phdr) >> 2) * nph, (uint32_t *)pheaders);
101 for (k = 0; k < nph; k++) {
102 unsigned int words = (pheaders[k].
revision >> 24) & 0xFF;
103 uint16_t
id = (((pheaders[k].
ptr) >> 16) & 0xFF00) | (pheaders[k].
revision & 0xFF);
104 uint32_t
ptr = pheaders[k].
ptr & 0xFFFFFF;
106 LOG_DEBUG(
"pheader %d len=0x%02x id=0x%04" PRIx16
107 " ptr=0x%06" PRIx32, k, words,
id,
ptr);
110 ptable = malloc(words << 2);
120 for (j = 0; j < words; j++)
121 LOG_DEBUG(
"word %02d 0x%08X", j + 1, ptable[j]);
128 LOG_ERROR(
"id=0x%04" PRIx16
" invalid length %d",
id, words);
133 LOG_DEBUG(
"basic flash parameter table");
143 if (table->
density & (1UL << 31))
157 erase = (table->
erase_t12 >> 0) & 0xFFFF;
159 if (((table->
erase_t12 >> 16) & 0xFF) > (erase & 0xFF)) {
160 erase = (table->
erase_t12 >> 16) & 0xFFFF;
163 if (((table->
erase_t34 >> 0) & 0xFF) > (erase & 0xFF)) {
164 erase = (table->
erase_t34 >> 0) & 0xFFFF;
167 if (((table->
erase_t34 >> 16) & 0xFF) > (erase & 0xFF)) {
168 erase = (table->
erase_t34 >> 16) & 0xFFFF;
189 if (((table->
fast_addr >> 17) & 0x3) == 0x0)
190 LOG_ERROR(
"device needs paging - not implemented");
203 }
else if (((table->
fast_addr >> 17) & 0x3) == 0x1)
204 LOG_INFO(
"device has to be switched to 4-byte addresses");
211 LOG_INFO(
"4-byte address parameter table");
214 if (table->
flags & (1UL << 0))
216 if (table->
flags & (1UL << 5))
218 if (table->
flags & (1UL << 6))
222 if ((erase_type == 1) && (table->
flags & (1UL << 9)))
224 else if ((erase_type == 2) && (table->
flags & (1UL << 10)))
226 else if ((erase_type == 3) && (table->
flags & (1UL << 11)))
228 else if ((erase_type == 4) && (table->
flags & (1UL << 12)))
231 LOG_ERROR(
"parameter table id=0x%04" PRIx16
" invalid length %d",
id, words);
233 LOG_DEBUG(
"unimplemented parameter table id=0x%04" PRIx16,
id);
239 if (erase_type != 0) {
#define ERROR_FLASH_BANK_NOT_PROBED
#define LOG_ERROR(expr ...)
#define LOG_INFO(expr ...)
#define LOG_DEBUG(expr ...)
int spi_sfdp(struct flash_bank *bank, struct flash_device *dev, read_sfdp_block_t read_sfdp_block)
static const char * sfdp_name
int(* read_sfdp_block_t)(struct flash_bank *bank, uint32_t addr, unsigned int words, uint32_t *buffer)
#define SPIFLASH_PAGE_PROGRAM
#define SPIFLASH_MASS_ERASE
static int read_sfdp_block(struct flash_bank *bank, uint32_t addr, unsigned int words, uint32_t *buffer)
Provides details of a flash bank, available either on-chip or through a major interface.