

Hello world project for NDS, using devKitPro based on devkitPro Updater 1.6.0 (ARM v5)
Explore the docs »
·
Report Bug
·
Request Feature
·
Table of Contents
This repository contains the source code for creating a .nds
executable that you can run in real or emulated hardware
of the Nintendo DS.
This project has been created as a way to test compilation environments.
It also features a workflow that builds and releases the binary on every commit.
To know more about my projects as a teacher for University Rovira i Virgili, you can check the GitHub page.
This section lists any major languages, frameworks and libraries used to bootstrap the hello-world-nds platform:
You can install it manually by moving the bmde
folder (not included) into C:\URV\
and creating the corresponding
environment variables.
Afterward, you can do the following to clone, compile and run the code:
git clone https://github.com/URV-teacher/bmde-linux
cd bmde-linux
make clean
make
make run
- Install Docker in your system.
- Clone the
bmde
repository:git clone https://github.com/URV-teacher/bmde-linux
- Enter inside the
input
folder:cd bmde-linux/input
and clone this repo:git clone https://github.com/URV-teacher/hello-world-nds
- Open a terminal in the root folder of the NDS project that you want to compile.
- Execute
make
. - The
.nds
binary from the project should be in the root folder of the repository.
- Go back to the root folder of the repository
bmde
:cd ..
- Run
docker compose up
- The
.nds
binary from thehello-world-nds
project will be on theoutput
folder.
- Download and install DeSmuME from official page. We target version
0.9.11-dev
that you can download from here, but the binary also has been proved to work in later versions. - Run DeSmuME and open the
.nds
file. - You should see the "Hello world" message being displayed in the inferior screen of the NDS.
- Download and install Flatpak
flatpak install flathub org.desmume.DeSmuME
- Run DeSmuMe Flatpak
flatpak run org.desmume.DeSmuME
- open the
.nds
file. - You should see the "Hello world" message being displayed in the inferior screen of the NDS.
You can use this project as a basic compilation test tool for a NDS development environment.
This project was used to test the
port of the bmde
environment to Linux that is used in the subjects Computers, Computer Fundamentals and Operating
System Structure
in the Universitat Rovira i Virgili.
There is also a GitHub workflow that is triggered on every push to master
branch to compile the project and release
it. You can download the .nds
from there to try it
directly without compilation.
This project is completely functional! But there is space for improvements...
- Refine Docker for usage with the port of the
bmde
environment to Linux.
See the open issues for a full list of proposed features (and known issues).
This is an open-source project, so any contributions are greatly appreciated ❤.
If you have an issue or suggestion that would make hello-world-nds better, please open a new issue explaining your inquiry. We will try to satisfy your needs as soon as possible.
If you want to make a contribution to hello-world-nds by yourself, please
open a new issue, so we can discuss the reach of your
contribution.
After that, fork the repo, implement your change and create a
pull request from your fork to the master
branch. We will merge
your changes as soon as possible, so they are available in the next releases of hello-world-nds-asban.
So, for each change that you want to do to hello-world-nds-asban by yourself, you will need to:
- Fork the repo.
- Create your Feature Branch (
git checkout -b feature/AmazingFeature
). - Add and commit your Changes (
git add src; git commit -am 'Add some AmazingFeature'
). - Push to the Branch (
git push origin feature/AmazingFeature
). - Repeat steps 3 and 4 as many times as you need.
- Open a pull request from your fork to the develop branch.
- Repeat steps 3 and 4 if further changes are required.
Do not forget to give the project a star ⭐ on GitHub!
Distributed under the GNU AFFERO GENERAL PUBLIC LICENSE, Version 3.
See LICENSE
to obtain a copy of the therms
of this license.
This software was developed by Aleix Mariné-Tena, substitute teacher at University Rovira i Virgili of subjects Computers and Computer Fundamentals.
hello-world-nds ultimately belongs to Aleix Mariné-Tena and has the control over the licensing and distribution therms.
Copyright 2025 - Present Aleix Mariné-Tena
This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
Aleix Mariné-Tena - [email protected] 📫
You can get more information of URV at https://urv.cat.
Shout out to @WinterMute and his team that created devkitPro.
Universitat Rovira i Virgili (URV): URV, The Universitat Rovira i Virgili is the university that
provides southern Catalonia with a knowledge structure of international renown. Through teaching, research, knowledge
transfer and culture it helps society to be more just and free.
Departament d'Enginyeria Informàtica i Matemàtiques (URV): The Department of Computer Engineering
and Mathematics (DEIM) is a department in the URV made up of professors and researchers specializing in different
disciplines corresponding to
areas of knowledge of Computer Science, Telematics and Mathematics.
- Aleix Mariné-Tena (URV): Substitute teacher of subject Computers and Fundamentals of Computers at URV.