Write SAM Coupé disk images to USB floppy drive
Project description
writeusb
A Python script to write SAM Coupé disk images to a USB floppy drive so they can be used on real SAM hardware.
Source disk images should be normal 80/2/10/512 format and in MGT/SAD/EDSK disk image containers. SAMDOS/MasterDOS/BDOS and some custom loaders are supported.
Background
USB floppy drives are usually limited to 1.44M (18-sector) and 720K (9-sector) formats used by PC floppy disks. This is a problem for regular SAM disks, which use a 10-sector disk format.
This script re-maps the sectors used by the files on the source disk image so it uses only 9 sectors on each track. It also patches the boot loaders on converted disks to keep within these limits. Most SAM disks should support conversion.
Please note that this script will NOT help to read existing 10-sector SAM Coupé disks. The 10th sector on each track is inaccessible on USB floppy drives.
Requirements
- Windows, Linux or macOS
- USB floppy drive and double-density disks
- Python 3.6 (or later)
Installation
To install:
python -m pip install mgtwriteusb
Or to install from local source code:
python setup.py install
Command-line Options
usage: writeusb [-h] [-o OUTPUT] [-n] [-f] [-a] [-s] diskimage
Write SAM disk image to USB floppy drive
positional arguments:
diskimage
optional arguments:
-h, --help show this help message and exit
-o OUTPUT, --output OUTPUT
output to disk image file
-n, --noverify don't verify disk after writing
-f, --force write even if boot loader is unknown
-a, --all write all tracks, not just used tracks
-s, --sniff detect boot loader on source image
Examples
Convert image.dsk
to 9-sector format, write used tracks to the connected USB
floppy drive, then verify the written data:
writeusb image.dsk
Convert image.dsk
to 9-sector format, save output to disk image output.img
for use with SimCoupe or another disk writing program:
writeusb image.dsk -o output.img
Converting non-bootable disks will add a special version of SAMDISK v2, patched
to dynamically support both 9-sector and 10-sector disks. It will appear in the
directory listing as samdisk9
. When an existing boot loader is patched it
supports only the converted 9-sector disks.
Troubleshooting
macOS and Linux users may need to run the script under sudo
, depending on the
permissions and group ownership of the USB floppy device. Linux users may just
need to be in the disk
group, depending on distribution.
Be sure to use real double-density media, which usually has a blue cover. High density disks have different magnetic properties, so covering the density hole is not a good solution. HD disks are often unreliable after writing (YMMV).
If you're reusing existing SAM disks be aware that some USB floppy drives may
not recognise the existing 10-sector format. You may have to reformat the disk
as true 9-sector before it'll work. Under Windows try format a: /t:80 /s:9
, or
under Linux try ufiformat /dev/sdX
(change sdX to the correct device name).
SAMDOS/MasterDOS/BDOS will retry after disk errors but custom loaders may not. The MNEMOtech loader used by MNEMOdemo 1 and 2 fails immediately fails with a Loading Error so you'll need good quality disks!
Expect disk errors. If in doubt try a different disk!
Limitations
Disk images containing custom formats are not supported and will be rejected. This prevents original copies of Lemmings, Prince or Persia, and maybe some other titles from working.
Reducing from 10 sectors to 9 sectors also reduces the disk capacity. The converted disk has 72 directory slots and 702K of free space, rather than 80 directory slots and 780K on a regular disk. Full disks may need to be split.
Disks storing data outside the normal filesystem structures will be missed by the conversion process. This affects the Pac-Man Emulator (v1.4 or earlier).
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 mgtwriteusb-0.9.1.tar.gz
.
File metadata
- Download URL: mgtwriteusb-0.9.1.tar.gz
- Upload date:
- Size: 15.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c631578118ed4940abdb11449faef188649cdf3d00961c97423eb590d091dcf3 |
|
MD5 | cb49e8900bec980b87703b4e624b9586 |
|
BLAKE2b-256 | e180b792085c5dfc4ac392f35a2fc83e2eeb353be7443e289cdf668ed0298069 |
File details
Details for the file mgtwriteusb-0.9.1-py3-none-any.whl
.
File metadata
- Download URL: mgtwriteusb-0.9.1-py3-none-any.whl
- Upload date:
- Size: 13.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8490d9bc17897243b6ba0ceb6d62baf698e219bc2ab96f3c6aef13b998c7c5db |
|
MD5 | 4c4755884d3026664c32274c4a0eea18 |
|
BLAKE2b-256 | 8fc2ea9996d934e8fef3f0f4bdc075effcf44f9d4e5765ec0490d50fba4bf254 |