Re: [PATCH REPOST] gpio: omap: use raw locks for locking

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Fri, Jun 19, 2015 at 7:42 PM, santosh shilimkar
<santosh.shilimkar@xxxxxxxxxx> wrote:
> On 6/19/2015 10:06 AM, Sebastian Andrzej Siewior wrote:
>>
>> This patch converts gpio_bank.lock from a spin_lock into a
>> raw_spin_lock. The call path is to access this lock is always under a
>> raw_spin_lock, for instance
>> - __setup_irq() holds &desc->lock with irq off
>>    + __irq_set_trigger()
>>     + omap_gpio_irq_type()
>>
>> - handle_level_irq() (runs with irqs off therefore raw locks)
>>    + mask_ack_irq()
>>     + omap_gpio_mask_irq()
>>
>> This fixes the obvious backtrace on -RT. However the locking vs context
>> is not and this is not limited to -RT:
>> - omap_gpio_irq_type() is called with IRQ off and has an conditional
>>    call to pm_runtime_get_sync() which may sleep. Either it may happen or
>>    it may not happen but pm_runtime_get_sync() should not be called with
>>    irqs off.
>>
>> - omap_gpio_debounce() is holding the lock with IRQs off.
>>    + omap2_set_gpio_debounce()
>>     + clk_prepare_enable()
>>      + clk_prepare() this one might sleep.
>>    The number of users of gpiod_set_debounce() / gpio_set_debounce()
>>    looks low but still this is not good.
>>
>> Signed-off-by: Sebastian Andrzej Siewior <bigeasy@xxxxxxxxxxxxx>
>> ---
>
> Should be safe to do it.
> Acked-by: Santosh Shilimkar <ssantosh@xxxxxxxxxx>
>

Answered on the wrong thread, sorry for the noise.

Acked-by: Javier Martinez Canillas <javier@xxxxxxxxxxxx>

Best regards,
Javier
--
To unsubscribe from this list: send the line "unsubscribe linux-gpio" in



[Index of Archives]     [Linux SPI]     [Linux Kernel]     [Linux ARM (vger)]     [Linux ARM MSM]     [Linux Omap]     [Linux Arm]     [Linux Tegra]     [Fedora ARM]     [Linux for Samsung SOC]     [eCos]     [Linux Fastboot]     [Gcc Help]     [Git]     [DCCP]     [IETF Announce]     [Security]     [Linux MIPS]     [Yosemite Campsites]

  Powered by Linux