[PATCH] drm/radeon: fix power state when port pm is unavailable (v2)
Alex Deucher
alexdeucher at gmail.com
Wed Nov 23 18:58:52 UTC 2016
On Wed, Nov 23, 2016 at 1:34 PM, Peter Wu <peter at lekensteyn.nl> wrote:
> On Wed, Nov 23, 2016 at 12:43:33PM -0500, Alex Deucher wrote:
>> From: Peter Wu <peter at lekensteyn.nl>
>>
>> When PCIe port PM is not enabled (system BIOS is pre-2015 or the
>> pcie_port_pm=off parameter is set), legacy ATPX PM should still be
>> marked as supported. Otherwise the GPU can fail to power on after
>> runtime suspend. This affected a Dell Inspiron 5548.
>>
>> Ideally the BIOS date in the PCI core is lowered to 2013 (the first year
>> where hybrid graphics platforms using power resources was introduced),
>> but that seems more risky at this point and would not solve the
>> pcie_port_pm=off issue.
>>
>> v2: agd: fix typo
>
> Oops, silly copy/paste error from my side (accidentally replaced
> is_hybrid instead of power_cntl). Good catch!
>
> Peter
>
> PS. mail server refused to accept mail due to '#' in Cc, need CC:
> <stable at ...> # 4.8+ below.
Whoops. fixed. thanks.
Alex
>
>> Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=98505
>> Signed-off-by: Peter Wu <peter at lekensteyn.nl>
>> Signed-off-by: Alex Deucher <alexander.deucher at amd.com>
>> Cc: stable at vger.kernel.org # 4.8
>> Reviewed-by: Alex Deucher <alexander.deucher at amd.com>
>> ---
>> drivers/gpu/drm/radeon/radeon_atpx_handler.c | 9 ++++++++-
>> 1 file changed, 8 insertions(+), 1 deletion(-)
>>
>> diff --git a/drivers/gpu/drm/radeon/radeon_atpx_handler.c b/drivers/gpu/drm/radeon/radeon_atpx_handler.c
>> index 2fdcd04..4129b12 100644
>> --- a/drivers/gpu/drm/radeon/radeon_atpx_handler.c
>> +++ b/drivers/gpu/drm/radeon/radeon_atpx_handler.c
>> @@ -34,6 +34,7 @@ struct radeon_atpx {
>>
>> static struct radeon_atpx_priv {
>> bool atpx_detected;
>> + bool bridge_pm_usable;
>> /* handle for device - and atpx */
>> acpi_handle dhandle;
>> struct radeon_atpx atpx;
>> @@ -203,7 +204,11 @@ static int radeon_atpx_validate(struct radeon_atpx *atpx)
>> atpx->is_hybrid = false;
>> if (valid_bits & ATPX_MS_HYBRID_GFX_SUPPORTED) {
>> printk("ATPX Hybrid Graphics\n");
>> - atpx->functions.power_cntl = false;
>> + /*
>> + * Disable legacy PM methods only when pcie port PM is usable,
>> + * otherwise the device might fail to power off or power on.
>> + */
>> + atpx->functions.power_cntl = !radeon_atpx_priv.bridge_pm_usable;
>> atpx->is_hybrid = true;
>> }
>>
>> @@ -474,6 +479,7 @@ static int radeon_atpx_power_state(enum vga_switcheroo_client_id id,
>> */
>> static bool radeon_atpx_pci_probe_handle(struct pci_dev *pdev)
>> {
>> + struct pci_dev *parent_pdev = pci_upstream_bridge(pdev);
>> acpi_handle dhandle, atpx_handle;
>> acpi_status status;
>>
>> @@ -487,6 +493,7 @@ static bool radeon_atpx_pci_probe_handle(struct pci_dev *pdev)
>>
>> radeon_atpx_priv.dhandle = dhandle;
>> radeon_atpx_priv.atpx.handle = atpx_handle;
>> + radeon_atpx_priv.bridge_pm_usable = parent_pdev && parent_pdev->bridge_d3;
>> return true;
>> }
>>
>> --
>> 2.5.5
More information about the amd-gfx
mailing list