Gupje/README.md

122 lines
4.7 KiB
Markdown
Raw Normal View History

2024-08-02 16:05:02 +02:00
# Gupje
2024-11-19 21:04:14 +01:00
Gupje is a bare metal architecture based stub debugger that helps in ``post-exploitation`` steps. Like booting a smartphone after RCE has been achieved. Gupje is also capable of doing ``hardware-in-the-middle`` approaches as well as keeping control over a device while it is booting, this is needed for reaching weird goals like hijacking ``trustzone``.
2024-08-02 16:05:02 +02:00
Gupje currently supporting the following architectures:
2024-12-24 17:16:01 +01:00
2024-08-02 16:05:02 +02:00
* ARM64 (good support)
* ARM (minimal)
* ARM Thumb (decent support)
The goal is to add support to more targets while I work on them. Because I mainly work on phones this list will probably not grow a lot in the short term. But if you have an interesting target and preferably a way to get into it(RCE), let me know and I will look into it.
The only actual things the debugger can do is:
2024-12-24 17:16:01 +01:00
2024-08-02 16:05:02 +02:00
* Send/Receive (needs to be implemented by the user)
2024-11-01 13:48:07 +01:00
* Read/Write *some* registers
2024-08-02 16:05:02 +02:00
2024-12-24 17:16:01 +01:00
These functions are enough for a processor to run. The code size of the debugger is currently smaller than 4096 bytes(depends a bit on user setup) but will probably grow to include 1 extra page to support custom functionality. Like dumping extra registers and more specific processor dependent code.
2024-08-02 16:05:02 +02:00
2024-12-24 17:16:01 +01:00
In the future it should also be possible to add fuzzing and same architecture rehosting for more advanced fuzzing. Once I find a project to implement this at least.
2024-08-02 16:05:02 +02:00
## Overview
A simple overview of how Gupje is meant to be used can be seen below:
![Simple Gupje Target](simple_device.drawio.svg)
2024-11-19 21:04:14 +01:00
The user is responsible for gaining RCE and setting up Gupje. After this Gupje, along with the ``Ghidra-Assistant``, can be used to interact with the device from within python and continue booting(or extract Crypto Engine keys or whatever).
2024-08-02 16:05:02 +02:00
### Gupje Setup
Because Gupje attempts to be a architecture based debugger the user only has to provide send/receive functionality to Gupje. Like sahara_tx/sahara_rx in Qualcomm based devices or a raw USB endpoint for the nvidia shield tablet.
2024-11-01 13:48:07 +01:00
Example C code for running gupje:
2024-08-02 16:05:02 +02:00
```c
void send(void *buffer, uint32_t size, uint32_t *num_xfer){
// TODO implement
}
int recv(void *buffer, uint32_t size, uint32_t *num_xfer){
// TODO implement
return 0;
}
void recv_data(void *data, uint32_t len) {
uint32_t rx_err_code;
uint32_t xfer = 0;
while(1) {
recv(data, len, &xfer);
if(xfer >= len) {
break;
}
}
}
int mystrlen(char *data) {
int i=0;
while(1) {
if(data[i++] == '\0'){
break;
}
}
return i-1;
}
void usb_log(char * msg, uint32_t * error){
send(msg, mystrlen(msg), error);
}
void concrete_main(uint32_t debugger){
// TODO device specific code
}
```
2024-11-01 13:48:07 +01:00
#### Building
Download an Android NDK and set it's root path:
```bash
$ export ANDROID_NDK_ROOT=$TOOLCHAINENV/android-ndk-r21_Linux
```
Now you can build one of your targets:
```bash
$ make -f devices/rpi4/Makefile
```
2024-08-02 16:05:02 +02:00
Other protocols, like UART, are also possible. I will try to add more reference devices and implementations.
### Memory layout
2024-11-01 13:48:07 +01:00
Overall 4 pages are always reserved for the debugger. I usually try to place them at the end of a memory region since the chance of these pages being corrupted/used by other functions is smaller. 3 pages are required at least for the debugger to function properly.
2024-08-02 16:05:02 +02:00
![debugger memory layout](simple_device_memory.drawio.svg)
## Documentation
The full documentation is covered in the ``documentation`` folder. To build it, navigate to the folder and run:
```bash
make livehtml
```
2024-11-01 13:48:07 +01:00
Install the python dependencies if they are missing.
2024-08-02 16:05:02 +02:00
2024-11-19 21:04:14 +01:00
This code works in combination with the ``Ghidra Assistant``, which is another personal project to make Ghidra more instrumentable.
2024-08-02 16:05:02 +02:00
2024-11-01 13:48:07 +01:00
## Example devices
Several example devices are under development to show what the Gupje is capable off:
* Nvidia Shield Tablet(boot bricked device)
* Nintendo Switch to add?
* Samsung S7 (boot and hijack trustzone)
* Raspberry Pi4(UART)
2024-08-02 16:05:02 +02:00
## TODO
2024-11-19 21:04:14 +01:00
* Support an Iphone (7? 11?)
2024-08-02 16:05:02 +02:00
* Add code that allows the host to easily write and execute shellcode on the device. This will significantly decrease the size of the debugger. (extra page required)
* Add a more *minimal* approach to the debugger. That does not store data but can just be used to read/write memory. Usefull for exploitation when there is a very limited constraint on shellcode size.
* Implement code block stepping.
* Build an emulator to explain the debugger
### ARM64
2024-11-01 13:48:07 +01:00
* Allow restoring all registers by writing X15 to SP and jump to ELRn to create a *full* restored state. Figure out a way to branch without corrupting X15. (ELR?)
2024-08-02 16:05:02 +02:00
### Thumb
* headless mode is not supported
* Figure out VBAR to implement single step debugging