我使用this .NET program在HKLM/Hardware/ACPI/DSDT
上对Windows注册表进行二进制转储。
然后,在其上运行Microsoft的ASL Compiler,我可以获得以下 *ACPI源语言 *:
Scope(\_TZ_)
{
Name(TBSE, 0xaac)
Name(CRT0, 0x0)
Name(PSV0, 0x0)
ThermalZone(TZS0)
{
Method(_TMP, 0x0, NotSerialized)
{
If(\ECON)
{
Store(\_SB_.PCI0.LPC0.EC0_.THS0, Local0)
Store(\_SB_.PCI0.LPC0.EC0_.KCSS, Local1)
Store(\_SB_.PCI0.LPC0.EC0_.KOSD, Local2)
}
Else
{
Store(RBEC(0x92), Local0)
And(Local0, 0x1, Local1)
And(Local0, 0x8, Local2)
Store(RBEC(0xa8), Local0)
}
If(Local1)
{
Add(PSV0, 0x1, Local0)
}
If(Local2)
{
If(LNot(LGreater(Local0, CRT0)))
{
Add(CRT0, 0x2, Local0)
}
}
Return(C2K_(Local0))
}
Method(_HOT, 0x0, NotSerialized)
{
If(LEqual(OSYS, 0x7d6))
{
If(\ECON)
{
Store(0x20, \_SB_.PCI0.LPC0.EC0_.TIID)
Store(\_SB_.PCI0.LPC0.EC0_.TSC0, Local0)
}
Else
{
WBEC(0x1, 0x20)
Store(RBEC(0xd1), Local0)
}
If(LOr(LNot(LLess(Local0, 0x80)), LLess(Local0, 0x1e)))
{
Store(0x78, Local0)
}
Store(Local0, CRT0)
Return(C2K_(Local0))
}
Else
{
Return(C2K_(0x78))
}
}
Method(_CRT, 0x0, NotSerialized)
{
If(LNot(LEqual(OSYS, 0x7d6)))
{
If(\ECON)
{
Store(0x20, \_SB_.PCI0.LPC0.EC0_.TIID)
Store(\_SB_.PCI0.LPC0.EC0_.TSC0, Local0)
}
Else
{
WBEC(0x1, 0x20)
Store(RBEC(0xd1), Local0)
}
If(LOr(LNot(LLess(Local0, 0x80)), LLess(Local0, 0x1e)))
{
Store(0x78, Local0)
}
Store(Local0, CRT0)
Return(C2K_(Local0))
}
Else
{
Return(C2K_(0x78))
}
}
Name(_PSL, Package(0x1)
{
\_PR_.CPU0
})
Method(_PSV, 0x0, NotSerialized)
{
If(\ECON)
{
Store(0x20, \_SB_.PCI0.LPC0.EC0_.TIID)
Store(\_SB_.PCI0.LPC0.EC0_.TSP0, Local0)
}
Else
{
WBEC(0x1, 0x20)
Store(RBEC(0xd0), Local0)
}
If(LOr(LNot(LLess(Local0, 0x80)), LLess(Local0, 0x1e)))
{
Store(0x5a, Local0)
}
Store(Local0, PSV0)
Return(C2K_(Local0))
}
Name(_TC1, 0x4)
Name(_TC2, 0x3)
Name(_TSP, 0x96)
Method(FMAX, 0x0, NotSerialized)
{
If(\ECON)
{
Store(0x40, \_SB_.PCI0.LPC0.EC0_.TIID)
Store(\_SB_.PCI0.LPC0.EC0_.TSP3, Local0)
}
Else
{
WBEC(0x1, 0x40)
Store(RBEC(0xd6), Local0)
}
Return(FSTL(Local0))
}
Method(FMIN, 0x0, NotSerialized)
{
If(\ECON)
{
Store(0x40, \_SB_.PCI0.LPC0.EC0_.TIID)
Store(\_SB_.PCI0.LPC0.EC0_.TSP0, Local0)
}
Else
{
WBEC(0x1, 0x40)
Store(RBEC(0xd0), Local0)
}
Return(FSTL(Local0))
}
Method(FRSP, 0x0, NotSerialized)
{
If(\ECON)
{
Store(\_SB_.PCI0.LPC0.EC0_.FSR1, Local0)
}
Else
{
Store(RBEC(0x95), Local0)
}
Return(FSTL(Local0))
}
Method(FSSP, 0x1, NotSerialized)
{
If(LEqual(Arg0, 0x0))
{
If(\ECON)
{
Store(0x1, \_SB_.PCI0.LPC0.EC0_.FSHC)
Sleep(0x64)
Store(0xff, \_SB_.PCI0.LPC0.EC0_.FSW1)
}
Else
{
Store(RBEC(0x93), Local0)
Or(Local0, 0x10, Local0)
WBEC(0x93, Local0)
Sleep(0x64)
WBEC(0x94, 0xff)
}
}
Else
{
If(\ECON)
{
Store(0x0, \_SB_.PCI0.LPC0.EC0_.FSHC)
}
Else
{
WBEC(0x93, 0x0)
}
}
}
Method(FSTL, 0x1, NotSerialized)
{
If(LOr(LEqual(Arg0, 0x0), LEqual(Arg0, 0xff)))
{
Store(Zero, Local1)
}
Else
{
Divide(0x78000, Arg0, Local0, Local1)
}
Return(Local1)
}
}
....
我只懂一些零碎的东西。TZ 指的是一个专门用于热区的范围(我想)。
通过阅读ACPI Spec,我看到_HOT和_CRT是与温度阈值相关的OSPM对象。
_HOT对象声明OSPM可以选择将系统转换到S4睡眠状态(如果支持)的临界温度;_CRT对象声明OSPM必须执行临界关机的临界温度。
因此,我认为DSDT的片段与根据热区域0中的感应温度来控制笔记本电脑风扇速度有关。基于此,我猜测上面的FSTL
是风扇设置级别或类似级别,FMAX
和FMIN
是风扇最大速度和最小速度,我认为C2K
是一个转换为开尔文的函数。除此之外,我只是根据猜测进行猜测。
- 编辑:* 经过进一步的检查,
_PSL
是被动列表(根据ACPI规范),它返回一个被动温度控制设备的列表。在风扇被认为是“主动”温度控制的地方,“被动”温度控制的一个例子是在CPU上降低电压或速度。所以我不确定这一节是否控制风扇。它可能专门用于被动温度控制。
我尝试做的是修改笔记本电脑的风扇速度,用于各种温度。在一些DSDT中,温度和风扇速度之间的Map是在一个整洁的小表格中,修改Map只是改变几个数字的问题。在这个ASL文件中似乎没有这样的表格,所以我认为一定有一些程序逻辑在做Map。
有人能帮我破译吗?
我真正想做的是让HP G60- 244 dx笔记本电脑的风扇放松。即使在CPU空闲时,它也会运行得太大声,而且......如果它像我以前的HP nc 8430笔记本电脑一样,风扇速度设置得不必要地高。可以降低风扇速度,但保持CPU温度不变。
我认为为了修改风扇速度我需要修补DSDT,这就是为什么我想破译上述。
非常感谢。
可能相关:
Setting an ACPI field in Linux
1条答案
按热度按时间l7wslrjt1#
在我的HP dm 1 - 3100 ev上尝试相同的过程时遇到了这个问题。没有直接的青运速度设置,它必须在代码中计算。最接近的发现是像FMIN和FMAX设置一样的东西,分别设置为20和56(这些看起来不像最小和最大青运速度的温度限制吗?)改变这些没有工作,虽然(也许HP Coolsense是覆盖的东西)。
如果我找到什么我会告诉你的!
编辑:我错了,FMIN和FMAX指定了最小和最大风扇转速:分别是2000和5600。不幸的是,更改这些值仍然不起作用。