The IOLib is a modular hardware detection and IRq loader framework for the Commodore 264 series of computers. Main goal of development was to create a totally asynchronous loader system that can be used together with any IRq handlers and is compatible with as many drive types as possible.
- file name based (first two characters of name are checked)
- you can load files in any order
- you can load files from an SD2IEC or other SD Card based storage solutions directory natively
- IRq loader
- you can interrupt loading any time
- uses serial protocol based on number of serial drives detected
- TODO: currently only the multi-drive protocol is implemented
- for parallel and TCBM interfaces the number of drives is not important and not used
- DOS compatible, sector based (NOT A TRACKLOADER)
- this ensures compatiblity with non-GCR drives
- but it's not so fast
All functionality of the library is divided into modules. All modules can be included/excluded using compilation options. List of modules:
- Hardware detection (mandatory)
- Detailed status report of detected hardware (for debugging purposes)
- Video standard detection
- Memory size detection
- Sound source detection
- Loader (includes drive type detection)
- Exomizer decruncher
Executes all included detection modules.
All hardware detection modules can report what they found via standard chrout printing to screen (lower case characters). This can be totally switched off to avoid printing the obvious and to save memory and disk space.
Detects available RAM size:
- 16k
- 32k
- 64k
- 128k (Hannes/Csory)
- 256k (Hannes/Csory)
- 512k (Hannes/Csory)
- 1024k (Hannes/Csory)
- 2048k (Hannes only)
- 4096k (Hannes only)
Based on TED control register #2 ($ff07) bit 6. (Yeah, it's simple, mostly for reporting)
Detects if a SID card is plugged in, the SID chip type (6581/8580) and if the card is an NST Audio Extension (BSz SID Card). Also detects the presens of AY extension (DIGIMUZ) and tries to detect FM emulation of SideKick or a SoundX card.
Detects devices connected to the computer from #4 to #31. First executes a drive ROM read and tries to identify the drive type. If that fails it will execute a UI command to get the initialization status message from the drive and uses that to look up drive type.
Drive types detected:
- Commodore 1540
- Commodore 1541
- Commodore 1541C
- Commodore 1541-II
- Commodore 1551
- Commodore 1570
- Commodore 1571
- Commodore 1581
- RF501C
- SD2IEC
- SD2IEC with VCPU extension (FlexSD)
- Jocó's SD drive (C16STM)
- TCBM2SD by ytm
- YaPE 1551 IEC protocol emulation
After the drive type is identified it will detected the interface used to connect the drive to the computer in the following order
- TCBM (1551)
- parallel (1541)
- serial (154*, 157*, 158*, RF501C, SD2IEC)
There is a module for unpacking Exomizer 3.1.1 packed files. To use this
feature you have to start exomizer with mem -f
options.
In the included IOLibV3Test.asm source you can see an example how to use the library. Basically you have to create an initialization part that detects hardware and installs loader. In this init part you have to include two sources:
iolib_def.inc
: definitions for the library. This is required for all programs where you want to use the libraryiolib.inc
: the library itself. It can be compiled to any memory location You also have to define which modules needed. For example:
#define io_prtstatus
// Detect video standard. Not really useful except for printing status message
#define io_detect_video
// Detect memory size and expansion type
#define io_detect_memory_size
// Detect available sound expansions including SID type and address
#define io_detect_sound
#define io_detect_drive
// Detect VICE xplus4 and optionally halt when detected
#define io_detect_emulator
#define io_halt_on_vice
// Detect CPU to get rid of unsupported 6502to7501 adapters
#define io_detect_cpu_port
#define io_halt_on_6502
// Include loader code (drive detection and loader)
#define need_loader
// Include exomizer on-the-fly decruncher
#define need_exodecrunch
#import "../core/iolib.inc"
You have to call two functions:
iolib.detect
to do hardware detectioniolib.init
to initialize the loader. This will install the loader from $fc00-$fcff with some variables from $fbfb-fbff. If you use exomizer decruncher it will occupy $fab0-$fbf9.
After that you only have to do the following in your parts:
- include
iolib_def.inc
- call
iolib.load
oriolib.decrunch
with first character of file name in XR and second one in YR - quit loader: set both X and Y to 0 and call
iolib.load
. It will report a load error and quits drive side code. NOTE This does not work with SD2IEC G.I. Joe loader (stock SD2IEC firmware).
For variables set by detection check the contents of iolib_def.inc.
There is an INIT.PRG
in the repository which can be used to start your software. All you have to do is put this as the first file in the directory and the program you want to load must be named II
and that must be compressed with exomizer mem -f
. After load/decompress a jmp $100d
will be made.
Address | Usage |
---|---|
$02/$03 | Init only (you can safely use it after iolib.init) |
$9e/$9f | Non-exomizer load pointer (you can use it but it will be destroyed during non-exomizer loads) |
$a7-$a9, $ae/$af, $fc-$ff | Exomizer decruncher only. Free if you don't use exomizer |
$b7 | Serial load shift area. Not used on non-serial drives |
$fab0-$fbf9 | Exomizer decruncher resident part |
$fbff-$fbff | Work area |
$fc00-$fcff | Loader resident part |
$ff40-$ffdc | Exomizer decruncher work area. Will be overwritten during Exomizer load. |