Reverse Engineering: Ghidra Review and IDA Pro Sticker Shock.
In this article we go over the installation and basic usage of the Ghidra reverse-engineering platform.
data:image/s3,"s3://crabby-images/90873/9087387d8f3549af1ffefc83d165948ca8e3336c" alt="Reverse Engineering: Ghidra Review and IDA Pro Sticker Shock."
IDA Pro (Just for x86) is about $5500US. Well clearly I didn't find that kind of money in my couch cushions so I will have to try an alternative. Enter Ghidra. Downloading Ghidra is available from gitlab: I have no idea how this compares to other Reverse Engineering Software so take this as a 'blind review' or a 'get it working guide' I leave pitfalls in there to show how they are solved as a learning guidance for anyone following this path. I am installing into a BackBox Linux which is basically Ubuntu Libraries.
data:image/s3,"s3://crabby-images/52137/52137cb3cb58029c73356c420dfd51e5302506ca" alt=""
Once you have downloaded the .tar.gz
tar -xvf ghidra-Ghidra_10.3.1_build.tar.gz
cd ghidra-Ghidra_10.3.1_build/
The build instructions advise us as:
## Build
To create the latest development build for your platform from this source repository:
##### Install build tools:
* [JDK 17 64-bit][jdk17]
* [Gradle 7.3+][gradle]
* make, gcc, and g++ (Linux/macOS-only)
* [Microsoft Visual Studio][vs] 2017+ or [Microsoft C++ Build Tools][vcbuildtools] with the
following components installed (Windows-only):
- MSVC
- Windows SDK
- C++ ATL
- Installing JDK 17 64-bit
sudo apt install openjdk-17-jdk openjdk-17-jre -y
2. Installing Gradle
sudo apt install snap
sudo snap install gradle
4. Install Gradle dependencies
gradle -I gradle/support/fetchDependencies.gradle init
data:image/s3,"s3://crabby-images/f0659/f0659fcf19723ddcf5530335f7259bc95f1a06c7" alt=""
Houston we have a problem.. Let's try seeing if it will build anyways:
gradle build Ghidra
Houston more problems:
data:image/s3,"s3://crabby-images/9f8b4/9f8b4b86e31cb699e37ca279d17ff7cf02e25461" alt=""
- 2 Problems to solve: Install Latest Gradle (See if it compiles without the module) and then then pull a similar missing module and see if this goes.
Downloading the latest gradle.8.2
- Latest Releases from here
unzip gradle-8.2-all.zip
cd gradle-8.2
Success Both Fixed (Call gradle 8.2 in the near-by directory and have it do the .grade init dependencies
../gradle-8.2/bin/gradle -I gradle/support/fetchDependencies.gradle init
data:image/s3,"s3://crabby-images/25c43/25c43047001b4a148cae1544e9c0347acdce3cd4" alt=""
../grade-8.2/bin/gradle buildGhidra
data:image/s3,"s3://crabby-images/e6351/e6351c278432078918a019ec66f4335cb44b719e" alt=""
Lots goes on here. This looks like about a 5-10 minute compile at this point.
What is neat about the installation is it shows 'per-core' as in:
data:image/s3,"s3://crabby-images/689b7/689b7d5ac2863f5c24b565543e2327db40bb1ffe" alt=""
We have 3 cores working and 9 idle. It did not take all 16 available.
Build time came in at a respectable 5 Min 59 Seconds.
data:image/s3,"s3://crabby-images/df7e1/df7e103bb0b345db684813f77af2bb2054d34f91" alt=""
Once that is done it produces a .zip file in /build/dist
-rw-rw-r-- 1 c c 361433570 Jul 5 19:24 ghidra_10.3.1_DEV_20230705_linux_x86_64.zip
Now copy the .zip to your /home/ and then unzip it - it contains a running production for it.
data:image/s3,"s3://crabby-images/babf0/babf0f6f0ec699a1613feb9962da6d6646402e83" alt=""
Inside the ghidra_10.3.1_DEV
./ghidraRun
Will present as:
data:image/s3,"s3://crabby-images/6401d/6401d6fad53179a5dfb97b833ca48550ffd98eba" alt=""
It will give you a project menu and a detailed manual guide pop-up
data:image/s3,"s3://crabby-images/26560/2656055ba98aaf94a7dc90c9ebc64ea0de284c0c" alt=""
And a detailed help guide:
data:image/s3,"s3://crabby-images/5eb8a/5eb8afdc0e008a6da989b64eb6995bbd4de1c2c1" alt=""
We will create a non-shared project:
data:image/s3,"s3://crabby-images/61941/619411e9df775da4faf8649d5a3577299d9f4f2b" alt=""
data:image/s3,"s3://crabby-images/5ee44/5ee446a42ce44ca17d13dfc21baf832e38c4e846" alt=""
Once you have made your project it will look like this (I guess their budget for icons was a bit lacking?)
data:image/s3,"s3://crabby-images/e56bb/e56bbdb3175cb3c28cfcd74cbc08aeb5e4127048" alt=""
Selecting the Dragon or 'code browser' will give an entire new IDE space.
data:image/s3,"s3://crabby-images/002c7/002c72a3849c4d8e9c75acc8e91ffb8104c2dbe5" alt=""
We select a .exe to import and it gives some decompiler information:
data:image/s3,"s3://crabby-images/ffc74/ffc7472f2f33914793d1c36c151930d1f64ffffc" alt=""
Once it is done ingestion it will give you a status and present you a reverse assembly language display.
data:image/s3,"s3://crabby-images/1db42/1db4273aef9f68fa826a42dde2df5c392579c28e" alt=""
Without even stepping the code there are a pile of analyzers that can assist you.
data:image/s3,"s3://crabby-images/59dd3/59dd3117e3a199d742b4a69ed1f0363668e2182a" alt=""
In the bottom right a bunch of progress boxes will show you as each analyzer module is called against the code.
data:image/s3,"s3://crabby-images/32de8/32de8583e204066581e9f8c6320bd26d391c313b" alt=""
In the left corner it did a really good job of finding the corresponding header files associated with the executable:
data:image/s3,"s3://crabby-images/82ee2/82ee2fe482367460bb4882f249d43363c4059886" alt=""
In the right side window it automatically produced Decompile C psuedo-code which is very impressive - but logically this might be quite confusing. I guess one could cut and paste this into CLion or some other compiler and step it.
data:image/s3,"s3://crabby-images/9e5a3/9e5a3ea07460bfdf95b01f5939f9efca95c66ad5" alt=""
In the data type manager it has a detailed object browser as in:
data:image/s3,"s3://crabby-images/dab99/dab99ba7a0154f142db8658fdb04657b7afbb017" alt=""
data:image/s3,"s3://crabby-images/4df24/4df24ff07bb758def188955b8a4435e7e43b00b3" alt=""
Cool plugin. Since they don't have the license for the intel manual they give you this installation screen:
data:image/s3,"s3://crabby-images/818d4/818d4594600fc96ff25b55f9665b88b9ac12d29f" alt=""
Summary: This is a very powerful and very specialized program to quickly analyze a program and produce a lot of engineering level statistics on it.
This is only a partial guide and one could spend a LONG time learning all the intricacies of this program. Anyone that does reverse engineering that is not plunking down the large $$$ for IDA pro should definitely have this in their tool box.