[U-Boot] [PATCH v6 06/21] sf: Add SPI_FLASH_MAX_ID_LEN

Jagan Teki jagan at openedev.com
Wed Nov 16 13:42:18 CET 2016


On Wed, Nov 16, 2016 at 11:26 AM, Siva Durga Prasad Paladugu
<siva.durga.paladugu at xilinx.com> wrote:
> Hi,
>
>
>> -----Original Message-----
>> From: Jagan Teki [mailto:jagan at openedev.com]
>> Sent: Wednesday, November 16, 2016 9:33 AM
>> To: u-boot at lists.denx.de
>> Cc: Jagan Teki <jagan at openedev.com>; Bin Meng <bmeng.cn at gmail.com>;
>> York Sun <york.sun at nxp.com>; Vignesh R <vigneshr at ti.com>; Mugunthan V
>> N <mugunthanvnm at ti.com>; Michal Simek <michal.simek at xilinx.com>; Siva
>> Durga Prasad Paladugu <sivadur at xilinx.com>
>> Subject: [PATCH v6 06/21] sf: Add SPI_FLASH_MAX_ID_LEN
>>
>> Add id length of 5 bytes numerical value to macro.
>>
>> Cc: Bin Meng <bmeng.cn at gmail.com>
>> Cc: York Sun <york.sun at nxp.com>
>> Cc: Vignesh R <vigneshr at ti.com>
>> Cc: Mugunthan V N <mugunthanvnm at ti.com>
>> Cc: Michal Simek <michal.simek at xilinx.com>
>> Cc: Siva Durga Prasad Paladugu <sivadur at xilinx.com>
>> Signed-off-by: Jagan Teki <jagan at openedev.com>
>> Reviewed-by: Simon Glass <sjg at chromium.org>
>> Reviewed-by: Jagan Teki <jagan at openedev.com>
>> Tested-by: Jagan Teki <jagan at openedev.com>
>> ---
>>  drivers/mtd/spi/sf_internal.h | 3 ++-
>>  drivers/mtd/spi/spi_flash.c   | 4 ++--
>>  2 files changed, 4 insertions(+), 3 deletions(-)
>>
>> diff --git a/drivers/mtd/spi/sf_internal.h b/drivers/mtd/spi/sf_internal.h
>> index 70617f2..770f628 100644
>> --- a/drivers/mtd/spi/sf_internal.h
>> +++ b/drivers/mtd/spi/sf_internal.h
>> @@ -107,6 +107,7 @@ int sst_write_bp(struct spi_flash *flash, u32 offset,
>> size_t len,
>>  #define JEDEC_MFR(info)              ((info)->id[0])
>>  #define JEDEC_ID(info)               (((info)->id[1]) << 8 | ((info)->id[2]))
>>  #define JEDEC_EXT(info)              (((info)->id[3]) << 8 | ((info)->id[4]))
>> +#define SPI_FLASH_MAX_ID_LEN 5
>>
>>  struct spi_flash_info {
>>       /* Device name ([MANUFLETTER][DEVTYPE][DENSITY][EXTRAINFO]) */
>> @@ -117,7 +118,7 @@ struct spi_flash_info {
>>        * The first three bytes are the JEDIC ID.
>>        * JEDEC ID zero means "no ID" (mostly older chips).
>>        */
>> -     u8              id[5];
>> +     u8              id[SPI_FLASH_MAX_ID_LEN];
>>       u8              id_len;
>>
>>       /*
>> diff --git a/drivers/mtd/spi/spi_flash.c b/drivers/mtd/spi/spi_flash.c index
>> f7634df..9430424 100644
>> --- a/drivers/mtd/spi/spi_flash.c
>> +++ b/drivers/mtd/spi/spi_flash.c
>> @@ -928,10 +928,10 @@ static int micron_quad_enable(struct spi_flash
>> *flash)  static const struct spi_flash_info *spi_flash_read_id(struct spi_flash
>> *flash)  {
>>       int                             tmp;
>> -     u8                              id[5];
>> +     u8                              id[SPI_FLASH_MAX_ID_LEN];
>>       const struct spi_flash_info     *info;
>>
>> -     tmp = spi_flash_cmd(flash->spi, CMD_READ_ID, id, 5);
>> +     tmp = spi_flash_cmd(flash->spi, CMD_READ_ID, id,
>> +SPI_FLASH_MAX_ID_LEN);
>
> Not only here, you are reading Id again in spi_flash_scan(), use same macro
> there as well. Also, you are reading 6 bytes of ID, please consider the same
> there.

This call is from spi_flash_scan itself , spi_flash_read_id

thanks!
-- 
Jagan Teki
Free Software Engineer | www.openedev.com
U-Boot, Linux | Upstream Maintainer
Hyderabad, India.


More information about the U-Boot mailing list