Skip to content
A GUI version of axi0mX's ipwndfu exploit
Java
Branch: master
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.

README.md

checkm8gui

checkm8gui is an application for macOS and Linux which adapts the ipwndfu command-line tool by axi0mX to a graphical application.

Credit

This program was written by me, however this program would not be possible without the work axi0mX has put into ipwndfu and the work Srikanth Lingala has put into zip4j.
zip4j is licensed under the Apache License 2.0.
zip4j Copyright 2010 Srikanth Reddy Lingala

Testing

This program's GUI has been tested on an Ubuntu virtual machine and on a Windows machine, however, it has not been tested on a physical iOS device because I own an S8003 iPhone 6s which is not currently supported by ipwndfu.

Features

This program can enter your device into pwned DFU mode on a checkm8-compatible device. Once the device is in pwned DFU mode, this program can dump the SecureROM of the device, demote the device, or verbose boot the device. Features which are planned to be implemented in the near future are: decrypting keybags, changing your boot logo, restoring to signed and unsigned firmwares, and running custom ipwndfu commands.

Disclaimer

This is not a tool for the inexperienced. This tool could seriously damage your device if misused. If you don't know what you're doing, stay away from this application. It is not feasibly possible to accidentally demote your device with this program. When the demote device option is chosen, multiple confirmation warnings are given before the task is carried out.

Compilation/Execution

This tool can either be run from the .jar executable of the latest release in the Releases tab, or can be compiled using javac.
If this program is compiled from the source code, the ipwndfu.zip file found in the src folder must be copied to the root of the compiled program's folder, otherwise checkm8gui will fail. If you run the program from the .jar in the Releases tab, this is not necessary and it can be run immediately.

Prerequisites

Java Runtime Environment or Java Development Kit
A Unix-based operating system

Command-line arguments

-v/-verbose - Prints the command issued to the terminal along with the output of the command when an option is picked. This is not to be confused with verbose booting your iOS device.
--ignore-os - Launches the application regardless of what operating system it's being run on.
--ipwndfu-folder folder - A command to manually specify your ipwndfu folder location. This does not overwrite the location recorded in checkm8gui.bin. This folder specification will only persist in the current session.

Troubleshooting

If the program crashes without any prior notification or explanation of what happened, run the program from the command-line. Useful information is printed to the console in the event of a crash.

Known issues

There are many performance and consistency issues in the source code. None of these will affect your experience with the program in practice, however these are planned to be fixed in the next update nonetheless. Saving changes to the program settings also crashes the program. This will be fixed soon. All features listed on disabled buttons are planned to be implemented in the near future.

Contacting me

I will respond to any PM I receive on Reddit. u/verystrangebeing

You can’t perform that action at this time.