Commit 930bd77e authored by Manivannan Sadhasivam's avatar Manivannan Sadhasivam Committed by Martin K. Petersen

scsi: ufs: core: Add OPP support for scaling clocks and regulators

UFS core is only scaling the clocks during devfreq scaling and
initialization. But for an optimum power saving, regulators should also be
scaled along with the clocks.

So let's use the OPP framework which supports scaling clocks, regulators,
and performance state using OPP table defined in devicetree. For
accomodating the OPP support, the existing APIs (ufshcd_scale_clks,
ufshcd_is_devfreq_scaling_required and ufshcd_devfreq_scale) are modified
to accept "freq" as an argument which in turn used by the OPP helpers.

The OPP support is added along with the old freq-table based clock scaling
so that the existing platforms work as expected.
Co-developed-by: default avatarKrzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Signed-off-by: default avatarKrzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Signed-off-by: default avatarManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Link: https://lore.kernel.org/r/20231012172129.65172-3-manivannan.sadhasivam@linaro.orgSigned-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent e820de1d
This diff is collapsed.
...@@ -429,6 +429,7 @@ struct ufs_clk_gating { ...@@ -429,6 +429,7 @@ struct ufs_clk_gating {
* @workq: workqueue to schedule devfreq suspend/resume work * @workq: workqueue to schedule devfreq suspend/resume work
* @suspend_work: worker to suspend devfreq * @suspend_work: worker to suspend devfreq
* @resume_work: worker to resume devfreq * @resume_work: worker to resume devfreq
* @target_freq: frequency requested by devfreq framework
* @min_gear: lowest HS gear to scale down to * @min_gear: lowest HS gear to scale down to
* @is_enabled: tracks if scaling is currently enabled or not, controlled by * @is_enabled: tracks if scaling is currently enabled or not, controlled by
* clkscale_enable sysfs node * clkscale_enable sysfs node
...@@ -448,6 +449,7 @@ struct ufs_clk_scaling { ...@@ -448,6 +449,7 @@ struct ufs_clk_scaling {
struct workqueue_struct *workq; struct workqueue_struct *workq;
struct work_struct suspend_work; struct work_struct suspend_work;
struct work_struct resume_work; struct work_struct resume_work;
unsigned long target_freq;
u32 min_gear; u32 min_gear;
bool is_enabled; bool is_enabled;
bool is_allowed; bool is_allowed;
...@@ -862,6 +864,7 @@ enum ufshcd_mcq_opr { ...@@ -862,6 +864,7 @@ enum ufshcd_mcq_opr {
* @auto_bkops_enabled: to track whether bkops is enabled in device * @auto_bkops_enabled: to track whether bkops is enabled in device
* @vreg_info: UFS device voltage regulator information * @vreg_info: UFS device voltage regulator information
* @clk_list_head: UFS host controller clocks list node head * @clk_list_head: UFS host controller clocks list node head
* @use_pm_opp: Indicates whether OPP based scaling is used or not
* @req_abort_count: number of times ufshcd_abort() has been called * @req_abort_count: number of times ufshcd_abort() has been called
* @lanes_per_direction: number of lanes per data direction between the UFS * @lanes_per_direction: number of lanes per data direction between the UFS
* controller and the UFS device. * controller and the UFS device.
...@@ -1012,6 +1015,7 @@ struct ufs_hba { ...@@ -1012,6 +1015,7 @@ struct ufs_hba {
bool auto_bkops_enabled; bool auto_bkops_enabled;
struct ufs_vreg_info vreg_info; struct ufs_vreg_info vreg_info;
struct list_head clk_list_head; struct list_head clk_list_head;
bool use_pm_opp;
/* Number of requests aborts */ /* Number of requests aborts */
int req_abort_count; int req_abort_count;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment