Hi Linus, please pull from: git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux-acpi-2.6.git release Please test this on your Evo before pushing it upstream. Due to a crash on some ACER laptops, this reverts the Notify-on-stack fix from 2.6.21 and goes back to an updated notify work-queue fix that we've discussed (and struggled with) before. I'm not totally satisfied that we've reverse engineered all the bizarre Notify cases that BIOS send us, but this should work on the machines we've seen to date... The bulk of the text changes are to restore the invariant that ACPICA is Lindent clean. thanks! -Len ps. individual patches are available on linux-acpi@xxxxxxxxxxxxxxx and a consolidated plain patch is available here: ftp://ftp.kernel.org/pub/linux/kernel/people/lenb/acpi/patches/release/2.6.21/acpi-release-20070126-2.6.21.diff.gz drivers/acpi/dispatcher/dsmethod.c | 12 drivers/acpi/dispatcher/dsopcode.c | 3 drivers/acpi/dispatcher/dsutils.c | 7 drivers/acpi/dispatcher/dswstate.c | 9 drivers/acpi/ec.c | 39 - drivers/acpi/events/evgpe.c | 5 drivers/acpi/events/evgpeblk.c | 3 drivers/acpi/events/evmisc.c | 20 drivers/acpi/events/evregion.c | 15 drivers/acpi/events/evrgnini.c | 3 drivers/acpi/events/evxface.c | 7 drivers/acpi/events/evxfevnt.c | 2 drivers/acpi/executer/exconvrt.c | 5 drivers/acpi/executer/excreate.c | 6 drivers/acpi/executer/exdump.c | 17 drivers/acpi/executer/exmutex.c | 37 - drivers/acpi/executer/exnames.c | 3 drivers/acpi/executer/exprep.c | 2 drivers/acpi/executer/exresop.c | 3 drivers/acpi/executer/exsystem.c | 30 - drivers/acpi/executer/exutils.c | 104 +++- drivers/acpi/hardware/hwsleep.c | 1 drivers/acpi/namespace/nseval.c | 13 drivers/acpi/namespace/nsinit.c | 7 drivers/acpi/namespace/nswalk.c | 6 drivers/acpi/namespace/nsxfeval.c | 17 drivers/acpi/osl.c | 45 + drivers/acpi/parser/psopcode.c | 618 ++++++++++++------------- drivers/acpi/resources/rscalc.c | 3 drivers/acpi/resources/rscreate.c | 13 drivers/acpi/resources/rsdump.c | 8 drivers/acpi/resources/rsinfo.c | 2 drivers/acpi/resources/rslist.c | 7 drivers/acpi/resources/rsmisc.c | 4 drivers/acpi/resources/rsutils.c | 6 drivers/acpi/resources/rsxface.c | 3 drivers/acpi/sleep/main.c | 3 drivers/acpi/sleep/proc.c | 11 drivers/acpi/tables/tbfadt.c | 6 drivers/acpi/tables/tbxface.c | 16 drivers/acpi/thermal.c | 104 ---- drivers/acpi/utilities/utalloc.c | 1 drivers/acpi/utilities/utcache.c | 3 drivers/acpi/utilities/utcopy.c | 4 drivers/acpi/utilities/utdebug.c | 4 drivers/acpi/utilities/utdelete.c | 1 drivers/acpi/utilities/utglobal.c | 6 drivers/acpi/utilities/utmisc.c | 6 drivers/acpi/utilities/utmutex.c | 8 drivers/acpi/utilities/utresrc.c | 1 drivers/acpi/utilities/utxface.c | 2 drivers/misc/Kconfig | 2 drivers/misc/asus-laptop.c | 66 ++ drivers/misc/msi-laptop.c | 12 drivers/misc/sony-laptop.c | 8 include/acpi/acdispat.h | 9 include/acpi/acglobal.h | 2 include/acpi/acinterp.h | 9 include/acpi/aclocal.h | 2 include/acpi/acnamesp.h | 6 include/acpi/acobject.h | 4 include/acpi/acpi_bus.h | 9 include/acpi/acpi_drivers.h | 6 include/acpi/acpi_numa.h | 2 include/acpi/acpiosxf.h | 3 include/acpi/actypes.h | 2 include/acpi/acutils.h | 3 include/acpi/platform/aclinux.h | 21 include/acpi/processor.h | 18 include/linux/acpi.h | 3 70 files changed, 721 insertions(+), 727 deletions(-) through these commits: Alexey Starikovskiy (1): ACPI: created a dedicated workqueue for notify() execution Corentin Chary (4): asus-laptop: notify ALL events asus-laptop: add GPS support asus-laptop: fix light sens init asus-laptop: version bump and lindent Len Brown (6): ACPI: thermal trip points are read-only ACPI: delete un-reliable concept of cooling mode Revert "ACPICA: revert "acpi_serialize" changes" Revert "Execute AML Notify() requests on stack." Revert "ACPICA: fix AML mutex re-entrancy" ACPICA: Lindent Lennart Poettering (1): acpi,msi-laptop: Fall back to EC polling mode for MSI laptop specific EC commands Mattia Dongili (1): sony-laptop: rename SONY_LAPTOP_OLD to a more meaningful SONYPI_COMPAT with this log: commit f685648e7d6520653fa2641840cccc58ba8ef8e0 Merge: f142051... 00eb43a... Author: Len Brown <len.brown@xxxxxxxxx> Date: Thu May 10 04:06:12 2007 -0400 Pull misc-for-upstream into release branch commit 00eb43a1897a8845d0edb198cec69ac5f1f299dd Author: Lennart Poettering <mzxreary@xxxxxxxxxxx> Date: Fri May 4 14:16:19 2007 +0200 acpi,msi-laptop: Fall back to EC polling mode for MSI laptop specific EC commands The ACPI EC that is used in MSI laptops knows some non-standard commands for changing the screen brighntess and a few other things, which are used by the msi-laptop.c driver. Unfortunately for these commands no GPE events for IBF and OBF are triggered. Since nowadays the EC code uses the ec_intr=1 mode by default, this causes these operations to timeout, although they don't fail. In result, all operations that you can do with the msi-laptop.c driver take more or less 1s to complete, which is awfully slow. In one of the more recent kernels (2.6.20?) the EC subsystem has been revamped. With that change the EC timeout has been increased. before that increase the MSI EC accesses were slow -- but not *that* slow, hence I took notice of this limitation of the MSI EC hardware only very recently. The standard EC operations on the MSI EC as defined in the ACPI spec support GPE events properly. The following patch adds a new argument "force_poll" to the ec_transaction() function (and friends). If set to 1, the function will poll for IBF/OBF even if ec_intr=1 is enabled. If set to 0 the current behaviour is used. The msi-laptop driver is modified to make use of this new flag, so that OBF/IBF is polled for the special MSI EC transactions -- but only for them. Signed-off-by: Lennart Poettering <mzxreary@xxxxxxxxxxx> Acked-by: Alexey Starikovskiy <aystarik@xxxxxxxxx> Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit f142051505154da4ba689e129deb06524c5ece8a Merge: 19ed0d6... a64e62a... Author: Len Brown <len.brown@xxxxxxxxx> Date: Thu May 10 02:50:09 2007 -0400 Pull misc-for-upstream into release branch commit 19ed0d6fa894aec0050ab75185e69785a656da91 Merge: 71b43ca... f398532... Author: Len Brown <len.brown@xxxxxxxxx> Date: Thu May 10 02:50:01 2007 -0400 Pull asus into release branch commit 71b43ca46fc5f0588ef64a14c6133c19a9b3f1ea Merge: 3dd6786... fd35094... Author: Len Brown <len.brown@xxxxxxxxx> Date: Thu May 10 02:49:34 2007 -0400 Pull acpica into release branch commit 3dd6786f55219f87fd33e153669600d715ca9270 Merge: f697b67... 88db5e1... Author: Len Brown <len.brown@xxxxxxxxx> Date: Thu May 10 02:49:21 2007 -0400 Pull bugzilla-8385 into release branch commit f697b677620d04d8c77841745727de85f7e948b1 Merge: de56037... eaca2d3... Author: Len Brown <len.brown@xxxxxxxxx> Date: Thu May 10 02:49:01 2007 -0400 Pull thermal into release branch commit a64e62a07097f67108f0b68bc15216c3a4a5299b Author: Mattia Dongili <malattia@xxxxxxxx> Date: Tue May 1 11:19:53 2007 +0900 sony-laptop: rename SONY_LAPTOP_OLD to a more meaningful SONYPI_COMPAT Signed-off-by: Mattia Dongili <malattia@xxxxxxxx> Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit f398532722b44aa797915d6b784e8694b277c2c7 Author: Corentin Chary <corentincj@xxxxxxxxxx> Date: Sun May 6 14:48:22 2007 +0200 asus-laptop: version bump and lindent Version bump, lindent, etc .. Signed-off-by: Corentin Chary <corentincj@xxxxxxxxxx> Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit 832d995029466e12aef66187bc9103487bf7be9f Author: Corentin Chary <corentincj@xxxxxxxxxx> Date: Sun May 6 14:47:29 2007 +0200 asus-laptop: fix light sens init Fix a stupid light sens detection bug. Signed-off-by: Corentin Chary <corentincj@xxxxxxxxxx> Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit e539c2f69ca17f71dd41ba89cde67612a1326c57 Author: Corentin Chary <corentincj@xxxxxxxxxx> Date: Sun May 6 14:47:06 2007 +0200 asus-laptop: add GPS support Just adds GPS support found in R2H thanks to Sam Lin. It will make a "gps" file in /sys/devices/platform/asus-laptop/. Signed-off-by: Corentin Chary <corentincj@xxxxxxxxxx> Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit a9dbcb37a45f45813fc64d672a1f7ae6135650b1 Author: Corentin Chary <corentincj@xxxxxxxxxx> Date: Sun May 6 14:46:41 2007 +0200 asus-laptop: notify ALL events We need to handle all events, because some dsdt use events >= 0x80 Signed-off-by: Corentin Chary <corentincj@xxxxxxxxxx> Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit fd3509436fde38d4c854bf5a6b83d2c779904f8e Author: Len Brown <len.brown@xxxxxxxxx> Date: Wed May 9 23:34:35 2007 -0400 ACPICA: Lindent Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit 88db5e1489f23876a226f5393fd978ddc09dc5f9 Author: Alexey Starikovskiy <alexey.y.starikovskiy@xxxxxxxxx> Date: Wed May 9 23:31:03 2007 -0400 ACPI: created a dedicated workqueue for notify() execution HP nx6125/nx6325/... machines have a _GPE handler with an infinite loop sending Notify() events to different ACPI subsystems. Notify handler in ACPI driver is a C-routine, which may call ACPI interpreter again to get access to some ACPI variables (acpi_evaluate_xxx). On these HP machines such an evaluation changes state of some variable and lets the loop above break. In the current ACPI implementation Notify requests are being deferred to the same kacpid workqueue on which the above GPE handler with infinite loop is executing. Thus we have a deadlock -- loop will continue to spin, sending notify events, and at the same time preventing these notify events from being run on a workqueue. All notify events are deferred, thus we see increase in memory consumption noticed by author of the thread. Also as GPE handling is bloked, machines overheat. Eventually by external poll of the same acpi_evaluate, kacpid is released and all the queued notify events are free to run, thus 100% cpu utilization by kacpid for several seconds or more. To prevent all these horrors it's needed to not put notify events to kacpid workqueue by either executing them immediately or putting them on some other thread. It's dangerous to execute notify events in place, as it will put several ACPI interpreter stacks on top of each other (at least 4 in case of nx6125), thus causing kernel stack overflow. First attempt to create a new thread was done by Peter Wainwright He created a bunch of threads, which were stealing work from a kacpid workqueue. This patch appeared in 2.6.15 kernel shipped with Ubuntu 6.06 LTS. Second attempt was done by me, I created a new thread for each Notify event. This worked OK on HP nx machines, but broke Linus' Compaq n620c, by producing threads with a speed what they stopped the machine completely. Thus this patch was reverted from 18-rc2 as I remember. I re-made the patch to create second workqueue just for notify events, thus hopping it will not break Linus' machine. Patch was tested on the same HP nx machines in #5534 and #7122, but I did not received reply from Linus on a test patch sent to him. Patch went to 19-rc and was rejected with much fanfare again. There was 4th patch, which inserted schedule_timeout(1) into deferred execution of kacpid, if we had any notify requests pending, but Linus decided that it was too complex (involved either changes to workqueue to see if it's empty or atomic inc/dec). Now you see last variant which adds yield() to every GPE execution. http://bugzilla.kernel.org/show_bug.cgi?id=5534 http://bugzilla.kernel.org/show_bug.cgi?id=8385 Signed-off-by: Alexey Starikovskiy <alexey.y.starikovskiy@xxxxxxxxx> Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit 262a7a28de060f3a63cae20035876d6f22fd7670 Author: Len Brown <len.brown@xxxxxxxxx> Date: Wed May 9 23:01:59 2007 -0400 Revert "ACPICA: fix AML mutex re-entrancy" This reverts commit c0d127b56937c3e72c2b1819161d2f6718eee877. These changes to AML locking were made to allow Notify handlers to be called on the stack and not deadlock. However, that scheme turns out to be flawed and was reverted by the previous commit, so this commit restores the locking to it previous design. Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit 40d07080e585396dc58bc64befa1de0695318b3b Author: Len Brown <len.brown@xxxxxxxxx> Date: Wed May 9 22:59:38 2007 -0400 Revert "Execute AML Notify() requests on stack." This reverts commit 5f7748cf91558a5026ded5be93c5bf6c1ac34edf. While that change fixed the HP http://bugzilla.kernel.org/show_bug.cgi?id=5534 it broke the ACER: http://bugzilla.kernel.org/show_bug.cgi?id=8385 which as AML that caused Linux go recursive and stack fault. So this commit by itself will restore the ACER and again break the HP, which we'll fix another way. Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit 4d2acd9ea539e0f59178b126f6750ccc41eefcdd Author: Len Brown <len.brown@xxxxxxxxx> Date: Wed May 9 22:56:38 2007 -0400 Revert "ACPICA: revert "acpi_serialize" changes" This reverts commit a8f4af6dc6600980885c594f52eecd60edd62013. Thus restoring ACPICA's new acpi_serialize code. This commit by itself may cause a regression, but it is reverted in this order so that subsequent reverts reverts under this one can be made without conflict. Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit eaca2d3f6c4de9d4274a4e2be54c9693e76b0303 Author: Len Brown <len.brown@xxxxxxxxx> Date: Mon Apr 30 23:27:43 2007 -0400 ACPI: delete un-reliable concept of cooling mode The scheme where the thermal driver displayed the cooling mode /proc/acpi/thermal_zone/*/cooling_mode was flawed in two ways. First, the success of _SCP doesn't actually mean that the BIOS moved any trip points. On many BIOS, _SCP is present, but does nothing. So displaying what _SCP executed actually was wrong more times than it was right. Second, examining the relative position of the trip points when the thermal_zone is added is insufficient -- as the BIOS reserves the right to change the trip points at run-time. The only reliable way for the user to determine if the thermal zone is in active, passive, or critical mode is to examine the relative position of the trip points. The user can do this without the kernel doing it for them by looking in /proc/acpi/thermal_zone/*/trip_points New contents for /proc/acpi/thermal_zone/*/cooling_mode: If _SCP available: "0 - Active; 1 - Passive\n" If _SCP unavailable: "<setting not supported>\n" Signed-off-by: Len Brown <len.brown@xxxxxxxxx> commit 11ccc0f249cb01a129f54760b8ff087f242935d4 Author: Len Brown <len.brown@xxxxxxxxx> Date: Mon Apr 30 22:36:01 2007 -0400 ACPI: thermal trip points are read-only /proc/acpi/thermal_zone/*/trip_points displays what the kernel reads from the BIOS via ACPI. If you echo a string of ':' deliminted numbers to this file then it will change what it displays. But it shouldn't, since the kernel has no way to communicate these changes to ACPI thermal zones. ACPI thermal zone trip points are read-only. The kernel does have the opportunity to ask the BIOS to change the trip points with _SCP - Set Cooling Policy. Request Active Cooling Mode: # echo 0 > /proc/acpi/thermal_zone/*/cooling_policy Request Passive Cooling Mode: # echo 1 > /proc/acpi/thermal_zone/*/cooling_policy However, in practice it is quite rare for the BIOS to support the optional _SCP, and it is even more rare for the BIOS to export an _SCP that actually changes the trip points. Signed-off-by: Len Brown <len.brown@xxxxxxxxx> - To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html