Re: [PATCH v3 02/17] ARM64 / ACPI: Get RSDP and ACPI boot-time tables
From: Grant Likely
Date: Sun Sep 14 2014 - 23:54:23 EST
On Sun, Sep 14, 2014 at 2:59 PM, Catalin Marinas
<catalin.marinas@xxxxxxx> wrote:
> On 14 Sep 2014, at 16:40, Grant Likely <grant.likely@xxxxxxxxxx> wrote:
>> On Thu, 11 Sep 2014 12:01:46 +0100, Catalin Marinas <catalin.marinas@xxxxxxx> wrote:
>>> On Wed, Sep 10, 2014 at 10:51:30PM +0100, Grant Likely wrote:
>>>> On Wed, 10 Sep 2014 13:33:52 +0100, Catalin Marinas <catalin.marinas@xxxxxxx> wrote:
>>>>> On Wed, Sep 10, 2014 at 12:13:51PM +0100, Hanjun Guo wrote:
>>>>>> I agree that we should rework the ACPI core to make sleep/cache related
>>>>>> stuff compatible with ARM, but I think we may not do this in one go, it will
>>>>>> need incremental changes over the next couple of years as real hardware
>>>>>> starts to appear and we finalise the standards to support this.
>>>>>>
>>>>>> Now, as we list in the arm-acpi.txt doc, power management of sleep states
>>>>>> and CPU power/frequency control are not well defined in ACPI spec for ARM,
>>>>>> we need some time to finalize the standard and then we know how to implement
>>>>>> that in a good shape.
>>>>>>
>>>>>> ACPI 5.1 already fixed lots missing features for ARM64 and provide the
>>>>>> fundamental needs to bring up the basic system for ARM server, power
>>>>>> management is not critical at now, so why not fix/implement it later?
>>>>>
>>>>> I don't have a problem with implementing (rather than fixing) power
>>>>> management later, once the ACPI spec covers it. But the point a few of
>>>>> us were trying to make is that even when ACPI spec is updated, the
>>>>> current power management code and hooks still won't make sense on ARM.
>>>>> The best is to avoid compiling it for ARM now and look at refactoring it
>>>>> later to accommodate ARM ACPI.
>>>>
>>>> I disagree strongly here. We're talking about a library of code that is
>>>> working on x86 and ia64, but hasn't been tuned for ARM.
>>>
>>> I think where we disagree is the "tuning" part. If it's just that, it
>>> would be fine, but there are fundamental differences in the
>>> architectures that the above would not even make sense on ARM (so it's
>>> more like rewriting than tuning).
>>>
>>>> Trying to
>>>> refactor it first, and then get it compiling for ARM is entirely the
>>>> wrong way around.
>>>
>>> Note that I explicitly stated "refactoring it later". I have not asked
>>> for the existing code to be refactored _now_ as it's not even clear how
>>> it would look like on ARM (what's clear though is that its behaviour is
>>> _undefined_).
>>>
>>>> The best way to get that code refactored for
>>>> ARM is to get it compiling first, and then refactor it to remove the
>>>> unnecessary stubs. That makes it a whole lot easier to make the
>>>> arguements about why the changes are needed. Otherwise it just shows
>>>> churn on the ACPICA side without any evidence of why the change is
>>>> good. Trying to refactor first also has the risk of breaking things
>>>> that work now in the name of "refactoring" and not being able to easily
>>>> bisect it for ARM. That's just madness.
>>>
>>> I agree with not starting the refactoring now. But is it difficult to
>>> make it compilable based on something like CONFIG_ACPI_SLEEP and the
>>> latter depend on !ARM64 until the spec is clear?
>>
>> This particular issue is pretty much moot now. The latest series was
>> able to compile out the sleep functions.
>
> That's what I was looking for.
>
>> If they hadn't however, we
>> weren't at any risk. Empty hooks have no impact, and even if the
>> behaviour is defined in a future revision of the spec, they will remain
>> noops for ACPI 5.1 systems.
>
> It's not the hooks I'm worried about but the code that calls those
> hooks. As Sudeep pointed out, the kernel will probably panic before even
> reaching the hooks. IOW, would you have been OK with simply defining
> these hooks as BUG()?
Yes.
> In principle, I'm against compiling in code paths that you can never
> test, it just goes against the idea of a "robust" system.
I don't dispute the code paths should be removed, but rather that
removing them shouldn't be a prerequisite for merging it into
mainline.
I went through exactly this same exercise when getting DT to be cross
platform. There was all kinds of stuff that got compiled into
Microblaze, and later ARM that was only applicable for PowerPC. The
refactoring came later and incrementally. It would have been a much
more difficult job if I had to maintain the patches out of tree until
the common code was near perfect. It would have taken a lot longer
too.
>>>> Aside from a slightly larger kernel, there is no downside to using
>>>> stubs for now.
>>>
>>> There is a serious downside - code with _undefined_ behaviour on arm64
>>> that may get executed depending on the content of the ACPI tables. I'm
>>> sure it's a lot of fun debugging this.
>>
>> It's really easy for us to deal with this. For ACPI 5.1, we don't do
>> anything, and we should never try to do anything with those states. If
>> and when a future revision of the ACPI spec appears that does define
>> those states, then we will use them, but only if the reported ACPI
>> version is high enough.
>
> It's the other way around: the reported ACPI version (by firmware) is
> high enough but the kernel code is not updated beyond 5.1 and may run
> the current ARM-undefined ACPI sleep code.
That is fine too. Future ACPI platforms are also to be backwards
compatible. Platforms are not allowed to use new features if the OS
only supports an old rev of the spec.
g.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/