Skip to content

Getting Started

Meziu edited this page Nov 1, 2024 · 12 revisions

Install Requirements

Below is written an extensive guide on how to setup the necessary tools and equipment to develop with the Rust3DS toolchain.

If you are looking for a less-hassle solution, you might prefer using prebuilt dev-containers, such as the official devkitARM container, which includes the base toolchain for C development, or even community made containers already configured to be used with Rust3DS, like nandolawson's. Keep in mind that these solutions are NOT affiliated with the rust3ds org.

Running apps

Custom firmware (CFW) 3DS

To run homebrew software on your Nintendo 3DS, you will need to modify the console's firmware. You will especially need the "Homebrew Launcher" application, which lets you run and debug your software (packaged in .3dsx executable files).

Emulation

You can also run 3DS homebrew using an emulator, for faster iteration while developing, or if you don't have / don't want to hack a 3DS. Note that there might be some differences / limitations compared to running on real hardware, so you should always test your code on a real device if possible.

Install the Rust programming language

Follow this guide to install the language on your platform.

Install the devkitARM toolchain

This section is unnecessary for people who already use the devkitARM toolchain to develop homebrew. If it's your first time using it, follow the next instruction, otherwise, skip to the next main paragraph.

Get dkp-pacman

devkitARM provides many packages to start working on software. You can install these tools and libraries on Windows, MacOS and Linux, by using dkp-pacman. Follow their "Getting Started" guide for your platform, by the end of which you should have the dkp-pacman installer ready in your terminal emulator (for Linux distros that use pacman, you can also just add their repositories as sources and use that instead, but keep in mind that we'll refer to it as dkp-pacman from now on).

Install the tools

dkp-pacman is the main installer for all devkitARM packages, including some third-party C libraries which have been ported over to Nintendo 3DS (these are known as "portlibs"). By using this tool, you can now install the main packages for developing. As the devkitPRO guide suggests, simply do sudo dkp-pacman -S 3ds-dev to install all main packages.

Link the tools to the system

This may be a hard step to follow (especially if you're not used to using the command line) but it's absolutely needed to get our tools up and running. Restart your terminal emulator and check whether the environment variables DEVKITPRO and DEVKITARM are properly set. Also, check if $DEVKITPRO/tools/bin and $DEVKITARM/bin are visible in the PATH. If not, set them manually.

Install the Rust3DS tools

We are finally out of the C realm, and can continue our safe journey into Rust programming.

Install cargo-3ds

cargo-3ds is our custom made cargo extension to build and test 3DS executable files. You can install the latest stable version on crates.io by running cargo install cargo-3ds.

Install LLVM for bindgen

Rust3DS -sys libraries use bindgen at build time to generate bindings to devkitPro APIs, which in turn uses LLVM to parse C headers. For this to work correctly bindgen needs some version of LLVM installed — see their documentation for detailed installation instructions.

Start developing

You can now start writing some real code! There are many ways to start depending on your objective. It's possible to use cargo-3ds to create a new project already prepared with the tools you'll need. Simply do cargo 3ds new <project-name> and get coding!

There are some very important things to note:

  • Even though building, running and testing can be done via standard cargo commands, we suggest you look into using cargo-3ds to speedup most of the workflow (go look at its README to learn how it works).
  • To use all system-specific functionality and the Rust std you'll have to depend on ctru-rs. There are ways to get those working by yourself, but for the sake of this guide you should just base your work on ctru-rs (there is a lot of great stuff here!).
  • Even while using ctru-rs, modules such as std::process and std::thread (plus most third party crates) may not work (or work differently than originally intended) because of how the OS operates. You can read more about that in System Flaws.

Get to know it

If you don’t feel ready to start your own project, or simply want to see what the console is capable of, you can try the included examples.

Happy coding! 👋 🦀