Visible to the public Handling Anti-Virtual Machine Techniques in Malicious Software

TitleHandling Anti-Virtual Machine Techniques in Malicious Software
Publication TypeJournal Article
Year of Publication2017
AuthorsShi, Hao, Mirkovic, Jelena, Alwabel, Abdulla
JournalACM Trans. Priv. Secur.
Volume21
Pagination2:1–2:31
Date PublishedDecember 2017
ISSN2471-2566
Keywordsassembly, Human Behavior, malware analysis, Metrics, privacy, pubcrawl, Resiliency, reverse engineering, system security, virtual machine testing
Abstract

Malware analysis relies heavily on the use of virtual machines (VMs) for functionality and safety. There are subtle differences in operation between virtual and physical machines. Contemporary malware checks for these differences and changes its behavior when it detects a VM presence. These anti-VM techniques hinder malware analysis. Existing research approaches to uncover differences between VMs and physical machines use randomized testing, and thus cannot guarantee completeness. In this article, we propose a detect-and-hide approach, which systematically addresses anti-VM techniques in malware. First, we propose cardinal pill testing--a modification of red pill testing that aims to enumerate the differences between a given VM and a physical machine through carefully designed tests. Cardinal pill testing finds five times more pills by running 15 times fewer tests than red pill testing. We examine the causes of pills and find that, while the majority of them stem from the failure of VMs to follow CPU specifications, a small number stem from under-specification of certain instructions by the Intel manual. This leads to divergent implementations in different CPU and VM architectures. Cardinal pill testing successfully enumerates the differences that stem from the first cause. Finally, we propose VM Cloak--a WinDbg plug-in which hides the presence of VMs from malware. VM Cloak monitors each execute malware command, detects potential pills, and at runtime modifies the command's outcomes to match those that a physical machine would generate. We implemented VM Cloak and verified that it successfully hides VM presence from malware.

URLhttps://dl.acm.org/doi/10.1145/3139292
DOI10.1145/3139292
Citation Keyshi_handling_2017