Skip to content

Files

Latest commit

 

History

History
 
 

scripts

Scripts for mt32-pi

An interactive Bash script for performing a first-time installation of mt32-pi. Intended for use on MiSTer FPGA, but should be usable on any Linux PC. Simply attach an SD card reader to your machine and insert a microSD card, then run the script as root.

Features

  • Easy and friendly step-by-step operation with confirmation at each stage.
  • Allows user to choose an SD card from a list, then partitions and formats it as FAT32.
  • Downloads the latest release from GitHub, and extracts it to the SD card.
  • Automatically edits the configuration files with the most common settings for use with MiSTer FPGA.
  • Optionally allows the user to set up and enable Wi-Fi and FTP. Copies MiSTer Wi-Fi configuration if present.

Limitations

  • Assumes I²S audio output, 128x64 SSD1306 OLED, MiSTer OSD enabled, and simple_encoder control scheme.
  • For performing clean installation only; does not save/restore settings or any extra files on the SD card.

Requirements

This script requires the following tools to be installed on your system. Use your system package manager (e.g. apt or pacman) to install them. If you're using MiSTer, all of these tools are available out of the box; no need to install any extra software.

  • awk
  • curl
  • dialog
  • grep
  • jq
  • mkfs.fat (from dosfstools)
  • parted
  • sed
  • udevadm (should be installed as part of the base system)
  • unzip

Usage

  1. Download mt32pi_installer.sh.
    • If you want to use it on MiSTer, copy it to the /Scripts directory on your SD card.
  2. Make the script executable by typing chmod +x mt32pi_installer.sh at a shell prompt.
  3. Insert a microSD card into a USB card reader, and then connect it to your Linux PC or MiSTer.
  4. Run the script by typing sudo ./mt32pi_installer.sh at a shell prompt.
    • On MiSTer, you should see mt32pi_installer in the Scripts menu - simply select it to run the script.

A non-interactive Python 3 script for automatically updating your mt32-pi via the embedded FTP server. Intended for use on MiSTer FPGA, but should be usable on any Linux or Windows PC.

⚠️ Note: mt32-pi v0.11.0+ is required, as the script depends on the FTP server feature which was introduced in this version. Networking and the FTP server must be enabled; see the wiki page to learn how to set them up.

A wrapper script (mt32pi_updater.sh) is provided so that it can be launched from the MiSTer OSD's Scripts menu.

Features

  • Self-updating.
  • Connects to your mt32-pi via FTP and compares the installed version with the latest version available on GitHub.
  • Exits early if your mt32-pi is up-to-date.
  • Shows the release notes for a few seconds before updating.
  • Creates a backup of your mt32-pi.cfg.
  • Intelligently merges your old mt32-pi.cfg settings into the latest template from the installation package, so that new options and documentation are preserved along with your old settings.
  • Restores your old config.txt and wpa_supplicant.conf.

Limitations

  • Does not intelligently merge your config.txt or wpa_supplicant.conf, but these files rarely change. Instead, the latest versions from the installation package are copied to your SD card as config.txt.new and wpa_supplicant.conf.new so that you may check and manually update them if necessary.

Usage

  1. Download mt32pi_updater.py and mt32pi_updater.cfg.
    • If you want to use it on MiSTer, download the the wrapper script too, and copy both scripts (.py and .sh) and the .cfg file to the /Scripts directory on your SD card.
  2. Make the script(s) executable by typing chmod +x mt32pi_updater.{py,sh} at a shell prompt.
  3. Enable mt32-pi's networking and embedded FTP server features.
  4. If you have set a custom hostname, IP address or FTP username/password in mt32-pi.cfg, edit the host, ftp_username and ftp_password settings inside mt32pi_updater.cfg so that they match.
  5. Run the script by typing ./mt32pi_updater.py at a shell prompt.
    • On MiSTer, you should see mt32pi_updater in the Scripts menu - simply select it to run the script.

⚠️ Note: If mt32-pi cannot be reached by hostname (e.g. the script cannot connect or ping mt32-pi fails), you may have an issue with DNS resolution within your LAN. Check your router's DNS/DHCP settings, or try using an IP address instead of a hostname instead.