On Mon, 3 Aug 2009 19:54:50 -0700
David Brownell <davi...@pacbell.net> wrote:

> On Thursday 30 July 2009, Anton Vorontsov wrote:
> > This patch converts the m25p80 driver so that now it uses .id_table
> > for device matching, making it properly detect devices on OpenFirmware
> > platforms (prior to this patch the driver misdetected non-JEDEC chips,
> > seeing all chips as "m25p80").
> 
> I suspect "detect" is a misnomer there.  It only "detects" JEDEC chips.
> All others got explicit declarations ... so if there's misbehavior for
> other chips, it's because those declarations were poorly handled.  Maybe
> they were not properly flagged as non-JDEC
> 
>  
> > Also, now jedec_probe() only does jedec probing, nothing else. If it
> > is not able to detect a chip, NULL is returned and the driver fall
> > backs to the information specified by the platform (platform_data, or
> > exact ID).
> 
> I'd rather keep the warning, so there's a clue about what's really
> going on:  JEDEC chip found, but its ID is not handled.
> 

afaik there was no response to David's review comments, so this patch
is in the "stuck" state.


> > Signed-off-by: Anton Vorontsov <avoront...@ru.mvista.com>
> > ---
> >  drivers/mtd/devices/m25p80.c |  146 
> > +++++++++++++++++++++++-------------------
> >  1 files changed, 80 insertions(+), 66 deletions(-)
> > 
> > diff --git a/drivers/mtd/devices/m25p80.c b/drivers/mtd/devices/m25p80.c
> > index 10ed195..0d74b38 100644
> > --- a/drivers/mtd/devices/m25p80.c
> > +++ b/drivers/mtd/devices/m25p80.c
> >                     ... deletia ...
> 
> > @@ -481,74 +480,83 @@ struct flash_info {
> >  #define    SECT_4K         0x01            /* OPCODE_BE_4K works uniformly 
> > */
> >  };
> >  
> > +#define INFO(_jedec_id, _ext_id, _sector_size, _n_sectors, _flags) \
> > +   ((kernel_ulong_t)&(struct flash_info) {                         \
> > +           .jedec_id = (_jedec_id),                                \
> > +           .ext_id = (_ext_id),                                    \
> > +           .sector_size = (_sector_size),                          \
> > +           .n_sectors = (_n_sectors),                              \
> > +           .flags = (_flags),                                      \
> > +   })
> 
> Anonymous inlined structures ... kind of ugly, but I can
> understand why you might not want to declare and name a
> few dozen single-use structures.
> 
> 
> >  
> >  /* NOTE: double check command sets and memory organization when you add
> >   * more flash chips.  This current list focusses on newer chips, which
> >   * have been converging on command sets which including JEDEC ID.
> >   */
> > -static struct flash_info __devinitdata m25p_data [] = {
> > -
> > +static const struct spi_device_id m25p_ids[] = {
> >     /* Atmel -- some are (confusingly) marketed as "DataFlash" */
> > -   { "at25fs010",  0x1f6601, 0, 32 * 1024, 4, SECT_4K, },
> > -   { "at25fs040",  0x1f6604, 0, 64 * 1024, 8, SECT_4K, },
> > +   { "at25fs010",  INFO(0x1f6601, 0, 32 * 1024, 4, SECT_4K) },
> > +   { "at25fs040",  INFO(0x1f6604, 0, 64 * 1024, 8, SECT_4K) },
> >  
> >             ... deletia ...
> >  
> 
> > @@ -596,6 +602,7 @@ static struct flash_info *__devinit jedec_probe(struct 
> > spi_device *spi)
> >   */
> >  static int __devinit m25p_probe(struct spi_device *spi)
> >  {
> > +   const struct spi_device_id      *id;
> >     struct flash_platform_data      *data;
> >     struct m25p                     *flash;
> >     struct flash_info               *info;
> > @@ -608,32 +615,38 @@ static int __devinit m25p_probe(struct spi_device 
> > *spi)
> >      */
> >     data = spi->dev.platform_data;
> >     if (data && data->type) {
> 
> At this point I wonder why you're not changing the probe sequence
> more.  Get "id" and then "id" here.  If it's for "m25p80" assume
> it's an old-style board init and do the current logic.  Else just
> verify "info".
> 
> There's a new error case of course:  new-style but data->type
> doesn't match id->name.
> 
> 
> > -           for (i = 0, info = m25p_data;
> > -                           i < ARRAY_SIZE(m25p_data);
> > -                           i++, info++) {
> > -                   if (strcmp(data->type, info->name) == 0)
> > -                           break;
> > +           for (i = 0; i < ARRAY_SIZE(m25p_ids) - 1; i++) {
> > +                   id = &m25p_ids[i];
> > +                   info = (void *)m25p_ids[i].driver_data;
> > +                   if (strcmp(data->type, id->name))
> > +                           continue;
> > +                   break;
> >             }
> >  
> >             /* unrecognized chip? */
> > -           if (i == ARRAY_SIZE(m25p_data)) {
> > +           if (i == ARRAY_SIZE(m25p_ids) - 1) {
> 
> Better:  "if (info == NULL) ..."   You've got all the pointers
> in hand; don't use indices.
> 
> >                     DEBUG(MTD_DEBUG_LEVEL0, "%s: unrecognized id %s\n",
> >                                     dev_name(&spi->dev), data->type);
> >                     info = NULL;
> >  
> >             /* recognized; is that chip really what's there? */
> >             } else if (info->jedec_id) {
> > -                   struct flash_info       *chip = jedec_probe(spi);
> > +                   id = jedec_probe(spi);
> >  
> > -                   if (!chip || chip != info) {
> > +                   if (id != &m25p_ids[i]) {
> 
> Again, don't use indices except during the lookup.
> 
> >                             dev_warn(&spi->dev, "found %s, expected %s\n",
> > -                                           chip ? chip->name : "UNKNOWN",
> > -                                           info->name);
> > +                                           id ? id->name : "UNKNOWN",
> > +                                           m25p_ids[i].name);
> >                             info = NULL;
> >                     }
> >             }
> > -   } else
> > -           info = jedec_probe(spi);
> > +   } else {
> > +           id = jedec_probe(spi);
> > +           if (!id)
> > +                   id = spi_get_device_id(spi);
> > +
> > +           info = (void *)id->driver_data;
> > +   }
> >  
> >     if (!info)
> >             return -ENODEV;
> 
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to