mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-12 00:38:55 +00:00
intel-gpio for v5.9-1
* Move GPIO PMIC drivers to use IRQ chip template * Introduce for_each_requested_gpio() and convert existing users * Replace unsigned by unsigned int in few drivers * Fix an issue in kernel doc that validator complains about * Move to verbose debug level the IRQ status message in gpio-pch The following is an automated git shortlog grouped by driver: ARM/orion/gpio: - Make use of for_each_requested_gpio() crystalcove: - Use irqchip template - changed every 'unsigned' to 'unsigned int' gpiolib: - Introduce for_each_requested_gpio_in_range() macro gpio-ml-ioh: - Fix missing ':' in 'struct ioh_gpio_reg_data ich: - changed every 'unsigned' to 'unsigned int' mvebu: - Make use of for_each_requested_gpio() pch: - Add a blank line between declaration and code - changed every 'unsigned' to 'unsigned int' - Move IRQ status message to verbose debug level pinctrl: - at91: Make use of for_each_requested_gpio() sch: - Add a blank line between declaration and code - changed every 'unsigned' to 'unsigned int' wcove: - Use irqchip template xra1403: - Make use of for_each_requested_gpio() -----BEGIN PGP SIGNATURE----- iQIzBAABCgAdFiEEqaflIX74DDDzMJJtb7wzTHR8rCgFAl8YPvwACgkQb7wzTHR8 rCgX6w/+MOk7PmVOHlYNrc7UiOnvVxpMbYRW/UpAXJ9r60FqnpeiwDh7Vqdonom5 TfQUfskHdKTQR1Ybo93HPJaKtxo601yu9PbV00pfB1uN9Nmj6pxQ+gXeFmV4Eov7 gKlqaKW2zIjF6Rrbs8Xa7O4UDnXLgIqKOguuGWyrHBywfkQKIz1i4/x0w/IOvyB6 ZM9n2iiEAysTGDOYsEvjKHAHgtruz+nQfqF5vWy6/6KBefuIUiHI6tbPXwkrhZ+x xNsbkoyQvL95o0naDLfXoL8xZ9gxeQfr041405I96kZwtlOHsJSEule7fR39r4A6 4KKICJ0MwC03NyOaVpKeElffA1rfreZhNACFHEylcjauYrfEC84wXCSL0hOfa2Pe 7PBMlRMQmrO7MkBxlihsy0oUip+fDG+XoANnB/51dX62AEJTjNs8Adh4aI2adaXh 11bi9GjLxUJ+Myopf1wF5lWrDPRvXviEWFeMxPNAS/lJSWkCnAtm9UvZOPTgl4Ps +vFs/oiORmsYUELcaVwnOsNsoLB+DOFHdH5K20H2n0fjch2th/n2Jph6lBcY6D9W 50pKighf/92gWMeOllTha0I/EOFNCBi57DnUsuiNkuZ7lQd0O05MAJ4GBsOmBuF8 sc4euGVU4mIvdn+bMNuN8c1vXJAWmPBfb1QiChXv9/BEVjZt0uI= =txvs -----END PGP SIGNATURE----- Merge tag 'intel-gpio-v5.9-1' of git://git.kernel.org/pub/scm/linux/kernel/git/andy/linux-gpio-intel into devel intel-gpio for v5.9-1 * Move GPIO PMIC drivers to use IRQ chip template * Introduce for_each_requested_gpio() and convert existing users * Replace unsigned by unsigned int in few drivers * Fix an issue in kernel doc that validator complains about * Move to verbose debug level the IRQ status message in gpio-pch The following is an automated git shortlog grouped by driver: ARM/orion/gpio: - Make use of for_each_requested_gpio() crystalcove: - Use irqchip template - changed every 'unsigned' to 'unsigned int' gpiolib: - Introduce for_each_requested_gpio_in_range() macro gpio-ml-ioh: - Fix missing ':' in 'struct ioh_gpio_reg_data ich: - changed every 'unsigned' to 'unsigned int' mvebu: - Make use of for_each_requested_gpio() pch: - Add a blank line between declaration and code - changed every 'unsigned' to 'unsigned int' - Move IRQ status message to verbose debug level pinctrl: - at91: Make use of for_each_requested_gpio() sch: - Add a blank line between declaration and code - changed every 'unsigned' to 'unsigned int' wcove: - Use irqchip template xra1403: - Make use of for_each_requested_gpio()
This commit is contained in:
commit
ce8672c20b
@ -129,7 +129,7 @@ static void crystalcove_update_irq_ctrl(struct crystalcove_gpio *cg, int gpio)
|
|||||||
regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE, cg->intcnt_value);
|
regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE, cg->intcnt_value);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int crystalcove_gpio_dir_in(struct gpio_chip *chip, unsigned gpio)
|
static int crystalcove_gpio_dir_in(struct gpio_chip *chip, unsigned int gpio)
|
||||||
{
|
{
|
||||||
struct crystalcove_gpio *cg = gpiochip_get_data(chip);
|
struct crystalcove_gpio *cg = gpiochip_get_data(chip);
|
||||||
int reg = to_reg(gpio, CTRL_OUT);
|
int reg = to_reg(gpio, CTRL_OUT);
|
||||||
@ -140,7 +140,7 @@ static int crystalcove_gpio_dir_in(struct gpio_chip *chip, unsigned gpio)
|
|||||||
return regmap_write(cg->regmap, reg, CTLO_INPUT_SET);
|
return regmap_write(cg->regmap, reg, CTLO_INPUT_SET);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int crystalcove_gpio_dir_out(struct gpio_chip *chip, unsigned gpio,
|
static int crystalcove_gpio_dir_out(struct gpio_chip *chip, unsigned int gpio,
|
||||||
int value)
|
int value)
|
||||||
{
|
{
|
||||||
struct crystalcove_gpio *cg = gpiochip_get_data(chip);
|
struct crystalcove_gpio *cg = gpiochip_get_data(chip);
|
||||||
@ -152,7 +152,7 @@ static int crystalcove_gpio_dir_out(struct gpio_chip *chip, unsigned gpio,
|
|||||||
return regmap_write(cg->regmap, reg, CTLO_OUTPUT_SET | value);
|
return regmap_write(cg->regmap, reg, CTLO_OUTPUT_SET | value);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int crystalcove_gpio_get(struct gpio_chip *chip, unsigned gpio)
|
static int crystalcove_gpio_get(struct gpio_chip *chip, unsigned int gpio)
|
||||||
{
|
{
|
||||||
struct crystalcove_gpio *cg = gpiochip_get_data(chip);
|
struct crystalcove_gpio *cg = gpiochip_get_data(chip);
|
||||||
unsigned int val;
|
unsigned int val;
|
||||||
@ -169,7 +169,7 @@ static int crystalcove_gpio_get(struct gpio_chip *chip, unsigned gpio)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void crystalcove_gpio_set(struct gpio_chip *chip,
|
static void crystalcove_gpio_set(struct gpio_chip *chip,
|
||||||
unsigned gpio, int value)
|
unsigned int gpio, int value)
|
||||||
{
|
{
|
||||||
struct crystalcove_gpio *cg = gpiochip_get_data(chip);
|
struct crystalcove_gpio *cg = gpiochip_get_data(chip);
|
||||||
int reg = to_reg(gpio, CTRL_OUT);
|
int reg = to_reg(gpio, CTRL_OUT);
|
||||||
@ -183,7 +183,7 @@ static void crystalcove_gpio_set(struct gpio_chip *chip,
|
|||||||
regmap_update_bits(cg->regmap, reg, 1, 0);
|
regmap_update_bits(cg->regmap, reg, 1, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int crystalcove_irq_type(struct irq_data *data, unsigned type)
|
static int crystalcove_irq_type(struct irq_data *data, unsigned int type)
|
||||||
{
|
{
|
||||||
struct crystalcove_gpio *cg =
|
struct crystalcove_gpio *cg =
|
||||||
gpiochip_get_data(irq_data_get_irq_chip_data(data));
|
gpiochip_get_data(irq_data_get_irq_chip_data(data));
|
||||||
@ -330,6 +330,7 @@ static int crystalcove_gpio_probe(struct platform_device *pdev)
|
|||||||
int retval;
|
int retval;
|
||||||
struct device *dev = pdev->dev.parent;
|
struct device *dev = pdev->dev.parent;
|
||||||
struct intel_soc_pmic *pmic = dev_get_drvdata(dev);
|
struct intel_soc_pmic *pmic = dev_get_drvdata(dev);
|
||||||
|
struct gpio_irq_chip *girq;
|
||||||
|
|
||||||
if (irq < 0)
|
if (irq < 0)
|
||||||
return irq;
|
return irq;
|
||||||
@ -353,14 +354,15 @@ static int crystalcove_gpio_probe(struct platform_device *pdev)
|
|||||||
cg->chip.dbg_show = crystalcove_gpio_dbg_show;
|
cg->chip.dbg_show = crystalcove_gpio_dbg_show;
|
||||||
cg->regmap = pmic->regmap;
|
cg->regmap = pmic->regmap;
|
||||||
|
|
||||||
retval = devm_gpiochip_add_data(&pdev->dev, &cg->chip, cg);
|
girq = &cg->chip.irq;
|
||||||
if (retval) {
|
girq->chip = &crystalcove_irqchip;
|
||||||
dev_warn(&pdev->dev, "add gpio chip error: %d\n", retval);
|
/* This will let us handle the parent IRQ in the driver */
|
||||||
return retval;
|
girq->parent_handler = NULL;
|
||||||
}
|
girq->num_parents = 0;
|
||||||
|
girq->parents = NULL;
|
||||||
gpiochip_irqchip_add_nested(&cg->chip, &crystalcove_irqchip, 0,
|
girq->default_type = IRQ_TYPE_NONE;
|
||||||
handle_simple_irq, IRQ_TYPE_NONE);
|
girq->handler = handle_simple_irq;
|
||||||
|
girq->threaded = true;
|
||||||
|
|
||||||
retval = request_threaded_irq(irq, NULL, crystalcove_gpio_irq_handler,
|
retval = request_threaded_irq(irq, NULL, crystalcove_gpio_irq_handler,
|
||||||
IRQF_ONESHOT, KBUILD_MODNAME, cg);
|
IRQF_ONESHOT, KBUILD_MODNAME, cg);
|
||||||
@ -370,7 +372,11 @@ static int crystalcove_gpio_probe(struct platform_device *pdev)
|
|||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
gpiochip_set_nested_irqchip(&cg->chip, &crystalcove_irqchip, irq);
|
retval = devm_gpiochip_add_data(&pdev->dev, &cg->chip, cg);
|
||||||
|
if (retval) {
|
||||||
|
dev_warn(&pdev->dev, "add gpio chip error: %d\n", retval);
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -74,8 +74,8 @@ struct ichx_desc {
|
|||||||
u32 use_sel_ignore[3];
|
u32 use_sel_ignore[3];
|
||||||
|
|
||||||
/* Some chipsets have quirks, let these use their own request/get */
|
/* Some chipsets have quirks, let these use their own request/get */
|
||||||
int (*request)(struct gpio_chip *chip, unsigned offset);
|
int (*request)(struct gpio_chip *chip, unsigned int offset);
|
||||||
int (*get)(struct gpio_chip *chip, unsigned offset);
|
int (*get)(struct gpio_chip *chip, unsigned int offset);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Some chipsets don't let reading output values on GPIO_LVL register
|
* Some chipsets don't let reading output values on GPIO_LVL register
|
||||||
@ -100,7 +100,7 @@ static int modparam_gpiobase = -1; /* dynamic */
|
|||||||
module_param_named(gpiobase, modparam_gpiobase, int, 0444);
|
module_param_named(gpiobase, modparam_gpiobase, int, 0444);
|
||||||
MODULE_PARM_DESC(gpiobase, "The GPIO number base. -1 means dynamic, which is the default.");
|
MODULE_PARM_DESC(gpiobase, "The GPIO number base. -1 means dynamic, which is the default.");
|
||||||
|
|
||||||
static int ichx_write_bit(int reg, unsigned nr, int val, int verify)
|
static int ichx_write_bit(int reg, unsigned int nr, int val, int verify)
|
||||||
{
|
{
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
u32 data, tmp;
|
u32 data, tmp;
|
||||||
@ -132,7 +132,7 @@ static int ichx_write_bit(int reg, unsigned nr, int val, int verify)
|
|||||||
return (verify && data != tmp) ? -EPERM : 0;
|
return (verify && data != tmp) ? -EPERM : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ichx_read_bit(int reg, unsigned nr)
|
static int ichx_read_bit(int reg, unsigned int nr)
|
||||||
{
|
{
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
u32 data;
|
u32 data;
|
||||||
@ -152,12 +152,12 @@ static int ichx_read_bit(int reg, unsigned nr)
|
|||||||
return !!(data & BIT(bit));
|
return !!(data & BIT(bit));
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool ichx_gpio_check_available(struct gpio_chip *gpio, unsigned nr)
|
static bool ichx_gpio_check_available(struct gpio_chip *gpio, unsigned int nr)
|
||||||
{
|
{
|
||||||
return !!(ichx_priv.use_gpio & BIT(nr / 32));
|
return !!(ichx_priv.use_gpio & BIT(nr / 32));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ichx_gpio_get_direction(struct gpio_chip *gpio, unsigned nr)
|
static int ichx_gpio_get_direction(struct gpio_chip *gpio, unsigned int nr)
|
||||||
{
|
{
|
||||||
if (ichx_read_bit(GPIO_IO_SEL, nr))
|
if (ichx_read_bit(GPIO_IO_SEL, nr))
|
||||||
return GPIO_LINE_DIRECTION_IN;
|
return GPIO_LINE_DIRECTION_IN;
|
||||||
@ -165,7 +165,7 @@ static int ichx_gpio_get_direction(struct gpio_chip *gpio, unsigned nr)
|
|||||||
return GPIO_LINE_DIRECTION_OUT;
|
return GPIO_LINE_DIRECTION_OUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ichx_gpio_direction_input(struct gpio_chip *gpio, unsigned nr)
|
static int ichx_gpio_direction_input(struct gpio_chip *gpio, unsigned int nr)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* Try setting pin as an input and verify it worked since many pins
|
* Try setting pin as an input and verify it worked since many pins
|
||||||
@ -174,7 +174,7 @@ static int ichx_gpio_direction_input(struct gpio_chip *gpio, unsigned nr)
|
|||||||
return ichx_write_bit(GPIO_IO_SEL, nr, 1, 1);
|
return ichx_write_bit(GPIO_IO_SEL, nr, 1, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ichx_gpio_direction_output(struct gpio_chip *gpio, unsigned nr,
|
static int ichx_gpio_direction_output(struct gpio_chip *gpio, unsigned int nr,
|
||||||
int val)
|
int val)
|
||||||
{
|
{
|
||||||
/* Disable blink hardware which is available for GPIOs from 0 to 31. */
|
/* Disable blink hardware which is available for GPIOs from 0 to 31. */
|
||||||
@ -191,12 +191,12 @@ static int ichx_gpio_direction_output(struct gpio_chip *gpio, unsigned nr,
|
|||||||
return ichx_write_bit(GPIO_IO_SEL, nr, 0, 1);
|
return ichx_write_bit(GPIO_IO_SEL, nr, 0, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ichx_gpio_get(struct gpio_chip *chip, unsigned nr)
|
static int ichx_gpio_get(struct gpio_chip *chip, unsigned int nr)
|
||||||
{
|
{
|
||||||
return ichx_read_bit(GPIO_LVL, nr);
|
return ichx_read_bit(GPIO_LVL, nr);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ich6_gpio_get(struct gpio_chip *chip, unsigned nr)
|
static int ich6_gpio_get(struct gpio_chip *chip, unsigned int nr)
|
||||||
{
|
{
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
u32 data;
|
u32 data;
|
||||||
@ -223,7 +223,7 @@ static int ich6_gpio_get(struct gpio_chip *chip, unsigned nr)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ichx_gpio_request(struct gpio_chip *chip, unsigned nr)
|
static int ichx_gpio_request(struct gpio_chip *chip, unsigned int nr)
|
||||||
{
|
{
|
||||||
if (!ichx_gpio_check_available(chip, nr))
|
if (!ichx_gpio_check_available(chip, nr))
|
||||||
return -ENXIO;
|
return -ENXIO;
|
||||||
@ -240,7 +240,7 @@ static int ichx_gpio_request(struct gpio_chip *chip, unsigned nr)
|
|||||||
return ichx_read_bit(GPIO_USE_SEL, nr) ? 0 : -ENODEV;
|
return ichx_read_bit(GPIO_USE_SEL, nr) ? 0 : -ENODEV;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ich6_gpio_request(struct gpio_chip *chip, unsigned nr)
|
static int ich6_gpio_request(struct gpio_chip *chip, unsigned int nr)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* Fixups for bits 16 and 17 are necessary on the Intel ICH6/3100
|
* Fixups for bits 16 and 17 are necessary on the Intel ICH6/3100
|
||||||
@ -254,7 +254,7 @@ static int ich6_gpio_request(struct gpio_chip *chip, unsigned nr)
|
|||||||
return ichx_gpio_request(chip, nr);
|
return ichx_gpio_request(chip, nr);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ichx_gpio_set(struct gpio_chip *chip, unsigned nr, int val)
|
static void ichx_gpio_set(struct gpio_chip *chip, unsigned int nr, int val)
|
||||||
{
|
{
|
||||||
ichx_write_bit(GPIO_LVL, nr, val, 0);
|
ichx_write_bit(GPIO_LVL, nr, val, 0);
|
||||||
}
|
}
|
||||||
|
@ -44,7 +44,7 @@ struct ioh_regs {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* struct ioh_gpio_reg_data - The register store data.
|
* struct ioh_gpio_reg_data - The register store data.
|
||||||
* @ien_reg To store contents of interrupt enable register.
|
* @ien_reg: To store contents of interrupt enable register.
|
||||||
* @imask_reg: To store contents of interrupt mask regist
|
* @imask_reg: To store contents of interrupt mask regist
|
||||||
* @po_reg: To store contents of PO register.
|
* @po_reg: To store contents of PO register.
|
||||||
* @pm_reg: To store contents of PM register.
|
* @pm_reg: To store contents of PM register.
|
||||||
|
@ -95,7 +95,7 @@ struct pch_gpio {
|
|||||||
spinlock_t spinlock;
|
spinlock_t spinlock;
|
||||||
};
|
};
|
||||||
|
|
||||||
static void pch_gpio_set(struct gpio_chip *gpio, unsigned nr, int val)
|
static void pch_gpio_set(struct gpio_chip *gpio, unsigned int nr, int val)
|
||||||
{
|
{
|
||||||
u32 reg_val;
|
u32 reg_val;
|
||||||
struct pch_gpio *chip = gpiochip_get_data(gpio);
|
struct pch_gpio *chip = gpiochip_get_data(gpio);
|
||||||
@ -112,14 +112,14 @@ static void pch_gpio_set(struct gpio_chip *gpio, unsigned nr, int val)
|
|||||||
spin_unlock_irqrestore(&chip->spinlock, flags);
|
spin_unlock_irqrestore(&chip->spinlock, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int pch_gpio_get(struct gpio_chip *gpio, unsigned nr)
|
static int pch_gpio_get(struct gpio_chip *gpio, unsigned int nr)
|
||||||
{
|
{
|
||||||
struct pch_gpio *chip = gpiochip_get_data(gpio);
|
struct pch_gpio *chip = gpiochip_get_data(gpio);
|
||||||
|
|
||||||
return !!(ioread32(&chip->reg->pi) & BIT(nr));
|
return !!(ioread32(&chip->reg->pi) & BIT(nr));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int pch_gpio_direction_output(struct gpio_chip *gpio, unsigned nr,
|
static int pch_gpio_direction_output(struct gpio_chip *gpio, unsigned int nr,
|
||||||
int val)
|
int val)
|
||||||
{
|
{
|
||||||
struct pch_gpio *chip = gpiochip_get_data(gpio);
|
struct pch_gpio *chip = gpiochip_get_data(gpio);
|
||||||
@ -146,7 +146,7 @@ static int pch_gpio_direction_output(struct gpio_chip *gpio, unsigned nr,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int pch_gpio_direction_input(struct gpio_chip *gpio, unsigned nr)
|
static int pch_gpio_direction_input(struct gpio_chip *gpio, unsigned int nr)
|
||||||
{
|
{
|
||||||
struct pch_gpio *chip = gpiochip_get_data(gpio);
|
struct pch_gpio *chip = gpiochip_get_data(gpio);
|
||||||
u32 pm;
|
u32 pm;
|
||||||
@ -196,9 +196,10 @@ static void __maybe_unused pch_gpio_restore_reg_conf(struct pch_gpio *chip)
|
|||||||
iowrite32(chip->pch_gpio_reg.gpio_use_sel_reg, &chip->reg->gpio_use_sel);
|
iowrite32(chip->pch_gpio_reg.gpio_use_sel_reg, &chip->reg->gpio_use_sel);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int pch_gpio_to_irq(struct gpio_chip *gpio, unsigned offset)
|
static int pch_gpio_to_irq(struct gpio_chip *gpio, unsigned int offset)
|
||||||
{
|
{
|
||||||
struct pch_gpio *chip = gpiochip_get_data(gpio);
|
struct pch_gpio *chip = gpiochip_get_data(gpio);
|
||||||
|
|
||||||
return chip->irq_base + offset;
|
return chip->irq_base + offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -304,9 +305,10 @@ static irqreturn_t pch_gpio_handler(int irq, void *dev_id)
|
|||||||
unsigned long reg_val = ioread32(&chip->reg->istatus);
|
unsigned long reg_val = ioread32(&chip->reg->istatus);
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
dev_dbg(chip->dev, "irq=%d status=0x%lx\n", irq, reg_val);
|
dev_vdbg(chip->dev, "irq=%d status=0x%lx\n", irq, reg_val);
|
||||||
|
|
||||||
reg_val &= BIT(gpio_pins[chip->ioh]) - 1;
|
reg_val &= BIT(gpio_pins[chip->ioh]) - 1;
|
||||||
|
|
||||||
for_each_set_bit(i, ®_val, gpio_pins[chip->ioh])
|
for_each_set_bit(i, ®_val, gpio_pins[chip->ioh])
|
||||||
generic_handle_irq(chip->irq_base + i);
|
generic_handle_irq(chip->irq_base + i);
|
||||||
|
|
||||||
|
@ -26,10 +26,10 @@ struct sch_gpio {
|
|||||||
unsigned short resume_base;
|
unsigned short resume_base;
|
||||||
};
|
};
|
||||||
|
|
||||||
static unsigned sch_gpio_offset(struct sch_gpio *sch, unsigned gpio,
|
static unsigned int sch_gpio_offset(struct sch_gpio *sch, unsigned int gpio,
|
||||||
unsigned reg)
|
unsigned int reg)
|
||||||
{
|
{
|
||||||
unsigned base = 0;
|
unsigned int base = 0;
|
||||||
|
|
||||||
if (gpio >= sch->resume_base) {
|
if (gpio >= sch->resume_base) {
|
||||||
gpio -= sch->resume_base;
|
gpio -= sch->resume_base;
|
||||||
@ -39,14 +39,14 @@ static unsigned sch_gpio_offset(struct sch_gpio *sch, unsigned gpio,
|
|||||||
return base + reg + gpio / 8;
|
return base + reg + gpio / 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned sch_gpio_bit(struct sch_gpio *sch, unsigned gpio)
|
static unsigned int sch_gpio_bit(struct sch_gpio *sch, unsigned int gpio)
|
||||||
{
|
{
|
||||||
if (gpio >= sch->resume_base)
|
if (gpio >= sch->resume_base)
|
||||||
gpio -= sch->resume_base;
|
gpio -= sch->resume_base;
|
||||||
return gpio % 8;
|
return gpio % 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sch_gpio_reg_get(struct sch_gpio *sch, unsigned gpio, unsigned reg)
|
static int sch_gpio_reg_get(struct sch_gpio *sch, unsigned int gpio, unsigned int reg)
|
||||||
{
|
{
|
||||||
unsigned short offset, bit;
|
unsigned short offset, bit;
|
||||||
u8 reg_val;
|
u8 reg_val;
|
||||||
@ -59,7 +59,7 @@ static int sch_gpio_reg_get(struct sch_gpio *sch, unsigned gpio, unsigned reg)
|
|||||||
return reg_val;
|
return reg_val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void sch_gpio_reg_set(struct sch_gpio *sch, unsigned gpio, unsigned reg,
|
static void sch_gpio_reg_set(struct sch_gpio *sch, unsigned int gpio, unsigned int reg,
|
||||||
int val)
|
int val)
|
||||||
{
|
{
|
||||||
unsigned short offset, bit;
|
unsigned short offset, bit;
|
||||||
@ -76,7 +76,7 @@ static void sch_gpio_reg_set(struct sch_gpio *sch, unsigned gpio, unsigned reg,
|
|||||||
outb((reg_val & ~BIT(bit)), sch->iobase + offset);
|
outb((reg_val & ~BIT(bit)), sch->iobase + offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sch_gpio_direction_in(struct gpio_chip *gc, unsigned gpio_num)
|
static int sch_gpio_direction_in(struct gpio_chip *gc, unsigned int gpio_num)
|
||||||
{
|
{
|
||||||
struct sch_gpio *sch = gpiochip_get_data(gc);
|
struct sch_gpio *sch = gpiochip_get_data(gc);
|
||||||
|
|
||||||
@ -86,13 +86,14 @@ static int sch_gpio_direction_in(struct gpio_chip *gc, unsigned gpio_num)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sch_gpio_get(struct gpio_chip *gc, unsigned gpio_num)
|
static int sch_gpio_get(struct gpio_chip *gc, unsigned int gpio_num)
|
||||||
{
|
{
|
||||||
struct sch_gpio *sch = gpiochip_get_data(gc);
|
struct sch_gpio *sch = gpiochip_get_data(gc);
|
||||||
|
|
||||||
return sch_gpio_reg_get(sch, gpio_num, GLV);
|
return sch_gpio_reg_get(sch, gpio_num, GLV);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void sch_gpio_set(struct gpio_chip *gc, unsigned gpio_num, int val)
|
static void sch_gpio_set(struct gpio_chip *gc, unsigned int gpio_num, int val)
|
||||||
{
|
{
|
||||||
struct sch_gpio *sch = gpiochip_get_data(gc);
|
struct sch_gpio *sch = gpiochip_get_data(gc);
|
||||||
|
|
||||||
@ -101,7 +102,7 @@ static void sch_gpio_set(struct gpio_chip *gc, unsigned gpio_num, int val)
|
|||||||
spin_unlock(&sch->lock);
|
spin_unlock(&sch->lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sch_gpio_direction_out(struct gpio_chip *gc, unsigned gpio_num,
|
static int sch_gpio_direction_out(struct gpio_chip *gc, unsigned int gpio_num,
|
||||||
int val)
|
int val)
|
||||||
{
|
{
|
||||||
struct sch_gpio *sch = gpiochip_get_data(gc);
|
struct sch_gpio *sch = gpiochip_get_data(gc);
|
||||||
@ -123,7 +124,7 @@ static int sch_gpio_direction_out(struct gpio_chip *gc, unsigned gpio_num,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sch_gpio_get_direction(struct gpio_chip *gc, unsigned gpio_num)
|
static int sch_gpio_get_direction(struct gpio_chip *gc, unsigned int gpio_num)
|
||||||
{
|
{
|
||||||
struct sch_gpio *sch = gpiochip_get_data(gc);
|
struct sch_gpio *sch = gpiochip_get_data(gc);
|
||||||
|
|
||||||
|
@ -400,6 +400,7 @@ static int wcove_gpio_probe(struct platform_device *pdev)
|
|||||||
struct wcove_gpio *wg;
|
struct wcove_gpio *wg;
|
||||||
int virq, ret, irq;
|
int virq, ret, irq;
|
||||||
struct device *dev;
|
struct device *dev;
|
||||||
|
struct gpio_irq_chip *girq;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This gpio platform device is created by a mfd device (see
|
* This gpio platform device is created by a mfd device (see
|
||||||
@ -442,19 +443,6 @@ static int wcove_gpio_probe(struct platform_device *pdev)
|
|||||||
wg->dev = dev;
|
wg->dev = dev;
|
||||||
wg->regmap = pmic->regmap;
|
wg->regmap = pmic->regmap;
|
||||||
|
|
||||||
ret = devm_gpiochip_add_data(dev, &wg->chip, wg);
|
|
||||||
if (ret) {
|
|
||||||
dev_err(dev, "Failed to add gpiochip: %d\n", ret);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = gpiochip_irqchip_add_nested(&wg->chip, &wcove_irqchip, 0,
|
|
||||||
handle_simple_irq, IRQ_TYPE_NONE);
|
|
||||||
if (ret) {
|
|
||||||
dev_err(dev, "Failed to add irqchip: %d\n", ret);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
virq = regmap_irq_get_virq(wg->regmap_irq_chip, irq);
|
virq = regmap_irq_get_virq(wg->regmap_irq_chip, irq);
|
||||||
if (virq < 0) {
|
if (virq < 0) {
|
||||||
dev_err(dev, "Failed to get virq by irq %d\n", irq);
|
dev_err(dev, "Failed to get virq by irq %d\n", irq);
|
||||||
@ -468,7 +456,21 @@ static int wcove_gpio_probe(struct platform_device *pdev)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
gpiochip_set_nested_irqchip(&wg->chip, &wcove_irqchip, virq);
|
girq = &wg->chip.irq;
|
||||||
|
girq->chip = &wcove_irqchip;
|
||||||
|
/* This will let us handle the parent IRQ in the driver */
|
||||||
|
girq->parent_handler = NULL;
|
||||||
|
girq->num_parents = 0;
|
||||||
|
girq->parents = NULL;
|
||||||
|
girq->default_type = IRQ_TYPE_NONE;
|
||||||
|
girq->handler = handle_simple_irq;
|
||||||
|
girq->threaded = true;
|
||||||
|
|
||||||
|
ret = devm_gpiochip_add_data(dev, &wg->chip, wg);
|
||||||
|
if (ret) {
|
||||||
|
dev_err(dev, "Failed to add gpiochip: %d\n", ret);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/* Enable GPIO0 interrupts */
|
/* Enable GPIO0 interrupts */
|
||||||
ret = regmap_update_bits(wg->regmap, IRQ_MASK_BASE, GPIO_IRQ0_MASK,
|
ret = regmap_update_bits(wg->regmap, IRQ_MASK_BASE, GPIO_IRQ0_MASK,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user