Re: [PATCH 01/11] MFD: DA9052/53 MFD core module v4

From: Mark Brown
Date: Thu Aug 18 2011 - 12:18:33 EST


On Thu, Aug 18, 2011 at 07:23:22PM +0530, ashishj3 wrote:

> +int da9052_reg_read(struct da9052 *da9052, unsigned char reg)
> +{
> + int val, ret;
> +
> + if (reg > DA9052_MAX_REG_CNT) {
> + dev_err(da9052->dev, "invalid reg %x\n", reg);
> + return -EINVAL;
> + }
> +
> + if (da9052->bustype == BUS_SPI)
> + reg = (reg << 1) | 1;

The same comment I made last time applies now: this isn't something that
should be being handled at the driver level.

For all your I/O functions there's not really any work going on in the
function except the translation from struct da9052 to the regmap it
points to. May as well just turn the functions into inlines.

> + if (events == 0)
> + goto err;
> +
> + for (i = 0; i < 32; i++) {
> + if (events & (1 << i))
> + handle_nested_irq(da9052->irq_base + i);
> + }
> +
> + da9052_group_write(da9052, DA9052_EVENT_A_REG, 4, v);
> +
> + if (da9052->chip_id == DA9052 || da9052->chip_id == DA9053_AA)
> + DA9052_FIXME();
> +
> +err:
> + return IRQ_HANDLED;

If you hit an error you didn't handle an IRQ and so ought to be
returning IRQ_NONE.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/