/Inferius

Create & Restore 64-bit custom IPSWs

Primary LanguagePythonBSD 3-Clause "New" or "Revised" LicenseBSD-3-Clause

Inferius

License Stars

Inferius is an xpwn-like tool to create & restore custom IPSWs to 64-bit devices.

Its current purpose is to downgrade devices (vulnerable to checkm8) to previous iOS versions. However, there are other possible uses for this tool as well.

Notes and Caveats

Before using Inferius, keep in mind that

  • No one but YOU is fully responsible for any data loss or damage caused to your device
  • Downgrades are currently limited to versions compatible with the latest signed SEP version.
  • Due to the downgrades being tethered, after restoring a custom IPSW you must patch the bootchain & send it to your device over pwned DFU manually to boot, as described here, or use one of these tools to automate the process for you:

By default, firmware bundles are automatically downloaded from an external repo. However, if there isn't a firmware bundle for the device+iOS version combo you're attempting to downgrade to, you'll need to create your own using bundlegen.

Pull requests for new firmware bundles are welcome, as long as the firmware bundle you want to add can create a usable IPSW for the targeted version.

Usage

./inferius -d 'Identifier' -f 'IPSW' [-c/-r] [-b 'BUNDLE']
Option (short) Option (long) Description
-d IDENTIFIER --device IDENTIFIER Device identifier
-f IPSW --ipsw IPSW Path to IPSW
-c --create Create custom IPSW
-r --restore Restore custom IPSW
-b --bundle BUNDLE (Optional) Path to local Firmware Bundle
-u --update Keep data while restoring custom IPSW

Requirements

  • A computer running macOS or Linux
  • At least 10gbs of free space on your computer
  • An Internet connection
  • A 64-bit device (vulnerable to checkm8)
  • A firmware bundle for your device & the iOS version to be downgraded to
    • If there isn't a firmware bundle for your device + iOS version combo, look at bundlegen
  • libusb
  • futurerestore
    • futurerestore must be compiled with my fork of img4tool, or else it can't be used with Inferius.
  • libirecovery
  • tsschecker
  • Python dependencies:
    • pip3 install -r requirements.txt

To-Do

  • Implement iOS 10 downgrades for A7 devices.
  • Update bundle documentation

Inferius Bundle Generator

Usage

./bundlegen -d 'Identifier' -i 'iOS Version'
Option (short) Option (long) Description
-d IDENTIFIER --device IDENTIFIER Device identifier
-i VERSION --version VERSION iOS version

Requirements

Special thanks

Finally, if you need help or have any questions about Inferius, join my Discord server.