Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 18 Nov 2003 13:28:09 -0800 (PST)
From:      Nate Lawson <nate@root.org>
To:        Lukas Ertl <l.ertl@univie.ac.at>
Cc:        current@freebsd.org
Subject:   Re: Updated acpi_cpu patch
Message-ID:  <20031118131708.C64933@root.org>
In-Reply-To: <20031118221008.U621@korben.in.tern>
References:  <20031118094821.T64353@root.org> <20031118221008.U621@korben.in.tern>

next in thread | previous in thread | raw e-mail | index | archive | help
On Tue, 18 Nov 2003, Lukas Ertl wrote:
> On Tue, 18 Nov 2003, Nate Lawson wrote:
> > Below you'll find the update patch for acpi_cpu.  Please test this,
> > especially for SMP and laptops with _CST objects in their ASL.
>
> Looks good here on a Centrino based laptop, which has a _CST method in
> its ASL:
>
> acpi_cpu0: <CPU> on acpi0
> acpi_cpu0: C2 state 1 lat
> acpi_cpu0: C3 state 85 lat

I'll be moving some printfs under bootverbose before release.

> hw.acpi.cpu.cx_supported: C1/1 C2/1 C3/85
> hw.acpi.cpu.cx_lowest: 0
> hw.acpi.cpu.cx_history: 86231/0 0/0 0/0

Try settings of cx_lowest of 1 and 2 (and 3 when the last C3 state is
available).  I'm interested in any benchmark results, especially IO.  I'm
hoping the scheduling of sleeps is good enough that you don't experience
much performance loss even with lower sleeps.

> Although it seems I have lost a C3 state (before, I had an additional
> C3/185).

_CST can change dynamically at runtime.  If you booted with the AC adapter
attached, your laptop may not offer all the sleep states.  When you unplug
the AC adapter, we get a notify on _CST to re-evaluate it and look for new
states.  However, that code is currently disabled due to complex locking
issues (i.e. what to do when a Cx state is being accessed but _CST is
being re-evaluated).  _CST re-evaluation won't be enabled until after
5.2R.  However, you can reboot your laptop with the AC adapter detached
(or attached) to see what states are available.

This excerpt from truckman@'s asl shows that 4 Cx states are only
available when the AC adapter is not attached.  (The C*NA memory addresses
appear to be managed by the BIOS and not the AML but the PSR access is
clear).

            Method (_CST, 0, NotSerialized)
            {
                If (\C2NA)
                {
                    Return (CST1)
                }

                If (\C3NA)
                {
                    Return (CST2)
                }

                If (\_SB.PCI0.LPC.EC.AC._PSR ())
                {
                    Return (CST3)
                }

                If (\C4NA)
                {
                    Return (CST3)
                }

                Return (CST4)
            }

-Nate



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20031118131708.C64933>