NTRLDR 3DS

From GameBrew
Revision as of 09:21, 15 June 2021 by HydeWing (talk | contribs) (Created page with "{{Infobox 3DS homebrew | title = NTRLDR | image = https://dlhb.gamebrew.org/3dshomebrew/NTRLDR.jpg|250px | type = System Tools | version = | licence = Mixed | author = dr1ft |...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Template:Infobox 3DS homebrew

Hello! I've been very intrigued as to why the old firmware.nds file failed to load properly under the 3DS. After almost a week of research and experimentation, I took my first dive into writing homebrew as a means to solve this problem. It's not particularly useful, but I learned a lot and it's a neat little novelty.

I've tested NTRLDR heavily under an NTR-mode flashcart (CycloDS iEvolution) and under TWL-mode nds-hb-menu (3DS SD). It does not seem to run under TWLoader/nds-bootstrap. firmware.nds is expected to be in the root of the partition /_nds/ntrldr

I do not recommend running this on an NDS or DSi system. It probably won't hurt anything, but it directly writes to flash/NVRAM (which is dangerous) and there's no real reason to (unless you are using SudokuHax or something). It will almost certainly brick an iQue NDS. YOU CANNOT BOOT NDS CARTRIDGES WITH THIS

Here's a tiny little demonstration:


An error occurred.

Unable to execute JavaScript.


Spoiler: Technical details

NVRAM patching The reason that firmware.nds traditionally fails on the 3DS is because for some reason NVRAM reports one of the bits in the flag bytes of user settings as a 1, when the DS firmware expects that bit to be a 0. We can write to NVRAM, but every time NTR mode is restarted this bit becomes a 1 again. As such, all we need to do to allow firmware.nds to boot is to flip that bit and correct the checksums in the user settings just prior to chainloading firmware.nds.

TWL->NTR mode switching The NDS firmware does not know how to deal with the extra features provided by TWL mode (obviously). The DMA register REG_SCFG_ROM is set to 0x703 to keep the firmware from crashing (this seems to cause the system to disable several TWL features) and writes are made to the TSC to switch it into NDS compatibility mode (see here) so that the firmware can understand the touch screen. I found the TSC values by going through this code and trying different combinations of values until I found the right ones.

DOWNLOAD: https://github.com/strdr1ft/ntrldr I can't supply firmware.nds, but it's not too hard to find if you're interested in trying this.

Advertising: