^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /* SPDX-License-Identifier: GPL-2.0-only */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) * Copyright 2012 Creative Product Design
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4) * Marc Reilly <marc@cpdesign.com.au>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) #ifndef __DRIVERS_MFD_MC13XXX_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7) #define __DRIVERS_MFD_MC13XXX_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) #include <linux/mutex.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) #include <linux/regmap.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) #include <linux/mfd/mc13xxx.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) #define MC13XXX_NUMREGS 0x3f
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) #define MC13XXX_IRQ_REG_CNT 2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) #define MC13XXX_IRQ_PER_REG 24
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) struct mc13xxx;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) struct mc13xxx_variant {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) const char *name;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) void (*print_revision)(struct mc13xxx *mc13xxx, u32 revision);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) extern struct mc13xxx_variant
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) mc13xxx_variant_mc13783,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) mc13xxx_variant_mc13892,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) mc13xxx_variant_mc34708;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) struct mc13xxx {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) struct regmap *regmap;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) struct device *dev;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) const struct mc13xxx_variant *variant;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) struct regmap_irq irqs[MC13XXX_IRQ_PER_REG * MC13XXX_IRQ_REG_CNT];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) struct regmap_irq_chip irq_chip;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) struct regmap_irq_chip_data *irq_data;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) struct mutex lock;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) int irq;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) int flags;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) int adcflags;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) int mc13xxx_common_init(struct device *dev);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) int mc13xxx_common_exit(struct device *dev);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) #endif /* __DRIVERS_MFD_MC13XXX_H */