1. 23 4月, 2020 1 次提交
  2. 01 4月, 2020 1 次提交
  3. 31 3月, 2020 1 次提交
  4. 28 3月, 2020 4 次提交
  5. 27 3月, 2020 1 次提交
  6. 25 3月, 2020 1 次提交
  7. 20 3月, 2020 1 次提交
  8. 11 3月, 2020 1 次提交
    • L
      gpiolib: Fix irq_disable() semantics · 8959b304
      Linus Walleij 提交于
      The implementation if .irq_disable() which kicks in between
      the gpiolib and the driver is not properly mimicking the
      expected semantics of the irqchip core: the irqchip will
      call .irq_disable() if that exists, else it will call
      mask_irq() which first checks if .irq_mask() is defined
      before calling it.
      
      Since we are calling it unconditionally, we get this bug
      from drivers/pinctrl/qcom/pinctrl-ssbi-gpio.c, as it only
      defines .irq_mask_ack and not .irq_mask:
      
        Unable to handle kernel NULL pointer dereference at virtual address 00000000
        pgd = (ptrval)
        (...)
        PC is at 0x0
        LR is at gpiochip_irq_disable+0x20/0x30
      
      Fix this by only calling .irq_mask() if it exists.
      
      Cc: Brian Masney <masneyb@onstation.org>
      Cc: Hans Verkuil <hans.verkuil@cisco.com>
      Cc: stable@vger.kernel.org
      Reviewed-by: NBartosz Golaszewski <bgolaszewski@baylibre.com>
      Fixes: 461c1a7d ("gpiolib: override irq_enable/disable")
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      Link: https://lore.kernel.org/r/20200306132326.1329640-1-linus.walleij@linaro.org
      8959b304
  9. 03 3月, 2020 1 次提交
  10. 02 3月, 2020 3 次提交
  11. 29 2月, 2020 1 次提交
  12. 25 2月, 2020 1 次提交
  13. 22 2月, 2020 1 次提交
  14. 21 2月, 2020 2 次提交
  15. 12 2月, 2020 4 次提交
  16. 10 2月, 2020 4 次提交
  17. 04 2月, 2020 1 次提交
  18. 23 1月, 2020 3 次提交
  19. 17 1月, 2020 1 次提交
  20. 15 1月, 2020 4 次提交
    • Y
      gpiolib: remove set but not used variable 'config' · e5e42ad2
      YueHaibing 提交于
      drivers/gpio/gpiolib.c: In function gpio_set_config:
      drivers/gpio/gpiolib.c:3053:16: warning:
       variable config set but not used [-Wunused-but-set-variable]
      
      commit d90f3685 ("gpiolib: have a single place
      of calling set_config()") left behind this unused variable.
      Reported-by: NHulk Robot <hulkci@huawei.com>
      Signed-off-by: NYueHaibing <yuehaibing@huawei.com>
      Link: https://lore.kernel.org/r/20200108121117.45060-1-yuehaibing@huawei.comReviewed-by: NBartosz Golaszewski <bgolaszewski@baylibre.com>
      Signed-off-by: NLinus Walleij <linus.walleij@linaro.org>
      e5e42ad2
    • S
      gpiolib: Set lockdep class for hierarchical irq domains · c34f6dc8
      Stephen Boyd 提交于
      I see the following lockdep splat in the qcom pinctrl driver when
      attempting to suspend the device.
      
       ============================================
       WARNING: possible recursive locking detected
       5.4.2 #2 Tainted: G S
       --------------------------------------------
       cat/6536 is trying to acquire lock:
       ffffff814787ccc0 (&irq_desc_lock_class){-.-.}, at: __irq_get_desc_lock+0x64/0x94
      
       but task is already holding lock:
       ffffff81436740c0 (&irq_desc_lock_class){-.-.}, at: __irq_get_desc_lock+0x64/0x94
      
       other info that might help us debug this:
        Possible unsafe locking scenario:
      
              CPU0
              ----
         lock(&irq_desc_lock_class);
         lock(&irq_desc_lock_class);
      
        *** DEADLOCK ***
      
        May be due to missing lock nesting notation
      
       7 locks held by cat/6536:
        #0: ffffff8140e0c420 (sb_writers#7){.+.+}, at: vfs_write+0xc8/0x19c
        #1: ffffff8121eec480 (&of->mutex){+.+.}, at: kernfs_fop_write+0x128/0x1f4
        #2: ffffff8147cad668 (kn->count#263){.+.+}, at: kernfs_fop_write+0x130/0x1f4
        #3: ffffffd011446000 (system_transition_mutex){+.+.}, at: pm_suspend+0x108/0x354
        #4: ffffff814302b970 (&dev->mutex){....}, at: __device_suspend+0x16c/0x420
        #5: ffffff81436740c0 (&irq_desc_lock_class){-.-.}, at: __irq_get_desc_lock+0x64/0x94
        #6: ffffff81479b8c10 (&pctrl->lock){....}, at: msm_gpio_irq_set_wake+0x48/0x7c
      
       stack backtrace:
       CPU: 4 PID: 6536 Comm: cat Tainted: G S                5.4.2 #2
       Call trace:
        dump_backtrace+0x0/0x174
        show_stack+0x20/0x2c
        dump_stack+0xdc/0x144
        __lock_acquire+0x52c/0x2268
        lock_acquire+0x1dc/0x220
        _raw_spin_lock_irqsave+0x64/0x80
        __irq_get_desc_lock+0x64/0x94
        irq_set_irq_wake+0x40/0x144
        msm_gpio_irq_set_wake+0x5c/0x7c
        set_irq_wake_real+0x40/0x5c
        irq_set_irq_wake+0x70/0x144
        cros_ec_rtc_suspend+0x38/0x4c
        platform_pm_suspend+0x34/0x60
        dpm_run_callback+0x64/0xcc
        __device_suspend+0x314/0x420
        dpm_suspend+0xf8/0x298
        dpm_suspend_start+0x84/0xb4
        suspend_devices_and_enter+0xbc/0x628
        pm_suspend+0x214/0x354
        state_store+0xb0/0x108
        kobj_attr_store+0x14/0x24
        sysfs_kf_write+0x4c/0x64
        kernfs_fop_write+0x158/0x1f4
        __vfs_write+0x54/0x18c
        vfs_write+0xdc/0x19c
        ksys_write+0x7c/0xe4
        __arm64_sys_write+0x20/0x2c
        el0_svc_common+0xa8/0x160
        el0_svc_compat_handler+0x2c/0x38
        el0_svc_compat+0x8/0x10
      
      This is because the msm_gpio_irq_set_wake() function calls
      irq_set_irq_wake() as a backup in case the irq comes in during the path
      to idle. Given that we're calling irqchip functions from within an
      irqchip we need to set the lockdep class to be different for this child
      controller vs. the default one that the parent irqchip gets.
      
      This used to be done before this driver was converted to hierarchical
      irq domains in commit e35a6ae0 ("pinctrl/msm: Setup GPIO chip in
      hierarchy") via the gpiochip_irq_map() function. With hierarchical irq
      domains this function has been replaced by
      gpiochip_hierarchy_irq_domain_alloc(). Therefore, set the lockdep class
      like was done previously in the irq domain path so we can avoid this
      lockdep warning.
      
      Fixes: fdd61a01 ("gpio: Add support for hierarchical IRQ domains")
      Cc: Thierry Reding <treding@nvidia.com>
      Cc: Brian Masney <masneyb@onstation.org>
      Cc: Lina Iyer <ilina@codeaurora.org>
      Cc: Marc Zyngier <maz@kernel.org>
      Cc: Maulik Shah <mkshah@codeaurora.org>
      Signed-off-by: NStephen Boyd <swboyd@chromium.org>
      Link: https://lore.kernel.org/r/20200114231103.85641-1-swboyd@chromium.orgSigned-off-by: NLinus Walleij <linus.walleij@linaro.org>
      c34f6dc8
    • K
      gpiolib: Add the support for the msi parent domain · 880b7cf2
      Kevin Hao 提交于
      If the gpio's parent irqdomain is a msi irqdomain, we should ignore
      the EEXIST error returned by the msi irqdomain because all the msi
      interrupts have already been allocated.
      Signed-off-by: NKevin Hao <haokexin@gmail.com>
      Link: https://lore.kernel.org/r/20200114082821.14015-4-haokexin@gmail.comSigned-off-by: NLinus Walleij <linus.walleij@linaro.org>
      880b7cf2
    • K
      gpiolib: Add support for the irqdomain which doesn't use irq_fwspec as arg · 24258761
      Kevin Hao 提交于
      Some gpio's parent irqdomain may not use the struct irq_fwspec as
      argument, such as msi irqdomain. So rename the callback
      populate_parent_fwspec() to populate_parent_alloc_arg() and make it
      allocate and populate the specific struct which is needed by the
      parent irqdomain.
      Signed-off-by: NKevin Hao <haokexin@gmail.com>
      Link: https://lore.kernel.org/r/20200114082821.14015-3-haokexin@gmail.comSigned-off-by: NLinus Walleij <linus.walleij@linaro.org>
      24258761
  21. 07 1月, 2020 3 次提交