Sys-patch Switch

From GameBrew
sys-patch
Syspatchnx.png
General
AuthorTotalJustice
TypeSysmodules
Version1.5.0
LicenseMIT License
Last Updated2023/10/25
Links
Download
Website
Source

A script-like system module that patches fs, es, ldr and nifm on boot. This has the same effect as sigpatches, the benefit of sys-patch is that it only needs updating when something major breaks.

sys-patch also outputs a log where you can see which patches are applied, which one failed and some other useful data. You can manually read the log or use the overlay, which you can also use to change the config.

sigpatch-updater was updated to support updating and auto running sys-patch. This means that you can update and apply patches without having to reboot.

Note: At this time, it's recommended to use this alongside sigpatches, so in case you forget to update patches, sys-patch should continue to work.

Features

  • A simple configuration file for customizing patch options, located at /config/sys-patch/config.ini.
  • An overlay that allows you to change the configuration options and see the applied patches.
  • A minimal memory footprint (16 KiB) and binary size (~50 KiB).

Installation

Extract the zip file to the root of the SD card.

User guide

What is being patched?

sys-patch is designed to patch the following components:

  • fs and es - Require new patches after every new firmware version.
  • ldr - Requires new patches after every new Atmosphere release.
  • nifm - The ctest patch allows the device to connect to a network without needing to make a connection to a server.

These patches are applied on boot, and once they are done, the sys-module stops running.

Config

sys-patch features a simple config. This can be manually edited or updated using the overlay.

The configuration file can be found in /config/sys-patch/config.ini. The file is generated once the module is ran for the first time.

[options]
patch_sysmmc=1   ; 1=(default) patch sysmmc, 0=don't patch sysmmc
patch_emummc=1   ; 1=(default) patch emummc, 0=don't patch emummc
enable_logging=1 ; 1=(default) output /config/sys-patch/log.ini 0=no log
version_skip=1   ; 1=(default) skips out of date patterns, 0=search all patterns

Overlay

The overlay can be used to change the config options and to see what patches are applied.

  • Unpatched means the patch wasn't applied (likely not found).
  • Patched (green) means it was patched by sys-patch.
  • Patched (yellow) means it was already patched, likely by sigpatches or a custom Atmosphere build.

FAQ

Q. If I am using sigpatches already, is there any point in using this?

Yes, in 3 situations.

  1. A new "ldr" patch needs to be created after every Atmosphere update. Sometimes, a new silent Atmosphere update is released. This tool will always patch "ldr" without having to update patches.
  2. Building Atmosphere from src will require you to generate a new "ldr" patch for that custom built Atmosphere. This is easy enough due to the public scripts / tools that exist out there, however this will always be able to patch "ldr".
  3. If you forget to update your patches when you update your firmware / Atmosphere, this sys-module should be able to patch everything. So it can be used as a fall back.

Q. Does this mean that I should stop downloading / using sigpatches?

No, I would personally recommend continuing to use sigpatches. Reason being is that should this tool ever break, I likely wont be quick to fix it.

Screenshots

syspatchnx2.jpgsyspatchnx3.jpgsyspatchnx4.jpgsyspatchnx5.jpg

Changelog

v1.5.0

  • Updated noncasigchk patch for fw 17.
  • Huge thank you to everyone that helped in #5.
  • Another huge thank you to the anon that created the patch.

v1.4.2

  • Fix options "logging" key missmatch between sysmod and overlay.

v1.4.1

  • The patch itself always worked, however it failed to detect if the patch was already applied.
  • This isn't a big issue, and the only one to notice was probably me.

v1.4.0

  • Add ctest patch, add per patch toggle, made overlay more organised.

v1.3.0

  • Add more logging, pattern version skipping, min/max fs pattern versions.

v1.2.0

  • Todo: document changes.

v1.1.1

  • Whilst the previous release worked, it did so out of sheer luck..
  • The path size passed to the fs set of functions was way too small. this is now fixed.

v1.1.0

  • Config can be found in /config/sys-patch/config.ini.
  • If no config file is found, a default one is created.
    • [options]
    • patch_sysmmc=1
    • patch_emummc=1
  • Change either of the above to disable sys-patch from running when booted as sys/emu.

v1.0.0

  • First Release.

Credits

Software is built on the shoulders of giants. This tool wouldn't be possible without these people:

External links

Advertising: