[PATCH 2/4] [v2] gpiolib: add bitmask for valid GPIO lines
Andy Shevchenko
andriy.shevchenko at linux.intel.com
Tue Dec 12 01:58:45 PST 2017
On Fri, 2017-12-01 at 17:28 -0600, Timur Tabi wrote:
> Add support for specifying that some GPIOs within a range are
> unavailable.
> Some systems have a sparse list of GPIOs, where a range of GPIOs is
> specified (usually 0 to n-1), but some subset within that range is
> absent or unavailable for whatever reason.
>
> To support this, allow drivers to specify a bitmask of GPIOs that
> are present or absent. Gpiolib will then block access to those that
> are absent.
> - status = gpiochip_irqchip_init_valid_mask(chip);
> + status = gpiochip_init_valid_mask(chip);
> if (status)
> goto err_remove_from_list;
>
> + status = gpiochip_irqchip_init_valid_mask(chip);
> + if (status)
> + goto err_remove_valid_mask;
Yes, this way it looks good!
> +static bool gpiochip_available(const struct gpio_chip *gpiochip,
> + unsigned int offset)
> +{
> + pr_info("%s:%u offset=%u\n", __func__, __LINE__, offset);
Debug leftover?
> +
> + /* No mask means all valid */
> + if (likely(!gpiochip->valid_mask))
> + return true;
> +
> + return test_bit(offset, gpiochip->valid_mask);
Not sure which one is better
return test_bit();
or
return !!test_bit();
--
Andy Shevchenko <andriy.shevchenko at linux.intel.com>
Intel Finland Oy
More information about the linux-arm-kernel
mailing list