On Thu, 8 Jul 2010 20:37:08 +0100
Matthew Garrett <[email protected]> wrote:

> On Thu, Jul 08, 2010 at 06:09:27PM +0100, Alan Cox wrote:
> > +   else if (offset < 14)/* it is GPOSW */
> > +           rc = intel_scu_ipc_update_register(GPOSWCTL0 +
> > offset - 8,
> > +                           GPOSW_DRV | GPOSW_DOU | GPOSW_RDRV,
> > +                           GPOSW_DRV | (value ? GPOSW_DOU :
> > 0));
> > +   else if (offset > 15 && offset < 24)/* it is GPO */
> 
> What happened to gpios 14 and 15?

Good question. I will double check this is correct but since everyone
is using the driver its probably right

> > +
> > +static int pmic_gpio_get(struct gpio_chip *chip, unsigned offset)
> > +{
> > +   u8 r;
> > +
> > +   /* we only have 8 GPIO pins we can use as input */
> > +   if (offset > 8)
> > +           return -1;
> 
> Is there any chance of this getting passed up to userspace? Using 
> something more descriptive would be nice (ditto for a couple of other 
> places)

No but it can get back to the caller. Right now gpiolib isn't really
internally sure what to do about gpio reads failing. Given that I might
as well hand back -Efoo codes.

> > +   if (intel_scu_ipc_ioread8(GPIO0 + offset, &r))
> > +           return -1;
> 
> ...especially since you get the same error for two different failure 
> modes :)
> 
> > +static int pmic_irq_type(unsigned irq, unsigned type)
> > +{
> > +   struct pmic_gpio *pg = get_irq_chip_data(irq);
> > +   u32 gpio = irq - pg->irq_base;
> > +   unsigned long flags;
> > +
> > +   if (gpio < 0 || gpio > pg->chip.ngpio)
> 
> It's unsigned, don't need to check that it's < 0.

Fixed

> I don't think it's really necessary to indicate that the driver's
> loaded here.

Agreed, fixed

> > +   if (!pdata || !pdata->gpio_base || !pdata->irq_base) {
> > +           dev_dbg(dev, "incorrect or missing platform
> > data\n");
> > +           return -EINVAL;
> > +   }
> 
> Shouldn't there be an is_mrst() check before trying to dereference
> this?

We check pdata == NULL so in the theoretical case someone loaded the
driver on the wrong platform and cooked up a device match you'd still
be ok

Alan
--
To unsubscribe from this list: send the line "unsubscribe platform-driver-x86" 
in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to