Re: [PATCH 00/14] _OSC simplification

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Friday, September 06, 2013 11:13:24 AM Bjorn Helgaas wrote:
> This is a long series of mostly minor changes with the goal of
> simplifying the _OSC-related code and making the negotiation between
> Linux and the platform more understandable.
> 
> My intent is that this doesn't change any behavior except for the text
> in dmesg.
> 
> However, this restructuring does raise some questions in my mind, such
> as the fact that we do not call pcie_no_aspm() to disable ASPM in two
> cases where it seems like we might want to:
> 
>   1) When pcie_ports_disabled, e.g., when booting with
>      "pcie_ports=compat".
>
>   2) When Linux doesn't support all the required services, e.g., if
>      compiled with ASPM support but not MSI support.

We tried that (i.e. 2)), but then it caused energy usage to increase on some
systems with power-hungry graphics adapters and Phoronix made some fuss about
that. :-)

Also, please have a look at:

commit 3c076351c4027a56d5005a39a0b518a4ba393ce2
Author: Matthew Garrett <mjg@xxxxxxxxxx>
Date:   Thu Nov 10 16:38:33 2011 -0500

    PCI: Rework ASPM disable code

> I haven't looked deeply, so maybe there are other constraints that
> keep us from using ASPM in these cases.  In any case, this series
> doesn't change any behavior in this regard.
> 
> Below are samples of the dmesg changes from this series.  Typical case
> where we successfully get control of PCIe services:
> 
>   -acpi PNP0A08:00: Requesting ACPI _OSC control (0x1d)
>   -acpi PNP0A08:00: ACPI _OSC control (0x1d) granted
>   +acpi PNP0A08:00: _OSC: OS supports [ExtendedConfig ASPM ClockPM Segments MSI]
>   +acpi PNP0A08:00: _OSC: OS now controls [PCIeHotplug PME AER PCIeCapability]
> 
> Failure case where the system has no _OSC method:
> 
>   -acpi PNP0A03:00: ACPI _OSC support notification failed, disabling PCIe ASPM
>   -acpi PNP0A03:00: Unable to request _OSC control (_OSC support mask: 0x08)
>   +acpi PNP0A03:00: _OSC: OS supports [ASPM ClockPM Segments MSI]
>   +acpi PNP0A03:00: _OSC failed (AE_NOT_FOUND); disabling ASPM
> 
> Linux only requests _OSC control of features as a group; if Linux
> doesn't support *all* of those features, we don't request control of
> any of them (per 415e12b237).  Here's an example booted with
> "pci=nomsi":
> 
>   -acpi PNP0A08:00: Unable to request _OSC control (_OSC support mask: 0x0f)
>   +acpi PNP0A08:00: _OSC: OS supports [ExtendedConfig ASPM ClockPM Segments]
>   +acpi PNP0A08:00: _OSC: not requesting OS control; OS requires [ExtendedConfig ASPM ClockPM MSI]
> 
> Here's a system that doesn't grant OS control of the PCIe Capability.
> This is another case where we don't want control of anything unless we
> have control of the PCIe Capability:
> 
>   -acpi PNP0A08:00: Requesting ACPI _OSC control (0x1d)
>   -acpi PNP0A08:00: ACPI _OSC request failed (AE_SUPPORT), returned control mask: 0x0d
>   -acpi PNP0A08:00: ACPI _OSC control for PCIe not granted, disabling ASPM
>   +acpi PNP0A08:00: _OSC: OS supports [ExtendedConfig ASPM ClockPM Segments MSI]
>   +acpi PNP0A08:00: _OSC: platform does not support [PCIeCapability]
>   +acpi PNP0A08:00: _OSC: not requesting control; platform does not support [PCIeCapability]
>   +acpi PNP0A08:00: _OSC: OS requested [PCIeHotplug PME AER PCIeCapability]
>   +acpi PNP0A08:00: _OSC: platform willing to grant [PCIeHotplug PME AER]
>   +acpi PNP0A08:00: _OSC failed (AE_SUPPORT); disabling ASPM

That looks nice. :-)

Thanks,
Rafael

--
To unsubscribe from this list: send the line "unsubscribe linux-pci" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [DMA Engine]     [Linux Coverity]     [Linux USB]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Greybus]

  Powered by Linux