diff options
| author | Jani Nikula <jani.nikula@intel.com> | 2025-08-28 15:20:57 +0300 | 
|---|---|---|
| committer | Jani Nikula <jani.nikula@intel.com> | 2025-09-04 14:02:59 +0300 | 
| commit | 7987b7643312f1b63f70da433b23b32e2a85160c (patch) | |
| tree | 83996d685a4b402bf4e5243f631afbf49b5f42c4 /drivers/gpu | |
| parent | 46013820f40220ca4ddcf4892401affe41d69747 (diff) | |
| download | linux-7987b7643312f1b63f70da433b23b32e2a85160c.tar.xz | |
drm/i915/tc: use generic poll_timeout_us() instead of wait_for()
Prefer generic poll helpers over i915 custom helpers.
The functional change is losing the exponentially growing sleep of
wait_for(), which used to be 10, 20, 40, ..., 640, and 1280 us.
Use an arbitrary constant 200 us sleep for the 5 ms timeout, and 1000 us
sleep for the 500 ms timeout. The timeouts remain the same.
Reviewed-by: Jouni Högander <jouni.hogander@intel.com>
Link: https://lore.kernel.org/r/50cd06b61210f541d5bb52a36af2d8bf059dd3a1.1756383233.git.jani.nikula@intel.com
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Diffstat (limited to 'drivers/gpu')
| -rw-r--r-- | drivers/gpu/drm/i915/display/intel_tc.c | 16 | 
1 files changed, 14 insertions, 2 deletions
diff --git a/drivers/gpu/drm/i915/display/intel_tc.c b/drivers/gpu/drm/i915/display/intel_tc.c index 23745fc99d35..c4a5601c5107 100644 --- a/drivers/gpu/drm/i915/display/intel_tc.c +++ b/drivers/gpu/drm/i915/display/intel_tc.c @@ -3,6 +3,8 @@   * Copyright © 2019 Intel Corporation   */ +#include <linux/iopoll.h> +  #include <drm/drm_print.h>  #include "i915_reg.h" @@ -1050,8 +1052,13 @@ static bool  xelpdp_tc_phy_wait_for_tcss_power(struct intel_tc_port *tc, bool enabled)  {  	struct intel_display *display = to_intel_display(tc->dig_port); +	bool is_enabled; +	int ret; -	if (wait_for(xelpdp_tc_phy_tcss_power_is_enabled(tc) == enabled, 5)) { +	ret = poll_timeout_us(is_enabled = xelpdp_tc_phy_tcss_power_is_enabled(tc), +			      is_enabled == enabled, +			      200, 5000, false); +	if (ret) {  		drm_dbg_kms(display->drm,  			    "Port %s: timeout waiting for TCSS power to get %s\n",  			    str_enabled_disabled(enabled), @@ -1332,8 +1339,13 @@ static bool tc_phy_is_connected(struct intel_tc_port *tc,  static bool tc_phy_wait_for_ready(struct intel_tc_port *tc)  {  	struct intel_display *display = to_intel_display(tc->dig_port); +	bool is_ready; +	int ret; -	if (wait_for(tc_phy_is_ready(tc), 500)) { +	ret = poll_timeout_us(is_ready = tc_phy_is_ready(tc), +			      is_ready, +			      1000, 500 * 1000, false); +	if (ret) {  		drm_err(display->drm, "Port %s: timeout waiting for PHY ready\n",  			tc->port_name);  | 
