May 04, 2015
                
              
                                                                Bypassing Virtualization and Sandbox Technologies
                
                  Written by
                                                            David Kennedy
                                                      
              
            
            
            
            
            
                              
                    Many security product-lines leverage sandboxing in order to detect more behavior analysis versus traditional signature based detection. Most behavior analytics are trivial to fake or circumvent depending on the technology. Regardless, these technologies are designed to handle the mass prevalent / mass infection methods, not targeted or custom malicious software. One example of this is by placing long time delays inside of the malicious code which triggers the sandbox environment to be tricked/fooled in detecting call outs to command and control or file droppers, etc.
One of the methods TrustedSec has used for a while and has been known for a long period of time is using core detection. Most commonly, this technique is being used in the Dyreza banking Trojan for sandbox evasion. The method is extremely simple, takes only a couple of lines of code, and works on almost any virtualization/sandbox technology on the market today. The way that most sandbox technologies work is by first creating a simulated environment - usually that of Windows or a Linux operating system (with wine-esk emulation) in order to determine how incoming malicious software occurs.
These virtual machines need to be heavily tweaked for efficiency and to not have a major hardware performance hit in order to operate under normal conditions. In this case, during simulated testing in our experience, it was found that a majority of the sandbox technologies leverage 1 core which is plenty for normal operation and to perform analysis quickly. This is done for efficiency and to ensure that under heavy load, it can still process a large amount of queries in fast manner. Under our testing conditions, we found three of the major sandbox technologies were vulnerable to this specific type of attack and went without detection.
Most sandbox technology analyzes both web content and incoming emails for malicious content and only requires minimal routines to be performed. This would be registry hooking, network communications, dropper files, and traditional malicious behavior. Since these technologies consistently leverage 1 core and the majority of systems in the workforce need to leverage more than 1 core, it's easy to determine when inside of a sandbox simply based on the amount of cores in a system. In order to skirt around the detection, simply detect how many cores we are operating under, and if it’s 1, there’s a high chance that we are inside of a sandbox technology.
There are a few methods on top of this; however, this one appears to be one of the more reliable methods for circumvention. In the below diagram, most sandbox technologies look at either (or both) web content and incoming/outgoing SMTP for malicious content. This could be executables, PDFs, documents, spreadsheets Applets, browser simulations, and more. Basic pattern criteria is that if a specific monitored application performs suspicious behavior, flag it as a potential malicious file.
Below depicts how this works from a technology perspective:









Get-WmiObject –class Win32_processor | ft NumberOfCoresThis simple PowerShell command can automatically detect and respond back with the number of cores a general machine is running under:
