Commit 0a5454c9 authored by Hans de Goede's avatar Hans de Goede Committed by Lee Jones

mfd: axp20x: Use IRQF_TRIGGER_LOW on the axp288

The interrupt line of the entire family of axp2xx pmics is active-low,
for devicetree enumerated irqs, this is dealt with in the devicetree.

ACPI irq resources have a flag field for this too, I tried using this
on my CUBE iwork8 Air tablet, but it does not contain the right data.

The dstd shows the irq listed as either ActiveLow or ActiveHigh,
depending on the OSID variable, which seems to be set by the
"OS IMAGE ID" in the BIOS/EFI setup screen.

Since the acpi-resource info is no good, simply pass in IRQF_TRIGGER_LOW
on the axp288.

Together with the other axp288 fixes in this series, this fixes the axp288
irq contineously triggering.
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
Acked-by: default avatarChen-Yu Tsai <wens@csie.org>
Signed-off-by: default avatarLee Jones <lee.jones@linaro.org>
parent 34a23327
...@@ -802,6 +802,7 @@ int axp20x_match_device(struct axp20x_dev *axp20x) ...@@ -802,6 +802,7 @@ int axp20x_match_device(struct axp20x_dev *axp20x)
axp20x->nr_cells = ARRAY_SIZE(axp288_cells); axp20x->nr_cells = ARRAY_SIZE(axp288_cells);
axp20x->regmap_cfg = &axp288_regmap_config; axp20x->regmap_cfg = &axp288_regmap_config;
axp20x->regmap_irq_chip = &axp288_regmap_irq_chip; axp20x->regmap_irq_chip = &axp288_regmap_irq_chip;
axp20x->irq_flags = IRQF_TRIGGER_LOW;
break; break;
case AXP806_ID: case AXP806_ID:
axp20x->nr_cells = ARRAY_SIZE(axp806_cells); axp20x->nr_cells = ARRAY_SIZE(axp806_cells);
...@@ -831,9 +832,8 @@ int axp20x_device_probe(struct axp20x_dev *axp20x) ...@@ -831,9 +832,8 @@ int axp20x_device_probe(struct axp20x_dev *axp20x)
int ret; int ret;
ret = regmap_add_irq_chip(axp20x->regmap, axp20x->irq, ret = regmap_add_irq_chip(axp20x->regmap, axp20x->irq,
IRQF_ONESHOT | IRQF_SHARED, -1, IRQF_ONESHOT | IRQF_SHARED | axp20x->irq_flags,
axp20x->regmap_irq_chip, -1, axp20x->regmap_irq_chip, &axp20x->regmap_irqc);
&axp20x->regmap_irqc);
if (ret) { if (ret) {
dev_err(axp20x->dev, "failed to add irq chip: %d\n", ret); dev_err(axp20x->dev, "failed to add irq chip: %d\n", ret);
return ret; return ret;
......
...@@ -523,6 +523,7 @@ enum axp809_irqs { ...@@ -523,6 +523,7 @@ enum axp809_irqs {
struct axp20x_dev { struct axp20x_dev {
struct device *dev; struct device *dev;
int irq; int irq;
unsigned long irq_flags;
struct regmap *regmap; struct regmap *regmap;
struct regmap_irq_chip_data *regmap_irqc; struct regmap_irq_chip_data *regmap_irqc;
long variant; long variant;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment