| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * Intel Tangier GPIO functions
- *
- * Copyright (c) 2016, 2021, 2023 Intel Corporation.
- *
- * Authors: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
- * Pandith N <pandith.n@intel.com>
- * Raag Jadav <raag.jadav@intel.com>
- */
- #ifndef _GPIO_TANGIER_H_
- #define _GPIO_TANGIER_H_
- #include <linux/gpio/driver.h>
- #include <linux/pm.h>
- #include <linux/spinlock_types.h>
- #include <linux/types.h>
- struct device;
- struct tng_gpio_context;
- /* Elkhart Lake specific wake registers */
- #define GWMR_EHL 0x100 /* Wake mask */
- #define GWSR_EHL 0x118 /* Wake source */
- #define GSIR_EHL 0x130 /* Secure input */
- /* Merrifield specific wake registers */
- #define GWMR_MRFLD 0x400 /* Wake mask */
- #define GWSR_MRFLD 0x418 /* Wake source */
- #define GSIR_MRFLD 0xc00 /* Secure input */
- /**
- * struct tng_wake_regs - Platform specific wake registers
- * @gwmr: Wake mask
- * @gwsr: Wake source
- * @gsir: Secure input
- */
- struct tng_wake_regs {
- u32 gwmr;
- u32 gwsr;
- u32 gsir;
- };
- /**
- * struct tng_gpio_pinrange - Map pin numbers to gpio numbers
- * @gpio_base: Starting GPIO number of this range
- * @pin_base: Starting pin number of this range
- * @npins: Number of pins in this range
- */
- struct tng_gpio_pinrange {
- unsigned int gpio_base;
- unsigned int pin_base;
- unsigned int npins;
- };
- #define GPIO_PINRANGE(gstart, gend, pstart) \
- (struct tng_gpio_pinrange) { \
- .gpio_base = (gstart), \
- .pin_base = (pstart), \
- .npins = (gend) - (gstart) + 1, \
- }
- /**
- * struct tng_gpio_pin_info - Platform specific pinout information
- * @pin_ranges: Pin to GPIO mapping
- * @nranges: Number of pin ranges
- * @name: Respective pinctrl device name
- */
- struct tng_gpio_pin_info {
- const struct tng_gpio_pinrange *pin_ranges;
- unsigned int nranges;
- const char *name;
- };
- /**
- * struct tng_gpio_info - Platform specific GPIO and IRQ information
- * @base: GPIO base to start numbering with
- * @ngpio: Amount of GPIOs supported by the controller
- * @first: First IRQ to start numbering with
- */
- struct tng_gpio_info {
- int base;
- u16 ngpio;
- unsigned int first;
- };
- /**
- * struct tng_gpio - Platform specific private data
- * @chip: Instance of the struct gpio_chip
- * @reg_base: Base address of MMIO registers
- * @irq: Interrupt for the GPIO device
- * @lock: Synchronization lock to prevent I/O race conditions
- * @dev: The GPIO device
- * @ctx: Context to be saved during suspend-resume
- * @wake_regs: Platform specific wake registers
- * @pin_info: Platform specific pinout information
- * @info: Platform specific GPIO and IRQ information
- */
- struct tng_gpio {
- struct gpio_chip chip;
- void __iomem *reg_base;
- int irq;
- raw_spinlock_t lock;
- struct device *dev;
- struct tng_gpio_context *ctx;
- struct tng_wake_regs wake_regs;
- struct tng_gpio_pin_info pin_info;
- struct tng_gpio_info info;
- };
- int devm_tng_gpio_probe(struct device *dev, struct tng_gpio *gpio);
- extern const struct dev_pm_ops tng_gpio_pm_ops;
- #endif /* _GPIO_TANGIER_H_ */
|