#include <linux/gpio/driver.h>
#include <linux/init.h>
#include <linux/interrupt.h>
#include <linux/io.h>
#include <linux/irq.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/platform_device.h>
#include <linux/seq_file.h>
#include <linux/spinlock.h>
#define IPROC_CCA_INT_F_GPIOINT …
#define IPROC_CCA_INT_STS …
#define IPROC_CCA_INT_MASK …
#define IPROC_GPIO_CCA_DIN …
#define IPROC_GPIO_CCA_DOUT …
#define IPROC_GPIO_CCA_OUT_EN …
#define IPROC_GPIO_CCA_INT_LEVEL …
#define IPROC_GPIO_CCA_INT_LEVEL_MASK …
#define IPROC_GPIO_CCA_INT_EVENT …
#define IPROC_GPIO_CCA_INT_EVENT_MASK …
#define IPROC_GPIO_CCA_INT_EDGE …
struct iproc_gpio_chip { … };
static inline struct iproc_gpio_chip *
to_iproc_gpio(struct gpio_chip *gc)
{ … }
static void iproc_gpio_irq_ack(struct irq_data *d)
{ … }
static void iproc_gpio_irq_unmask(struct irq_data *d)
{ … }
static void iproc_gpio_irq_mask(struct irq_data *d)
{ … }
static int iproc_gpio_irq_set_type(struct irq_data *d, u32 type)
{ … }
static irqreturn_t iproc_gpio_irq_handler(int irq, void *data)
{ … }
static void iproc_gpio_irq_print_chip(struct irq_data *d, struct seq_file *p)
{ … }
static const struct irq_chip iproc_gpio_irq_chip = …;
static int iproc_gpio_probe(struct platform_device *pdev)
{ … }
static void iproc_gpio_remove(struct platform_device *pdev)
{ … }
static const struct of_device_id bcm_iproc_gpio_of_match[] = …;
MODULE_DEVICE_TABLE(of, bcm_iproc_gpio_of_match);
static struct platform_driver bcm_iproc_gpio_driver = …;
module_platform_driver(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_LICENSE(…) …;