Advanced Software Protection - Attacks And Defense For Security Researchers And Developers

Arnau Gàmez I Montolio

BOOK NOW

ABSTRACT

In an increasingly interconnected digital world, the need for robust software protection mechanisms is paramount. Advanced Software Protection - Attacks and Defense is a comprehensive 4-day course that delves into the intricate realm of software security. Designed to empower students with advanced knowledge and techniques, this course offers a holistic approach to safeguarding software assets.

Over four intensive days, attendees will embark on a journey through the software protection landscape. Beginning with a deep dive into obfuscation, cryptography, and analysis fundamentals, participants will then explore advanced topics such as Mixed Boolean-Arithmetic (MBA), virtualization-based protection, and the synergy between cryptography and obfuscation. The course also covers the intriguing world of white-box cryptography and emerging trends in software security.

Led by an expert instructor, this course caters to a diverse audience of professionals, including developers and security engineers responsible for safeguarding valuable software assets, red team members seeking to enhance their implant-building and protection skills, reverse engineers faced with the formidable challenge of analyzing heavily protected targets, and enthusiastic security researchers eager to expand their horizons in this intellectually stimulating field. Regardless of your background or goals, this course equips you with the tools and knowledge necessary to defend against evolving threats and secure software components, preserving commercial value and intellectual property. Join us for a transformative learning experience and contribute to advancing software security in a dynamic digital landscape.

INTENDED AUDIENCE

💡
Developers and security engineers that need to protect sensitive software components against abuse to preserve commercial value and intellectual property. Red team members who want to build, protect, and diversify their implants to bypass detection engines and thwart defense analysis efforts. Reverse engineers dealing with highly obfuscated targets in malware analysis or application security assessments. Enthusiastic security researchers that enjoy an intellectually stimulating challenge, exploring a vast field beyond their comfort zone.

KEY LEARNING OBJECTIVES

  • Develop the skills needed to protect software components and preserve commercial value and intellectual property.
  • Understand the fundamentals of software protection, including obfuscation, cryptography, and analysis techniques.
  • Explore advanced obfuscation methods, including Mixed Boolean-Arithmetic (MBA) and virtualization-based protection.
  • Strengthen cryptographic implementations through obfuscation and delve into white-box cryptography design, development, and attacks.
  • Enhance capabilities for reverse engineering highly protected targets and bypassing detection engines.
  • Equip professionals to safeguard software assets effectively, from developers to security researchers.

COURSE DETAILS

AGENDA

MODULE 1

INTRODUCTION, CONTEXT, AND MOTIVATION

  • Software protection landscape
  • Secure design and architecture

OBFUSCATION 101

  • Code obfuscation and code deobfuscation
  • Data flow based obfuscation
  • Control flow based obfuscation

CRYPTOGRAPHY 101

  • Cryptography and cryptanalysis
  • Myths and realities of practical cryptography

ANALYSIS 101

  • SMT-based analysis
  • Symbolic execution
  • Program synthesis

MODULE 2

MATH REFRESHER

  • Matrices and vectors
  • Polynomials
  • Linearity
  • Invertible mappings

MIXED BOOLEAN-ARITHMETIC (MBA)

  • Introduction and motivation
  • Polynomial MBA expressions
  • Linear MBA expressions

OBFUSCATION WITH MBA

  • Rewriting rules
  • Insertion of identities
  • Opaque constants

MODULE 3

VIRTUALIZATION (VM) BASED SOFTWARE PROTECTION

  • Anatomy of an in-process VM
  • Implementation specifics
  • Hardening techniques

ANALYSIS OF VIRTUALIZATION OBFUSCATORS

  • Identifying the VM bytecode and architecture
  • Recovering handler semantics
  • Reconstructing control flow
  • Automation

MODULE 4

HARDENING CRYPTOGRAPHY WITH OBFUSCATION

  • Mixing operators in obfuscation vs. cryptography
  • Conceal recognizable algorithms and computations
  • Conceal known constants

WHITE-BOX CRYPTOGRAPHY

  • Introduction and motivation
  • Design and development
  • Analysis and attacks

MISC. AND FUTURE

  • Perfect vs. provably secure obfuscation
  • Homomorphic encryption
  • Post-quantum cryptography

KNOWLEDGE PREQUISITES

  • Understanding of basic programming concepts
  • Familiarity with x86/ARM assembly, C and Python
  • Knowledge of reverse engineering fundamentals

REQUIREMENTS

HARDWARE

  • A working computer capable of running virtual machines
  • 40 GB free hard disk space

SOFTWARE

  • Virtualization software

ABOUT THE TRAINER

Arnau is a hacker, security researcher and mathematician with a strong bias towards software security and reverse engineering. Specialized in software protection research and development (obfuscation, cryptography, mixed boolean-arithmetic algebra, inverse mappings, etc.) from a dual attack-and-defense perspective, both in academia and industry.

Experienced malware analyst in the antivirus sector and security engineer in the gaming industry. Founder of fura labs, a boutique security firm focused on software protection research and education. Speaker and trainer at several international security conferences.