Skip to content

Commit 709adbf

Browse files
westerigregkh
authored andcommitted
pinctrl: baytrail: Use raw_spinlock for locking
commit 78e1c89 upstream. The Intel Baytrail pinctrl driver implements irqchip callbacks which are called with desc->lock raw_spinlock held. In mainline this is fine because spinlock resolves to raw_spinlock. However, running the same code in -rt we get: BUG: sleeping function called from invalid context at kernel/locking/rtmutex.c:917 in_atomic(): 1, irqs_disabled(): 1, pid: 0, name: swapper/0 Preemption disabled at:[<ffffffff81092e9f>] cpu_startup_entry+0x17f/0x480 CPU: 0 PID: 0 Comm: swapper/0 Not tainted 4.1.5-rt5 #13 ... Call Trace: <IRQ> [<ffffffff816283c6>] dump_stack+0x4a/0x61 [<ffffffff81077e17>] ___might_sleep+0xe7/0x170 [<ffffffff8162d6cf>] rt_spin_lock+0x1f/0x50 [<ffffffff812e3b88>] byt_gpio_clear_triggering+0x38/0x60 [<ffffffff812e3bc1>] byt_irq_mask+0x11/0x20 [<ffffffff810a7013>] handle_level_irq+0x83/0x150 [<ffffffff810a3457>] generic_handle_irq+0x27/0x40 [<ffffffff812e3a5f>] byt_gpio_irq_handler+0x7f/0xc0 [<ffffffff810050aa>] handle_irq+0xaa/0x190 ... This is because in -rt spinlocks are preemptible so taking the driver private spinlock in irqchip callbacks causes might_sleep() to trigger. In order to keep -rt happy but at the same time make sure that register accesses get serialized, convert the driver to use raw_spinlock instead. Also shorten the critical section a bit in few places. Suggested-by: Linus Walleij <[email protected]> Signed-off-by: Mika Westerberg <[email protected]> Signed-off-by: Linus Walleij <[email protected]> Cc: Lucas De Marchi <[email protected]> Signed-off-by: Greg Kroah-Hartman <[email protected]>
1 parent 7b4744e commit 709adbf

File tree

1 file changed

+25
-25
lines changed

1 file changed

+25
-25
lines changed

drivers/pinctrl/intel/pinctrl-baytrail.c

Lines changed: 25 additions & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -146,7 +146,7 @@ struct byt_gpio_pin_context {
146146
struct byt_gpio {
147147
struct gpio_chip chip;
148148
struct platform_device *pdev;
149-
spinlock_t lock;
149+
raw_spinlock_t lock;
150150
void __iomem *reg_base;
151151
struct pinctrl_gpio_range *range;
152152
struct byt_gpio_pin_context *saved_context;
@@ -174,11 +174,11 @@ static void byt_gpio_clear_triggering(struct byt_gpio *vg, unsigned offset)
174174
unsigned long flags;
175175
u32 value;
176176

177-
spin_lock_irqsave(&vg->lock, flags);
177+
raw_spin_lock_irqsave(&vg->lock, flags);
178178
value = readl(reg);
179179
value &= ~(BYT_TRIG_POS | BYT_TRIG_NEG | BYT_TRIG_LVL);
180180
writel(value, reg);
181-
spin_unlock_irqrestore(&vg->lock, flags);
181+
raw_spin_unlock_irqrestore(&vg->lock, flags);
182182
}
183183

184184
static u32 byt_get_gpio_mux(struct byt_gpio *vg, unsigned offset)
@@ -203,7 +203,7 @@ static int byt_gpio_request(struct gpio_chip *chip, unsigned offset)
203203
u32 value, gpio_mux;
204204
unsigned long flags;
205205

206-
spin_lock_irqsave(&vg->lock, flags);
206+
raw_spin_lock_irqsave(&vg->lock, flags);
207207

208208
/*
209209
* In most cases, func pin mux 000 means GPIO function.
@@ -225,7 +225,7 @@ static int byt_gpio_request(struct gpio_chip *chip, unsigned offset)
225225
"pin %u forcibly re-configured as GPIO\n", offset);
226226
}
227227

228-
spin_unlock_irqrestore(&vg->lock, flags);
228+
raw_spin_unlock_irqrestore(&vg->lock, flags);
229229

230230
pm_runtime_get(&vg->pdev->dev);
231231

@@ -251,7 +251,7 @@ static int byt_irq_type(struct irq_data *d, unsigned type)
251251
if (offset >= vg->chip.ngpio)
252252
return -EINVAL;
253253

254-
spin_lock_irqsave(&vg->lock, flags);
254+
raw_spin_lock_irqsave(&vg->lock, flags);
255255
value = readl(reg);
256256

257257
WARN(value & BYT_DIRECT_IRQ_EN,
@@ -270,7 +270,7 @@ static int byt_irq_type(struct irq_data *d, unsigned type)
270270
else if (type & IRQ_TYPE_LEVEL_MASK)
271271
__irq_set_handler_locked(d->irq, handle_level_irq);
272272

273-
spin_unlock_irqrestore(&vg->lock, flags);
273+
raw_spin_unlock_irqrestore(&vg->lock, flags);
274274

275275
return 0;
276276
}
@@ -282,9 +282,9 @@ static int byt_gpio_get(struct gpio_chip *chip, unsigned offset)
282282
unsigned long flags;
283283
u32 val;
284284

285-
spin_lock_irqsave(&vg->lock, flags);
285+
raw_spin_lock_irqsave(&vg->lock, flags);
286286
val = readl(reg);
287-
spin_unlock_irqrestore(&vg->lock, flags);
287+
raw_spin_unlock_irqrestore(&vg->lock, flags);
288288

289289
return val & BYT_LEVEL;
290290
}
@@ -296,7 +296,7 @@ static void byt_gpio_set(struct gpio_chip *chip, unsigned offset, int value)
296296
unsigned long flags;
297297
u32 old_val;
298298

299-
spin_lock_irqsave(&vg->lock, flags);
299+
raw_spin_lock_irqsave(&vg->lock, flags);
300300

301301
old_val = readl(reg);
302302

@@ -305,7 +305,7 @@ static void byt_gpio_set(struct gpio_chip *chip, unsigned offset, int value)
305305
else
306306
writel(old_val & ~BYT_LEVEL, reg);
307307

308-
spin_unlock_irqrestore(&vg->lock, flags);
308+
raw_spin_unlock_irqrestore(&vg->lock, flags);
309309
}
310310

311311
static int byt_gpio_direction_input(struct gpio_chip *chip, unsigned offset)
@@ -315,13 +315,13 @@ static int byt_gpio_direction_input(struct gpio_chip *chip, unsigned offset)
315315
unsigned long flags;
316316
u32 value;
317317

318-
spin_lock_irqsave(&vg->lock, flags);
318+
raw_spin_lock_irqsave(&vg->lock, flags);
319319

320320
value = readl(reg) | BYT_DIR_MASK;
321321
value &= ~BYT_INPUT_EN; /* active low */
322322
writel(value, reg);
323323

324-
spin_unlock_irqrestore(&vg->lock, flags);
324+
raw_spin_unlock_irqrestore(&vg->lock, flags);
325325

326326
return 0;
327327
}
@@ -335,7 +335,7 @@ static int byt_gpio_direction_output(struct gpio_chip *chip,
335335
unsigned long flags;
336336
u32 reg_val;
337337

338-
spin_lock_irqsave(&vg->lock, flags);
338+
raw_spin_lock_irqsave(&vg->lock, flags);
339339

340340
/*
341341
* Before making any direction modifications, do a check if gpio
@@ -354,7 +354,7 @@ static int byt_gpio_direction_output(struct gpio_chip *chip,
354354
else
355355
writel(reg_val & ~BYT_LEVEL, reg);
356356

357-
spin_unlock_irqrestore(&vg->lock, flags);
357+
raw_spin_unlock_irqrestore(&vg->lock, flags);
358358

359359
return 0;
360360
}
@@ -363,18 +363,19 @@ static void byt_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip)
363363
{
364364
struct byt_gpio *vg = to_byt_gpio(chip);
365365
int i;
366-
unsigned long flags;
367366
u32 conf0, val, offs;
368367

369-
spin_lock_irqsave(&vg->lock, flags);
370-
371368
for (i = 0; i < vg->chip.ngpio; i++) {
372369
const char *pull_str = NULL;
373370
const char *pull = NULL;
371+
unsigned long flags;
374372
const char *label;
375373
offs = vg->range->pins[i] * 16;
374+
375+
raw_spin_lock_irqsave(&vg->lock, flags);
376376
conf0 = readl(vg->reg_base + offs + BYT_CONF0_REG);
377377
val = readl(vg->reg_base + offs + BYT_VAL_REG);
378+
raw_spin_unlock_irqrestore(&vg->lock, flags);
378379

379380
label = gpiochip_is_requested(chip, i);
380381
if (!label)
@@ -427,7 +428,6 @@ static void byt_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip)
427428

428429
seq_puts(s, "\n");
429430
}
430-
spin_unlock_irqrestore(&vg->lock, flags);
431431
}
432432

433433
static void byt_gpio_irq_handler(unsigned irq, struct irq_desc *desc)
@@ -459,10 +459,10 @@ static void byt_irq_ack(struct irq_data *d)
459459
unsigned offset = irqd_to_hwirq(d);
460460
void __iomem *reg;
461461

462-
spin_lock(&vg->lock);
462+
raw_spin_lock(&vg->lock);
463463
reg = byt_gpio_reg(&vg->chip, offset, BYT_INT_STAT_REG);
464464
writel(BIT(offset % 32), reg);
465-
spin_unlock(&vg->lock);
465+
raw_spin_unlock(&vg->lock);
466466
}
467467

468468
static void byt_irq_unmask(struct irq_data *d)
@@ -474,9 +474,9 @@ static void byt_irq_unmask(struct irq_data *d)
474474
void __iomem *reg;
475475
u32 value;
476476

477-
spin_lock_irqsave(&vg->lock, flags);
478-
479477
reg = byt_gpio_reg(&vg->chip, offset, BYT_CONF0_REG);
478+
479+
raw_spin_lock_irqsave(&vg->lock, flags);
480480
value = readl(reg);
481481

482482
switch (irqd_get_trigger_type(d)) {
@@ -497,7 +497,7 @@ static void byt_irq_unmask(struct irq_data *d)
497497

498498
writel(value, reg);
499499

500-
spin_unlock_irqrestore(&vg->lock, flags);
500+
raw_spin_unlock_irqrestore(&vg->lock, flags);
501501
}
502502

503503
static void byt_irq_mask(struct irq_data *d)
@@ -589,7 +589,7 @@ static int byt_gpio_probe(struct platform_device *pdev)
589589
if (IS_ERR(vg->reg_base))
590590
return PTR_ERR(vg->reg_base);
591591

592-
spin_lock_init(&vg->lock);
592+
raw_spin_lock_init(&vg->lock);
593593

594594
gc = &vg->chip;
595595
gc->label = dev_name(&pdev->dev);

0 commit comments

Comments
 (0)