Blog posts
The implementation is rather complex and this domain in software development is rarely documented in layman's terms. This is why there are blog posts which detail every design choice and go over the quirks of working with the LLVM API.- https://blog.scrt.ch/2020/06/19/engineering-antivirus-evasion/
- https://blog.scrt.ch/2020/07/15/engineering-antivirus-evasion-part-ii/
Build
docker build . -t avcleanerdocker run -v ~/dev/scrt/avcleaner:/home/toto -it avcleaner bash #adapt ~/dev/scrt/avcleaner to the path where you cloned avcleanersudo pacman -Syumkdir CMakeBuild && cd CMakeBuildcmake ..make -j 2./avcleaner.bin --helpUsage
For simple programs, this is as easy as:avcleaner.bin test/strings_simplest.c --strings=true --However, you should know that you're using a compiler frontend, which can only work well if you give it the path to ALL the includes required to build your project. As an example,
test/string_simplest.c includes headers from the WinSDK, and the script run_example.sh shows how to handle such scenarios.Common errors
CommandLine Error: Option 'non-global-value-max-name-size' registered more than once! LLVM ERROR: inconsistency in registered CommandLine optionsIn case you encounter this error, please use
CMakeLists_archlinux.txt instead of CMakeLists.txt and it should go away.Source Github : https://github.com/scrt/avcleaner