Skip to content

Latest commit

 

History

History

EnigmaX1

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Enigma X1 - PCIe to USB-C:

This project contains software and HDL code for the Enigma X1 board.

Once flashed it may be used together with the PCILeech Direct Memory Access (DMA) Attack Toolkit or MemProcFS - The Memory Process File System to perform DMA attacks, dump memory or perform research.

⚠️ LeetDMA, also sold by enigma-x1.com, uses the PCIeSquirrel firmware and is not compatible with the EnigmaX1 firmware.

⚠️ This guide only applies to Enigma X1. There are other DMA boards selling as 75T devices under different names that may not to work since they have different PIN layouts on the FPGA. Please consult your DMA card vendor if your 75T DMA board is not an Enigma X1 board.

Capabilities:

  • Retrieve memory from the target system over USB3/USB-C in excess of 200MB/s.
  • Access physical memory of target system unless protected with VT-d/IOMMU.
  • Raw PCIe Transaction Layer Packet (TLP) access.

For information about more capabilities check out the general readme and info wiki pages at: PCILeech, MemProcFS and LeechCore for information about features and capabilities.

For information about other supported FPGA based devices please check out PCILeech FPGA.

The Hardware: Enigma X1

The Enigma x1 PCIe board contains a large Artix7 75T FPGA which allows for good performance and also interesting applications besides PCILeech/MemProcFS. The Enigma x1 may be purchased from: Smart Hardware Solution / enigma-x1.com. For more information about the hardware please check out Smart Hardware Solution / enigma-x1.com. Please note that the Enigma x1 is sold by a 3rd party and not by the PCILeech project itself!

The picture below depicts an Enigma x1. The Enigma x1 contains a SuperSpeed USB-C port for data transfer and an update port for easy updating without the need for additional hardware.

When using PCILeech gateware the button will reset the device on press, for full reset hold it 5 seconds. LED1 show the PCIe link status; LED2 will blink 3 times on startup and light up if there are data to read.

Flashing:

Please note that this instruction applies to the built-in update port. There is a separate JTAG port as well for experienced users.

  1. Install Vivado WebPACK or Lab Edition (only for flashing).
  2. Build PCILeech Enigma X1 (see below) alternatively download and unzip pre-built binary (see below in releases section).
  3. Open Vivado Tcl Shell command prompt.
  4. cd into the directory of your unpacked files, or this directory (forward slash instead of backslash in path).
  5. Make sure the update port is connected to the computer running Vivado.
  6. Run source vivado_flash.tcl -notrace to flash the PCILeech bitstream onto the Enigma x1 board.
    Alternatively flash using Xilinx Vivado Hardware Manager (shown below). Please select memory part: is25lp128f.
  7. Finished !!!

Building:

  1. Install Xilinx Vivado WebPACK 2023.2 or later.
  2. Open Vivado Tcl Shell command prompt.
  3. cd into the directory of EnigmaX1 (forward slash instead of backslash in path).
  4. Run source vivado_generate_project.tcl -notrace to generate required project files.
  5. Run source vivado_build.tcl -notrace to generate Xilinx proprietary IP cores and build bitstream.
  6. Finished !!!

Building the project may take a very long time (~1 hour).

The PCIe device will show as Xilinx Ethernet Adapter with Device ID 0x0666 on the target system by default. For instructions how to change the device id and other advanced build properties check out the build readme for information.

Other Notes:

The completed solution contains Xilinx proprietary IP cores licensed under the Xilinx CORE LICENSE AGREEMENT. This project as-is published on Github contains no Xilinx proprietary IP. Published source code are licensed under the MIT License. The end user that have downloaded the no-charge Vivado WebPACK from Xilinx will have the proper licenses and will be able to re-generate Xilinx proprietary IP cores by running the build detailed above.

Support PCILeech/MemProcFS development:

Thank You Smart Hardware Solution / Enigma x1 for supporting the PCILeech project 💖

Some other hardware sellers have chosen not to support the project! If you think PCILeech and/or MemProcFS is awesome or if you had a use for it it's now possible to support the project via Github Sponsors: https://github.com/sponsors/ufrisk.

To all my sponsors, Thank You 💖

Releases / Version History:

Previous releases (click to expand):

v4.10

  • Initial Release
  • Download pre-built binaries below:
    • Enigma x1 SHA256: 7fbb3891f600443e2b9966d778d6d27363ea4dbca6863bef9ceabdbfb4425a24

v4.11

  • Bug fixes and new USB core.
  • Download pre-built binaries below:
    • Enigma x1 SHA256: 253ec0d7ef2361269589d35d948b0d4786619c5eb376e9d0237573494fb79b53

v4.12

  • Bug fixes.
  • Download pre-built binaries below:
    • Enigma x1 SHA256: cdba0ddfbcd0b1b03f55e7c2d5d301be8ce25d3dcac756439c9910d6faa87927

v4.13

  • Bug fixes.
  • New internal design with on-board PIO BAR support.
  • Download pre-built binaries below:
    • Enigma x1 SHA256: 69a21c8f32298df81e288d7c4f6745da27cf6bfc6e4bbd8ffa68297980b725d7

v4.14

  • Bug fixes.
  • Download pre-built binaries below:
    • Enigma x1 SHA256: de423196bd1f7a8c5d4e6f437c18bdfb1cbfdac2cc4d8878c093fdd3153ca186