ghidra/README.md

141 lines
6.2 KiB
Markdown
Raw Permalink Normal View History

2021-04-05 12:54:18 +00:00
<img src="Ghidra/Features/Base/src/main/resources/images/GHIDRA_3.png" width="400">
2019-03-02 01:40:39 +00:00
# Ghidra Software Reverse Engineering Framework
2021-04-05 12:54:18 +00:00
Ghidra is a software reverse engineering (SRE) framework created and maintained by the
[National Security Agency][nsa] Research Directorate. This framework includes a suite of
full-featured, high-end software analysis tools that enable users to analyze compiled code on a
variety of platforms including Windows, macOS, and Linux. Capabilities include disassembly,
assembly, decompilation, graphing, and scripting, along with hundreds of other features. Ghidra
supports a wide variety of processor instruction sets and executable formats and can be run in both
user-interactive and automated modes. Users may also develop their own Ghidra extension components
and/or scripts using Java or Python.
In support of NSA's Cybersecurity mission, Ghidra was built to solve scaling and teaming problems
on complex SRE efforts, and to provide a customizable and extensible SRE research platform. NSA has
applied Ghidra SRE capabilities to a variety of problems that involve analyzing malicious code and
generating deep insights for SRE analysts who seek a better understanding of potential
vulnerabilities in networks and systems.
If you are a U.S. citizen interested in projects like this, to develop Ghidra and other
cybersecurity tools for NSA to help protect our nation and its allies, consider applying for a
[career with us][career].
2021-12-15 17:27:35 +00:00
## Security Warning
**WARNING:** There are known security vulnerabilities within certain versions of Ghidra. Before
proceeding, please read through Ghidra's [Security Advisories][security] for a better understanding
of how you might be impacted.
2021-04-05 12:54:18 +00:00
## Install
To install an official pre-built multi-platform Ghidra release:
2024-04-18 12:28:52 +00:00
* Install [JDK 21 64-bit][jdk]
2021-11-03 13:09:47 +00:00
* Download a Ghidra [release file][releases]
- **NOTE:** The official multi-platform release file is named
`ghidra_<version>_<release>_<date>.zip` which can be found under the "Assets" drop-down.
Downloading either of the files named "Source Code" is not correct for this step.
2021-04-05 12:54:18 +00:00
* Extract the Ghidra release file
* Launch Ghidra: `./ghidraRun` (or `ghidraRun.bat` for Windows)
For additional information and troubleshooting tips about installing and running a Ghidra release,
please refer to `docs/InstallationGuide.html` which can be found in your extracted Ghidra release
directory.
## Build
To create the latest development build for your platform from this source repository:
##### Install build tools:
2024-04-18 12:28:52 +00:00
* [JDK 21 64-bit][jdk]
2024-07-03 12:04:27 +00:00
* [Gradle 8.5+][gradle] (or provided Gradle wrapper if Internet connection is available)
* [Python3][python3] (version 3.9 to 3.12) with bundled pip
2021-04-05 12:54:18 +00:00
* 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):
2022-11-02 15:01:47 +00:00
- MSVC
- Windows SDK
- C++ ATL
2021-04-05 12:54:18 +00:00
##### Download and extract the source:
[Download from GitHub][master]
```
2023-05-02 21:59:23 +00:00
unzip ghidra-master
cd ghidra-master
2021-04-05 12:54:18 +00:00
```
**NOTE:** Instead of downloading the compressed source, you may instead want to clone the GitHub
repository: `git clone https://github.com/NationalSecurityAgency/ghidra.git`
2024-07-03 12:04:27 +00:00
##### Download additional build dependencies into source repository:
**NOTE:** If an Internet connection is available and you did not install Gradle, the following
`gradle` commands may be replaced with `./gradle(.bat)`.
2021-04-05 12:54:18 +00:00
```
gradle -I gradle/support/fetchDependencies.gradle
2021-04-05 12:54:18 +00:00
```
##### Create development build:
```
2023-05-02 21:59:23 +00:00
gradle buildGhidra
2021-04-05 12:54:18 +00:00
```
The compressed development build will be located at `build/dist/`.
For more detailed information on building Ghidra, please read the [Developer Guide][devguide].
For issues building, please check the [Known Issues][known-issues] section for possible solutions.
2021-04-05 12:54:18 +00:00
## Develop
### User Scripts and Extensions
Ghidra installations support users writing custom scripts and extensions via the *GhidraDev* plugin
for Eclipse. The plugin and its corresponding instructions can be found within a Ghidra release at
2023-08-04 23:00:32 +00:00
`Extensions/Eclipse/GhidraDev/` or at [this link][ghidradev].
**NOTE:** The *GhidraDev* plugin for Eclipse only supports developing against fully built
Ghidra installations which can be downloaded from the [Releases][releases] page.
2021-04-05 12:54:18 +00:00
### Advanced Development
To develop the Ghidra tool itself, it is highly recommended to use Eclipse, which the Ghidra
development process has been highly customized for.
##### Install build and development tools:
* Follow the above [build instructions](#build) so the build completes without errors
2021-04-05 12:54:18 +00:00
* Install [Eclipse IDE for Java Developers][eclipse]
##### Prepare the development environment:
2021-04-05 12:54:18 +00:00
```
2023-05-02 21:59:23 +00:00
gradle prepdev eclipse buildNatives
2021-04-05 12:54:18 +00:00
```
##### Import Ghidra projects into Eclipse:
* *File* -> *Import...*
* *General* | *Existing Projects into Workspace*
* Select root directory to be your downloaded or cloned ghidra source repository
* Check *Search for nested projects*
* Click *Finish*
2021-04-05 12:54:18 +00:00
When Eclipse finishes building the projects, Ghidra can be launched and debugged with the provided
**Ghidra** Eclipse *run configuration*.
2019-03-02 01:40:39 +00:00
2021-04-05 12:54:18 +00:00
For more detailed information on developing Ghidra, please read the [Developer Guide][devguide].
2019-04-03 18:14:37 +00:00
2021-04-05 12:54:18 +00:00
## Contribute
If you would like to contribute bug fixes, improvements, and new features back to Ghidra, please
take a look at our [Contributor Guide][contrib] to see how you can participate in this open
source project.
[nsa]: https://www.nsa.gov
[contrib]: CONTRIBUTING.md
2021-04-05 12:54:18 +00:00
[devguide]: DevGuide.md
[known-issues]: DevGuide.md#known-issues
[career]: https://www.intelligencecareers.gov/nsa
2021-11-03 13:09:47 +00:00
[releases]: https://github.com/NationalSecurityAgency/ghidra/releases
2024-04-18 12:28:52 +00:00
[jdk]: https://adoptium.net/temurin/releases
2021-04-05 12:54:18 +00:00
[gradle]: https://gradle.org/releases/
[python3]: https://www.python.org/downloads/
2021-04-05 12:54:18 +00:00
[vs]: https://visualstudio.microsoft.com/vs/community/
2022-10-08 13:37:20 +00:00
[vcbuildtools]: https://visualstudio.microsoft.com/visual-cpp-build-tools/
2021-04-05 12:54:18 +00:00
[eclipse]: https://www.eclipse.org/downloads/packages/
[master]: https://github.com/NationalSecurityAgency/ghidra/archive/refs/heads/master.zip
2023-05-02 21:59:23 +00:00
[security]: https://github.com/NationalSecurityAgency/ghidra/security/advisories
2023-08-04 23:00:32 +00:00
[ghidradev]: https://htmlpreview.github.io/?https://github.com/NationalSecurityAgency/ghidra/blob/master/GhidraBuild/EclipsePlugins/GhidraDev/GhidraDevPlugin/GhidraDev_README.html