1. 15 Dec, 2022 1 commit
    • Johan Hovold's avatar
      regulator: core: fix deadlock on regulator enable · cb3543cf
      Johan Hovold authored
      When updating the operating mode as part of regulator enable, the caller
      has already locked the regulator tree and drms_uA_update() must not try
      to do the same in order not to trigger a deadlock.
      
      The lock inversion is reported by lockdep as:
      
        ======================================================
        WARNING: possible circular locking dependency detected
        6.1.0-next-20221215 #142 Not tainted
        ------------------------------------------------------
        udevd/154 is trying to acquire lock:
        ffffc11f123d7e50 (regulator_list_mutex){+.+.}-{3:3}, at: regulator_lock_dependent+0x54/0x280
      
        but task is already holding lock:
        ffff80000e4c36e8 (regulator_ww_class_acquire){+.+.}-{0:0}, at: regulator_enable+0x34/0x80
      
        which lock already depends on the new lock.
      
        ...
      
         Possible unsafe locking scenario:
      
               CPU0                    CPU1
               ----                    ----
          lock(regulator_ww_class_acquire);
                                       lock(regulator_list_mutex);
                                       lock(regulator_ww_class_acquire);
          lock(regulator_list_mutex);
      
         *** DEADLOCK ***
      
      just before probe of a Qualcomm UFS controller (occasionally) deadlocks
      when enabling one of its regulators.
      
      Fixes: 9243a195 ("regulator: core: Change voltage setting path")
      Fixes: f8702f9e ("regulator: core: Use ww_mutex for regulators locking")
      Cc: stable@vger.kernel.org      # 5.0
      Signed-off-by: default avatarJohan Hovold <johan+linaro@kernel.org>
      Link: https://lore.kernel.org/r/20221215104646.19818-1-johan+linaro@kernel.orgSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      cb3543cf
  2. 14 Dec, 2022 1 commit
  3. 08 Dec, 2022 2 commits
  4. 07 Dec, 2022 1 commit
  5. 02 Dec, 2022 4 commits
  6. 01 Dec, 2022 2 commits
  7. 28 Nov, 2022 2 commits
  8. 25 Nov, 2022 1 commit
  9. 24 Nov, 2022 7 commits
  10. 23 Nov, 2022 15 commits
  11. 22 Nov, 2022 4 commits