Files
libretro/emulators/handy.yml
2026-03-24 09:33:06 +01:00

56 lines
2.5 KiB
YAML

emulator: Handy
type: libretro
core_classification: community_fork
source: "https://github.com/libretro/libretro-handy"
upstream: "https://handy.sourceforge.net/"
profiled_date: "2026-03-23"
core_version: "0.95"
display_name: "Atari - Lynx (Handy)"
cores:
- handy
systems: [atari-lynx]
notes: |
Handy is an Atari Lynx emulator by K. Wilkins (Handy 0.95, 2007).
The core loads lynxboot.img from the system directory and validates
it by CRC32 (0x0D973C9D). If the file is missing or the CRC does
not match, the core falls back to an internal HLE BIOS that
replicates the boot sequence in software (ram clear, cart loader
decrypt, jump to $0200).
The HLE path intercepts CPU calls to ROM addresses FE00, FE19, FE4A
and FF80 via a Mikie register write trap (address 0xFD97). When
useEmu is true (no valid BIOS loaded), CRom initialises mRomData
with a default fill byte (0x88) plus reset vectors pointing to
the HLE entry points.
Upstream Handy 0.95 requires the BIOS (throws CLynxException) and
validates by checking the first 16 bytes against a hardcoded
signature. The libretro port added the HLE fallback and switched
to full CRC32 validation.
For headerless cartridges (no LNX/BS93 header), the core loads
howard.o from the system directory. This is the Epyx development
kit bootloader used to bootstrap raw/headerless ROMs into memory.
Upstream requires howard.o for headerless carts (throws exception);
the libretro port makes it optional (logs error, continues).
files:
- name: "lynxboot.img"
system: atari-lynx
description: "Atari Lynx boot ROM (Mikie internal 512B ROM)"
required: false
hle_fallback: true
size: 512
crc32: "0d973c9d"
validation: [size, crc32]
source_ref: "rom.h:48-49 (ROM_SIZE=0x200, ROM_CRC32=0x0D973C9D), rom.cpp:76-129 (CRom constructor), libretro.cpp:1231-1258 (bios path + CSystem init)"
notes: "Validated by CRC32 at load time. If invalid or missing, core uses HLE fallback (system.cpp:303-361 HLE_BIOS_* functions, system.cpp:406-428 trap writes)."
- name: "howard.o"
system: atari-lynx
description: "Epyx Howard bootloader for headerless cartridges"
required: false
source_ref: "system.cpp:197-238 (CartHeaderLess check, howard.o load via fill_pathname_resolve_relative)"
notes: "Loaded only for headerless carts (no LNX/BS93 header). Resolved relative to the BIOS file path (system directory). Passed to CRam for execution. Most commercial games have headers and skip this entirely."