Lines Matching refs:clk_scaling
1138 memcpy(&new_pwr_info, &hba->clk_scaling.saved_pwr_info.info, in ufshcd_scale_gear()
1144 if (hba->pwr_info.gear_tx > hba->clk_scaling.min_gear || in ufshcd_scale_gear()
1145 hba->pwr_info.gear_rx > hba->clk_scaling.min_gear) { in ufshcd_scale_gear()
1147 memcpy(&hba->clk_scaling.saved_pwr_info.info, in ufshcd_scale_gear()
1152 new_pwr_info.gear_tx = hba->clk_scaling.min_gear; in ufshcd_scale_gear()
1153 new_pwr_info.gear_rx = hba->clk_scaling.min_gear; in ufshcd_scale_gear()
1179 if (!hba->clk_scaling.is_allowed || in ufshcd_clock_scaling_prepare()
1258 clk_scaling.suspend_work); in ufshcd_clk_scaling_suspend_work()
1262 if (hba->clk_scaling.active_reqs || hba->clk_scaling.is_suspended) { in ufshcd_clk_scaling_suspend_work()
1266 hba->clk_scaling.is_suspended = true; in ufshcd_clk_scaling_suspend_work()
1275 clk_scaling.resume_work); in ufshcd_clk_scaling_resume_work()
1279 if (!hba->clk_scaling.is_suspended) { in ufshcd_clk_scaling_resume_work()
1283 hba->clk_scaling.is_suspended = false; in ufshcd_clk_scaling_resume_work()
1312 if (!hba->clk_scaling.active_reqs) in ufshcd_devfreq_target()
1341 queue_work(hba->clk_scaling.workq, in ufshcd_devfreq_target()
1342 &hba->clk_scaling.suspend_work); in ufshcd_devfreq_target()
1370 struct ufs_clk_scaling *scaling = &hba->clk_scaling; in ufshcd_devfreq_get_dev_status()
1471 hba->clk_scaling.window_start_t = 0; in __ufshcd_suspend_clkscaling()
1480 cancel_work_sync(&hba->clk_scaling.suspend_work); in ufshcd_suspend_clkscaling()
1481 cancel_work_sync(&hba->clk_scaling.resume_work); in ufshcd_suspend_clkscaling()
1484 if (!hba->clk_scaling.is_suspended) { in ufshcd_suspend_clkscaling()
1486 hba->clk_scaling.is_suspended = true; in ufshcd_suspend_clkscaling()
1500 if (hba->clk_scaling.is_suspended) { in ufshcd_resume_clkscaling()
1502 hba->clk_scaling.is_suspended = false; in ufshcd_resume_clkscaling()
1515 return sysfs_emit(buf, "%d\n", hba->clk_scaling.is_enabled); in ufshcd_clkscale_enable_show()
1535 if (value == hba->clk_scaling.is_enabled) in ufshcd_clkscale_enable_store()
1541 hba->clk_scaling.is_enabled = value; in ufshcd_clkscale_enable_store()
1562 hba->clk_scaling.enable_attr.show = ufshcd_clkscale_enable_show; in ufshcd_init_clk_scaling_sysfs()
1563 hba->clk_scaling.enable_attr.store = ufshcd_clkscale_enable_store; in ufshcd_init_clk_scaling_sysfs()
1564 sysfs_attr_init(&hba->clk_scaling.enable_attr.attr); in ufshcd_init_clk_scaling_sysfs()
1565 hba->clk_scaling.enable_attr.attr.name = "clkscale_enable"; in ufshcd_init_clk_scaling_sysfs()
1566 hba->clk_scaling.enable_attr.attr.mode = 0644; in ufshcd_init_clk_scaling_sysfs()
1567 if (device_create_file(hba->dev, &hba->clk_scaling.enable_attr)) in ufshcd_init_clk_scaling_sysfs()
1573 if (hba->clk_scaling.enable_attr.attr.name) in ufshcd_remove_clk_scaling_sysfs()
1574 device_remove_file(hba->dev, &hba->clk_scaling.enable_attr); in ufshcd_remove_clk_scaling_sysfs()
1584 if (!hba->clk_scaling.min_gear) in ufshcd_init_clk_scaling()
1585 hba->clk_scaling.min_gear = UFS_HS_G1; in ufshcd_init_clk_scaling()
1587 INIT_WORK(&hba->clk_scaling.suspend_work, in ufshcd_init_clk_scaling()
1589 INIT_WORK(&hba->clk_scaling.resume_work, in ufshcd_init_clk_scaling()
1594 hba->clk_scaling.workq = create_singlethread_workqueue(wq_name); in ufshcd_init_clk_scaling()
1596 hba->clk_scaling.is_initialized = true; in ufshcd_init_clk_scaling()
1601 if (!hba->clk_scaling.is_initialized) in ufshcd_exit_clk_scaling()
1605 destroy_workqueue(hba->clk_scaling.workq); in ufshcd_exit_clk_scaling()
1607 hba->clk_scaling.is_initialized = false; in ufshcd_exit_clk_scaling()
1974 if (!hba->clk_scaling.active_reqs++) in ufshcd_clk_scaling_start_busy()
1977 if (!hba->clk_scaling.is_enabled || hba->pm_op_in_progress) { in ufshcd_clk_scaling_start_busy()
1983 queue_work(hba->clk_scaling.workq, in ufshcd_clk_scaling_start_busy()
1984 &hba->clk_scaling.resume_work); in ufshcd_clk_scaling_start_busy()
1986 if (!hba->clk_scaling.window_start_t) { in ufshcd_clk_scaling_start_busy()
1987 hba->clk_scaling.window_start_t = curr_t; in ufshcd_clk_scaling_start_busy()
1988 hba->clk_scaling.tot_busy_t = 0; in ufshcd_clk_scaling_start_busy()
1989 hba->clk_scaling.is_busy_started = false; in ufshcd_clk_scaling_start_busy()
1992 if (!hba->clk_scaling.is_busy_started) { in ufshcd_clk_scaling_start_busy()
1993 hba->clk_scaling.busy_start_t = curr_t; in ufshcd_clk_scaling_start_busy()
1994 hba->clk_scaling.is_busy_started = true; in ufshcd_clk_scaling_start_busy()
2001 struct ufs_clk_scaling *scaling = &hba->clk_scaling; in ufshcd_clk_scaling_update_busy()
2008 hba->clk_scaling.active_reqs--; in ufshcd_clk_scaling_update_busy()
5902 hba->clk_scaling.is_allowed = allow; in ufshcd_clk_scaling_allow()
5909 if (hba->clk_scaling.is_enabled) in ufshcd_clk_scaling_suspend()
5914 if (hba->clk_scaling.is_enabled) in ufshcd_clk_scaling_suspend()
5945 hba->clk_scaling.is_enabled) in ufshcd_err_handling_prepare()
7882 memcpy(&hba->clk_scaling.saved_pwr_info.info, in ufshcd_add_lus()
7885 hba->clk_scaling.saved_pwr_info.is_valid = true; in ufshcd_add_lus()
7886 hba->clk_scaling.is_allowed = true; in ufshcd_add_lus()
7892 hba->clk_scaling.is_enabled = true; in ufshcd_add_lus()