No project description provided
Project description
GnWManager
GnWManager is THE game-and-watch device manager. GnWManager is a command line tool who's responsible for getting firmware onto your device, managing the filesystem, and other device administrative tasks.
GnWManager accomplishes this via a small bundled pre-compiled firmware that gets executed from the STM32's RAM.
Features
- Simple installation.
- Works on all operating systems (Linux, MacOS, Windows).
- Automatic debugging probe detection.
- No need to specify if you have a stlink, jlink, CMSIS-DAP, or Raspberry Pi.
- Fast internal and external flash firmware flashing.
- Hardware-accelerated hashing for rapid duplicate discovery.
- Only syncs changed data.
- Minimizes flash erases and writes, extending flash lifespan.
- Double buffered, asynchronous, LZMA-compressed transfers for maximum speed.
- Hardware-accelerated hashing for rapid duplicate discovery.
- Complete filesystem management.
- Backup and restore files.
- Interactive filesystem explorer.
- Automatic Real-Time-Clock (RTC) configuration.
- Developer tools:
- Easily monitor device
printf
statements and launch GDB sessions. - Capture screenshots, regardless of the running firmware.
- Easily monitor device
Tutorials
Tutorials useful for typical end-users
Tutorials useful for developers
Compatibility
GnWManager works with all major operating systems: Windows, Mac, and Linux. GnWManager is also compatible with the following probes:
- Raspberry Pi Pico (Recommended)
- STLink
- JLink
- DAPLink
- Raspberry Pi (GPIO)
Raspberry Pi Pico
All Raspberry Pi Picos can be transformed into programmers via the picoprobe project.
- Download
picoprobe.uf2
from picoprobe releases. - Hold BOOT button on the pico and plug it into the computer. It should show up as a USB drive. Drag and drop
picoprobe.uf2
to it. - Hook up the 3 wires (GND, GP2, GP3) to (GND, SDCLK, SWDIO), respectively.
STLink
Hook up your STLink to your game and watch as follows:
Raspberry Pi (GPIO)
Hook up your Raspberry Pi to your game and watch as follows:
Usage
To see available commands, run gnwmanager --help
.
$ gnwmanager --help
Usage: gnwmanager [OPTIONS] COMMAND [ARGS]...
Game And Watch Device Manager.
Manages device flashing, filesystem management, peripheral configuration, and more.
╭─ Options ──────────────────────────────────────────────────────────────────────────╮
│ --version -v Print gnwmanager version. │
│ --frequency -f INT_PARSER Probe frequency. [default: None] │
│ --backend -b [pyocd] OCD Backend. [default: pyocd] │
│ --help Show this message and exit. │
╰────────────────────────────────────────────────────────────────────────────────────╯
╭─ Commands ─────────────────────────────────────────────────────────────────────────╮
│ debug GnWManager internal debugging tools │
│ disable-debug Disable the microcontroller's debug block. │
│ erase Erase a section of flash. │
│ flash Flash firmware to device. │
│ format Format device's filesystem. │
│ gdb Launch a gdbserver and connect to it with gdb. │
│ gdbserver Launch a gdbserver. │
│ install Install third party executables, like openocd. │
│ lock Re-lock your device. │
│ ls List contents of device directory. │
│ mkdir Create a directory on device. │
│ monitor Monitor the device's stdout logging buffer. │
│ mv Move/Rename a file or directory. │
│ pull Pull a file or folder from device. │
│ push Push file(s) and folder(s) to device. │
│ sdpush Push file(s) to SD Card connected to device. │
│ screenshot Capture and transfer screenshots from device. │
│ shell Launch an interactive shell to browse device filesystem. │
│ start Start firmware at location. │
│ tree List contents of device directory and its descendants. │
│ unlock Backs up and unlocks a stock Game & Watch console. │
╰────────────────────────────────────────────────────────────────────────────────────╯
Need Help?
If you need any help, either open up a github issue here, or join the stacksmashing discord for live help.
When sharing gnwmanager
output, it is recommended to increase the verbosity level:
- Via CLI argument:
gnwmanager --verbosity=debug
- Via environment variable
export GNWMANAGER_VERBOSITY=debug
Developer Installation
If developing for GnWManager, perform the following steps to setup your local environment. We use pre-commit to run linting, and poetry for python management.
git clone git@github.com:BrianPugh/gnwmanager.git
cd gnwmanager
pre-commit install # Ensures linting passes prior to committing
poetry install
make -j4 # Builds stm32 firmware binaries.
When changing C sources, make
must be re-ran to update the binaries located at:
gnwmanager/firmware.bin
gnwmanager/unlock.bin
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file gnwmanager-0.12.0.tar.gz
.
File metadata
- Download URL: gnwmanager-0.12.0.tar.gz
- Upload date:
- Size: 81.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.12 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fba11448184a73f7fc8f34c18b35cafd0b6ef3e844b4fd5eb0a472ac5a15abdd |
|
MD5 | 2691741964773cb28b58e8d38817456a |
|
BLAKE2b-256 | 29838674d484864eba455299ab6229e4f5039f938919f2332f6daf6db3f14969 |
File details
Details for the file gnwmanager-0.12.0-py3-none-any.whl
.
File metadata
- Download URL: gnwmanager-0.12.0-py3-none-any.whl
- Upload date:
- Size: 90.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.12 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 291ce04f15502dccb64f6339911288cd865bb2acc3faa05109ff96f3a5a5d01d |
|
MD5 | 192d7064f7474f094d3c66712d68db13 |
|
BLAKE2b-256 | d32f40b2cae95de7fbe19bf4c93135629a8b25e2bf5082c5ea096c9a7ba413e0 |