Home Technology BareMetal RAM Dumper – Bare-metal x86 tool for Cold Boot...
Technology

BareMetal RAM Dumper – Bare-metal x86 tool for Cold Boot Attack experiments

Key Points

A simple x86 bare-metal tool designed to boot from a disk/USB and dump the system's RAM directly to the booting medium. It relies on BIOS interrupts to boot and perform disk operations, and enters unreal mode to access memory above the 1MB barrier. This tool was originally developed and successfully tested for experimenting with Cold Boot Attacks.

A simple x86 bare-metal tool designed to boot from a disk/USB and dump the system's RAM directly to the booting medium. It relies on BIOS interrupts to boot and perform disk operations, and enters unreal mode to access memory above the 1MB barrier. This tool was originally developed and successfully tested for experimenting with Cold Boot Attacks. By freezing a laptop's RAM (down to -60°C) and quickly rebooting from a USB drive containing this tool, it is possible to dump the frozen memory contents to the disk before the data decays, allowing for the extraction of sensitive information like encryption keys. - Custom Bootloader: Boots directly from the BIOS (Legacy CSM). No OS required. - Unreal Mode: Switches temporarily to unreal mode to access and read 32-bit physical memory addresses. - Memory Map parsing: Uses BIOS INT 0x15 E820 to detect valid RAM regions and avoid dumping reserved memory or memory-mapped I/O. - Direct Disk Write: Uses BIOS INT 0x13 AH=0x43 (Extended Write) to write the memory contents directly back to the boot drive starting at LBA 64. stage1.asm is a 512-byte boot sector. It initializes segment registers, sets up the stack, and uses Extended Read (INT 0x13 AH=0x42 ) to loadstage2 from LBA 1 into memory at0x8000 . Then it jumps tostage2 .stage2.asm performs the main logic:- Queries the BIOS for EDD (Enhanced Disk Drive) support. - Gets the memory map using INT 0x15 E820 . - Calculates the maximum RAM size. - Loops through RAM in 32KB chunks. - For each chunk, it switches to unreal mode to copy data from high memory into a low memory buffer ( 0x90000 ). - Writes the 32KB chunk to disk using Extended Write, starting at LBA 64. - Prints a progress percentage on the screen. This tool writes raw data directly to the boot drive starting at Sector 64! If you write this to a USB drive containing important data, the RAM dump will overwrite whatever is present at LBA 64 and beyond. Use a dedicated, blank USB flash drive for this purpose. You will need NASM installed to compile this project. On Windows, run the provided build script: build.bat On Linux, you can run: nasm -f bin stage1.asm -o stage1.bin nasm -f bin stage2.asm -o stage2.bin cat stage1.bin stage2.bin > boot.bin - Build the project to generate boot.bin . - Write boot.bin to a USB drive (e.g. usingdd on Linux/macOS, or Rufus / Win32DiskImager on Windows).- Note: Make sure your USB drive has enough space to hold your system's RAM. - Example (Linux): sudo dd if=boot.bin of=/dev/sdX bs=512 - Boot your target PC from the USB drive (ensure Legacy BIOS / CSM boot is enabled). - Wait for the dump to complete (it will show 100%).
BareMetal (ORG) USB (ORG) CSM (ORG) loadstage2 (PERSON) tostage2 (PERSON) RAM (ORG) KB (ORG) NASM (ORG) Linux (LOCATION) Linux/macOS (ORG) Rufus / Win32DiskImager (ORG)
Originally published by Hacker News Read original →