Cyber security

Lucid – Revolutionizing Fuzzing Through Bochs Emulation Technology

Lucid is an educational fuzzing project which aims to create a Bochs emulator based snapshot fuzzer capable of fuzzing traditionally hard to fuzz targets such as kernels and browsers.

Lucid is based on a fuzzer originally conceived of and developed by Brandon Falk.

Lucid utilizes changes to Musl in order to affect Bochs’ behavior and achieve a functional sandbox that will allow Lucid to run Bochs within its virtual address space without being able to interact directly with the operating system.

The goal of the sandbox is to achieve determinism.

Under Development

Lucid is currently in the early stages of development and can load and run a -static-pie test program as well as Bochs itself.

Lucid is also capable of sandboxing the test program from syscalls and access to thread-local-storage. More sandboxing work is required.

You can catch up on development efforts on the blog detailing each development step: The current codebase is more current than the latest blogpost.

Build

Rust

Building the Rust portions of the project is very straightfoward, you should just be able to:

git clone https://github.com/h0mbre/Lucid

cd Lucid

cargo build --release

Musl

Lucid requires Musl libc 1.2.4, modified with Lucid-specific patches. Download and extract Musl:

tar -xzf musl-1.2.4.tar.gz

Apply Lucid patches to Musl:

cd path/to/musl-1.2.4

patch -p1 < path/to/musl_patches/musl.patch

Build and install the customized Musl:

./configure

make

sudo make install

Test Application

Confirm that Musl is now installed at /usr/local/musl, then you can:

gcc --specs=/path/to/musl_specs/musl-gcc.specs test.c -o test -g --static-pie

Usage

./lucid --bochs-image /path/to/test (--bochs-args)

Expected Output

lucid· Bochs image path: 'test'
lucid· Loading Bochs...
lucid· Bochs mapping: 0x10000 - 0x18000
lucid· Bochs mapping size: 0x8000
lucid· Bochs stack: 0x7F906B7FD000
lucid· Bochs entry: 0x11058
lucid· Creating Bochs execution context...
lucid· Starting Bochs...
       Argument count: 1
       Args:
          -./bochs
       Test alive!
       Test alive!
       Test alive!
       Test alive!
       Test alive!
       g_lucid_ctx: 0x55a26ef9fce0
fatal: Bochs exited early

Varshini

Tamil has a great interest in the fields of Cyber Security, OSINT, and CTF projects. Currently, he is deeply involved in researching and publishing various security tools with Kali Linux Tutorials, which is quite fascinating.

Recent Posts

Kali Linux 2024.4 Released, What’s New?

Kali Linux 2024.4, the final release of 2024, brings a wide range of updates and…

4 hours ago

Lifetime-Amsi-EtwPatch : Disabling PowerShell’s AMSI And ETW Protections

This Go program applies a lifetime patch to PowerShell to disable ETW (Event Tracing for…

4 hours ago

GPOHunter – Active Directory Group Policy Security Analyzer

GPOHunter is a comprehensive tool designed to analyze and identify security misconfigurations in Active Directory…

2 days ago

2024 MITRE ATT&CK Evaluation Results – Cynet Became a Leader With 100% Detection & Protection

Across small-to-medium enterprises (SMEs) and managed service providers (MSPs), the top priority for cybersecurity leaders…

5 days ago

SecHub : Streamlining Security Across Software Development Lifecycles

The free and open-source security platform SecHub, provides a central API to test software with…

1 week ago

Hawker : The Comprehensive OSINT Toolkit For Cybersecurity Professionals

Don't worry if there are any bugs in the tool, we will try to fix…

1 week ago