💾 Archived View for radare.org › book › first_steps › history.gmi captured on 2024-05-10 at 10:50:44. Gemini links have been rewritten to link to archived content
⬅️ Previous capture (2023-11-04)
-=-=-=-=-=-=-
In 2006, Sergi Àlvarez (aka pancake) was working as a forensic analyst. Since he wasn't allowed to use the company software for his personal needs, he decided to write a small tool-a hexadecimal editor-with very basic characteristics:
- be extremely portable (unix friendly, command line, c, small)
- open disk devices, this is using 64bit offsets
- search for a string or hexpair
- review and dump the results to disk
The editor was originally designed to recover a deleted file from an HFS+ partition.
After that, pancake decided to extend the tool to have a pluggable io to be able to attach to processes and implemented the debugger functionalities, support for multiple architectures, and code analysis.
Since then, the project has evolved to provide a complete framework for analyzing binaries, while making use of basic UNIX concepts. Those concepts include the famous "everything is a file", "small programs that interact using stdin/stdout", and "keep it simple" paradigms.
The need for scripting showed the fragility of the initial design: a monolithic tool made the API hard to use, and so a deep refactoring was needed. In 2009 radare2 (r2) was born as a fork of radare1. The refactor added flexibility and dynamic features. This enabled much better integration, paving the way to use r2 from different programming languages[1]. Later on, the r2pipe API[2] allowed access to radare2 via pipes from any language.
1: from different programming languages
What started as a one-man project, with some eventual contributions, gradually evolved into a big community-based project around 2014. The number of users was growing fast, and the author-and main developer-had to switch roles from coder to manager in order to integrate the work of the different developers that were joining the project.
Instructing users to report their issues allows the project to define new directions to evolve in. Everything is managed in radare2's GitHub[1] and discussed in the Telegram channel.
The project remains active at the time of writing this book, and there are several side projects that provide, among other things, a graphical user interface (Iaito[1], a decompiler (r2dec[2], radeco[3], Frida integration (r2frida[4], Yara, Unicorn, Keystone, and many other projects indexed in the r2pm[5] (the radare2 package manager).
Since 2016, the community gathers once a year in r2con[1], a congress around radare2 that takes place in Barcelona.