#include <linux/acpi.h>
#include <linux/bitops.h>
#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/mod_devicetable.h>
#include <linux/of.h>
#include <linux/platform_device.h>
#include <linux/pm.h>
#include <linux/pm_runtime.h>
#include <linux/property.h>
#include <linux/slab.h>
#include <linux/spinlock.h>
#define MPC8XXX_GPIO_PINS …
#define GPIO_DIR …
#define GPIO_ODR …
#define GPIO_DAT …
#define GPIO_IER …
#define GPIO_IMR …
#define GPIO_ICR …
#define GPIO_ICR2 …
#define GPIO_IBE …
struct mpc8xxx_gpio_chip { … };
static inline u32 mpc_pin2mask(unsigned int offset)
{ … }
static int mpc8572_gpio_get(struct gpio_chip *gc, unsigned int gpio)
{ … }
static int mpc5121_gpio_dir_out(struct gpio_chip *gc,
unsigned int gpio, int val)
{ … }
static int mpc5125_gpio_dir_out(struct gpio_chip *gc,
unsigned int gpio, int val)
{ … }
static int mpc8xxx_gpio_to_irq(struct gpio_chip *gc, unsigned offset)
{ … }
static irqreturn_t mpc8xxx_gpio_irq_cascade(int irq, void *data)
{ … }
static void mpc8xxx_irq_unmask(struct irq_data *d)
{ … }
static void mpc8xxx_irq_mask(struct irq_data *d)
{ … }
static void mpc8xxx_irq_ack(struct irq_data *d)
{ … }
static int mpc8xxx_irq_set_type(struct irq_data *d, unsigned int flow_type)
{ … }
static int mpc512x_irq_set_type(struct irq_data *d, unsigned int flow_type)
{ … }
static struct irq_chip mpc8xxx_irq_chip = …;
static int mpc8xxx_gpio_irq_map(struct irq_domain *h, unsigned int irq,
irq_hw_number_t hwirq)
{ … }
static const struct irq_domain_ops mpc8xxx_gpio_irq_ops = …;
struct mpc8xxx_gpio_devtype { … };
static const struct mpc8xxx_gpio_devtype mpc512x_gpio_devtype = …;
static const struct mpc8xxx_gpio_devtype mpc5125_gpio_devtype = …;
static const struct mpc8xxx_gpio_devtype mpc8572_gpio_devtype = …;
static const struct mpc8xxx_gpio_devtype mpc8xxx_gpio_devtype_default = …;
static const struct of_device_id mpc8xxx_gpio_ids[] = …;
static int mpc8xxx_probe(struct platform_device *pdev)
{ … }
static void mpc8xxx_remove(struct platform_device *pdev)
{ … }
static int mpc8xxx_suspend(struct device *dev)
{ … }
static int mpc8xxx_resume(struct device *dev)
{ … }
static DEFINE_RUNTIME_DEV_PM_OPS(mpc8xx_pm_ops,
mpc8xxx_suspend, mpc8xxx_resume, NULL);
#ifdef CONFIG_ACPI
static const struct acpi_device_id gpio_acpi_ids[] = …;
MODULE_DEVICE_TABLE(acpi, gpio_acpi_ids);
#endif
static struct platform_driver mpc8xxx_plat_driver = …;
static int __init mpc8xxx_init(void)
{ … }
arch_initcall(mpc8xxx_init);