LoFP LoFP / other legimate tools loading drivers. including but not limited to, sysinternals, cpu-z, avs etc. a baseline needs to be created according to the used products and allowed tools. a good thing to do is to try and exclude users who are allowed to load drivers.

Techniques

Sample rules

Potential Privileged System Service Operation - SeLoadDriverPrivilege

Description

Detects the usage of the ‘SeLoadDriverPrivilege’ privilege. This privilege is required to load or unload a device driver. With this privilege, the user can dynamically load and unload device drivers or other code in to kernel mode. This user right does not apply to Plug and Play device drivers. If you exclude privileged users/admins and processes, which are allowed to do so, you are maybe left with bad programs trying to load malicious kernel drivers. This will detect Ghost-In-The-Logs (https://github.com/bats3c/Ghost-In-The-Logs) and the usage of Sysinternals and various other tools. So you have to work with a whitelist to find the bad stuff.

Detection logic

condition: selection_1 and not 1 of filter_*
filter_endswith:
  ProcessName|endswith:
  - \procexp64.exe
  - \procexp.exe
  - \procmon64.exe
  - \procmon.exe
  - \Google\Chrome\Application\chrome.exe
  - \AppData\Local\Microsoft\Teams\current\Teams.exe
filter_exact:
  ProcessName:
  - C:\Windows\System32\Dism.exe
  - C:\Windows\System32\rundll32.exe
  - C:\Windows\System32\fltMC.exe
  - C:\Windows\HelpPane.exe
  - C:\Windows\System32\mmc.exe
  - C:\Windows\System32\svchost.exe
  - C:\Windows\System32\wimserv.exe
  - C:\Windows\System32\RuntimeBroker.exe
  - C:\Windows\System32\SystemSettingsBroker.exe
  - C:\Windows\explorer.exe
filter_startswith:
  ProcessName|startswith: C:\Program Files\WindowsApps\Microsoft
selection_1:
  EventID: 4673
  PrivilegeList: SeLoadDriverPrivilege
  Service: '-'