Re: [RFC PATCH 1/3] mfd: upboard: Add UP2 platform controller driver

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sat, Apr 21, 2018 at 10:30 AM, Javier Arteaga <javier@xxxxxxxxxx> wrote:

This:

> +#define UPBOARD_ADDRESS_SIZE  7
> +#define UPBOARD_REGISTER_SIZE 16
>
> +#define UPBOARD_READ_FLAG     BIT(UPBOARD_ADDRESS_SIZE)
(...)

> +static int upboard_read(void *context, unsigned int reg, unsigned int *val)
> +{
> +       const struct upboard * const upboard = context;
> +       int i;
> +
> +       gpiod_set_value(upboard->clear_gpio, 0);
> +       gpiod_set_value(upboard->clear_gpio, 1);
> +
> +       reg |= UPBOARD_READ_FLAG;

Bit 7 read/write?

> +       for (i = UPBOARD_ADDRESS_SIZE; i >= 0; i--) {
> +               gpiod_set_value(upboard->strobe_gpio, 0);
> +               gpiod_set_value(upboard->datain_gpio, (reg >> i) & 0x1);
> +               gpiod_set_value(upboard->strobe_gpio, 1);
> +       }

Address 7 bits.

> +       gpiod_set_value(upboard->strobe_gpio, 0);
> +       *val = 0;
> +
> +       for (i = UPBOARD_REGISTER_SIZE - 1; i >= 0; i--) {
> +               gpiod_set_value(upboard->strobe_gpio, 1);
> +               gpiod_set_value(upboard->strobe_gpio, 0);
> +               *val |= gpiod_get_value(upboard->dataout_gpio) << i;
> +       }

16 bits register size.

> +       gpiod_set_value(upboard->strobe_gpio, 1);

Clockitclock.

To me this just looks like bit-banged I2C with 16bit register size.
Compare to the bitbanging algorithm in
drivers/i2c/algos/i2c-algo-bit.c

So it should be able to use drivers/i2c/busses/i2c-gpio.c

Can't you just instantiate this GPIO bit-banged host from whatever
platform description
you have (ACPI? I don't know). The driver may need some modification
so you can tell it that the registers are optionally 16bits wide.

In that case the regmap should also be able to use:
drivers/base/regmap/regmap-i2c.c

Maybe augmented a but to optionally use 16bit wide registers.

But Wolfram needs to have a say in this, I guess the difference to I2C
is that each
address signifies a set of 16 bits, two bytes instead of  8 bits one byte. Maybe
this is to unorthodox for the I2C subsystem to accomodate, and that would
be his pick.

Yours,
Linus Walleij



[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux