Homebrew [RELEASE] NDSFactory - unpack and repack NDS roms

Luca91

Well-Known Member
OP
Newcomer
Joined
Sep 13, 2019
Messages
74
Trophies
1
Age
33
XP
937
Country
Italy
Hello,
I was interested in getting code execution before the game's own NitroMain(), but my final ARM9 binary was bigger than the original one, and eventually was overlapping with the ARM7 binary.
Instead to try all the funcky ways to compress my code (that anyway is not a viable solution in most of the cases since the padding between ARM9 and ARM7 binaries is extremely small), I decided to write a tool to help me (and maybe other roms hackers/reverse engineers) to unpack and repack nds roms.

So, this is NDSFactory. With this tool you can unpack every sections of nds roms (but be aware that roms with OVERLAYS aren't supported right now!!!) and then repack them back (after editing them if you want).
Using this tool, you can set custom address and size of your edited sections and then it will rebuild a new rom.
Be aware that some general rom layout knowlege is required before using it. For example if the fat_data.bin (the FAT files) address is different, you have to patch your fat.bin using the 3rd tab.

I'd like to post a pic, but sadly I haven't the right post counter :/

If you want to contribute, you are very welcome, there is still a lot of things to do (checks, fat contents decoding, fat rebuilding, overlay support, a nice icon, and ofc bugs to fix!)


GitHub repo: https://github.com/Luca1991/NDSFactory


Thank you, and I'll be watching this thread for any suggestions/questions :)
 
Last edited by Luca91,

CMDreamer

Well-Known Member
Member
Joined
Oct 29, 2014
Messages
1,769
Trophies
1
Age
39
XP
3,829
Country
Mexico
This has so many posibilities!!!

On the wrong hands though... :wtf:

Can the NDS file be checked against an "official hash" to know they have been tampered with?

Thank you for this great tool!!!
 

Luca91

Well-Known Member
OP
Newcomer
Joined
Sep 13, 2019
Messages
74
Trophies
1
Age
33
XP
937
Country
Italy
This has so many posibilities!!!

On the wrong hands though... :wtf:

Can the NDS file be checked against an "official hash" to know they have been tampered with?

Thank you for this great tool!!!

I honestly don't think that this is useful to malware writers, if this is what you are thinking by "wrong hands". For at least three reasons:
1) NDS format is greatly documented (since 2005 IIRC)
2) A malware writer can easily write his/her own tools to unpack and repack nds roms (and also to apply patches to the fat)
3) I haven't done any research, but I think that there might be other tools like this one already released 14 years ago (I decided to write my own for fun)

Of course any nds roms can be checked against its official hash (the hash of a clean/untouched dump), you are welcome to write a function to calc and display the md5 of the final patched rom, and send me a PR on github. I'll be more than happy to merge your work :)


tl;dr: i don't think that malware writers have any advantages using this tool. Also, we have perfectly working emus nowadays: test your software using one of them, before running it on a real console.
 
Last edited by Luca91,
  • Like
Reactions: 4d1xlaan

Luca91

Well-Known Member
OP
Newcomer
Joined
Sep 13, 2019
Messages
74
Trophies
1
Age
33
XP
937
Country
Italy
Hi all,
from time to time I update this project. Here is a list of features added in the last couple of months:
- New UI: new scrollable UI for both packer and unpacker view. You can resize the window now and use this app on smaller screens.
- maOS version released
- Tested and working on ARM64 CPU (Raspberry Pi with QTAnywhere)
- Build system changed: switched to CMake
- Various workflow updates: added a CI to autobuild, added build version on each release etc.
- Improved stability (TM)

Planned features:
- Fat files decoding
- Fat_data creation from a set of files
- Support roms with overlay
 

Julie_Pilgrim

Secretly three raccoons in a trench coat
Member
Joined
Sep 2, 2020
Messages
2,648
Trophies
5
Location
(REDACTED)
Website
zoey-on-github.github.io
XP
2,033
Country
United States
Hi all,
from time to time I update this project. Here is a list of features added in the last couple of months:
- New UI: new scrollable UI for both packer and unpacker view. You can resize the window now and use this app on smaller screens.
- maOS version released
- Tested and working on ARM64 CPU (Raspberry Pi with QTAnywhere)
- Build system changed: switched to CMake
- Various workflow updates: added a CI to autobuild, added build version on each release etc.
- Improved stability (TM)

Planned features:
- Fat files decoding
- Fat_data creation from a set of files
- Support roms with overlay
Nice work!
 
  • Like
Reactions: banjo2

Luca91

Well-Known Member
OP
Newcomer
Joined
Sep 13, 2019
Messages
74
Trophies
1
Age
33
XP
937
Country
Italy
In this **HOT** summer Sunday evening...

NDSFactory v1.1 is available for download!

While this may seem like a minor release (in a way it is), it includes many quality of life improvements and many bug fixes. But more importantly, it paves the way for the implementation of all the missing features (support for ROMs with overlay and FAT rebuilding).

Further quality of life improvements are planned in the next release.
 
  • Like
Reactions: 4d1xlaan and Maeson

Kirby0Louise

Member
Newcomer
Joined
Aug 18, 2023
Messages
10
Trophies
0
XP
237
Country
United States
Works pretty well, and honestly I find it more convinent than DeSmuME's Nitro FS explorer.

Question - What exactly doesn't work right now with overlay ROMs? I got an error when using "extract everything", but upon checking the folder I extracted to, many of the files were there, and the FAT decode also worked fine on an overlay ROM.
 
  • Like
Reactions: Luca91

Luca91

Well-Known Member
OP
Newcomer
Joined
Sep 13, 2019
Messages
74
Trophies
1
Age
33
XP
937
Country
Italy
Works pretty well, and honestly I find it more convinent than DeSmuME's Nitro FS explorer.
Thanks a lot for your feedback!

Question - What exactly doesn't work right now with overlay ROMs? I got an error when using "extract everything", but upon checking the folder I extracted to, many of the files were there, and the FAT decode also worked fine on an overlay ROM.
It will not extract the overlay(s). I’m working adding the logic to parse the overlay(s) data and extract the binary(ies). Other than that, rebuilding FAT is currently missing.
 

Luca91

Well-Known Member
OP
Newcomer
Joined
Sep 13, 2019
Messages
74
Trophies
1
Age
33
XP
937
Country
Italy
Well, it seems to have spit out a9ovr.bin with the exact contents and size specified by the header. Unless there's more to it than that, seems to be working

Hey, sorry for the confusion, you are right that overlays extraction code is already in place, but files contained in overlays aren’t extracted yet.
 
Last edited by Luca91,

Kirby0Louise

Member
Newcomer
Joined
Aug 18, 2023
Messages
10
Trophies
0
XP
237
Country
United States
Hey, sorry for the confusion, you are right that overlays extraction code is already in place, but files contained in overlays aren’t extracted yet.
I see. The ROM I tested it on only has a 224 byte overlay. And looking at the data, I'm not sure there's any files contained in it

Regardless, definitely a project I'll keep an eye on
 

Luca91

Well-Known Member
OP
Newcomer
Joined
Sep 13, 2019
Messages
74
Trophies
1
Age
33
XP
937
Country
Italy
NDSFactory v1.2 is available for download!

This release FINALLY adds support to ROMs with overlays!! (this feature has been on my TODO list for at least 5 years!). Even though it's experimental, it should work!

Please report any bugs so I can fix them. Thanks.
 
  • Like
Reactions: 4d1xlaan

Luca91

Well-Known Member
OP
Newcomer
Joined
Sep 13, 2019
Messages
74
Trophies
1
Age
33
XP
937
Country
Italy
NDSFactory v1.3 is available for download!

Finally, in this version the FAT rebuild feature is now available: you can create a new FAT (fat.bin and fat_data.bin) from a previously decoded FAT.

Now, NDSFactory has all the features I had initially planned to add. Obviosuly, it can still be improved (for example regarding fat patching in ROMs with overlay).

NOTE: The Linux version will be coming later tonight (hopefully), as I have some issues with the latest GCC release in GitHub CI.
Post automatically merged:

NDSFactory v1.3.1 is available for download!

Linux build is now fixed :)
 
Last edited by Luca91,

Luca91

Well-Known Member
OP
Newcomer
Joined
Sep 13, 2019
Messages
74
Trophies
1
Age
33
XP
937
Country
Italy
Any plans for a command line version?

The project is divided into two parts:
  • UI directory: this is the GUI, written in Qt6
  • ndsfactory directory: this directory contains ndsfactory.cpp with all the program functions, in pure C++.
Now, you can easily write a command-line version by simply parsing user input and calling the relevant functions from ndsfactory.cpp.

I'm not interested in a command line version at the moment, but if anyone wants to do so, I'd definitely accept the PR.

This is also a good task for anyone learning to code.
 

Site & Scene News

Popular threads in this forum

General chit-chat
Help Users
  • No one is chatting at the moment.
  • Xdqwerty @ Xdqwerty:
    Is anyone here?
  • BigOnYa @ BigOnYa:
    I'm not
  • Xdqwerty @ Xdqwerty:
    @BigOnYa, I can see you hiding
    +1
  • K3Nv2 @ K3Nv2:
    The cops are gone you can come out
    +2
  • BigOnYa @ BigOnYa:
    Thank goodness, I was tired of hiding in the cloud.
    +1
  • K3Nv2 @ K3Nv2:
    5-0 we got him
    +2
  • Xdqwerty @ Xdqwerty:
    Good night
  • Michael-MSL @ Michael-MSL:
    good evening
  • K3Nv2 @ K3Nv2:
    Good lord
  • BigOnYa @ BigOnYa:
    Nighty night
    +1
  • K3Nv2 @ K3Nv2:
    Rp5 is shipping with 8gb of ram now
    +2
  • WinReset @ WinReset:
    haha hello
  • Psionic Roshambo @ Psionic Roshambo:
    @K3Nv2, I think the RP5 has had 8GBs for a while? I know mine has 8GBs not sure it's needed for emulation though? Probably 4GBs is enough for 99% of what it's fast enough to emulate? I could be wrong if it can do like GC and PS2 stuff maybe more is needed? Probably stream the ROMs like the consoles did off the drives.
  • Psionic Roshambo @ Psionic Roshambo:
    I believe what they do is OS and translation layer (emulator) and the emulator has its RAM like 36MBs for PS2 so like 3 times that maybe as things are shuffled around, a frame buffer and. Load the data from the ROM file into that systems RAM. I think I read that even 2GBs is enough if your just using a Pi for emulation.
  • BakerMan @ BakerMan:
    What's an RP5?
  • Psionic Roshambo @ Psionic Roshambo:
    Raspberry Pi 5
  • Psionic Roshambo @ Psionic Roshambo:
    For me it's just an emulation machine
  • Psionic Roshambo @ Psionic Roshambo:
    Like a super mini system, I use Batocera as an OS and it's pretty easy to set up, has a ton of UI skins you can make it look almost anyway you want. Still would kill for a WiiFlow like skin (some are close)
  • Psionic Roshambo @ Psionic Roshambo:
    I bought the 8GB model because my thoughts on that is the the difference between the models is like 20 bucks so why not get the good one just in case.
  • Psionic Roshambo @ Psionic Roshambo:
    Almost never hear anyone complaining about too much RAM but not enough? Yeah best to avoid that one. Lol
  • Psionic Roshambo @ Psionic Roshambo:
    I did kind of overshoot on storage, a 2TB nvme drive and I think 1TB would have been plenty.
  • Psionic Roshambo @ Psionic Roshambo:
    Probably have like 700GBs of stuff on it now, and don't think I can add much more.
    Psionic Roshambo @ Psionic Roshambo: https://m.youtube.com/watch?v=5FrGx-L5XaM