On Mon, Oct 27, 2014 at 06:31:12PM +0200, Octavian Purdila wrote:
> From: Daniel Baluta <daniel.bal...@intel.com>
> 
> This patch adds GPIO and IRQ support for the Diolan DLN-2 GPIO module.

[...]

> +static void dln2_gpio_pin_set_out_val(struct dln2_gpio *dln2,
> +                                   unsigned int pin, int value)
> +{
> +     struct dln2_gpio_pin_val req = {
> +             .pin = cpu_to_le16(pin),
> +             .value = cpu_to_le16(value),

Drop cpu_to_le16 (value is u8).

> +     };
> +
> +     dln2_transfer_tx(dln2->pdev, DLN2_GPIO_PIN_SET_OUT_VAL, &req,
> +                      sizeof(req));
> +}
> +
> +#define DLN2_GPIO_DIRECTION_IN               0
> +#define DLN2_GPIO_DIRECTION_OUT              1
> +
> +static int dln2_gpio_request(struct gpio_chip *chip, unsigned offset)
> +{
> +     struct dln2_gpio *dln2 = container_of(chip, struct dln2_gpio, gpio);
> +     struct dln2_gpio_pin req = {
> +             .pin = cpu_to_le16(offset),
> +     };
> +     struct dln2_gpio_pin_val rsp;
> +     int len = sizeof(rsp);
> +     int ret;
> +
> +     ret = dln2_gpio_pin_cmd(dln2, DLN2_GPIO_PIN_ENABLE, offset);
> +     if (ret < 0)
> +             return ret;
> +
> +     /* cache the pin direction */
> +     ret = dln2_transfer(dln2->pdev, DLN2_GPIO_PIN_GET_DIRECTION,
> +                         &req, sizeof(req), &rsp, &len);
> +     if (ret < 0)
> +             return ret;
> +     if (len < sizeof(rsp) || req.pin != rsp.pin) {
> +             ret = -EPROTO;
> +             goto out_disable;
> +     }
> +
> +     switch (rsp.value) {
> +     case DLN2_GPIO_DIRECTION_IN:
> +             clear_bit(offset, dln2->output_enabled);
> +             return 0;
> +     case DLN2_GPIO_DIRECTION_OUT:
> +             set_bit(offset, dln2->output_enabled);
> +             return 0;
> +     default:
> +             ret = -EPROTO;
> +             goto out_disable;
> +     }
> +
> +out_disable:
> +     dln2_gpio_pin_cmd(dln2, DLN2_GPIO_PIN_DISABLE, offset);
> +     return ret;
> +}
> +
> +static void dln2_gpio_free(struct gpio_chip *chip, unsigned offset)
> +{
> +     struct dln2_gpio *dln2 = container_of(chip, struct dln2_gpio, gpio);
> +
> +     dln2_gpio_pin_cmd(dln2, DLN2_GPIO_PIN_DISABLE, offset);
> +}
> +
> +static int dln2_gpio_get_direction(struct gpio_chip *chip, unsigned offset)
> +{
> +     struct dln2_gpio *dln2 = container_of(chip, struct dln2_gpio, gpio);
> +
> +     if (test_bit(offset, dln2->output_enabled))
> +             return GPIOF_DIR_OUT;
> +
> +     return GPIOF_DIR_IN;
> +}
> +
> +static int dln2_gpio_get(struct gpio_chip *chip, unsigned int offset)
> +{
> +     struct dln2_gpio *dln2 = container_of(chip, struct dln2_gpio, gpio);
> +     int dir;
> +
> +     dir = dln2_gpio_get_direction(chip, offset);
> +     if (dir < 0)
> +             return dir;
> +
> +     if (dir == GPIOF_DIR_IN)
> +             return dln2_gpio_pin_get_in_val(dln2, offset);
> +
> +     return dln2_gpio_pin_get_out_val(dln2, offset);
> +}
> +
> +static void dln2_gpio_set(struct gpio_chip *chip, unsigned offset, int value)
> +{
> +     struct dln2_gpio *dln2 = container_of(chip, struct dln2_gpio, gpio);
> +
> +     dln2_gpio_pin_set_out_val(dln2, offset, value);
> +}
> +
> +static int dln2_gpio_set_direction(struct gpio_chip *chip, unsigned offset,
> +                                unsigned dir)
> +{
> +     struct dln2_gpio *dln2 = container_of(chip, struct dln2_gpio, gpio);
> +     struct dln2_gpio_pin_val req = {
> +             .pin = cpu_to_le16(offset),
> +             .value = cpu_to_le16(dir),

Same here.

Johan
--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to