This project is an exploration of the network communications between macOS and the T2 chip. It can be used to decode and print the XPC messages, and provides an example of building a protocol-compliant client to communicate with a service on the T2 chip.
More information can be found in our report.
This is a Python3 project.
One of the changes in 3.7 was how python handles multiple inheritance, particularly with method resolution order (MRO). Because the h2 library has a bug with this new method resolution order, we need to use Python 3.6.
On a mac, to do this we need to use pyenv. (use brew
to install it if you don't have it)
pyenv install 3.6.7
And then every time you want to run it (or pip3 install stuff), you'll need to
run this from the project directory:
eval "$(pyenv init -)"
To install, you will need to install:
pip3 install Twisted hexdump scapy
The hyper-h2 module is HTTP/2 spec-compliant. Unfortuantely, Apple communications are not. We have included a slightly-modified copy of the h2 module, still under its original MIT license.
There are currently two main utilities contained in this repo:
vhc128sniff.py
will listen on the VHC128 interface and decode as many XPC messages as it can between the t2 chip and the mac. It can also be run with the-f
flag and a file path to read from a tcpdump-format packet capture.sysdiagnose_client.py
will attempt to connect to the t2 chip and initiate a sysdiagnose connection.
csrutil disable # (in recovery)
nvram boot-args=”amfi_get_out_of_my_way=0x01” # (reboot)
cp /usr/libexec/remotectl /tmp/
cat << EOF > /tmp/entitlements.ent
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>com.apple.private.RemoteServiceDiscovery.device-admin</key>
<true/>
<key>com.apple.private.network.intcoproc.restricted</key>
<true/>
</dict>
</plist>
EOF
jtool --sign --ent /tmp/entitlements.ent --inplace /tmp/remotectl
/tmp/remotectl relay localbridge com.apple.sysdiagnose.remote