Vulnerability Research & Fuzzing

A complete introduction to 0-day discovery for Windows targets, focusing on closed-source real-world software, including kernel modules and user code.

Vulnerability Research & Fuzzing | Signal Labs | Advanced Offensive Cybersecurity Training | Self-Paced Trainings | Live Trainings | Virtual Trainings | Custom Private Trainings for Business

Learn about snapshot-fuzzing real-world Windows targets & finding logic 0-days.

Who should take this course?

Anyone looking to get into Windows vulnerability research and fuzzing, although many of the concepts and approaches taught can be used for fuzzing on other platforms (MacOS/Linux, etc), all the exercises will focus on Windows. Also useful for red-teamers looking to add zero-days to their arsenal (with a dedicated section on finding quick 0-days on time-limited engagements).

Most topics are beginner friendly and assume limited or no prior experience with modern fuzzing approaches and Windows vulnerability research, with advanced topics (hypervisors & emulators, for example) presented in an easy-to-understand manner.

Course Syllabus

  • Static vs Dynamic Techniques
  • Terminology (harnesses, coverage, mutations, grammars, etc)
  • Paging (page tables, faults, exception types, exception handlers)
  • Symbolic Execution & Related Techniques
  • Integrity Levels, Rings, Privileges
  • Attack Surfaces (Files, Named Pipes, RPC, TCP/UDP, Mapped Memory, Device Drivers, etc)
  • Analyzing Attack Surfaces with Tools
  • Intro to Analyzing Kernel Targets
  • Persistent Fuzzing with WinAFL
  • Harness Optimization Techniques (Reducing I/O, Context Switching, etc)
  • Utilizing Coverage Guidance
  • Research Techniques & Target Optimization
  • Triaging Crashes with WinDBG
  • Time-Travel Tracing & Time Slicing
  • Taint Analysis
  • Utilizing Coverage Traces & Coverage Diffs
  • Identifying Targets (Modules & Non-Exported Functions)
  • Argument & Structure Recovery via Reverse Engineering
  • Calling Internal Functions w/ Custom Pointer Arithmetic & Modeling Structures
  • Debugging Issues & Overcoming Limitations via Hooking & Target Manipulation (e.g. Fuzz an RPC Target Directly, Bypassing the RPC Protocol)
  • Handling Initial Argument State Setup (Locating & Calling Private C++ Constructors, Modeling & Parsing VTables)
  • Initializing Globals & Resetting State for Persistent Fuzzing (Intercepting Access Violations, Reversing Globals, Detecting & Resetting Modified State between Fuzz Sessions)
  • Full-System Snapshot Fuzzing Theory
  • Custom Code to Remove Device I/O (e.g. Hooking All File I/O With our Custom Userland MemDisk Implementation)
  • Snapshot Fuzzing our Real Target w/ what-the-fuzz
  • Snapshot Fuzzing our Real Target w/ kAFL & Nyx
  • Comparing Approaches & Requirements (Device Handling, Limitations, Use-Cases)
  • Tools and Techniques (Incl. Custom Tooling) to Quickly Find Exploitable 0-Days in Time-Limited Engagements (e.g. Red Teams)
  • Common Vulnerable Patterns in Windows Code
  • Identifying & Analyzing a Real Kernel Driver Logic (0-Day) Bug (+ Developing Our Own Exploitation Code)
  • Additional Logic (Real Target) 0-Day Challenges + Walkthroughs

This course is a complete introduction to finding 0-days on Windows, covering static & dynamic manual approaches alongside state-of-the-art snapshot fuzzing techniques with multiple walkthroughs of real live 0-days. Includes both memory corruption style bugs & logic bugs.

Course Benefits

Beginner & Advanced Content with Live Demonstrations

Community Environment to Engage in Discussions with Peers & Instructor

Live Q&A Sessions & Ongoing Support After the Course

Frequently Updated Content with the Latest Techniques & Tools

Custom Code Developed by Signal Labs for Students

(Optional) Assessments & Completion Certificates

What makes Signal Labs self-paced courses different?

A firsthand look at our innovative self-paced course content.

Self-Paced Training

$3,100.00 USD

  • 34 Self-Paced Lessons.
  • 12-month access to the course.
  • Multiple hands-on exercises for each section.
  • Includes both memory corruption style bugs & logic bugs.
  • Advanced custom tooling, including custom kernel drivers.
  • Exercises with crash triaging techniques and program analysis concepts.
  • Community pages to engage with discussions between peers & instructor.
  • Course Materials: Recorded Content, Code Files.
  • (Optional) Assessments & completion certificates.
  • Note: Training platform access supports Windows and MacOS machines only.

*For larger business teams, reach out for custom packages.

Christopher Vella | Signal Labs | Advanced Offensive Cybersecurity Training | Self-Paced Trainings | Live Trainings | Virtual Trainings | Custom Private Trainings for Business

Instructor

Christopher Vella has extensive experience with vulnerability research and has found vulnerabilities in a range of high-profile software (Hyper-V Hypervisor, Adobe PDF, Windows OS & Kernel). Public vulnerabilities discovered by Christopher include (CVE-2020-17414, CVE-2020-24559, CVE-2021-25250, CVE-2020-24557, CVE-2020-24556, CVE-2020-24558, + more) alongside multiple non-public vulnerabilities.

Strong Signals

Stay Connected

We'll let you know when our next live training is scheduled.

Stay Connected

We'll let you know when our next live training is scheduled.

Stay Connected

We'll let you know when our next live training is scheduled.

Stay Connected

We'll let you know when our next live training is scheduled.