| /* SPDX-License-Identifier: GPL-2.0-only */ |
| |
| /* Generated by acpigen */ |
| External (\PPKG, MethodObj) |
| |
| #include "../thermal.h" |
| |
| // Thermal Zone |
| |
| #define HAVE_THERMALZONE |
| Scope (\_TZ) |
| { |
| ThermalZone (THRM) |
| { |
| Name (_TC1, 0x02) |
| Name (_TC2, 0x05) |
| |
| // Thermal zone polling frequency: 10 seconds |
| Name (_TZP, 100) |
| |
| // Thermal sampling period for passive cooling: 2 seconds |
| Name (_TSP, 20) |
| |
| Name (F0ON, FAN0_2_THRESHOLD_ON) |
| Name (F0OF, FAN0_2_THRESHOLD_OFF) |
| Name (F0PW, FAN0_2_PWM) |
| Name (F1ON, FAN1_2_THRESHOLD_ON) |
| Name (F1OF, FAN1_2_THRESHOLD_OFF) |
| Name (F1PW, FAN1_2_PWM) |
| Name (F2ON, FAN2_2_THRESHOLD_ON) |
| Name (F2OF, FAN2_2_THRESHOLD_OFF) |
| Name (F2PW, FAN2_2_PWM) |
| Name (F3ON, FAN3_2_THRESHOLD_ON) |
| Name (F3OF, FAN3_2_THRESHOLD_OFF) |
| Name (F3PW, FAN3_2_PWM) |
| Name (F4PW, FAN4_2_PWM) |
| Name (THTB, 2) |
| |
| // Convert from Degrees C to 1/10 Kelvin for ACPI |
| Method (CTOK, 1) { |
| // 10th of Degrees C |
| Local0 = Arg0 * 10 |
| |
| // Convert to Kelvin |
| Local0 += 2732 |
| |
| Return (Local0) |
| } |
| |
| // Thermal Table 0 |
| Method (TTB0, 0) { |
| Store (FAN0_0_THRESHOLD_ON, F0ON) |
| Store (FAN0_0_THRESHOLD_OFF, F0OF) |
| Store (FAN0_0_PWM, F0PW) |
| Store (FAN1_0_THRESHOLD_ON, F1ON) |
| Store (FAN1_0_THRESHOLD_OFF, F1OF) |
| Store (FAN1_0_PWM, F1PW) |
| Store (FAN2_0_THRESHOLD_ON, F2ON) |
| Store (FAN2_0_THRESHOLD_OFF, F2OF) |
| Store (FAN2_0_PWM, F2PW) |
| Store (FAN3_0_THRESHOLD_ON, F3ON) |
| Store (FAN3_0_THRESHOLD_OFF, F3OF) |
| Store (FAN3_0_PWM, F3PW) |
| Store (FAN4_0_PWM, F4PW) |
| Store (0, THTB) |
| } |
| |
| // Thermal Table 1 |
| Method (TTB1, 0) { |
| Store (FAN0_1_THRESHOLD_ON, F0ON) |
| Store (FAN0_1_THRESHOLD_OFF, F0OF) |
| Store (FAN0_1_PWM, F0PW) |
| Store (FAN1_1_THRESHOLD_ON, F1ON) |
| Store (FAN1_1_THRESHOLD_OFF, F1OF) |
| Store (FAN1_1_PWM, F1PW) |
| Store (FAN2_1_THRESHOLD_ON, F2ON) |
| Store (FAN2_1_THRESHOLD_OFF, F2OF) |
| Store (FAN2_1_PWM, F2PW) |
| Store (FAN3_1_THRESHOLD_ON, F3ON) |
| Store (FAN3_1_THRESHOLD_OFF, F3OF) |
| Store (FAN3_1_PWM, F3PW) |
| Store (FAN4_1_PWM, F4PW) |
| Store (1, THTB) |
| } |
| |
| // Thermal Table 2 |
| Method (TTB2, 0) { |
| Store (FAN0_2_THRESHOLD_ON, F0ON) |
| Store (FAN0_2_THRESHOLD_OFF, F0OF) |
| Store (FAN0_2_PWM, F0PW) |
| Store (FAN1_2_THRESHOLD_ON, F1ON) |
| Store (FAN1_2_THRESHOLD_OFF, F1OF) |
| Store (FAN1_2_PWM, F1PW) |
| Store (FAN2_2_THRESHOLD_ON, F2ON) |
| Store (FAN2_2_THRESHOLD_OFF, F2OF) |
| Store (FAN2_2_PWM, F2PW) |
| Store (FAN3_2_THRESHOLD_ON, F3ON) |
| Store (FAN3_2_THRESHOLD_OFF, F3OF) |
| Store (FAN3_2_PWM, F3PW) |
| Store (FAN4_2_PWM, F4PW) |
| Store (2, THTB) |
| } |
| |
| // Update Thermal Table |
| Method (UPTB, 0) { |
| // Get System Temperature via SuperIO TMPIN2 |
| Store (\_SB.PCI0.LPCB.SIO.ENVC.TIN2, Local0) |
| |
| // Check for "no reading available |
| If (Local0 == 0x80) { |
| Store (THERMAL_POLICY_0_THRESHOLD_ON, Local0) |
| } |
| |
| // Check for invalid readings |
| If (Local0 == 255 || Local0 == 0) { |
| Store (THERMAL_POLICY_0_THRESHOLD_ON, Local0) |
| } |
| |
| If (THTB == 2) { |
| If (Local0 >= THERMAL_POLICY_0_THRESHOLD_ON) { |
| TTB0 () |
| } ElseIf (Local0 >= THERMAL_POLICY_1_THRESHOLD_ON) { |
| TTB1 () |
| } |
| } ElseIf (THTB == 1) { |
| If (Local0 >= THERMAL_POLICY_0_THRESHOLD_ON) { |
| TTB0 () |
| } ElseIf (LLessEqual (Local0, THERMAL_POLICY_1_THRESHOLD_OFF)) { |
| TTB2 () |
| } |
| } Else { |
| If (Local0 < THERMAL_POLICY_1_THRESHOLD_OFF) { |
| TTB2 () |
| } ElseIf (LLessEqual (Local0, THERMAL_POLICY_0_THRESHOLD_OFF)) { |
| TTB1 () |
| } |
| } |
| } |
| |
| // Threshold for OS to shutdown |
| Method (_CRT, 0, Serialized) |
| { |
| Return (CTOK (\TCRT)) |
| } |
| |
| // Threshold for passive cooling |
| Method (_PSV, 0, Serialized) |
| { |
| Return (CTOK (\TPSV)) |
| } |
| |
| // Processors used for passive cooling |
| Method (_PSL, 0, Serialized) |
| { |
| Return (\PPKG ()) |
| } |
| |
| // Start fan at state 4 = lowest temp state |
| Method (_INI) |
| { |
| Store (4, \FLVL) |
| Store (FAN4_2_PWM, \_SB.PCI0.LPCB.SIO.ENVC.F2PS) |
| Notify (\_TZ.THRM, 0x81) |
| } |
| |
| Method (TCHK, 0, Serialized) |
| { |
| // Update Thermal Table |
| UPTB () |
| |
| // Get CPU Temperature from PECI via SuperIO TMPIN3 |
| Store (\_SB.PCI0.LPCB.SIO.ENVC.TIN3, Local0) |
| |
| // Check for "no reading available |
| If (Local0 == 0x80) { |
| Return (CTOK (FAN0_0_THRESHOLD_ON)) |
| } |
| |
| // Check for invalid readings |
| If (Local0 == 255 || Local0 == 0) { |
| Return (CTOK (FAN0_0_THRESHOLD_ON)) |
| } |
| |
| // PECI raw value is an offset from Tj_max |
| Local1 = 255 - Local0 |
| |
| // Handle values greater than Tj_max |
| If (Local1 >= \TMAX) { |
| Return (CTOK (\TMAX)) |
| } |
| |
| // Subtract from Tj_max to get temperature |
| Local0 = \TMAX - Local1 |
| Return (CTOK (Local0)) |
| } |
| |
| Method (_TMP, 0, Serialized) |
| { |
| // Get temperature from SuperIO in deci-kelvin |
| Store (TCHK (), Local0) |
| |
| // Critical temperature in deci-kelvin |
| Store (CTOK (\TMAX), Local1) |
| |
| If (Local0 >= Local1) { |
| Printf ("CRITICAL TEMPERATURE: %o", Local0) |
| |
| // Wait 1 second for SuperIO to re-poll |
| Sleep (1000) |
| |
| // Re-read temperature from SuperIO |
| Store (TCHK (), Local0) |
| |
| Printf ("RE-READ TEMPERATURE: %o", Local0) |
| } |
| |
| Return (Local0) |
| } |
| |
| Method (_AC0) { |
| If (LLessEqual (\FLVL, 0)) { |
| Return (CTOK (F0OF)) |
| } Else { |
| Return (CTOK (F0ON)) |
| } |
| } |
| |
| Method (_AC1) { |
| If (LLessEqual (\FLVL, 1)) { |
| Return (CTOK (F1OF)) |
| } Else { |
| Return (CTOK (F1ON)) |
| } |
| } |
| |
| Method (_AC2) { |
| If (LLessEqual (\FLVL, 2)) { |
| Return (CTOK (F2OF)) |
| } Else { |
| Return (CTOK (F2ON)) |
| } |
| } |
| |
| Method (_AC3) { |
| If (LLessEqual (\FLVL, 3)) { |
| Return (CTOK (F3OF)) |
| } Else { |
| Return (CTOK (F3ON)) |
| } |
| } |
| |
| Method (_AC4) { |
| If (LLessEqual (\FLVL, 4)) { |
| Return (CTOK (0)) |
| } Else { |
| Return (CTOK (0)) |
| } |
| } |
| |
| Name (_AL0, Package () { FAN0 }) |
| Name (_AL1, Package () { FAN1 }) |
| Name (_AL2, Package () { FAN2 }) |
| Name (_AL3, Package () { FAN3 }) |
| Name (_AL4, Package () { FAN4 }) |
| |
| PowerResource (FNP0, 0, 0) |
| { |
| Method (_STA) { |
| If (LLessEqual (\FLVL, 0)) { |
| Return (One) |
| } Else { |
| Return (Zero) |
| } |
| } |
| Method (_ON) { |
| If (! _STA ()) { |
| Store (0, \FLVL) |
| Store (F0PW, |
| \_SB.PCI0.LPCB.SIO.ENVC.F2PS) |
| Notify (\_TZ.THRM, 0x81) |
| } |
| } |
| Method (_OFF) { |
| If (_STA ()) { |
| Store (1, \FLVL) |
| Store (F1PW, |
| \_SB.PCI0.LPCB.SIO.ENVC.F2PS) |
| Notify (\_TZ.THRM, 0x81) |
| } |
| } |
| } |
| |
| PowerResource (FNP1, 0, 0) |
| { |
| Method (_STA) { |
| If (LLessEqual (\FLVL, 1)) { |
| Return (One) |
| } Else { |
| Return (Zero) |
| } |
| } |
| Method (_ON) { |
| If (! _STA ()) { |
| Store (1, \FLVL) |
| Store (F1PW, |
| \_SB.PCI0.LPCB.SIO.ENVC.F2PS) |
| Notify (\_TZ.THRM, 0x81) |
| } |
| } |
| Method (_OFF) { |
| If (_STA ()) { |
| Store (2, \FLVL) |
| Store (F2PW, |
| \_SB.PCI0.LPCB.SIO.ENVC.F2PS) |
| Notify (\_TZ.THRM, 0x81) |
| } |
| } |
| } |
| |
| PowerResource (FNP2, 0, 0) |
| { |
| Method (_STA) { |
| If (LLessEqual (\FLVL, 2)) { |
| Return (One) |
| } Else { |
| Return (Zero) |
| } |
| } |
| Method (_ON) { |
| If (! _STA ()) { |
| Store (2, \FLVL) |
| Store (F2PW, |
| \_SB.PCI0.LPCB.SIO.ENVC.F2PS) |
| Notify (\_TZ.THRM, 0x81) |
| } |
| } |
| Method (_OFF) { |
| If (_STA ()) { |
| Store (3, \FLVL) |
| Store (F3PW, |
| \_SB.PCI0.LPCB.SIO.ENVC.F2PS) |
| Notify (\_TZ.THRM, 0x81) |
| } |
| } |
| } |
| |
| PowerResource (FNP3, 0, 0) |
| { |
| Method (_STA) { |
| If (LLessEqual (\FLVL, 3)) { |
| Return (One) |
| } Else { |
| Return (Zero) |
| } |
| } |
| Method (_ON) { |
| If (! _STA ()) { |
| Store (3, \FLVL) |
| Store (F3PW, |
| \_SB.PCI0.LPCB.SIO.ENVC.F2PS) |
| Notify (\_TZ.THRM, 0x81) |
| } |
| } |
| Method (_OFF) { |
| If (_STA ()) { |
| Store (4, \FLVL) |
| Store (F4PW, |
| \_SB.PCI0.LPCB.SIO.ENVC.F2PS) |
| Notify (\_TZ.THRM, 0x81) |
| } |
| } |
| } |
| |
| PowerResource (FNP4, 0, 0) |
| { |
| Method (_STA) { |
| If (LLessEqual (\FLVL, 4)) { |
| Return (One) |
| } Else { |
| Return (Zero) |
| } |
| } |
| Method (_ON) { |
| If (! _STA ()) { |
| Store (4, \FLVL) |
| Store (F4PW, |
| \_SB.PCI0.LPCB.SIO.ENVC.F2PS) |
| Notify (\_TZ.THRM, 0x81) |
| } |
| } |
| Method (_OFF) { |
| If (_STA ()) { |
| Store (4, \FLVL) |
| Store (F4PW, |
| \_SB.PCI0.LPCB.SIO.ENVC.F2PS) |
| Notify (\_TZ.THRM, 0x81) |
| } |
| } |
| } |
| |
| Device (FAN0) |
| { |
| Name (_HID, EISAID ("PNP0C0B")) |
| Name (_UID, 0) |
| Name (_PR0, Package () { FNP0 }) |
| } |
| |
| Device (FAN1) |
| { |
| Name (_HID, EISAID ("PNP0C0B")) |
| Name (_UID, 1) |
| Name (_PR0, Package () { FNP1 }) |
| } |
| |
| Device (FAN2) |
| { |
| Name (_HID, EISAID ("PNP0C0B")) |
| Name (_UID, 2) |
| Name (_PR0, Package () { FNP2 }) |
| } |
| |
| Device (FAN3) |
| { |
| Name (_HID, EISAID ("PNP0C0B")) |
| Name (_UID, 3) |
| Name (_PR0, Package () { FNP3 }) |
| } |
| |
| Device (FAN4) |
| { |
| Name (_HID, EISAID ("PNP0C0B")) |
| Name (_UID, 4) |
| Name (_PR0, Package () { FNP4 }) |
| } |
| } |
| } |