1. 17 8月, 2020 3 次提交
    • M
      regulator: push allocations in create_regulator() outside of lock · 87fe29b6
      Michał Mirosław 提交于
      Move all allocations outside of the regulator_lock()ed section.
      
      ======================================================
      WARNING: possible circular locking dependency detected
      5.7.13+ #535 Not tainted
      ------------------------------------------------------
      f2fs_discard-179:7/702 is trying to acquire lock:
      c0e5d920 (regulator_list_mutex){+.+.}-{3:3}, at: regulator_lock_dependent+0x54/0x2c0
      
      but task is already holding lock:
      cb95b080 (&dcc->cmd_lock){+.+.}-{3:3}, at: __issue_discard_cmd+0xec/0x5f8
      
      which lock already depends on the new lock.
      
      the existing dependency chain (in reverse order) is:
      
      [...]
      
      -> #3 (fs_reclaim){+.+.}-{0:0}:
             fs_reclaim_acquire.part.11+0x40/0x50
             fs_reclaim_acquire+0x24/0x28
             __kmalloc_track_caller+0x54/0x218
             kstrdup+0x40/0x5c
             create_regulator+0xf4/0x368
             regulator_resolve_supply+0x1a0/0x200
             regulator_register+0x9c8/0x163c
      
      [...]
      
      other info that might help us debug this:
      
      Chain exists of:
        regulator_list_mutex --> &sit_i->sentry_lock --> &dcc->cmd_lock
      
      [...]
      
      Fixes: f8702f9e ("regulator: core: Use ww_mutex for regulators locking")
      Signed-off-by: NMichał Mirosław <mirq-linux@rere.qmqm.pl>
      Cc: stable@vger.kernel.org
      Link: https://lore.kernel.org/r/6eebc99b2474f4ffaa0405b15178ece0e7e4f608.1597195321.git.mirq-linux@rere.qmqm.plSigned-off-by: NMark Brown <broonie@kernel.org>
      87fe29b6
    • M
      regulator: push allocation in regulator_ena_gpio_request() out of lock · 467bf301
      Michał Mirosław 提交于
      Move another allocation out of regulator_list_mutex-protected region, as
      reclaim might want to take the same lock.
      
      WARNING: possible circular locking dependency detected
      5.7.13+ #534 Not tainted
      ------------------------------------------------------
      kswapd0/383 is trying to acquire lock:
      c0e5d920 (regulator_list_mutex){+.+.}-{3:3}, at: regulator_lock_dependent+0x54/0x2c0
      
      but task is already holding lock:
      c0e38518 (fs_reclaim){+.+.}-{0:0}, at: __fs_reclaim_acquire+0x0/0x50
      
      which lock already depends on the new lock.
      
      the existing dependency chain (in reverse order) is:
      
      -> #1 (fs_reclaim){+.+.}-{0:0}:
             fs_reclaim_acquire.part.11+0x40/0x50
             fs_reclaim_acquire+0x24/0x28
             kmem_cache_alloc_trace+0x40/0x1e8
             regulator_register+0x384/0x1630
             devm_regulator_register+0x50/0x84
             reg_fixed_voltage_probe+0x248/0x35c
      [...]
      other info that might help us debug this:
      
       Possible unsafe locking scenario:
      
             CPU0                    CPU1
             ----                    ----
        lock(fs_reclaim);
                                     lock(regulator_list_mutex);
                                     lock(fs_reclaim);
        lock(regulator_list_mutex);
      
       *** DEADLOCK ***
      [...]
      2 locks held by kswapd0/383:
       #0: c0e38518 (fs_reclaim){+.+.}-{0:0}, at: __fs_reclaim_acquire+0x0/0x50
       #1: cb70e5e0 (hctx->srcu){....}-{0:0}, at: hctx_lock+0x60/0xb8
      [...]
      
      Fixes: 541d052d ("regulator: core: Only support passing enable GPIO descriptors")
      [this commit only changes context]
      Fixes: f8702f9e ("regulator: core: Use ww_mutex for regulators locking")
      [this is when the regulator_list_mutex was introduced in reclaim locking path]
      Signed-off-by: NMichał Mirosław <mirq-linux@rere.qmqm.pl>
      Link: https://lore.kernel.org/r/41fe6a9670335721b48e8f5195038c3d67a3bf92.1597195321.git.mirq-linux@rere.qmqm.plSigned-off-by: NMark Brown <broonie@kernel.org>
      467bf301
    • M
      regulator: push allocation in regulator_init_coupling() outside of lock · 73a32129
      Michał Mirosław 提交于
      Allocating memory with regulator_list_mutex held makes lockdep unhappy
      when memory pressure makes the system do fs_reclaim on eg. eMMC using
      a regulator. Push the lock inside regulator_init_coupling() after the
      allocation.
      
      ======================================================
      WARNING: possible circular locking dependency detected
      5.7.13+ #533 Not tainted
      ------------------------------------------------------
      kswapd0/383 is trying to acquire lock:
      cca78ca4 (&sbi->write_io[i][j].io_rwsem){++++}-{3:3}, at: __submit_merged_write_cond+0x104/0x154
      but task is already holding lock:
      c0e38518 (fs_reclaim){+.+.}-{0:0}, at: __fs_reclaim_acquire+0x0/0x50
      which lock already depends on the new lock.
      the existing dependency chain (in reverse order) is:
      -> #2 (fs_reclaim){+.+.}-{0:0}:
             fs_reclaim_acquire.part.11+0x40/0x50
             fs_reclaim_acquire+0x24/0x28
             __kmalloc+0x54/0x218
             regulator_register+0x860/0x1584
             dummy_regulator_probe+0x60/0xa8
      [...]
      other info that might help us debug this:
      
      Chain exists of:
        &sbi->write_io[i][j].io_rwsem --> regulator_list_mutex --> fs_reclaim
      
      Possible unsafe locking scenario:
      
             CPU0                    CPU1
             ----                    ----
        lock(fs_reclaim);
                                     lock(regulator_list_mutex);
                                     lock(fs_reclaim);
        lock(&sbi->write_io[i][j].io_rwsem);
       *** DEADLOCK ***
      
      1 lock held by kswapd0/383:
       #0: c0e38518 (fs_reclaim){+.+.}-{0:0}, at: __fs_reclaim_acquire+0x0/0x50
      [...]
      
      Fixes: d8ca7d18 ("regulator: core: Introduce API for regulators coupling customization")
      Signed-off-by: NMichał Mirosław <mirq-linux@rere.qmqm.pl>
      Reviewed-by: NDmitry Osipenko <digetx@gmail.com>
      Cc: stable@vger.kernel.org
      Link: https://lore.kernel.org/r/1a889cf7f61c6429c9e6b34ddcdde99be77a26b6.1597195321.git.mirq-linux@rere.qmqm.plSigned-off-by: NMark Brown <broonie@kernel.org>
      73a32129
  2. 24 7月, 2020 1 次提交
    • V
      regulator: fix memory leak on error path of regulator_register() · 9177514c
      Vladimir Zapolskiy 提交于
      The change corrects registration and deregistration on error path
      of a regulator, the problem was manifested by a reported memory
      leak on deferred probe:
      
          as3722-regulator as3722-regulator: regulator 13 register failed -517
      
          # cat /sys/kernel/debug/kmemleak
          unreferenced object 0xecc43740 (size 64):
            comm "swapper/0", pid 1, jiffies 4294937640 (age 712.880s)
            hex dump (first 32 bytes):
              72 65 67 75 6c 61 74 6f 72 2e 32 34 00 5a 5a 5a  regulator.24.ZZZ
              5a 5a 5a 5a 5a 5a 5a 5a 5a 5a 5a 5a 5a 5a 5a 5a  ZZZZZZZZZZZZZZZZ
            backtrace:
              [<0c4c3d1c>] __kmalloc_track_caller+0x15c/0x2c0
              [<40c0ad48>] kvasprintf+0x64/0xd4
              [<109abd29>] kvasprintf_const+0x70/0x84
              [<c4215946>] kobject_set_name_vargs+0x34/0xa8
              [<62282ea2>] dev_set_name+0x40/0x64
              [<a39b6757>] regulator_register+0x3a4/0x1344
              [<16a9543f>] devm_regulator_register+0x4c/0x84
              [<51a4c6a1>] as3722_regulator_probe+0x294/0x754
              ...
      
      The memory leak problem was introduced as a side ef another fix in
      regulator_register() error path, I believe that the proper fix is
      to decouple device_register() function into its two compounds and
      initialize a struct device before assigning any values to its fields
      and then using it before actual registration of a device happens.
      
      This lets to call put_device() safely after initialization, and, since
      now a release callback is called, kfree(rdev->constraints) shall be
      removed to exclude a double free condition.
      
      Fixes: a3cde953 ("regulator: core: fix regulator_register() error paths to properly release rdev")
      Signed-off-by: NVladimir Zapolskiy <vz@mleia.com>
      Cc: Wen Yang <wenyang@linux.alibaba.com>
      Link: https://lore.kernel.org/r/20200724005013.23278-1-vz@mleia.comSigned-off-by: NMark Brown <broonie@kernel.org>
      9177514c
  3. 20 7月, 2020 1 次提交
  4. 15 7月, 2020 1 次提交
  5. 30 5月, 2020 1 次提交
  6. 29 5月, 2020 1 次提交
  7. 30 4月, 2020 1 次提交
  8. 14 4月, 2020 1 次提交
  9. 14 3月, 2020 1 次提交
  10. 05 3月, 2020 1 次提交
    • J
      regulator: Use driver_deferred_probe_timeout for regulator_init_complete_work · dca0b449
      John Stultz 提交于
      The regulator_init_complete_work logic defers the cleanup for an
      arbitrary 30 seconds of time to allow modules loaded by userland
      to start.
      
      This arbitrary timeout is similar to the
      driver_deferred_probe_timeout value, and its been suggested we
      align these so users have a method to extend the timeouts as
      needed.
      
      So this patch changes the logic to use the
      driver_deferred_probe_timeout value for the delay value if it
      is set (using a delay of 0 if it is not).
      
      Cc: linux-pm@vger.kernel.org
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Cc: Linus Walleij <linus.walleij@linaro.org>
      Cc: Thierry Reding <treding@nvidia.com>
      Cc: Mark Brown <broonie@kernel.org>
      Cc: Liam Girdwood <lgirdwood@gmail.com>
      Cc: Bjorn Andersson <bjorn.andersson@linaro.org>
      Cc: Saravana Kannan <saravanak@google.com>
      Cc: Todd Kjos <tkjos@google.com>
      Cc: Len Brown <len.brown@intel.com>
      Cc: Pavel Machek <pavel@ucw.cz>
      Cc: Ulf Hansson <ulf.hansson@linaro.org>
      Cc: Kevin Hilman <khilman@kernel.org>
      Cc: "Rafael J. Wysocki" <rjw@rjwysocki.net>
      Cc: Rob Herring <robh@kernel.org>
      Acked-by: NMark Brown <broonie@kernel.org>
      Signed-off-by: NJohn Stultz <john.stultz@linaro.org>
      Link: https://lore.kernel.org/r/20200225050828.56458-7-john.stultz@linaro.orgSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      dca0b449
  11. 21 1月, 2020 1 次提交
  12. 17 1月, 2020 1 次提交
  13. 10 12月, 2019 1 次提交
    • C
      regulator: core: avoid unneeded .list_voltage calls · 6d30fc51
      Cristian Marussi 提交于
      Inside machine_constraints_voltage() a loop is in charge of verifying that
      each of the defined voltages are within the configured constraints and
      that those constraints are in fact compatible with the available voltages'
      list.
      
      When the registered regulator happens to be defined with a wide range of
      possible voltages the above O(n) loop can be costly.
      Moreover since this behaviour is triggered during the registration process,
      it means also that it can be easily triggered at probe time, slowing down
      considerably some module loading.
      
      On the other side if such wide range of voltage values happens to be also
      continuous and without discontinuity of any kind, the above potentially
      cumbersome operation is also useless.
      
      For these reasons, avoid such .list_voltage poll loop when regulator is
      described as 'continuous_voltage_range' as is, indeed, similarly already
      done inside regulator_is_supported_voltage().
      Signed-off-by: NCristian Marussi <cristian.marussi@arm.com>
      Link: https://lore.kernel.org/r/20191209125239.46054-1-cristian.marussi@arm.comSigned-off-by: NMark Brown <broonie@kernel.org>
      6d30fc51
  14. 03 12月, 2019 1 次提交
  15. 27 11月, 2019 1 次提交
  16. 15 11月, 2019 2 次提交
  17. 28 10月, 2019 2 次提交
  18. 17 9月, 2019 1 次提交
  19. 11 9月, 2019 1 次提交
  20. 04 9月, 2019 1 次提交
    • M
      regulator: Defer init completion for a while after late_initcall · 55576cf1
      Mark Brown 提交于
      The kernel has no way of knowing when we have finished instantiating
      drivers, between deferred probe and systems that build key drivers as
      modules we might be doing this long after userspace has booted. This has
      always been a bit of an issue with regulator_init_complete since it can
      power off hardware that's not had it's driver loaded which can result in
      user visible effects, the main case is powering off displays. Practically
      speaking it's not been an issue in real systems since most systems that
      use the regulator API are embedded and build in key drivers anyway but
      with Arm laptops coming on the market it's becoming more of an issue so
      let's do something about it.
      
      In the absence of any better idea just defer the powering off for 30s
      after late_initcall(), this is obviously a hack but it should mask the
      issue for now and it's no more arbitrary than late_initcall() itself.
      Ideally we'd have some heuristics to detect if we're on an affected
      system and tune or skip the delay appropriately, and there may be some
      need for a command line option to be added.
      
      Link: https://lore.kernel.org/r/20190904124250.25844-1-broonie@kernel.orgSigned-off-by: NMark Brown <broonie@kernel.org>
      Tested-by: NLee Jones <lee.jones@linaro.org>
      Cc: stable@vger.kernel.org
      55576cf1
  21. 16 8月, 2019 1 次提交
  22. 05 8月, 2019 1 次提交
  23. 05 7月, 2019 1 次提交
  24. 25 6月, 2019 2 次提交
  25. 19 6月, 2019 1 次提交
  26. 15 6月, 2019 1 次提交
  27. 31 5月, 2019 1 次提交
  28. 08 5月, 2019 1 次提交
  29. 03 5月, 2019 1 次提交
  30. 26 4月, 2019 2 次提交
  31. 05 4月, 2019 1 次提交
    • C
      regulator: core: Avoid potential deadlock on regulator_unregister · 06377301
      Charles Keepax 提交于
      Lockdep reports the following issue on my setup:
      
      Possible unsafe locking scenario:
      
      CPU0                    CPU1
      ----                    ----
      lock((work_completion)(&(&rdev->disable_work)->work));
                              lock(regulator_list_mutex);
                              lock((work_completion)(&(&rdev->disable_work)->work));
      lock(regulator_list_mutex);
      
      The problem is that regulator_unregister takes the
      regulator_list_mutex and then calls flush_work on disable_work. But
      regulator_disable_work calls regulator_lock_dependent which will
      also take the regulator_list_mutex. Resulting in a deadlock if the
      flush_work call actually needs to flush the work.
      
      Fix this issue by moving the flush_work outside of the
      regulator_list_mutex. The list mutex is not used to guard the point at
      which the delayed work is queued, so its use adds no additional safety.
      
      Fixes: f8702f9e ("regulator: core: Use ww_mutex for regulators locking")
      Signed-off-by: NCharles Keepax <ckeepax@opensource.cirrus.com>
      Reviewed-by: NDmitry Osipenko <digetx@gmail.com>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      06377301
  32. 19 3月, 2019 1 次提交
    • S
      regulator: core: fix error path for regulator_set_voltage_unlocked · 70b46491
      Steve Twiss 提交于
      During several error paths in the function
      regulator_set_voltage_unlocked() the value of 'ret' can take on negative
      error values. However, in calls that go through the 'goto out' statement,
      this return value is lost and return 0 is used instead, indicating a
      'pass'.
      
      There are several cases where this function should legitimately return a
      fail instead of a pass: one such case includes constraints check during
      voltage selection in the call to regulator_check_voltage(), which can
      have -EINVAL for the case when an unsupported voltage is incorrectly
      requested. In that case, -22 is expected as the return value, not 0.
      
      Fixes: 9243a195 ("regulator: core: Change voltage setting path")
      Cc: stable <stable@vger.kernel.org>
      Signed-off-by: NSteve Twiss <stwiss.opensource@diasemi.com>
      Reviewed-by: NDmitry Osipenko <digetx@gmail.com>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      70b46491
  33. 18 3月, 2019 1 次提交
    • M
      regulator: core: Fix application of "drop lockdep annotation in drms_uA_update()" · a48f1275
      Mark Brown 提交于
      [The original commit was sent against -next but needed to be sent as a
      bugfix, however -next had some additional changes which needed to be
      reverted.  Now everything is all in one branch applying the rest of the
      changes to fix up the merge issue -- broonie]
      
      commit e5e21f70 ("regulator: core: Take lock before applying system
      load") took the regulator lock before calling drms_uA_update() in order
      to silence a lockdep warning during regulator_register().
      
      However, we are not supposed to need locks at this point as the regulator
      is in the process of being registered, so there should be no possibility
      of concurrent access.
      
      Instead, remove the unnecessary locking and simply drop the lockdep
      annotation, since it is no longer valid.
      
      Fixes: e5e21f70 ("regulator: core: Take lock before applying system load")
      Signed-off-by: NNiklas Cassel <niklas.cassel@linaro.org>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      a48f1275
  34. 22 2月, 2019 1 次提交