rabbitizer/README.md

107 lines
4.4 KiB
Markdown
Raw Normal View History

2022-06-03 17:46:51 +00:00
# rabbitizer
2022-06-23 04:29:41 +00:00
[![PyPI - Downloads](https://img.shields.io/pypi/dm/rabbitizer)](https://pypi.org/project/rabbitizer/)
![GitHub](https://img.shields.io/github/license/Decompollaborate/rabbitizer)
![GitHub release (latest SemVer)](https://img.shields.io/github/v/release/Decompollaborate/rabbitizer)
![PyPI](https://img.shields.io/pypi/v/rabbitizer)
2022-12-18 21:37:07 +00:00
![crate.io](https://img.shields.io/crates/dv/rabbitizer)
2022-06-23 04:29:41 +00:00
![GitHub contributors](https://img.shields.io/github/contributors/Decompollaborate/rabbitizer?logo=purple)
2022-12-24 00:41:45 +00:00
MIPS instruction decoder API.
2022-06-23 04:29:41 +00:00
2022-12-24 00:41:45 +00:00
## Features
- Should produce matching assembly.
- Fully written in C for fast decoding.
2022-12-24 02:21:54 +00:00
- The library is completely allocation-less, in other words `rabbitizer`
doesn't allocate in anything in the heap by itself.
2022-12-24 00:41:45 +00:00
- Other language bindings supported in this repo:
- Python bindings
- The minimal Python version is 3.7, older versions are not guaranteed to work.
- C++ bindings
- Rust bindings
- Simple per-word instruction decoding.
2022-12-24 02:21:54 +00:00
- The library doesn't try to be too smart by processing multiple instructions
at a time.
2022-12-24 00:41:45 +00:00
- Can perform validation checks for instructions.
2022-12-24 02:21:54 +00:00
- Provides many examination/grouping functions for instructions, allowing to
simplify checking characteristics of an instruction and minimizing the need to
check for specific instructions in a hardcoded way.
2022-12-24 00:41:45 +00:00
- Includes some minor tools to build your own pointer/symbol detection.
- Configurable, many features can be turned on and off.
- MIPS instructions features:
- Named registers for MIPS VR4300's coprocessors.
- Support for many pseudo-instructions.
- Properly handle move to/from coprocessor instructions.
- Support for numeric, o32, n32 and n64 ABI register names.
- Some workarounds for some specific compilers/assemblers:
- `SN64`:
- `div`/`divu` fix: tweaks a bit the produced `div`, `divu` and `break` instructions.
- Multiple MIPS architectures are supported:
- Main focus on MIPS I, II and III architectures. Partial support for MIPS IV too.
- N64 RSP instruction decoding support.
- RSP decoding has been tested to build back to matching assemblies with [armips](https://github.com/Kingcom/armips/).
- R5900 (PS2's Emotion Engine processor) decoding support.
## Non-features
In order to keep it simple and fast the following features will not be added:
- Pseudo-instructions which expands to more than one instruction.
2022-06-23 04:29:41 +00:00
## Installing
2022-12-18 21:37:07 +00:00
### Python bindings
2022-06-23 04:29:41 +00:00
The recommended way to install is using from the PyPi release, via `pip`:
```bash
pip install rabbitizer
```
2022-12-24 02:21:54 +00:00
In case you want to mess with the latest development version without wanting to
clone the repository, then you could use the following command:
2022-06-23 04:29:41 +00:00
```bash
pip install git+https://github.com/Decompollaborate/rabbitizer.git@develop
```
2022-12-24 02:21:54 +00:00
NOTE: Installing the development version is not recommended. Proceed at your own
risk.
2022-06-23 04:29:41 +00:00
2022-12-18 21:37:07 +00:00
See this package at <https://pypi.org/project/rabbitizer/>.
### Rust bindings
Add this crate to your `Cargo.toml` via:
```toml
[build]
2022-12-20 16:03:11 +00:00
rabbitizer = "1.5.8"
2022-12-18 21:37:07 +00:00
```
See this crate at <https://crates.io/crates/rabbitizer>.
## References
2022-12-14 18:27:16 +00:00
- MIPS CPU:
- MIPS IV Instruction Set (Revision 3.2): <https://www.cs.cmu.edu/afs/cs/academic/class/15740-f97/public/doc/mips-isa.pdf>
- MIPS Calling Convention Summary: <https://courses.cs.washington.edu/courses/cse410/09sp/examples/MIPSCallingConventionsSummary.pdf>
- mipt-mips pseudo instructions: <https://github.com/MIPT-ILab/mipt-mips/wiki/MIPS-pseudo-instructions>
- N64's RSP (Reality Signal Processor):
- Nintendo Ultra64 RSP Programmers Guide: <https://ultra64.ca/files/documentation/silicon-graphics/SGI_Nintendo_64_RSP_Programmers_Guide.pdf>
- N64brew Reality Signal Processor/CPU Core: <https://n64brew.dev/wiki/Reality_Signal_Processor/CPU_Core>
- R3000 GTE:
- PSYQ SDK headers: <https://github.com/FoxdieTeam/psyq_sdk/blob/master/psyq_4.4/INCLUDE/INLINE_A.H>
- no$psx documentation: <https://problemkaputt.de/psxspx-gte-opcode-summary.htm>
- no$psx documentation: <http://problemkaputt.de/psx-spx.htm#geometrytransformationenginegte>
- <http://www.raphnet.net/electronique/psx_adaptor/Playstation.txt>
- R5900:
- EmotionEngine instruction decoding: <https://psi-rockin.github.io/ps2tek/#eeinstructiondecoding>
- Official documentation from Toshiba: <https://wiki.qemu.org/images/2/2a/C790.pdf>
- VU instruction manual: <http://lukasz.dk/files/vu-instruction-manual.pdf>
- GNU binutils: <https://github.com/bminor/binutils-gdb/blob/master/opcodes/mips-opc.c>