Architecture | Download Links |
---|---|
Windows x64 | Latest |
Linux x64 | See docker wrapper to quickly get libdragon up and running. |
This is a simple library for N64 that allows one to code using the gcc compiler suite and nothing else. No proprietary library is needed.
To get started from scratch, follow the following steps:
- Create a directory and copy the build script there from the tools/ directory.
- Read the comments in the build script to see what additional packages are needed.
- Run ./build from the created directory, let it build and install the toolchain.
- Install libpng-dev if not already installed.
Below steps can also be executed by running build.sh
at the top level.
- Make libdragon by typing 'make' at the top level.
- Install libdragon by typing 'make install' at the top level.
- Make the tools by typing 'make tools' at the top level.
- Install the tools by typing 'make tools-install' at the top level.
- Install libmikmod for the examples using it. See
build.sh
at the top level for details. - Compile the examples by typing 'make examples' at the top level.
You are now ready to run the examples on your N64. For more information, visit http://www.dragonminded.com/n64dev/
Libdragon uses assembly macros to program the RSP chip defined in ucode.S
. These mainly wrap cop2
, lwc2
and swc2
instructions.
The syntax is similar to that of Nintendo's but with a few changes. For example if we take vabs
instruction;
vabs vd, vs, vt[e]
it becomes;
vabs vd, vs, vt, e
and element (e
) is always required. It is also similar for load/store instructions. As an example, sbv
instruction;
sbv vt[element], offset(base)
becomes;
sbv vt, element, offset, base
Basically all operands are required and separated by commas.
While using these custom instructions, you should use $v00
-$v31
when naming vector registers and $0
-$31
when naming scalar registers.
Due to the fact that windows does not include some header files needed for the tools, it is necessary to download them separately. Please look at the azure-pipelines.yml file, to see how the lib and tools are built in a windows environment.