- iOS Installation Instructions
- Table of Contents
- Install the required dependencies
- Clone the Iceman repository
- Compile and use the project
^Top
If you are using unc0ver or checkra1n, see On Bingner bootstrap Otherwise, see On Procursus bootstrap Note: compilation has not yet been attempted on Procursus' bootstrap or on rootless. Attempt at your own peril.
^Top
Run this as root
, as sudo isn't installed by default. The default password is alpine
.
apt install git make clang odcctools gawk sudo pkg-config python3.7 libpython3.7-dev
Furthermore, if you're trying to build from git instead of a release, you'll need SWIG from The-SamminAter's repo.
^Top
Currently, you're on your own. Most of the packages should be named similarly, but sometimes Procursus packages up components differently than bingner. Furthermore, if you're using a rootless jailbreak and want to build from git, you'll likely have to port over SWIG yourself.
^Top
- Git clone theos/sdks and symlink or move the target version (tested with 13.7, others should work) to
/usr/share/SDKs/iPhoneOS.sdk
. - Delete
__IOS_PROHIBITED
from line 188 ofiPhoneOS.sdk/usr/include/stdlib.h
- Git clone theos/headers and move
headers/openssl
toiPhoneOS.sdk/usr/include/
- Download the latest macOS SDK from phracker/MacOSX-SDKs (tested with 11.3) and move
MacOSX.sdk/System/Library/Frameworks/OpenCL.framework
andOpenGL.framework
toiPhoneOS.sdk/System/Library/Frameworks/
Note: when compiling hitag2crack/crack5opencl, the following warning is to be expected:
ld: warning: building for iOS, but linking in .tbd file (/usr/share/SDKs/iPhoneOS.sdk/System/Library/Frameworks//OpenCL.framework/OpenCL.tbd) built for macOS
^Top
git clone https://github.com/RfidResearchGroup/proxmark3.git
^Top
Now you're ready to (mostly) follow the compilation instructions.
^Top
Because there's no arm-none-eabi-gcc (or objcopy) for iOS, you'll have to build these components on a different operating system. The files and directories you'll need to copy over from a desktop build to iOS are armsrc/fpga_version_info.c
, armsrc/obj/
, bootrom/version_pm3.c
, bootrom/obj/
, and lastly recovery/
. Everything else will build successfully, but make all
and make install
will fail without them.
^Top
Because of the lack of arm-none-eabi-gcc (and objcopy), to successfully run make all
and/or make install
you'll have to create the following scripts as a workaround.
/usr/local/bin/arm-none-eabi-gcc
and arm-none-eabi-objcopy
#!/bin/bash
#This exists just to trick proxmark3 into making the fullimage, bootrom, and recovery
#Don't worry about it
cc --version
echo "Arguments: $@"
With those in place, make all
and make install
will run flawlessly.
^Top
As iOS doesn't support USB-CDC ACM, you'll need to use usbselfserial. A compiled binary can be found at The-SamminAter's repo.
Once the proxmark is connected to your iOS device via a USB adapter, run usbselfserial -v 0x9ac4 -p 0x4b8f --driver cdcacm -o /tmp/tty.usbmodemiceman1
(for devices other than the PM3 Easy, adjust the identifiers accordingly). If proxmark3 can't communicate with the device, try providing the port as an argument, or run sudo killall usbmuxd
.
Lastly, it may also be helpful to modify pm3
as follows, to automatically select the right port:
function get_pm3_list_macOS {
N=$1
#PM3LIST=()
PM3LIST=(/tmp/tty.usbmodemiceman1) #<-- our addition
for DEV in $(ioreg -r -c "IOUSBHostDevice" -l | awk -F '"' '
$2=="USB Vendor Name"{b=($4=="proxmark.org")}
b==1 && $2=="IODialinDevice"{print $4}'); do
PM3LIST+=("$DEV")
if [ ${#PM3LIST[*]} -ge "$N" ]; then
return
fi
done
}