intel-pinctrl for v5.2-2
Fix a laggish ELAN touchpad responsiveness due to an odd interrupt masking. The following is an automated git shortlog grouped by driver: intel: - Clear interrupt status in mask/unmask callback - Use GENMASK() consistently -----BEGIN PGP SIGNATURE----- iQIzBAABCgAdFiEEqaflIX74DDDzMJJtb7wzTHR8rCgFAlzoEN4ACgkQb7wzTHR8 rChoeBAAv5CLBatkDMzEfQ19ahvKIUMLXX2USh8bgYgQYoWtZPTwbEdGBxDrp7+U Cqq9RbRRRx9CRkNAGDhShb1kKmWU2UBdHOUmSzTXWBrLz4W82E3mE0SbSzDKTxHf /lz5lfjv0zJrvUcltIc+caja6/XidC6h5dB0VoUUMk8kSRdGy/m/+h2Gdto4vczA QtiTHp367EOyeZPKJSXn6pk1oI8Oyrk9jRtMGzbRMlPPHTxzQBINQEA1iR9KXlnO HqvpAEH/30ST4j0td8dxQSFLGqff9KORWLfsUEEz+ZQcHuYXjWoMFV9RSkKv8exw FtLA78Y1Vf67dcKfu51sFQRq2CMfEkpRMe24lrj2JS6MMrOFKABfCVIuj+rTxm2R zTGGq7uNCSZHnC1jlFqx7rwjttmcDpZo1lcHcSZ3b7KqnQgOHpzlX4ZF/TrqzPvH XEmUOlRtfuBHB+DDu8DQaTTaqF8PfHSeOpwatToNEFLKgoN4uWkcpNZ2lA3D8Yfm BvUZqXbTxOZe0a+D/7ylXTpBbY9TjrJtK1DjKSFGnPM5aAZJmxDwZFh5ccmbCLob 5ks/a2CMvBA1LPtwo1rLeaiyN+aluJ1RXZU5DMi69mU6jlEVlzLT6cHl14NCfbWa tvNWtTf7GyMXEESv3mg4cOCMV46eYxhmSvGi7OOGeZpoyGocNnI= =8RfE -----END PGP SIGNATURE----- Merge tag 'intel-pinctrl-v5.2-2' of git://git.kernel.org/pub/scm/linux/kernel/git/pinctrl/intel into fixes intel-pinctrl for v5.2-2 Fix a laggish ELAN touchpad responsiveness due to an odd interrupt masking. The following is an automated git shortlog grouped by driver: intel: - Clear interrupt status in mask/unmask callback - Use GENMASK() consistently
This commit is contained in:
commit
b1fa7d8592
|
@ -33,13 +33,13 @@
|
||||||
|
|
||||||
#define PADOWN_BITS 4
|
#define PADOWN_BITS 4
|
||||||
#define PADOWN_SHIFT(p) ((p) % 8 * PADOWN_BITS)
|
#define PADOWN_SHIFT(p) ((p) % 8 * PADOWN_BITS)
|
||||||
#define PADOWN_MASK(p) (0xf << PADOWN_SHIFT(p))
|
#define PADOWN_MASK(p) (GENMASK(3, 0) << PADOWN_SHIFT(p))
|
||||||
#define PADOWN_GPP(p) ((p) / 8)
|
#define PADOWN_GPP(p) ((p) / 8)
|
||||||
|
|
||||||
/* Offset from pad_regs */
|
/* Offset from pad_regs */
|
||||||
#define PADCFG0 0x000
|
#define PADCFG0 0x000
|
||||||
#define PADCFG0_RXEVCFG_SHIFT 25
|
#define PADCFG0_RXEVCFG_SHIFT 25
|
||||||
#define PADCFG0_RXEVCFG_MASK (3 << PADCFG0_RXEVCFG_SHIFT)
|
#define PADCFG0_RXEVCFG_MASK GENMASK(26, 25)
|
||||||
#define PADCFG0_RXEVCFG_LEVEL 0
|
#define PADCFG0_RXEVCFG_LEVEL 0
|
||||||
#define PADCFG0_RXEVCFG_EDGE 1
|
#define PADCFG0_RXEVCFG_EDGE 1
|
||||||
#define PADCFG0_RXEVCFG_DISABLED 2
|
#define PADCFG0_RXEVCFG_DISABLED 2
|
||||||
|
@ -51,7 +51,7 @@
|
||||||
#define PADCFG0_GPIROUTSMI BIT(18)
|
#define PADCFG0_GPIROUTSMI BIT(18)
|
||||||
#define PADCFG0_GPIROUTNMI BIT(17)
|
#define PADCFG0_GPIROUTNMI BIT(17)
|
||||||
#define PADCFG0_PMODE_SHIFT 10
|
#define PADCFG0_PMODE_SHIFT 10
|
||||||
#define PADCFG0_PMODE_MASK (0xf << PADCFG0_PMODE_SHIFT)
|
#define PADCFG0_PMODE_MASK GENMASK(13, 10)
|
||||||
#define PADCFG0_GPIORXDIS BIT(9)
|
#define PADCFG0_GPIORXDIS BIT(9)
|
||||||
#define PADCFG0_GPIOTXDIS BIT(8)
|
#define PADCFG0_GPIOTXDIS BIT(8)
|
||||||
#define PADCFG0_GPIORXSTATE BIT(1)
|
#define PADCFG0_GPIORXSTATE BIT(1)
|
||||||
|
@ -60,7 +60,7 @@
|
||||||
#define PADCFG1 0x004
|
#define PADCFG1 0x004
|
||||||
#define PADCFG1_TERM_UP BIT(13)
|
#define PADCFG1_TERM_UP BIT(13)
|
||||||
#define PADCFG1_TERM_SHIFT 10
|
#define PADCFG1_TERM_SHIFT 10
|
||||||
#define PADCFG1_TERM_MASK (7 << PADCFG1_TERM_SHIFT)
|
#define PADCFG1_TERM_MASK GENMASK(12, 10)
|
||||||
#define PADCFG1_TERM_20K 4
|
#define PADCFG1_TERM_20K 4
|
||||||
#define PADCFG1_TERM_2K 3
|
#define PADCFG1_TERM_2K 3
|
||||||
#define PADCFG1_TERM_5K 2
|
#define PADCFG1_TERM_5K 2
|
||||||
|
@ -914,35 +914,6 @@ static void intel_gpio_irq_ack(struct irq_data *d)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void intel_gpio_irq_enable(struct irq_data *d)
|
|
||||||
{
|
|
||||||
struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
|
|
||||||
struct intel_pinctrl *pctrl = gpiochip_get_data(gc);
|
|
||||||
const struct intel_community *community;
|
|
||||||
const struct intel_padgroup *padgrp;
|
|
||||||
int pin;
|
|
||||||
|
|
||||||
pin = intel_gpio_to_pin(pctrl, irqd_to_hwirq(d), &community, &padgrp);
|
|
||||||
if (pin >= 0) {
|
|
||||||
unsigned int gpp, gpp_offset, is_offset;
|
|
||||||
unsigned long flags;
|
|
||||||
u32 value;
|
|
||||||
|
|
||||||
gpp = padgrp->reg_num;
|
|
||||||
gpp_offset = padgroup_offset(padgrp, pin);
|
|
||||||
is_offset = community->is_offset + gpp * 4;
|
|
||||||
|
|
||||||
raw_spin_lock_irqsave(&pctrl->lock, flags);
|
|
||||||
/* Clear interrupt status first to avoid unexpected interrupt */
|
|
||||||
writel(BIT(gpp_offset), community->regs + is_offset);
|
|
||||||
|
|
||||||
value = readl(community->regs + community->ie_offset + gpp * 4);
|
|
||||||
value |= BIT(gpp_offset);
|
|
||||||
writel(value, community->regs + community->ie_offset + gpp * 4);
|
|
||||||
raw_spin_unlock_irqrestore(&pctrl->lock, flags);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void intel_gpio_irq_mask_unmask(struct irq_data *d, bool mask)
|
static void intel_gpio_irq_mask_unmask(struct irq_data *d, bool mask)
|
||||||
{
|
{
|
||||||
struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
|
struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
|
||||||
|
@ -955,15 +926,20 @@ static void intel_gpio_irq_mask_unmask(struct irq_data *d, bool mask)
|
||||||
if (pin >= 0) {
|
if (pin >= 0) {
|
||||||
unsigned int gpp, gpp_offset;
|
unsigned int gpp, gpp_offset;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
void __iomem *reg;
|
void __iomem *reg, *is;
|
||||||
u32 value;
|
u32 value;
|
||||||
|
|
||||||
gpp = padgrp->reg_num;
|
gpp = padgrp->reg_num;
|
||||||
gpp_offset = padgroup_offset(padgrp, pin);
|
gpp_offset = padgroup_offset(padgrp, pin);
|
||||||
|
|
||||||
reg = community->regs + community->ie_offset + gpp * 4;
|
reg = community->regs + community->ie_offset + gpp * 4;
|
||||||
|
is = community->regs + community->is_offset + gpp * 4;
|
||||||
|
|
||||||
raw_spin_lock_irqsave(&pctrl->lock, flags);
|
raw_spin_lock_irqsave(&pctrl->lock, flags);
|
||||||
|
|
||||||
|
/* Clear interrupt status first to avoid unexpected interrupt */
|
||||||
|
writel(BIT(gpp_offset), is);
|
||||||
|
|
||||||
value = readl(reg);
|
value = readl(reg);
|
||||||
if (mask)
|
if (mask)
|
||||||
value &= ~BIT(gpp_offset);
|
value &= ~BIT(gpp_offset);
|
||||||
|
@ -1107,7 +1083,6 @@ static irqreturn_t intel_gpio_irq(int irq, void *data)
|
||||||
|
|
||||||
static struct irq_chip intel_gpio_irqchip = {
|
static struct irq_chip intel_gpio_irqchip = {
|
||||||
.name = "intel-gpio",
|
.name = "intel-gpio",
|
||||||
.irq_enable = intel_gpio_irq_enable,
|
|
||||||
.irq_ack = intel_gpio_irq_ack,
|
.irq_ack = intel_gpio_irq_ack,
|
||||||
.irq_mask = intel_gpio_irq_mask,
|
.irq_mask = intel_gpio_irq_mask,
|
||||||
.irq_unmask = intel_gpio_irq_unmask,
|
.irq_unmask = intel_gpio_irq_unmask,
|
||||||
|
|
Loading…
Reference in New Issue