Skip to content

Lakr233/vphone-cli

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

154 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

vphone-cli

Boot a virtual iPhone (iOS 26) via Apple's Virtualization.framework using PCC research VM infrastructure.

poc

Tested Environments

Host iPhone CloudOS
Mac16,12 26.3 17,3_26.1_23B85 26.1-23B85
Mac16,12 26.3 17,3_26.3_23D127 26.1-23B85
Mac16,12 26.3 17,3_26.3_23D127 26.3-23D128
Mac16,12 26.3 17,3_26.3.1_23D8133 26.3-23D128

Firmware Variants

Three patch variants are available with increasing levels of security bypass:

Variant Boot Chain CFW Make Targets
Regular 41 patches 10 phases fw_patch + cfw_install
Development 52 patches 12 phases fw_patch_dev + cfw_install_dev
Jailbreak 112 patches 14 phases fw_patch_jb + cfw_install_jb

JB finalization (symlinks, Sileo, apt, TrollStore) runs automatically on first boot via /cores/vphone_jb_setup.sh LaunchDaemon. Monitor progress: /var/log/vphone_jb_setup.log.

See research/0_binary_patch_comparison.md for the detailed per-component breakdown.

Prerequisites

Host OS: macOS 15+ (Sequoia) is required for PV=3 virtualization.

Configure SIP/AMFI β€” required for private Virtualization.framework entitlements and unsigned binary workflows.

Boot into Recovery (long press power button), open Terminal, then choose one setup path:

  • Option 1: Fully disable SIP + AMFI boot-arg (most permissive)

    In Recovery:

    csrutil disable
    csrutil allow-research-guests enable

    After restarting into macOS:

    sudo nvram boot-args="amfi_get_out_of_my_way=1 -v"

    Restart once more.

  • Option 2: Keep SIP mostly enabled, disable only debug restrictions, use amfidont

    In Recovery:

    csrutil enable --without debug
    csrutil allow-research-guests enable

    After restarting into macOS:

    xcrun python3 -m pip install amfidont
    sudo amfidont --path [PATH_TO_VPHONE_DIR]

Install dependencies:

brew install ideviceinstaller wget gnu-tar openssl@3 ldid-procursus sshpass keystone autoconf automake pkg-config libtool cmake

Submodules β€” this repo uses a git submodule for resource archives. Clone with:

git clone --recurse-submodules https://github.com/Lakr233/vphone-cli.git

Quick Start

make setup_machine            # full automation through "First Boot" (includes restore/ramdisk/CFW)
# options: NONE_INTERACTIVE=1 SUDO_PASSWORD=...

Manual Setup

make setup_tools              # install brew deps, build trustcache, clone insert_dylib, build libimobiledevice, create Python venv
make build                    # build + sign vphone-cli
make vm_new                   # create vm/ directory (ROMs, disk, SEP storage)
make fw_prepare               # download IPSWs, extract, merge, generate manifest
make fw_patch                 # patch boot chain (regular variant)
# or: make fw_patch_dev       # dev variant (+ TXM entitlement/debug bypasses)
# or: make fw_patch_jb        # jailbreak variant (+ full security bypass)

Restore

You'll need two terminals for the restore process. Keep terminal 1 running while using terminal 2.

# terminal 1
make boot_dfu                 # boot VM in DFU mode (keep running)
# terminal 2
make restore_get_shsh         # fetch SHSH blob
make restore                  # flash firmware via idevicerestore

Install Custom Firmware

Stop the DFU boot in terminal 1 (Ctrl+C), then boot into DFU again for the ramdisk:

# terminal 1
make boot_dfu                 # keep running
# terminal 2
sudo make ramdisk_build       # build signed SSH ramdisk
make ramdisk_send             # send to device

Once the ramdisk is running (you should see Running server in the output), open a third terminal for the iproxy tunnel, then install CFW from terminal 2:

# terminal 3 β€” keep running
iproxy 2222 22
# terminal 2
make cfw_install
# or: make cfw_install_jb        # jailbreak variant

First Boot

Stop the DFU boot in terminal 1 (Ctrl+C), then:

make boot

After cfw_install_jb, the jailbreak variant will have Sileo and TrollStore available on first boot. You can use Sileo to install openssh-server for SSH access.

For the regular/development variant, the VM gives you a direct console. When you see bash-4.4#, press Enter and run these commands to initialize the shell environment and generate SSH host keys:

export PATH='/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/bin/X11:/usr/games:/iosbinpack64/usr/local/sbin:/iosbinpack64/usr/local/bin:/iosbinpack64/usr/sbin:/iosbinpack64/usr/bin:/iosbinpack64/sbin:/iosbinpack64/bin'

mkdir -p /var/dropbear
cp /iosbinpack64/etc/profile /var/profile
cp /iosbinpack64/etc/motd /var/motd

# generate SSH host keys (required for SSH to work)
dropbearkey -t rsa -f /var/dropbear/dropbear_rsa_host_key
dropbearkey -t ecdsa -f /var/dropbear/dropbear_ecdsa_host_key

shutdown -h now

Note: Without the host key generation step, dropbear (SSH server) will accept connections but immediately close them because it has no keys to perform the SSH handshake.

Subsequent Boots

make boot

In a separate terminal, start iproxy tunnels:

iproxy 22222 22222   # SSH (dropbear)
iproxy 2222 22       # SSH (JB: if you install openssh-server from Sileo)
iproxy 5901 5901     # VNC
iproxy 5910 5910     # RPC

Connect via:

  • SSH (JB): ssh -p 2222 mobile@127.0.0.1 (password: alpine)
  • SSH (Regular/Dev): ssh -p 2222 root@127.0.0.1 (password: alpine)
  • VNC: vnc://127.0.0.1:5901
  • RPC: rpcclient -p 5910 127.0.0.1

FAQ

Before anything else β€” run git pull to make sure you have the latest version.

Q: I get zsh: killed ./vphone-cli when trying to run it.

AMFI/debug restrictions are not bypassed correctly. Choose one setup path:

  • Option 1 (full AMFI disable):

    sudo nvram boot-args="amfi_get_out_of_my_way=1 -v"
  • Option 2 (debug restrictions only): use Recovery mode csrutil enable --without debug (no full SIP disable), then install/load amfidont while keeping AMFI otherwise enabled.

Q: System apps (App Store, Messages, etc.) won't download or install.

During iOS setup, do not select Japan or European Union as your region. These regions enforce additional regulatory checks (e.g., sideloading disclosures, camera shutter requirements) that the virtual machine cannot satisfy, which prevents system apps from being downloaded and installed. Choose any other region (e.g., United States) to avoid this issue.

Q: I'm stuck on the "Press home to continue" screen.

Connect via VNC (vnc://127.0.0.1:5901) and right-click anywhere on the screen (two-finger click on a Mac trackpad). This simulates the home button press.

Q: How do I get SSH access?

Install openssh-server from Sileo (available on the jailbreak variant after first boot).

Q: SSH doesn't work after installing openssh-server.

Reboot the VM. The SSH server will start automatically on the next boot.

Q: Can I install .tipa files?

Yes. The install menu supports both .ipa and .tipa packages. Drag and drop or use the file picker.

Q: Can I update to a newer iOS version?

Yes. Override fw_prepare with the IPSW URL for the version you want:

export IPHONE_SOURCE=/path/to/some_os.ipsw
export CLOUDOS_SOURCE=/path/to/some_os.ipsw
make fw_prepare
make fw_patch

Our patches are applied via binary analysis, not static offsets, so newer versions should work. If something breaks, ask AI for help.

Acknowledgements