2. Bitland MIFS driver (bitland-mifs-wmi)

2.1. Introduction

2.2. EC WMI interface description

The EC WMI interface description can be decoded from the embedded binary MOF (bmof) data using the bmfdec utility:

class WMIEvent : __ExtrinsicEvent {
};

[WMI, Dynamic, Provider("WmiProv"), Locale("MS\\0x40A"), Description("Root WMI HID_EVENT20"), guid("{46c93e13-ee9b-4262-8488-563bca757fef}")]
class HID_EVENT20 : WmiEvent {
  [key, read] string InstanceName;
  [read] boolean Active;
  [WmiDataId(1), read, write, Description("Package Data")] uint8 EventDetail[8];
};

[WMI, Dynamic, Provider("WmiProv"), Locale("MS\\0x40A"), Description("Root WMI HID_EVENT21"), guid("{fa78e245-2c0f-4ca1-91cf-15f34e474850}")]
class HID_EVENT21 : WmiEvent {
  [key, read] string InstanceName;
  [read] boolean Active;
  [WmiDataId(1), read, write, Description("Package Data")] uint8 EventDetail[8];
};

[WMI, Dynamic, Provider("WmiProv"), Locale("MS\\0x40A"), Description("Root WMI HID_EVENT22"), guid("{1dceaf0a-4d63-44bb-bd0c-0d6281bfddc5}")]
class HID_EVENT22 : WmiEvent {
  [key, read] string InstanceName;
  [read] boolean Active;
  [WmiDataId(1), read, write, Description("Package Data")] uint8 EventDetail[8];
};

[WMI, Dynamic, Provider("WmiProv"), Locale("MS\\0x40A"), Description("Root WMI HID_EVENT23"), guid("{3f9e3c26-b077-4f86-91f5-37ff64d8c7ed}")]
class HID_EVENT23 : WmiEvent {
  [key, read] string InstanceName;
  [read] boolean Active;
  [WmiDataId(1), read, write, Description("Package Data")] uint8 EventDetail[8];
};

[WMI, Dynamic, provider("WmiProv"), Locale("MS\\0x409"), Description("Class used to operate firmware interface"), guid("{b60bfb48-3e5b-49e4-a0e9-8cffe1b3434b}")]
class MICommonInterface {
  [key, read] string InstanceName;
  [read] boolean Active;

  [WmiMethodId(1), Implemented, read, write, Description("Method used to support system functions.")] void MiInterface([in, Description("WMI Interface")] uint8 InData[32], [out] uint8 OutData[30], [out] uint16 Reserved);
};

2.3. Reverse-Engineering the EC WMI interface

The OEM software can be download from this link

Nothing is obfuscated, In this case, ILSpy could be helpful.

2.4. WMI Methods (MICommonInterface)

The MICommonInterface class (GUID: {b60bfb48-3e5b-49e4-a0e9-8cffe1b3434b}) is the primary control interface. It uses a 32-byte buffer for both input (InData) and output (OutData).

2.4.1. Method Structure

The data packet follows a standardized format:

Byte

Description

1

Method Type: Get (0xFA / 250) or Set (0xFB / 251)

3

Command ID (Method Name)

4 - 31

Arguments (for Set) or Return Data (for Get)

2.4.2. Command IDs

The following Command IDs are used in the third byte of the buffer:

ID

Name

Values / Description

8

SystemPerMode

0: Balance, 1: Performance, 2: Quiet, 3: Full-speed

9

GPUMode

0: Hybrid, 1: Discrete, 2: UMA

10

KeyboardType

0: White, 1: Single RGB, 2: Zone RGB

11

FnLock

0: Off, 1: On

12

TPLock

0: Unlock, 1: Lock (Touchpad)

13

CPUGPUSYSFanSpeed

Returns 12 bytes of fan data: Bytes 4-5: CPU Fan RPM (Little Endian) Bytes 6-7: GPU Fan RPM (Little Endian) Bytes 10-11: SYS Fan RPM (Little Endian)

16

RGBKeyboardMode

0: Off, 1: Auto Cyclic, 2: Fixed, 3: Custom

17

RGBKeyboardColor

Bytes 4, 5, 6: Red, Green, Blue values

18

RGBKeyboardBrightness

0-10: Brightness Levels, 128: Auto

19

SystemAcType

1: Type-C, 2: Circular Hole (DC)

20

MaxFanSpeedSwitch

Byte 4: Fan Type (0: CPU/GPU, 1: SYS) Byte 5: State (0: Off, 1: On)

21

MaxFanSpeed

Sets manual fan speed duty cycle

22

CPUThermometer

Returns CPU Temperature

2.5. WMI Events (HID_EVENT20)

The driver listens for events from the HID_EVENT20 class (GUID: {46c93e13-ee9b-4262-8488-563bca757fef}). These events are triggered by hotkeys or system state changes (e.g., plugging in AC power).

2.5.1. Event Structure

The event data is provided in an 8-byte array (EventDetail):

Byte

Description

0

Event Type (Always 0x01 for HotKey/Notification)

1

Event ID (Corresponds to the Command IDs above)

2

Value (The new state or value of the feature)

2.5.2. Common Event IDs:

Note: reserved event ids are not listed there

Event Id

Description

4

AirPlane mode change

5

Keyboard brightness change

6

Touchpad state (enabled/disabled) change

7

FnLock state (enabled/disabled) change

8

Keyboard mode change

9

CapsLock state change

13

NumLock state change

14

ScrollLock state change

15

Performance plan change

25

Display refresh rate change

33

Super key lock state (enabled/disabled) change

35

Open control center key

2.6. Implementation Details

2.6.1. Performance Modes

Changing the performance mode via Command ID 0x08 (SystemPerMode) affects the power limits (PL1/PL2) and fan curves managed by the Embedded Controller (EC). Note that the “Full-speed” and “Performance” mode (1, 3) is typically only available when the system is connected to a DC power source (not USB-C/PD).

In the driver implementation, switch to performance/full-speed mode without DC power connected will throw the EOPNOTSUPP error.

2.6.2. Graphics Switching

The GPUMode (0x09) allows switching between Hybrid (Muxless) and Discrete (Muxed) graphics. Changing this value usually requires a system reboot to take effect in the BIOS/Firmware.

2.6.3. Fan Control

The system supports both automatic EC control and manual overrides. Command ID 0x14 (MaxFanSpeedSwitch) is used to toggle manual control, while ID 0x15 sets the actual PWM duty cycle.