Loading drivers/regulator/core.c +10 −2 Original line number Original line Diff line number Diff line Loading @@ -2396,6 +2396,14 @@ static void regulator_disable_work(struct work_struct *work) count = rdev->deferred_disables; count = rdev->deferred_disables; rdev->deferred_disables = 0; rdev->deferred_disables = 0; /* * Workqueue functions queue the new work instance while the previous * work instance is being processed. Cancel the queued work instance * as the work instance under processing does the job of the queued * work instance. */ cancel_delayed_work(&rdev->disable_work); for (i = 0; i < count; i++) { for (i = 0; i < count; i++) { ret = _regulator_disable(rdev); ret = _regulator_disable(rdev); if (ret != 0) if (ret != 0) Loading Loading @@ -2439,10 +2447,10 @@ int regulator_disable_deferred(struct regulator *regulator, int ms) mutex_lock(&rdev->mutex); mutex_lock(&rdev->mutex); rdev->deferred_disables++; rdev->deferred_disables++; mod_delayed_work(system_power_efficient_wq, &rdev->disable_work, msecs_to_jiffies(ms)); mutex_unlock(&rdev->mutex); mutex_unlock(&rdev->mutex); queue_delayed_work(system_power_efficient_wq, &rdev->disable_work, msecs_to_jiffies(ms)); return 0; return 0; } } EXPORT_SYMBOL_GPL(regulator_disable_deferred); EXPORT_SYMBOL_GPL(regulator_disable_deferred); Loading Loading
drivers/regulator/core.c +10 −2 Original line number Original line Diff line number Diff line Loading @@ -2396,6 +2396,14 @@ static void regulator_disable_work(struct work_struct *work) count = rdev->deferred_disables; count = rdev->deferred_disables; rdev->deferred_disables = 0; rdev->deferred_disables = 0; /* * Workqueue functions queue the new work instance while the previous * work instance is being processed. Cancel the queued work instance * as the work instance under processing does the job of the queued * work instance. */ cancel_delayed_work(&rdev->disable_work); for (i = 0; i < count; i++) { for (i = 0; i < count; i++) { ret = _regulator_disable(rdev); ret = _regulator_disable(rdev); if (ret != 0) if (ret != 0) Loading Loading @@ -2439,10 +2447,10 @@ int regulator_disable_deferred(struct regulator *regulator, int ms) mutex_lock(&rdev->mutex); mutex_lock(&rdev->mutex); rdev->deferred_disables++; rdev->deferred_disables++; mod_delayed_work(system_power_efficient_wq, &rdev->disable_work, msecs_to_jiffies(ms)); mutex_unlock(&rdev->mutex); mutex_unlock(&rdev->mutex); queue_delayed_work(system_power_efficient_wq, &rdev->disable_work, msecs_to_jiffies(ms)); return 0; return 0; } } EXPORT_SYMBOL_GPL(regulator_disable_deferred); EXPORT_SYMBOL_GPL(regulator_disable_deferred); Loading