我使用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对象。
因此,我认为DSDT的片段与根据热区0中感测到的温度来控制笔记本电脑风扇的速度有关。基于此,我猜测上面的
FSTL
是Fan-Set-Level或类似的东西。相似,并且FMAX
和FMIN
分别是Fan-Max-Speed和-Min-Speed。我认为C2K
是转换为开尔文的函数。除此之外,我只是基于猜测进行猜测。编辑:经过进一步审查,
_PSL
是Passive List(根据ACPI规范),它返回被动温度控制设备的列表。在将风扇视为“主动”温度控制的情况下,“被动”温度控制的一个例子是调低CPU的电压或降低其速度。因此,我不确定该部分是否完全控制风扇。它可以专门用于被动温度控制。我想做的是修改用于各种温度的笔记本电脑风扇的速度。在某些DSDT中,温度和风扇速度之间的映射位于一个整洁的小表中,而修改映射只是更改一些数字即可。似乎在此ASL文件中没有像这样的表,因此我认为必须有一些程序逻辑在进行映射。
谁能帮我破译它?
我真正想做的就是让风扇在HP G60-244dx笔记本电脑上放松。即使CPU处于空闲状态,它的声音也太大了,并且...如果像我以前的HP nc8430笔记本电脑一样,风扇速度设置过高。可以降低风扇速度,但保持CPU温度不变。
我认为,为了修改风扇速度,我需要修补DSDT,这就是为什么我想破译以上内容的原因。
非常感谢。
可能相关:
Setting an ACPI field in Linux
最佳答案
在我的HP dm1-3100ev上尝试相同的过程时遇到了这个问题。没有直接的风扇速度设置,必须使用代码进行计算。最接近的发现类似于FMIN和FMAX设置,分别设置为20和56(这些看起来不像最小和最大风扇速度的温度限制吗?)更改这些没有用,但是(也许HP Coolsense压倒一切了) )。
如果我设法找到任何东西,我会通知您!
编辑:我错了,FMIN和FMAX指定最小和最大风扇速度:分别为2000和5600。不幸的是,更改这些仍然无效。