## Class Details
The course will present an in-depth description of the techniques implemented in modern malware to evade defenders and security products (such as AV, IPS, IDS, EDR), and how attackers design and operate their implants in order to ensure a prompt redeployment after a detection or a public disclosure by researchers or security vendors.
The course will also cover real-world scenarios that impair (effectively slow-down or dissuade) reverse engineering efforts and make the job of first responders tougher. The techniques will be demonstrated in two ways: first, by reversing real malware samples, and then by re-implementing an improved version of the malware code. The training is designed from an attacker's point of view, teaching red-teams how to make their implants stealthier, but it will also teach defenders how to deal with the anti-reversing and the OPSEC techniques demonstrated in class.
The course focuses primarily on Windows malware and on the analysis, tweaking and re-purposing of real malware samples. Participants will be provided with plenty of custom code to facilitate the understanding of complex malware techniques.
As part of the course, theory sessions will be followed by exercises where participants will reverse and re-implement specific parts of real malware in order to fully understand the hidden corners of all the techniques involved. The 50% of the course will be dedicated to hands-on labs that will show how to translate the theory principles into practice.
Labs are designed to provide flexibility in terms of complexity and include bonus tracks to ensure that you always feel engaged and have something interesting to explore and learn.
To develop and test the techniques described during the theory sessions, students will be provided with the source-code of our training agent and its corresponding C2.
## Key Learning objective
* Be able to recognize, implement and deal with stealthy malware/backdoors techniques and tradecrafts.
* Be able to modify malware components and pre/post build tools to protect them against reversing efforts.
* Familiarize with the latest advances in code and DLL injection techniques and customize reflective loader.
* Be able to build custom obfuscators and to recognize some pattern left by some obfuscation transforms.
* Learn tradecrafts used by attackers to prevent and effectively impair defensive incident responders from analyzing their tools, payloads, and backdoors.
## Who should Attend
Developers and Reverse engineers who want to understand the tradecraft from a different point of view, red-team members who want to go beyond using third-party implants, and researchers who want to develop anti-detection techniques of real malware/apt.
## Prerequisites
* Programming experience (C, C++, Python, .NET, and PowerShell)
* Be familiar with assembly language and Debuggers (IDA pro, WinDBG)
## Hardware/Software requirements
#### Laptop Requirements:
* Virtualization capable CPU(s)
* Minimum 8GB of RAM (for running one guest VM)
* Minimum 80 GB free disk space
#### Software Requirements:
* Host OS Windows 10 64-bit
* Debugging Tools for Windows (Ida Pro, WinDBG). Decompiler recommended.
* SysInternals Tools
* Virtualization Software (VMWare, VirtualBox)
* Guest OS Windows 10 64-bit Version 20H2
* System Administrator access required on both host and guest OSs
## Course Agenda
#### Module 1
* Warm up (refresh basic concepts)
* DynLoader
* Dynamic APIs resolution
* Import by hash
* PEB walk
* Syscall direct invocation
* API Custom implementation
* Obfuscation I
* Obfuscation techniques
* Opaque predicates, MBA, VM obfuscators
#### Module 2
* Obfuscation II
* Source level obfuscation
* Intermediate representation obfuscations (LLVM)
* Bring your own Loader
* Windows Loader
* Alternative Loaders
* Injection I (Advanced Reflective Loader)
* Wide used injection techniques
* Reflective Loader deep analysis
* Customize RL
#### Module 3
* Injection II (Exotic Injection)
* Uncommon injection techniques
* Hooks
* Implement an exotic injector
* Anti-Debug
* Debugging internals
* Breakpoint detection (HW and SW)
* Anti-tampering
* Persistence and LPE
* COM/DLL Hijacking
* WMI persistence
* SID, UAC, DACL, PPL, PP
* Abuse WinSxS
* Handle stealer
#### Module 4
* Anti-VM
* Artifact detection
* Instruction and timing detection
* Build an anti-vm module
* Multi Lang Module
* Run managed code from unmanaged
* AMSI
* Execution Guardrails
* IPC
* Dealing with ETW
* Providers, Consumers, Sessions
* User-space provider bypass
* The Threat Intelligence Provider
* Final Lab
Dr. Silvio La Porta is a Senior Cyber Security Architect designing security products and researching advanced detection technology for complex malware/APT. Silvio previously was a lead research scientist with EMC Research Europe based in the Centre of Excellence in Cork, Ireland. His primary research focus areas were real-time network monitoring and data analysis in smart grids to detect malware activity in SCADA systems and corporate networks. He was also leading Security Service Level Agreement (Sec-SLA) and end user security/privacy protected data store projects for hybrid Cloud environments. He is a frequent speaker in professional and industry conferences. Before joining EMC, Silvio worked as a Malware Reverse Engineer in Symantec’s Security Response team in Dublin, Ireland. Silvio holds a PhD in Computer Network Security from the University of Pisa, Italy.
Antonio Villani
Dr. Antonio Villani spent the past years analyzing high level implants for top tier customers, providing detailed implementation information to support cyber-defense and cyber threat intelligence teams. Now, he uses his experience in the reverse-engineering of multi-stage implants to improve detection and response capabilities of endpoint security products. As a researcher he published in top tier conferences and journals and he participated in European research projects in the field of cyber resilience and data security. During its PhD he also worked in the field of malware research and digital forensics.
#### VENUE
| |
|---------------------|
| Park MGM, Las Vegas |
#### TRAINING SCHEDULE
| | |
|------------------|---------------------|
| AUG 6 Saturday | 9 am to 5 pm PST |
| AUG 7 Sunday | 9 am to 5 pm PST |
| AUG 8 Monday | 9 am to 5 pm PST |
| AUG 9 Tuesday | 9 am to 5 pm PST |
#### TRAINING SCHEDULE
This training shall be conducted during
**EXACT LECTURE DATES SHALL BE ANNOUNCED SOON.**