Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c53c6bed authored by Dave Airlie's avatar Dave Airlie
Browse files

drm/radeon: fix runtime suspend breaking secondary GPUs



Same fix as for nouveau, when we fail with EINVAL, subsequent
gets fail hard, causing the device not to open.

Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
Reviewed-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent adbbdbac
Loading
Loading
Loading
Loading
+12 −5
Original line number Diff line number Diff line
@@ -403,11 +403,15 @@ static int radeon_pmops_runtime_suspend(struct device *dev)
	struct drm_device *drm_dev = pci_get_drvdata(pdev);
	int ret;

	if (radeon_runtime_pm == 0)
		return -EINVAL;
	if (radeon_runtime_pm == 0) {
		pm_runtime_forbid(dev);
		return -EBUSY;
	}

	if (radeon_runtime_pm == -1 && !radeon_is_px())
		return -EINVAL;
	if (radeon_runtime_pm == -1 && !radeon_is_px()) {
		pm_runtime_forbid(dev);
		return -EBUSY;
	}

	drm_dev->switch_power_state = DRM_SWITCH_POWER_CHANGING;
	drm_kms_helper_poll_disable(drm_dev);
@@ -456,12 +460,15 @@ static int radeon_pmops_runtime_idle(struct device *dev)
	struct drm_device *drm_dev = pci_get_drvdata(pdev);
	struct drm_crtc *crtc;

	if (radeon_runtime_pm == 0)
	if (radeon_runtime_pm == 0) {
		pm_runtime_forbid(dev);
		return -EBUSY;
	}

	/* are we PX enabled? */
	if (radeon_runtime_pm == -1 && !radeon_is_px()) {
		DRM_DEBUG_DRIVER("failing to power off - not px\n");
		pm_runtime_forbid(dev);
		return -EBUSY;
	}