-
-
Notifications
You must be signed in to change notification settings - Fork 415
FS_YaraSearch
The directory search/yara exists as a sub-directory to the file system root under /misc/search/yara and in each process directory.
The search functionality allows for flexible efficient searching with yara rules in process virtual memory and/or physical memory.
The files in the search/yara directories are listed in the table below:
File | Description |
---|---|
addr-min.txt | Minimum address to search from. |
addr-max.txt | Maximum address to search to. |
readme.txt | README file. |
reset.txt | Write 1 to prepare for new search / abort on-going search / empty previous search. |
result.txt | Addresses with search matches. |
result-v.txt | Detailed information about the yara search matches. |
status.txt | Status of an ongoing or completed search. |
yara-rules-file.txt | Full path to yara rules file (compiled or source). |
Files in the search/yara directories are read-write with the exception of readme.txt, result.txt and status.txt.
Before a search is initiated it's possible to set optional constraints, such as min and max address.
The search is initiated by writing the path to a yara rules file into yara-rules-file.txt. Once written the search starts immediately if the rules can be loaded.
It's possible to follow the status of the search by monitoring status.txt. It's also possible to abort/clear a previous search by writing 1 into reset.txt - this will allow for new search.
The search functionality in misc/search
will search the entire physical memory space.
The search functionality in each process will search the process virtual memory. In case of a 64-bit address space the search will only be performed on the relevant address space (as shown in the memmap functionality) for performance reasons. To search kernel address space please select the SYSTEM (PID 4) process or one of the CSRSS.EXE processes. Other processes are usually only searched in the user part of the address space - i.e. 0x0 to 0x7fffffffffff.
Yara searching requires supporting files - vmmyara.dll
(Windows) and vmmyara.so
(Linux). The required supporting files from the vmmyara project are pre-packaged with the MemProcFS binary releases.
The example shows the search for the trickbot malware in a single svchost process.
The search/yara sub-directories are implemented as a built-in native C-code plugin. The plugin source is located in the file modules/m_searchyara.c in the vmm project.
Sponsor PCILeech and MemProcFS:
PCILeech and MemProcFS is free and open source!
I put a lot of time and energy into PCILeech and MemProcFS and related research to make this happen. Some aspects of the projects relate to hardware and I put quite some money into my projects and related research. If you think PCILeech and/or MemProcFS are awesome tools and/or if you had a use for them it's now possible to contribute by becoming a sponsor!
If you like what I've created with PCIleech and MemProcFS with regards to DMA, Memory Analysis and Memory Forensics and would like to give something back to support future development please consider becoming a sponsor at: https://github.com/sponsors/ufrisk
Thank You 💖