gpio: split gpiod board registration into machine header
As per example from the regulator subsystem: put all defines and functions related to registering board info for GPIO descriptors into a separate <linux/gpio/machine.h> header. Cc: Andrew Victor <linux@maxim.org.za> Cc: Nicolas Ferre <nicolas.ferre@atmel.com> Cc: Jean-Christophe Plagniol-Villard <plagnioj@jcrosoft.com> Cc: Ralf Baechle <ralf@linux-mips.org> Cc: Thierry Reding <thierry.reding@gmail.com> Acked-by: Stephen Warren <swarren@wwwdotorg.org> Reviewed-by: Alexandre Courbot <gnurou@gmail.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
This commit is contained in:
parent
c7caf86823
commit
0a6d315827
7 changed files with 63 additions and 57 deletions
|
@ -60,7 +60,7 @@ Platform Data
|
||||||
Finally, GPIOs can be bound to devices and functions using platform data. Board
|
Finally, GPIOs can be bound to devices and functions using platform data. Board
|
||||||
files that desire to do so need to include the following header:
|
files that desire to do so need to include the following header:
|
||||||
|
|
||||||
#include <linux/gpio/driver.h>
|
#include <linux/gpio/machine.h>
|
||||||
|
|
||||||
GPIOs are mapped by the means of tables of lookups, containing instances of the
|
GPIOs are mapped by the means of tables of lookups, containing instances of the
|
||||||
gpiod_lookup structure. Two macros are defined to help declaring such mappings:
|
gpiod_lookup structure. Two macros are defined to help declaring such mappings:
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
|
|
||||||
#include <linux/dma-mapping.h>
|
#include <linux/dma-mapping.h>
|
||||||
#include <linux/gpio.h>
|
#include <linux/gpio.h>
|
||||||
#include <linux/gpio/driver.h>
|
#include <linux/gpio/machine.h>
|
||||||
#include <linux/platform_device.h>
|
#include <linux/platform_device.h>
|
||||||
#include <linux/i2c-gpio.h>
|
#include <linux/i2c-gpio.h>
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/platform_device.h>
|
#include <linux/platform_device.h>
|
||||||
#include <linux/gpio/driver.h>
|
#include <linux/gpio/machine.h>
|
||||||
#include <linux/rfkill-gpio.h>
|
#include <linux/rfkill-gpio.h>
|
||||||
#include "board.h"
|
#include "board.h"
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/gpio.h>
|
#include <linux/gpio.h>
|
||||||
|
#include <linux/gpio/machine.h>
|
||||||
|
|
||||||
#include <linux/input.h>
|
#include <linux/input.h>
|
||||||
#include <linux/gpio_keys.h>
|
#include <linux/gpio_keys.h>
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <linux/acpi.h>
|
#include <linux/acpi.h>
|
||||||
#include <linux/gpio/driver.h>
|
#include <linux/gpio/driver.h>
|
||||||
|
#include <linux/gpio/machine.h>
|
||||||
|
|
||||||
#include "gpiolib.h"
|
#include "gpiolib.h"
|
||||||
|
|
||||||
|
|
|
@ -151,60 +151,6 @@ void gpio_unlock_as_irq(struct gpio_chip *chip, unsigned int offset);
|
||||||
|
|
||||||
struct gpio_chip *gpiod_to_chip(const struct gpio_desc *desc);
|
struct gpio_chip *gpiod_to_chip(const struct gpio_desc *desc);
|
||||||
|
|
||||||
enum gpio_lookup_flags {
|
|
||||||
GPIO_ACTIVE_HIGH = (0 << 0),
|
|
||||||
GPIO_ACTIVE_LOW = (1 << 0),
|
|
||||||
GPIO_OPEN_DRAIN = (1 << 1),
|
|
||||||
GPIO_OPEN_SOURCE = (1 << 2),
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* struct gpiod_lookup - lookup table
|
|
||||||
* @chip_label: name of the chip the GPIO belongs to
|
|
||||||
* @chip_hwnum: hardware number (i.e. relative to the chip) of the GPIO
|
|
||||||
* @con_id: name of the GPIO from the device's point of view
|
|
||||||
* @idx: index of the GPIO in case several GPIOs share the same name
|
|
||||||
* @flags: mask of GPIO_* values
|
|
||||||
*
|
|
||||||
* gpiod_lookup is a lookup table for associating GPIOs to specific devices and
|
|
||||||
* functions using platform data.
|
|
||||||
*/
|
|
||||||
struct gpiod_lookup {
|
|
||||||
const char *chip_label;
|
|
||||||
u16 chip_hwnum;
|
|
||||||
const char *con_id;
|
|
||||||
unsigned int idx;
|
|
||||||
enum gpio_lookup_flags flags;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct gpiod_lookup_table {
|
|
||||||
struct list_head list;
|
|
||||||
const char *dev_id;
|
|
||||||
struct gpiod_lookup table[];
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Simple definition of a single GPIO under a con_id
|
|
||||||
*/
|
|
||||||
#define GPIO_LOOKUP(_chip_label, _chip_hwnum, _con_id, _flags) \
|
|
||||||
GPIO_LOOKUP_IDX(_chip_label, _chip_hwnum, _con_id, 0, _flags)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Use this macro if you need to have several GPIOs under the same con_id.
|
|
||||||
* Each GPIO needs to use a different index and can be accessed using
|
|
||||||
* gpiod_get_index()
|
|
||||||
*/
|
|
||||||
#define GPIO_LOOKUP_IDX(_chip_label, _chip_hwnum, _con_id, _idx, _flags) \
|
|
||||||
{ \
|
|
||||||
.chip_label = _chip_label, \
|
|
||||||
.chip_hwnum = _chip_hwnum, \
|
|
||||||
.con_id = _con_id, \
|
|
||||||
.idx = _idx, \
|
|
||||||
.flags = _flags, \
|
|
||||||
}
|
|
||||||
|
|
||||||
void gpiod_add_lookup_table(struct gpiod_lookup_table *table);
|
|
||||||
|
|
||||||
#ifdef CONFIG_GPIOLIB_IRQCHIP
|
#ifdef CONFIG_GPIOLIB_IRQCHIP
|
||||||
|
|
||||||
void gpiochip_set_chained_irqchip(struct gpio_chip *gpiochip,
|
void gpiochip_set_chained_irqchip(struct gpio_chip *gpiochip,
|
||||||
|
|
58
include/linux/gpio/machine.h
Normal file
58
include/linux/gpio/machine.h
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
#ifndef __LINUX_GPIO_MACHINE_H
|
||||||
|
#define __LINUX_GPIO_MACHINE_H
|
||||||
|
|
||||||
|
enum gpio_lookup_flags {
|
||||||
|
GPIO_ACTIVE_HIGH = (0 << 0),
|
||||||
|
GPIO_ACTIVE_LOW = (1 << 0),
|
||||||
|
GPIO_OPEN_DRAIN = (1 << 1),
|
||||||
|
GPIO_OPEN_SOURCE = (1 << 2),
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* struct gpiod_lookup - lookup table
|
||||||
|
* @chip_label: name of the chip the GPIO belongs to
|
||||||
|
* @chip_hwnum: hardware number (i.e. relative to the chip) of the GPIO
|
||||||
|
* @con_id: name of the GPIO from the device's point of view
|
||||||
|
* @idx: index of the GPIO in case several GPIOs share the same name
|
||||||
|
* @flags: mask of GPIO_* values
|
||||||
|
*
|
||||||
|
* gpiod_lookup is a lookup table for associating GPIOs to specific devices and
|
||||||
|
* functions using platform data.
|
||||||
|
*/
|
||||||
|
struct gpiod_lookup {
|
||||||
|
const char *chip_label;
|
||||||
|
u16 chip_hwnum;
|
||||||
|
const char *con_id;
|
||||||
|
unsigned int idx;
|
||||||
|
enum gpio_lookup_flags flags;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct gpiod_lookup_table {
|
||||||
|
struct list_head list;
|
||||||
|
const char *dev_id;
|
||||||
|
struct gpiod_lookup table[];
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Simple definition of a single GPIO under a con_id
|
||||||
|
*/
|
||||||
|
#define GPIO_LOOKUP(_chip_label, _chip_hwnum, _con_id, _flags) \
|
||||||
|
GPIO_LOOKUP_IDX(_chip_label, _chip_hwnum, _con_id, 0, _flags)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Use this macro if you need to have several GPIOs under the same con_id.
|
||||||
|
* Each GPIO needs to use a different index and can be accessed using
|
||||||
|
* gpiod_get_index()
|
||||||
|
*/
|
||||||
|
#define GPIO_LOOKUP_IDX(_chip_label, _chip_hwnum, _con_id, _idx, _flags) \
|
||||||
|
{ \
|
||||||
|
.chip_label = _chip_label, \
|
||||||
|
.chip_hwnum = _chip_hwnum, \
|
||||||
|
.con_id = _con_id, \
|
||||||
|
.idx = _idx, \
|
||||||
|
.flags = _flags, \
|
||||||
|
}
|
||||||
|
|
||||||
|
void gpiod_add_lookup_table(struct gpiod_lookup_table *table);
|
||||||
|
|
||||||
|
#endif /* __LINUX_GPIO_MACHINE_H */
|
Loading…
Add table
Reference in a new issue