OrganizationFiles in order by name alphabetically;expl.js - Contains the heart of the exploit and establishes a read/write primitive.gadgets.js - Contains gadget maps and function stub maps for a variety of firmwares. Which map is used is determined in the post-exploitation phase.index.html - The main page for the exploit. Launches the exploit and contains post-exploitation stuff, as well as output and code execution.rop.js - Contains the ROP framework modified from Qwerty's original exploit as well as the array in which module base addresses are held and gadget addresses are calculated.syscalls.js - Contains a system call map for a variety of firmwares as well as a 'name -> number' map for syscall ID's.UsageSimply setup a web-server on localhost using xampp or any other program and setup these files in a directory. You can then go to your computer's local IPv4 address (found by running ipconfig in cmd.exe) and access the exploit.NotesThe exploit is pretty stable but will still sometimes crash. If the browser freezes simply back out and retry, if a segmentation fault (identified by prompt "You do not have enough free system memory") occurs, refresh the page before trying again as it seems to lead to better results.This only allows code execution in ring3, to get ring0 execution a kernel exploit and KROP chain is needed.If I've made an error (particularly having to do with firmware compatibility and gadgets) feel free to open an issue on the repo.The exploit has been tested on 3.55 and 4.00, it is assumed to work on other firmwares listed but not guaranteed, again if you encounter a problem - open an issue on the repo.