#KEY | ui32 | 4 | K_CONST | Number of Keys |
+LKS | flag | 1 | K_FUNC_R | Returns whether or not lock bits are set. Returns 3 bit value, where
each bit represents one of the three lock bit regions. 1 => set. |
AL! | ui8 | 1 | K_VAR_RW | Each "1" bit in gui8ALSForced indicates that a certain writable ALS
variable has been overridden (i.e., forced) by the host OS or
host diagnostics, and that variable should not be written by the SMC
again until the applicable bit is cleared in gui8ALSForced.
Currently, the used bits are:
Bit 0 protects gui16ALSScale
Bit 1 protects ui16Chan0 and ui16Chan1 of aalsvALSData
Bit 2 protects gui16ALSLux
Bit 3 protects fHighGain of aalsvALSData
Bit 4 protects gai16ALSTemp[MAX_ALS_SENSORS]
All other bits are reserved and should be cleared to 0. |
ALA0 | {ala | | K_VAR_ATOM_RW | ALS analog lux calculation information |
ALA1 | {ala | | K_VAR_ATOM_RW | ALS analog lux calculation information |
ALA2 | {ala | | K_VAR_ATOM_RW | ALS analog lux calculation information |
ALA3 | {ala | | K_VAR_ATOM_RW | ALS analog lux calculation information |
ALA4 | {ala | | K_VAR_ATOM_RW | ALS analog lux calculation information |
ALA5 | {ala | | K_VAR_ATOM_RW | ALS analog lux calculation information |
ALAT | {alt | | K_VAR_ATOM_RW | analog lux calculation thresholds |
ALI0 | {ali | | K_CONST | ALS Sensor 0 Info |
ALI1 | {ali | | K_CONST | ALS Sensor 1 Info |
ALRV | ui16 | 2 | K_CONST | ALS/SIL version ID for the application program interface |
ALSC | {alc | | K_VAR_ATOM_RW | ALS Configuration (some fields of which are used by the SIL
on both ALS and non-ALS systems) |
ALSF | fp1f | 2 | K_VAR_ATOM_RW | ALS Scale Factor for SIL in 1.15 fixed-point representation |
ALSL | ui16 | 2 | K_VAR_ATOM_RW | Average ALS Ambient Light Reading in Lux |
ALT0 | ui16 | 2 | K_VAR_ATOM_RW | ALS Ambient Light Sensor Temperature for sensor 0 (deg C, FP16.0) |
ALT1 | ui16 | 2 | K_VAR_ATOM_RW | ALS Ambient Light Sensor Temperature for sensor 1 (deg C, FP16.0) |
ALTH | {alr | | K_VAR_ATOM_RW | ALS Ambient Light Sensor Thermal Coefficient and baseline temperature |
ALV0 | {alv | | K_VAR_ATOM_RW | Latest ambient light reading from sensor 0 |
ALV1 | {alv | | K_VAR_ATOM_RW | Latest ambient light reading from sensor 1 |
AUPO | ui8 | 1 | K_VAR_ATOM_RW | Auto Power-on key. If set to 1, system will be automatically
powered on by SMC after next transition to S5/G3HOT. |
BATP | flag | 1 | K_VAR_R | System currently being powered by battery. Used by FW TDM. Needed on all platforms. |
BNum | ui8 | 1 | K_VAR_R | Maximum number of supported batteries. Architecturally visiable key used by EFIUtil. Needed on all platforms. |
BSIn | ui8 | 1 | K_VAR_R | Battery System info byte. BSIn[7:0]
0=Charging
1=AC present
2=AC presence changed
3=OS Stop Charge
4=OS Calibration Req
5=BatteryQueryInProgress
6=batOK
7=adcInProgress
Architecturally visiable key used by EFIUtil. Needed on all platforms. |
CLKT | ui32 | 4 | K_FUNC_RW | SMC local time in seconds since midnight
Used to control SIL brightness on some systems based on time of day. |
CRCB | ui32 | 4 | K_VAR_R | Returns a CRC32 value representing all of UserBootMAT. |
CRCU | ui32 | 4 | K_FUNC_R | Generates a CRC32 value representing all of UserMAT. |
DPLM | {lim | | KPRIV_FUNC_W | Tests Plimit plumbing from SMC to OS. 3 bytes input are Cpu Plimit, Gpu Plimit, Mem Plimit. |
EPCA | ui32 | 4 | K_CONST | EPM CV Start Address |
EPCF | flag | 1 | K_FUNC_R | EPM CV Flash Status 1=flashed |
EPCI | ui32 | 4 | K_VAR_R | EPM CV Configuration ID |
EPCV | ui16 | 2 | K_VAR_R | EPM CV Configuration Version |
EPMA | ch8* | | K_FUNC_R | EPM Meta Table Address First set EPMI and then read EPMA |
EPMI | ui8 | 1 | K_VAR_ATOM_RW | EPM Meta Table Index First set EPMI and then read EPMA |
EPUA | ui32 | 4 | K_CONST | EPM UV Start Address |
EPUF | flag | 1 | K_FUNC_R | EPM UV Flash Status. 1=flashed |
EPUI | ui32 | 4 | K_VAR_R | EPM UV Configuration ID |
EPUV | ui16 | 2 | K_VAR_R | EPM UV Configuration Version |
EVCT | ui16 | 2 | K_FUNC_R | Event Trace Buffer. Returns a 2 byte value. The first byte is the number of events
that have been put into the trace buffer since the last time this key was read and the second
is the index into the buffer for the next event to be written.
If they are not the same, then the trace buffer has been overwritten and more then 16 events
have occured since the last time it was read |
EVMD | ui32 | 4 | K_FUNC_W | Event Mode. Used for debug to determine if we should reset SMC or jump into flasher on
a detected SMC health check. If key is written to a value of 0x87126534, then we will jump into the
flasher on any SMC health check. |
EVRD | ch8* | | K_FUNC_R | Event Trace Buffer Read. 32 byte read from event trace buffer. Issue key read 4 times to
read entire event trace buffer |
F0Ac | fpe2 | 2 | K_VAR_ATOM_RW | Fan0 Actual RPM, DIAG_LOG |
F0ID | {fds | | K_CONST | Fan0 Description |
F0Mn | fpe2 | 2 | K_VAR_ATOM_RW | Fan0 Minimum RPM |
F0Mt | ui16 | 2 | K_VAR_ATOM_RW | Fan0 Max calculated target RPM |
F0Mx | fpe2 | 2 | K_VAR_ATOM_RW | Fan0 Maximum RPM |
F0Sf | fpe2 | 2 | K_VAR_ATOM_RW | Fan0 Safe RPM |
F0Tg | fpe2 | 2 | K_VAR_ATOM_RW | Modify this in conjunction with Fan force bit [0] to set fan speed. |
F1Ac | fpe2 | 2 | K_VAR_ATOM_RW | Fan1 Actual RPM |
F1ID | {fds | | K_CONST | Fan1 Description |
F1Mn | fpe2 | 2 | K_VAR_ATOM_RW | Fan1 Minimum RPM |
F1Mt | ui16 | 2 | K_VAR_ATOM_RW | Fan1 Max calculated target RPM |
F1Mx | fpe2 | 2 | K_VAR_ATOM_RW | Fan1 Maximum RPM |
F1Sf | fpe2 | 2 | K_VAR_ATOM_RW | Fan1 Safe RPM |
F1Tg | fpe2 | 2 | K_VAR_ATOM_RW | Modify this in conjunction with Fan force bit [1] to set fan speed. |
F2Ac | fpe2 | 2 | K_VAR_ATOM_RW | Fan2 Actual RPM |
F2ID | {fds | | K_CONST | Fan2 Description |
F2Mn | fpe2 | 2 | K_VAR_ATOM_RW | Fan2 Minimum RPM |
F2Mt | ui16 | 2 | K_VAR_ATOM_RW | Fan2 Max calculated target RPM |
F2Mx | fpe2 | 2 | K_VAR_ATOM_RW | Fan2 Maximum RPM |
F2Sf | fpe2 | 2 | K_VAR_ATOM_RW | Fan2 Safe RPM |
F2Tg | fpe2 | 2 | K_VAR_ATOM_RW | Modify this in conjunction with Fan force bit [2] to set fan speed. |
FNum | ui8 | 1 | K_CONST | Number of supported fans. |
FPhz | si16 | 2 | KPRIV_VAR_ATOM_RW | Programmable Fan Phase offset affects all fans. Signed value
has legal values between 0 and 360. Default is 360 (no change). |
FS! | ui16 | 2 | K_VAR_ATOM_RW | Fan force bits. FS![15:0] Setting bit to 1 allows for external control over fan speed target and
prevents thermal manager from actively overidding value set via key access. |
GCID | ui32 | 4 | K_VAR_ATOM_RW | Graphics Card Identification. Communicates the graphics
card's Device ID (DID) and Vendor ID (VID) to the SMC so that the SMC
can communicate with that graphics card's thermal sensor(s). The 32-bit
value that is written to this key contains the graphics card's DID in
its most-significant 16 bits, and the VID occupies the least-significant
16-bits. |
GPU! | ui8 | 1 | K_VAR_ATOM_RW | MXM GPU Force bits[7:0]: GPU![0] = GTHR force override
bit. |
GTHR | ui8 | 1 | K_VAR_ATOM_RW | MXM_GPU_AC_BATT_L. Drive SMC output with written value.
Needs to be written in conjunction with GPU![0]. |
HBWK | flag | 1 | K_VAR_RW | Allows a one-time lid-open event to "wake" the system from S5. |
HDBS | ui8 | 1 | K_VAR_ATOM_R | Hang Detect. A/B switch value |
HDST | ui16 | 2 | K_VAR_ATOM_R | Hang Detect. Current System State Machine value |
HDSW | ui32 | 4 | K_VAR_ATOM_R | Hang Detect. {Sleep[15:0]|Wake[15:0]} Count. |
IC0C | fp79 | 2 | K_VAR_ATOM_RW | CPU 0 core current. |
ID0R | fp5b | 2 | K_VAR_ATOM_RW | DC In S0 rail current. |
ID5R | fp4c | 2 | K_VAR_ATOM_RW | DC In S5 rail current. |
IG0R | fp4c | 2 | K_VAR_ATOM_RW | GPU 0 rail current. |
IG0r | ui16 | 2 | K_VAR_ATOM_RW | GPU 0 rail current. Raw ADC input value. |
LAcN | ui8 | 1 | KPRIV_FUNC_W | Queue up ACPI Notify byte |
LAtN | ui16 | 2 | KPRIV_FUNC_W | Queue up Proprietary ATTN_IF Notify byte |
LCCN | ui8 | 1 | K_VAR_R | LPC Debug counter data: Num of Acpi Notifies |
LCCQ | ui8 | 1 | K_VAR_R | LPC Debug counter data: Num of Acpi Queries |
LCKA | ui8 | 1 | K_VAR_R | LPC Debug counter data: Num of Key Accesses |
LCSA | ui8 | 1 | K_VAR_R | LPC Debug counter data: Num of Smb Accesses |
LCTN | ui8 | 1 | K_VAR_R | LPC Debug counter data: Num of Attn Notifies |
LCTQ | ui8 | 1 | K_VAR_R | LPC Debug counter data: Num of Attn Queries |
LDSP | flag | 1 | K_VAR_W | When OS X sleeps due to a lid-closed event, it writes a 1 in this key. |
LS! | ui8 | 1 | K_VAR_RW | Each "1" bit in gui8LmsForced indicates that a certain writable SIL
variable has been overridden (i.e., forced) by the host OS or
host diagnostics, and that variable should not be written by the SMC
again until the applicable bit is cleared in gui8LmsForced.
Currently, this is just a place-holder. All bits are reserved and
should be cleared to 0. |
LSCF | {lsc | | K_VAR_ATOM_RW | LmsConfig structure provides overall system-specific config info for the SIL. |
LSDD | {lsd | | K_VAR_ATOM_RW | LmsDwell structures provide dwell fade-down configuration |
LSDU | {lsd | | K_VAR_ATOM_RW | LmsDwell structures provide dwell fade-up configuration |
LSFD | {lsf | | K_VAR_ATOM_RW | LmsFlare structures provide flare config for non-breathing fade-down |
LSFU | {lsf | | K_VAR_ATOM_RW | LmsFlare structures provide flare config for non-breathing fade-up |
LSLB | {pwm | | K_VAR_ATOM_RW | SIL's PWM "Full On" value (usually 0xFFFF, used for power switch override) |
LSLF | {pwm | | K_VAR_ATOM_RW | SIL's PWM "Off" value (usually 0) |
LSLN | {pwm | | K_VAR_ATOM_RW | SIL's PWM "On" value (varies per system) |
LSOF | flag | 1 | K_VAR_R | Reads TRUE (1) if the SIL is Off |
LSOO | flag | 1 | K_FUNC_W | ui8LmsSetOnOff is a function called by the OS to set
the SIL to either on (max brightness, flag=1) or off (flag = 0). |
LSPV | {pwm | | K_VAR_R | SIL's Current PWM value |
LSRB | flag | 1 | K_FUNC_W | ui8LmsRevertToSSMBehavior is a function called by the OS to revert the
SIL's behavior to the most recent behavior requested by the SMC's system
state machine. |
LSSB | {lso | | K_FUNC_W | ui8LmsSetBehavior is a function called by the OS to override the SIL's
behavior. The calling parameters must conform to the
LmsOverrideBehavior struct. |
LSSE | flag | 1 | K_VAR_RW | gfLmsMaxBrightScalingEnabled lets diagnotics enable and
disable the SIL's per-unit max brightness scaling. This flag will
normally be 1 (i.e, TRUE), which enables per-unit scaling. Set this
flag to 0 (FALSE) to disable per-unit scaling. |
LSSS | {lso | | K_FUNC_W | ui8LmsSetSSMBehavior is a function called by the OS to
override the SIL's behavior while pretending to be the SMC's System
State Machine (host software should normally use LSSB instead of this
special-purpose key). The calling parameters must conform to the
LmsOverrideBehavior struct. |
LSSV | ui16 | 2 | K_VAR_RW | gui16LmsMaxBrightScale holds the SIL's per-unit max
brightness scale value. A value of 0xFFFF indicates that no scaling
will be done for this particular unit. |
LSUP | ui8 | 1 | K_FUNC_W | ui8LmsUpdateBehaviorParams is a function called by the SIL tuning
application to force an update of the SIL's behavior parameters at the
user's implicit request (i.e., after the user updates underlying data
that affects the behavior params). |
MACA | ui32 | 4 | K_VAR_ATOM_RW | Memory Address Cycle Address. Sets the address for subsequent MACR calls |
MACM | flag | 1 | K_VAR_ATOM_RW | Memory Address Cycle Mode. Sets the addressing mode for MACR calls. Defaults to auto-incrementing |
MACR | ch8* | | K_FUNC_R | Memory Address Cycle Read. Reads 32 bytes from SMC @ address pointed to by MACA. Restricted to EPM address range. If
MACM==1 then MACA will be incremented by 32 bytes at the completion of the read. |
MOCF | ui16 | 2 | K_VAR_ATOM_RW | MOtion sensor (SMS) Configuration register |
MOCN | ui16 | 2 | K_VAR_ATOM_RW | MOtion sensor (SMS) Control register - enables accelerometer and threshold testing |
MSAL | ui8 | 1 | KWPRIV_FUNC_RW | Allows control of the thermal routine's behavior for debug and testing purposes.
7 - Unused
6 - Plimits enabled. 0 => thermal routine will not send plimits, but
all other thermal code is still active. 1 => routine sends plimits
normally, assuming routine is active.
5 - Unused
4 - Unused
3 - Thermal Subsystem Operating Normally, read-only. If this bit is 1,
the SMC's thermal subsystem is operating normally. If it is 0, then
the thermal code is disabled, fans are set to max RPM, and plimits
are all set to max. On systems that require a throttle selector
table in the UV EPM block, this bit will be set to 0 if the throttle
selector table is invalid or is missing.
2 - Valid current/power calibration coefficients in UV EPM block,
read-only.
1 - Prochot Enable
0 - Thermtrip Enable |
MSAc | fp88 | 2 | K_VAR_ATOM_R | Returns the average CPU PLIMIT sent by the SMC, DIAG_LOG |
MSAg | fp88 | 2 | K_VAR_ATOM_R | Returns the average GPU PLIMIT sent by the SMC, DIAG_LOG |
MSAm | fp88 | 2 | K_VAR_ATOM_R | Returns the average MEM PLIMIT sent by the SMC, DIAG_LOG |
MSC0 | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSC1 | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSC2 | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSC3 | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSCP | ui16 | 2 | K_VAR_ATOM_RW | Total number of sub samples to calibrate with |
MSCR | ui16 | 2 | K_VAR_ATOM_RW | Total number of sub samples to calibrate with |
MSCS | ui8 | 1 | K_FUNC_W | Calibration Start key - Writing a value of 0x11 to this key will begin |
MSCT | ui8 | 1 | K_VAR_ATOM_RW | Total number of samples to calibrate with |
MSCa | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSCb | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSCc | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSCd | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSCl | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSCm | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSCn | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSCo | ui16 | 2 | K_VAR_ATOM_RW | Calibration key |
MSDI | flag | 1 | K_VAR_R | Indicates whether an optical disk has been inserted in the
optical disk drive (1) or the drive is empty (0). |
MSDW | flag | 1 | K_FUNC_W | ui8SSMDisplayWakeSleep is a function called by the OS to notify the SMC
that the display is now awake (i.e., on) or asleep (i.e. off), so that
the SMC can set the correct behavior for the Status Indicator Light. |
MSHA | fp79 | 2 | K_VAR_ATOM_R | Average HDD activity (range 0 to 1) in U7.9 format. |
MSLD | ui8 | 1 | K_VAR_R | Returns the current Lid Switch state |
MSPA | fp6a | 2 | K_VAR_ATOM_R | Average count of prochot assertions between 0 and 1 in 6.10 format, DIAG_LOG. |
MSPC | ui8 | 1 | K_FUNC_RW | reads and writes the number of available "Power states" for the CPU. |
MSPS | {msp | | K_VAR_R | Returns the current (enumerated) system power state exported by the
SMC's System State Machine. |
MSSD | si8 | 1 | K_FUNC_RW | Stores the last known Shut-down cause.
STOP_CAUSE_SHUTDOWN_GOOD_CODE 5
STOP_CAUSE_SLEEP_GOOD_CODE 5
STOP_CAUSE_POWERKEY_GOOD_CODE 3
SLEEP_CAUSE_SLEEP_LOWBATT_CODE 2 // Deprecated. Use STOP_CAUSE_LOWBATT
SLEEP_CAUSE_SLEEP_OVERTEMP_CODE 1 // Deprecated. Use appropriate STOP_CAUSE_TEMP*
STOP_CAUSE_INIT_CODE 0 // Initial code
STOP_CAUSE_HEALTHCHECK_CODE -1 // 0xFF
STOP_CAUSE_PS_CODE -2 // 0xFE
STOP_CAUSE_TEMP_MULTISLEEP_CODE -3 // 0xFD
STOP_CAUSE_SENSORFAN_CODE -4 // 0xFC
STOP_CAUSE_TEMP_OVERLIMITTO_CODE -30 // 0xE2
STOP_CAUSE_PSWRSMRST_CODE -40 // 0xD8
STOP_CAUSE_UNMAPPED_CODE -50 // 0xCE Deprecated because it should never occur
STOP_CAUSE_LOWBATT_CODE -60 // 0xC4
STOP_CAUSE_NINJA_SHUTDOWN_CODE -61 // 0xFF
STOP_CAUSE_NINJA_RESTART_CODE -62 // 0xC2
STOP_CAUSE_TEMP_PALM_CODE -70 // 0xBA
STOP_CAUSE_TEMP_SODIMM_CODE -71 // 0xB9
STOP_CAUSE_TEMP_HEATPIPE_CODE -72 // 0xB8
STOP_CAUSE_TEMP_BATT_CODE -74 // 0xB6
STOP_CAUSE_ADAPTERTO_CODE -75 // 0xB5
STOP_CAUSE_TEMP_MANUAL_CODE -77 // 0xB3 Not currently used.
STOP_CAUSE_CURRENT_ADAPTER_CODE -78 // 0xB2
STOP_CAUSE_CURRENT_BATT_CODE -79 // 0xB1
STOP_CAUSE_TEMP_SKIN_CODE -82 // 0xAE
STOP_CAUSE_TEMP_BACKUP_CODE -84 // 0xAC
STOP_CAUSE_TEMP_SKIN_BOTHBAD_CODE -83 // 0xAB Will die with M57, M59, M75, M76
STOP_CAUSE_TEMP_CPUPROX_CODE -86 // 0xAA
STOP_CAUSE_TEMP_CPU_CODE -95 // 0xA1
STOP_CAUSE_TEMP_PS_CODE -100 // 0x9C
STOP_CAUSE_TEMP_LCD_CODE -101 // 0x9B
STOP_CAUSE_RSM_POWER_FAIL_CODE -102 // 0x9A
STOP_CAUSE_BATT_CUV_CODE -103 // 0x99
STOP_CAUSE_UNKNOWN_CODE -128 // 0x80 for unknown shutdown cause
|
MSSF | ui32 | 4 | K_FUNC_RW | Bad fan flag bits. A bit-vector in which each bit position represents a corresponding fan status. The
bit-vector is write-one-to-clear for each fan/bit position |
MSSP | si8 | 1 | K_VAR_RW | Stores the last known Sleep Request cause. See MSSD for list of causes. |
MSSS | {mss | | K_VAR_R | Returns the current (enumerated) state of the SMC's System State Machine |
MSTC | ui16 | 2 | K_VAR_ATOM_RW | - ScratchPad register that outputs via Tlog so that a script running on the SUT can add to the log what test case was running. |
MSTM | ui8 | 1 | K_FUNC_R | Returns whether power balancing is enabled or not. |
MSTc | ui8 | 1 | K_VAR_ATOM_R | Returns the last CPU PLIMIT sent by the SMC |
MSTg | ui8 | 1 | K_VAR_ATOM_R | Returns the last GPU PLIMIT sent by the SMC |
MSTm | ui8 | 1 | K_VAR_ATOM_R | Returns the last MEM PLIMIT sent by the SMC |
MSWR | ui8 | 1 | K_FUNC_W | ui8SSMStartWarmReset is a function called by the OS to notify that SMC
that a warm reset is beginning. |
NATJ | ui8 | 1 | K_VAR_RW | Ninja Action Timer Job. This job is performed when the Ninja Action Timer
counts down to zero. Job can be any of:
0 = Do Nothing
1 = Force Shutdown to S5
2 = Force Restart
3 = Force Startup
4 = reserved |
NATi | ui16 | 2 | K_VAR_ATOM_RW | Ninja Action Timer. This timer can be set to the number of seconds before a job
(defined in NATJ) is performed. Value is in seconds and counts down to zero. Setting to zero
cancels any previously set timer. |
NTOK | ui8 | 1 | K_FUNC_W | Key for OS X to write to turn on Proprietary Host Notifies. |
ONMI | ui8 | 1 | K_VAR_ATOM_RW | NMI flag (For OS NMI) |
PC0C | fp88 | 2 | K_VAR_ATOM_RW | CPU 0 core power |
PC0c | ui16 | 2 | K_VAR_ATOM_RW | CPU 0 core power. Raw ADC input value. |
PD0R | fp88 | 2 | K_VAR_ATOM_RW | DC-In MLB S0 rail power |
PD5R | fp88 | 2 | K_VAR_ATOM_RW | DC-In MLB S5 rail power |
PDMR | fp88 | 2 | K_VAR_ATOM_RW | DC-In MLB Total (S0+S5) power |
PDTR | fpa6 | 2 | K_VAR_ATOM_RW | DC-In System Total (S0+S5+LCD+HDD) power |
PG0R | fp88 | 2 | K_VAR_ATOM_RW | GPU0 rail power |
PZ0E | fp88 | 2 | K_VAR_ATOM_RW | Zone0 average target power (PC0C+PG0R) |
PZ0G | fp88 | 2 | K_VAR_ATOM_RW | Zone0 average power (PC0C+PG0R) |
RBr | ch8* | | K_DESC_STR | Source branch |
REV | {rev | | K_CONST | Source revision |
RMde | char | 1 | K_CONST | Mode. What code is currently being executed. 'B'=base flasher, 'U'=update flasher or 'A'=app code |
RPlt | ch8* | | K_CONST | Platform String |
RSvn | ui32 | 4 | K_CONST | SVN database revision |
RVBF | {rev | | K_FUNC_R | Base flasher revision |
RVUF | {rev | | K_FUNC_R | Update flasher revision |
SAS! | ui32 | 4 | KWPRIV_VAR_ATOM_RW | ADC sensor force bits [31:0]. Setting bit(s) will prevent periodic ADC conversion cycle from overwriting
sensor data for selected channels. |
SBF | ui16 | 2 | K_VAR_ATOM_R | Bad sensor flags. One per PID, defined as follows:
PID Bit Hex Dec
--- --- ------ ---
CPU 0 0x0001 1
GPU 1 0x0002 2
HDD 2 0x0004 4
ODD 3 0x0008 8
PS 4 0x0010 16
LCD 5 0x0020 32 |
SBFC | ui16 | 2 | K_VAR_ATOM_RW | When a bit has been set by the SMC in SBF key and is then subsequently reset by writing
this key, it will cause the appropriate data elements for the PID to be reset
and the pid will resume normal behaviour if it's sensors are working properly again.
Note that it may take a few minutes for the fans associated with that PID loop to return
to normal speed due to PID loop tuning. |
SBFE | flag | 1 | K_VAR_ATOM_RW | The state of this flag determines whether vTmBadSensorCheck
will display sensor error codes instead of actual temperatures when it
detects unstable temperatures or temperatures that are below the allowed
minimum. Defaults to TRUE (displays error codes). |
SCIA | ui16 | 2 | K_FUNC_RW | Lpc Base Address for SCIF, default is 0x3F8 |
SCIL | ui8 | 1 | K_FUNC_RW | Set this to 1 to enable SCIF to be LPC slave for EFI debug |
SCTg | sp78 | 2 | K_VAR_ATOM_RW | CPU Thermal Target Temp |
SDPE | ui8 | 1 | K_VAR_ATOM_RW | Mode bit to enable polling of developmental build sensors. Default state will vary depending on build. |
SDRd | ui16 | 2 | K_FUNC_W | Delayed sensor read. Writing a value in ms will cause the SMC to start a timer which when
expires will cause the SMC to set force bits for polled sensors. This effectively allows a follow on
query to sample the state of the sensors at the desired time. Value in ms. |
SGHT | ui8 | 1 | K_VAR_ATOM_R | Sensor Graphics HoT. 1 = GPU Overtemp. |
SGTT | sp78 | 2 | K_VAR_ATOM_RW | GPU Heatsink Throttle Threshold Temperature. If the GPU's
heatsink temperature exceeds this temperature, the SMC will assert the
GPU's throttle to slow and cool the GPU. |
SGTg | sp78 | 2 | K_VAR_ATOM_RW | GPU Thermal Target Temp |
SHTg | sp78 | 2 | K_VAR_ATOM_RW | HDD Thermal Target Temp |
SIS! | ui16 | 2 | KWPRIV_VAR_ATOM_RW | I2C sensor force bits. Setting bit(s) will prevent periodic
I2C polling cycle overwriting sensor data. This key is intended for
expert use only. Bit mappings for M72/M78/K2/K3 are as follows:
Bit Hex Dec Key Description
--- ------ ----- ---- ------------
0 0x0001 1 TC0H CPU Heatsink
1 0x0002 2 TG0H GPU Heatsink
2 0x0004 4 TH0P HDD Proximity
3 0x0008 8 TO0P ODD Proximity
4 0x0010 16 Tm0P MLB Proximity
5 0x0020 32 TA0P Ambient
6 0x0040 64 Tp0P Power Supply Proximity
7 0x0080 128 TW0P Wireless (Airport) Proximity
8 0x0100 256 TC0P CPU Proximity
9 0x0200 512 TC0D CPU Die
10 0x0400 1024 TG0P GPU Proximity
11 0x0800 2048 TG0D GPU Die
12 0x1000 4096 TL0P LCD Proximity
13 0x2000 8192 SGTT GPU Heatsink Throttle Threshold
Special error codes (used by individual temperature keys, not by SIS!):
Hex Dec Description
------ ----- -----------
0x7FE7 127.9 Hot temperature
0x8400 -124 Unstable temperature
0x8300 -125 Temperature below allowed minimum
0x8200 -126 Sensor failed to initialize
0x8100 -127 Sensor skipped
0x8000 -128 Temperature can't be read |
SLPT | sp78 | 2 | K_VAR_ATOM_RW | LCD Prochot threshold. TL0P temp at which Prochot will be asserted. |
SLST | sp78 | 2 | K_VAR_ATOM_RW | LCD Sleep threshold. TL0P temp at which Sleep will be requested. |
SLTg | sp78 | 2 | K_VAR_ATOM_RW | LCD Fan Temp Target |
SLTp | sp78 | 2 | K_VAR_ATOM_RW | LCD Power Temp Target |
SOTg | sp78 | 2 | K_VAR_ATOM_RW | ODD Thermal Target Temp |
SPH0 | ui16 | 2 | K_VAR_R | CPU Prochot event count since last boot |
SPHR | ui32 | 4 | K_VAR_ATOM_R | Any bit set to 1 identifies an active Prochot requestor.
For K2/K3, the following bits are defined:
Bit 31: User-forced Prochot
Bit 30: RSVD for "Prochot forever in lieu of Thermtrip" (currently unused)
Bits 4-29: RSVD
Bit 3: Prochot Power Index
Bit 2: Power-supply overcurrent
Bit 1: Power-supply overtemp
Bit 0: LCD panel overtemp |
SPHS | ui8 | 1 | K_VAR_ATOM_RW | Indicates if PROCHOT was ever set after entering S0, DIAG_LOG |
SPHT | ui16 | 2 | K_VAR_ATOM_R | Current state of all Prochots and whether the SMC itself is
asserting each one.
Bits 0-7: Prochot state for CPUs 0-7, respectively (1 bit per CPU).
1 = Prochot asserted. 0 = Prochot deasserted.
Bits 8-15: The SMC itself is asserting Prochot for CPUs 0-7,
respectively (1 bit per CPU; bit 8 corresponds to CPU 0,
bit 15 corresponds to CPU 7).
1 = SMC is asserting Prochot to that CPU.
0 = SMC is NOT asserting Prochot to that CPU.
|
SPHZ | ui8 | 1 | K_FUNC_W | Drive SMC Prochot(s). In the single byte of write data,
bits 0 through 7 control the Prochots for CPUs 0 through 7,
respectively. For example, writing 0x01 sets Prochot for CPU 0, while
writing 0x80 sets Prochot for CPU 7, and writing 0xFF sets all 8
Prochots. Setting bits for CPUs that don't exist does nothing
and causes no harm.
|
SPS! | ui16 | 2 | KWPRIV_VAR_ATOM_RW | Power force bits. Setting bit(s) will prevent periodic power calculations from overwriting
existing data. Bit mapping varies by platform and is intended for expert use only. |
SpCP | fps4 | 2 | K_VAR_ATOM_R | Read-only PS I-squared sum Prochot threshold in U27.4 format.
Sample computation: [(Prochot threshold in watts)/12v]^2 * (Filter depth = 24576)
Hex value is the above * 16. |
SpCS | fps4 | 2 | K_VAR_ATOM_R | Read-only PS I-squared sum target for P3-level PS current control, in U27.4 format.
Sample computation: [(Target in watts)/12v]^2 * (Filter depth = 24576)
Hex value is the above * 16. |
SpCT | fpc4 | 2 | K_VAR_ATOM_R | Read-only PS I-squared target (non-summed) for initializing PS current control filter history, in U12.4 format.
Sample computation: [(Target in watts)/12v]^2.
Hex value is the above * 16. |
SpPT | sp78 | 2 | K_VAR_ATOM_RW | PS Prochot threshold. Tp0P temp at which Prochot will be asserted |
SpST | sp78 | 2 | K_VAR_ATOM_RW | PS Sleep threshold. Tp0P temp at which Sleep will be requested. |
SpTg | sp78 | 2 | K_VAR_ATOM_RW | PS Fan Temp Target |
TA0P | sp78 | 2 | K_VAR_ATOM_RW | Ambient temp |
TC0D | sp78 | 2 | K_VAR_ATOM_RW | CPU 0 die temp |
TC0H | sp78 | 2 | K_VAR_ATOM_RW | CPU 0 Heatsink temp |
TC0P | sp78 | 2 | K_VAR_ATOM_RW | CPU 0 Proximity temp |
TG0D | sp78 | 2 | K_VAR_ATOM_RW | GPU 0 die temp |
TG0H | sp78 | 2 | K_VAR_ATOM_RW | GPU 0 Heatsink temp |
TG0P | sp78 | 2 | K_VAR_ATOM_RW | GPU 0 Proximity temp |
TH0P | sp78 | 2 | K_VAR_ATOM_RW | HardDisk proximity temp |
TL0P | sp78 | 2 | K_VAR_ATOM_RW | LCD proximity temp |
TO0P | sp78 | 2 | K_VAR_ATOM_RW | Optical Drive proximity temp |
TW0P | sp78 | 2 | K_VAR_ATOM_RW | Airport temp |
Tm0P | sp78 | 2 | K_VAR_ATOM_RW | Misc Local temp |
Tp0P | sp78 | 2 | K_VAR_ATOM_RW | Power Supply Proximity temp |
UPRC | ui16 | 2 | K_CONST | Type of SMC microcontroller upon which system is based (value of UPROC macro) |
VC0C | fp1f | 2 | K_VAR_ATOM_RW | CPU 0 core voltage. |
VC0c | ui16 | 2 | K_VAR_ATOM_RW | CPU 0 core voltage. Raw ADC input value. |
VD0R | fp4c | 2 | K_VAR_ATOM_RW | DC In S0 rail voltage. |
VD5R | fp4c | 2 | K_VAR_ATOM_RW | DC In S5 rail voltage. |
VG0R | fp4c | 2 | K_VAR_ATOM_RW | GPU 0 rail voltage. |
VG0r | ui16 | 2 | K_VAR_ATOM_RW | GPU 0 rail voltage. Raw ADC input value. |
dBA0 | sp78 | 2 | K_VAR_ATOM_R | Acoustic Reporting. Fan 0 Noise Component (dBA). |
dBA1 | sp78 | 2 | K_VAR_ATOM_R | Acoustic Reporting. Fan 1 Noise Component (dBA). |
dBA2 | sp78 | 2 | K_VAR_ATOM_R | Acoustic Reporting. Fan 2 Noise Component (dBA). |
dBAH | sp78 | 2 | K_VAR_ATOM_R | Acoustic Reporting. HDD Noise Component (dBDA). |
dBAT | sp78 | 2 | K_VAR_ATOM_R | Acoustic Reporting. Total Noise of all calculated components (dBDA). |
zDBG | ui8 | 1 | K_FUNC_RW | Set this to 1 to enable SCIF debug output to USB 0 Port |
{ala | \0\0\0\0 | | K_DESC_STR | ALS analog lux calculation information.
struct ALSLuxLine {
UInt16 ui16ALSM; // Slope of line.
Int16 i16ALSB; // Y-Intercept of line.
UInt16 ui16ALSR; // Region.
}
|
{alc | \0\0\0\0 | | K_DESC_STR | ALSConfig structure contains global ALS configuration and tuning info
struct ALSConfig {
UInt16 ui16ALSI2CTime; // Int interval (ms) for ALS I2C task.
UInt16 ui16ALSADCTime; // Int interval (ms) for ALS ADC ISR.
UInt16 ui16LMax; // Maximum cd/m^2 for SIL.
UInt16 ui16LMin; // Minimum cd/m^2 for SIL.
UInt16 ui16ELow; // Low room illum threshold (lux).
UInt16 ui16EHigh; // High room illum threshold (lux).
UInt16 ui16Reflect; // Bezel reflection coefficient.
UInt8 ui8ALSSensors; // Actual number of ALS sensors in system.
UInt8 ui8LidDelay; // Delay after lid opens (in tenths of seconds)
// during which ALS readings don't affect the
// SIL.
}
|
{ali | \0\0\0\0 | | K_DESC_STR | ALSSensor structure contains sensor-specific information for this system
enum ALSType { NoSensor, BS520, TSL2561CS, LX1973A, ISL29003 };
struct ALSSensor {
enum ALSType alstALSType; // Type of sensor.
Flag fValidWhenLidClosed; // TRUE if no lid or if sensor works with
// closed lid. FALSE otherwise.
Flag fControlSIL; // TRUE if the SIL brightness depends on
// this sensor's value. FALSE otherwise.
}
|
{alr | \0\0\0\0 | | K_DESC_STR | ALS analog lux temperature coefficients.
struct ALSTherm {
Int16 i16ALSTempBase; // Temperature baseline (deg C, FP16.0)
UInt16 ui16ALSTempCoefV; // Temperature coeff (ADC Counts/deg C, FP12.4)
UInt16 ui16ALSTempInflV; // Thermal compensation inflection point voltage
// (ADCCounts, FP16.0)
Int16 i16ALSTempLow; // Low temperature boundary (deg C, FP16.0)
Int16 i16ALSTempHigh; // High temperature boundary (deg C, FP16.0)
}
|
{alt | \0\0\0\0 | | K_DESC_STR | ALS analog lux calculation thresholds.
struct ALSLuxThrsh {
UInt16 ui16ALSThrshLow; // ADC threshold while in low gain.
UInt16 ui16ALSThrshHigh; // ADC threshold while in high gain.
}
|
{alv | \0\0\0\0 | | K_DESC_STR | ALSValue structure contains latest ambient light info from 1 sensor
struct ALSValue {
Flag fValid; // If TRUE, data in this struct is valid.
Flag fHighGain; // If TRUE, ui16Chan0/1 are high-gain
// readings. If FALSE, ui16Chan0/1 are
// low-gain readings.
UInt16 ui16Chan0; // I2C channel 0 data or analog(ADC) data.
UInt16 ui16Chan1; // I2C channel 1 data.
The following field only exists on systems that send ALS change
notifications to the OS:
UInt32 ui32RoomLux; // Room illumination in lux, FP18.14.
}
|
{fds | \0\0\0\0 | | K_DESC_STR | Fan Diag description
typedef struct fanTypeDescStruct {
FanType type;
UInt8 ui8Zone;
LocationType location;
UChar rsvd; // padding to get us to 16 bytes
char strFunction[DIAG_FUNCTION_STR_LEN];
} FanTypeDescStruct;
FAN constants
+---+
z/ /|
/ / |
+---+ |
| | +
y| | /
| |/
+---+
x
typedef enum { LEFT_LOWER_FRONT, CENTER_LOWER_FRONT, RIGHT_LOWER_FRONT,
LEFT_MID_FRONT, CENTER_MID_FRONT, RIGHT_MID_FRONT,
LEFT_UPPER_FRONT, CENTER_UPPER_FRONT, RIGHT_UPPER_FRONT,
LEFT_LOWER_REAR, CENTER_LOWER_REAR, RIGHT_LOWER_REAR,
LEFT_MID_REAR, CENTER_MID_REAR, RIGHT_MID_REAR,
LEFT_UPPER_REAR, CENTER_UPPER_REAR, RIGHT_UPPER_REAR } LocationType;
typedef enum { FAN_PWM_TACH, FAN_RPM, PUMP_PWM, PUMP_RPM, FAN_PWM_NOTACH, EMPTY_PLACEHOLDER } FanType;
|
{lim | \0\0\0\0 | | KPRIV_DESC_STR | Plimits group is 3 UInt8s:
MSB: Cpu Limit
Gpu Limit
LSB: Mem Limit
|
{lsc | \0\0\0\0 | | K_DESC_STR | LmsConfig structure provides overall system-specific config info for the SIL.
See "{pwm" for details on PWMValue
See "{lsm" for details on LmsScaleMode
struct LmsConfig {
PWMValue modvBrightnessBreatheMin; // Breathe dwell PWM setting
PWMValue modvMaxChangePerTick; // Max PWM change per 1/152 sec
UInt16 ui16ScaleConstant; // Scale constant (1.15 fixed-point
// representation) if not using
// ALS or TOD scaling
LmsScaleMode lmsmScaleMode; // Scale by ALS, TOD, or constant
UInt8 ui8RampDuration; // Ramp length (equals 152 *
// ramp time in seconds)
Flag fPowerSwitchOverridesSIL; // TRUE if pressing the power
// switch should force the
// SIL to full brightness
UInt8 ui8MinTicksToTarget; // Slow the slew rate so that
// it takes at least this many
// ticks to reach the target
// from the prev PWM value.
}
|
{lsd | \0\0\0\0 | | K_DESC_STR | LmsDwell structures provide dwell fade-up/down configuration
struct LmsDwell {
UInt16 ui16MidToStartRatio; // Mid-step size / start-step size
UInt16 ui16MidToEndRatio; // Mid-step size / end-step size
UInt16 ui16StartTicks; // # of ticks using start-step size
UInt16 ui16EndTicks; // # of ticks using end-step size
}
|
{lsf | \0\0\0\0 | | K_DESC_STR | LmsFlare structures provide flare config for non-breathing fade-up/down
See "{pwm" for details on PWMValue
struct LmsFlare {
PWMValue modvFlareCeiling; // Flare algorithm is active below this value.
PWMValue modvMinChange; // Minimum rate of change while flaring.
UInt16 ui16FlareAdjust; // Smaller value causes stronger flare as
} // PWM value descends below modvFlareCeiling.
|
{lsm | \0\0\0\0 | | K_DESC_STR | LmsScaleMode enum
enum LmsScaleMode { kLmsScaleALS, // Use ALS autoscale
kLmsScaleTOD, // Use TOD autoscale
kLmsScaleConst // Scale only by a constant
}
|
{lso | \0\0\0\0 | | K_DESC_STR | LmsOverrideBehavior structure provides a means to override the SIL's
behavior.
See "{lss" for details on LmsSelect
struct LmsOverrideBehavior {
LmsSelect lmssTargetBehavior; // Enumerated SIL behavior
Flag fRamp; // Set to 1 (LMS_RAMP) for a slew-rate
// controlled transition. Set to 0
// (LMS_NO_RAMP) for a step change.
}
|
{lss | \0\0\0\0 | | K_DESC_STR | LmsSelect behavior enum
enum LmsSelect { kLmsOff, // SIL off
kLmsOn, // SIL on, autoscale OK
kLmsBreathe, // SIL breathing, autoscale OK
kLmsBrightNoScale // SIL on bright, no autoscale
// (for power switch override)
}
|
{msp | \0\0\0\0 | | K_DESC_STR | SSMPowerState typedef
enum SSMPowerState { SSM_POWER_STATE_S0 = 0,
SSM_POWER_STATE_S3 = 1,
SSM_POWER_STATE_S4 = 2,
SSM_POWER_STATE_S5 = 3,
SSM_POWER_STATE_G3_AC = 4,
SSM_POWER_STATE_G3_HOT = 5,
SSM_POWER_STATE_QUERY = 6,
}
|
{mss | \0\0\0\0 | | K_DESC_STR | SSMState typedef
enum SSMState { SSM_S0_DISP_WAKE = 0,
SSM_S0_DISP_SLEEP = 1,
SSM_G3_HOT = 2,
SSM_S3_SLEEP = 3,
SSM_S4_HIBER = 4,
SSM_S5_OFF = 5,
SSM_S0_ASP_WAIT = 6,
SSM_S0_IMVP_WAIT = 7,
SSM_S0_EARLY_DISP_SLEEP = 8,
SSM_S0_EARLY_DISP_WAKE = 9,
SSM_S3_EARLY = 10,
SSM_S4_EARLY = 11,
SSM_QUERY = 12,
SSM_ICH_RST = 13,
SSM_G2_BATTERY_DEAD = 14,
SSM_G2_POWER_WAIT = 15,
SSM_G2_RESET_WAIT = 16,
SSM_G3_AC = 17,
SSM_G2_ACPWR_WAIT = 18,
SSM_G2_ACRST_WAIT = 19
}
|
{pwm | \0\0\0\0 | | K_DESC_STR | PWMValue typedef
typedef UInt16 PWMValue;
0xFFFF is full-on, 0x0 is full-off.
|