SD2IEC & IEC-2-SD Adapters
Appearance
The SD2IEC familyβand its ARM-based off-shoots usually sold as IEC-2-SDβare open-hardware adapters that let Commodore 8-bit machines read and write FAT/FAT32-formatted SD-cards through the standard IEC serial bus. Acting as a *smart* disk-drive clone they implement the most-used 1541/1571/1581 DOS commands (LOAD, SAVE, directory, block API, β, β, etc.) plus a small command channel interpreter that maps files and sub-directories to disk images on the card.
Quick facts
[edit | edit source]- βLoader-ready in <β1 sβ β no mechanical spin-up / head-seek delays.
- Capacity: 32 GB+ per card, thousands of ββD64/D71/D81ββ images or plain PRGs.
- Speed: β 45Γ stock 1541 with JiffyDOS fast-loader (β 12βkBβs-1).
- Firmware upgradable from the C64 itself (`LOAD "FW.BIN",8,1` & `RUN`).
- 100 % open-source: hardware KiCad / Eagle files & AVR/ARM firmware on GitHub.
π History
[edit | edit source]- 2006-07 β MMC2IEC β Lars Pontoppidan prototypes an ATmega32 board that translates IEC β SPI-MMC.[1]
- 2008 β sd2iec β Ingo Korb forks the code, adds FAT32, long filenames, D71/D81 and renames the firmware sd2iec.[2]
- 2010-12 β Commercial kits β Jim Brain's uIEC/SD and NKC Electronics sell through-hole DIY modules.
- 2014-15 β TFW8b v4/v5 β TheFutureWas8bit releases compact SMD units with button board & OLED.
- 2018 β IEC-2-SD (STM32) β Petter Lundsten ports the protocol to the STM32 βBlue Pillβ, bringing USB mass-storage gadget mode.[3]
π οΈ Hardware architecture
[edit | edit source]| Variant | MCU | Clock | RAM | Notes |
|---|---|---|---|---|
| Classic SD2IEC | ATmega1284P | 20 MHz crystal | 16 KB | SPIβSD, UARTβdebug, optional OLED/IΒ²C |
| uIEC/SD | ATmega644P | 16 MHz | 4 KB | 2Γ micro-SD sockets, daughter-card form factor |
| IEC-2-SD | STM32F103C8T6 | 72 MHz | 20 KB SRAM | USB-C, full-speed USB gadget (card seen as drive on PC) |
| SaRuMan-SD | ATmega1284P | 24 MHz (X-tal) | 16 KB | Sidekick64 plug-on module, exposed JTAG |
Most boards power entirely from the +5 V IEC bus (β 100 mA). A 3 V LDO or DC/DC step-down supplies the SD slot. Level-shifting is done by resistor networks or BSS138 FETs depending on revision.
βοΈ Firmware features
[edit | edit source]- DOS Commands: `LOAD, SAVE, OPEN, B-A (block execute), VALIDATE`, etc.
- Disk image hot-swap using buttons (NEXT / PREV) or via `OPEN 15,"CD:somedir"`.
- Long-file-name to C64 PETSCII mapping (configurable).
- GEOS support (`U0>M0`) and native fast-loader patches for JiffyDOS, Final Cartridge III, Epyx FastLoad, SJLoad, etc.
- Config file `sd2iec.cfg` β set default device #, Jiffy mode, drive # mapping, LED polarity.
- IEC passthrough so real 1541s can daisy-chain behind the adapter.
Known limitations
[edit | edit source]- No true 6502-cycle-exact 1541 CPU emulation β copy-protected titles that rely on drive-side code or nibble-level flux patterns fail.
- Relative files not supported.
- Burst-mode fast-loaders designed for the 1571/1581 may require a parallel-IEC mod or fail altogether.
- Command channel buffers are 254 bytes β very long `@` commands can overflow.
π Fast-loader compatibility matrix
[edit | edit source]| Loader | Stock C64 | JiffyDOS | SD2IEC (AVR) | IEC-2-SD (STM32) |
|---|---|---|---|---|
| JiffyDOS (KERNAL) | β | β | β 45Γ | β 45Γ |
| Epyx FastLoad (cart) | β 5Γ | β 5Γ | β 30Γ | β 35Γ |
| Final Cartridge III | β 6Γ | β | β 32Γ | β 34Γ |
| Dolphin DOS | β | β | β | β |
| Fast Load V5 PAL | β | β | β (needs ``OPEN15,"UX"` patch) | β |
π Using SD2IEC
[edit | edit source]<plainlist>
- Device number β shipped as *8*; change with `OPEN15,8,15,"U0>"+CHR$(10+new#):CLOSE15`.
- Browse directories β `LOAD"$",8` or use FB64 file-browser PRG on the card root.
- Mount D64 image β `OPEN1,8,15,"CD:DEMOS/DISK1.D64":CLOSE1`.
- Swap image β front buttons (NEXT/PREV) or `OPEN15,"XS:next":CLOSE15`.
- Firmware update β copy `firmware.bin` to card root β reset while holding βNEXTβ.
</plainlist>
π Pi1541 / 1541 Ultimate
[edit | edit source]| Feature | SD2IEC / IEC-2-SD | Pi1541 | 1541 Ultimate-II+ |
|---|---|---|---|
| MCU / SoC | 8-bit AVR / STM32 | Raspberry Pi (ARM) | FPGA (Cyclone III) |
| Cycle-exact 6502 emulation | β | β | β |
| Copy-protected G64 / TAP | β | β | β |
| Price (2024) | US$25-60 | US$60-90 | US$200+ |
| Plug-and-play (no Pi setup) | β | β SD card image & config needed | β |
| Real-time clock, Ethernet, RAM-expansion | β | β | β |
π Popular ready-made units
[edit | edit source]| Brand / Model | Notes | Approx. price (2024) |
|---|---|---|
| TheFutureWas8bit SD2IEC v5B | OLED, 3 buttons, IEC thru, 3-D printed shell | Β£34 GB |
| Retro-Port uIEC/SD | Daughter-card w. 6-pin header, fits internal C64 installs | US$44 |
| Pi1541 Zero (not SD2IEC) | Cycle-exact but needs Pi Zero β see separate page | β¬49 |
| IEC-2-SD βBluePill editionβ | STM32, USB-C, optional OLED, DIY kit | β¬29 kit / β¬45 built |
π§ DIY resources
[edit | edit source]- PCB & schematic: <https://github.com/IngmarK/sd2iec-hardware>
- Firmware source: <https://github.com/sd2iec/sd2iec>
- IEC-2-SD repo: <https://github.com/plundstr/IEC-2-SD>
- Forum support: Lemon64 βsd2iec user threadβ, retro-computing Stack Exchange tag ββsd2iecββ.
π See also
[edit | edit source]π References
[edit | edit source]π External links
[edit | edit source]- Official sd2iec wiki β documentation, binaries, parts list.
- The Future Was 8-bit β commercial SD2IEC hardware.
- Retroleum blog β tutorial βCompiling sd2iec on macOSβ.