Skip to content

57600 bps Commodore 64 PETSCII terminal implementing the Turbo56K protocol

License

Notifications You must be signed in to change notification settings

retrocomputacion/retroterm

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

91 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Retroterm

VERSION 0.21 Beta

Jorge Castillo & Pablo Roldán

Badge commodore Badge MSX1 GitHub all releases Badge license Discord


Table of contents:

  1. Introduction
    1. Release history
    2. The Turbo56K protocol
    3. Features
    4. Requirements
  2. Usage
  3. Building
    1. Symbols
    2. Intro screen
    3. Customizing
  4. Known bugs
  5. To-do
  6. Acknowledgments

1 Introduction

Retroterm is a small, minimal PETSCII terminal for the Commodore 64 / 128 (in 64 mode), Commodore Plus/4 and MSX1 (in development).

ATTENTION THE MSX PORT IS CURRENTLY IN ALPHA STATE

It implements the Turbo56k protocol for high speed data transfer & streaming when connecting to a BBS supporting the protocol, such as RetroBBS.

Data rate is fixed at the following speeds:

  • 57600bps for Retroterm 64 for userport and Turbo232**
  • 57600bps for Retroterm MSX for parallel port (very alpha state)
  • 38400bps for Retroterm 64 for Swiftlink**
  • 19200bps for Retroterm Plus/4** and Retroterm MSX for RS232

(**)The full data throughput while using the turbo transfer / streaming can only be achieved with the screen disabled.

The effective throughput for text is 1500 / 1800bps depending on PAL/NTSC timings respectively.

Retroterm is optimized for use with Wi-Fi modems using the Zimodem firmware.

It also runs on the latest VICE/Z64K emulators.

Separate Commodore 64 versions of the executable are provided for cartridges featuring an ACIA 6551 such as SwiftLink (limited to 38400bps) and Turbo232.
The Commodore Plus/4 version is limited to the maximum speed for the built in ACIA: 19200bps
The MSX 1 RS-232 version (rt232.com) is also at this moment limited to 19200bps, and only supports RS-232 interfaces that adhere to the MSX standard (ie: SVI-738 and HX-22 built-in ports, SVI-737 and Sony HB-232, or any other interface implemented with the i8251 + i8253 USART and Timer combo)

1.1 Release history

v0.21 (??/??/????):

  • New shortcut key for the Plus/4 port: CBM+, disables/enables the FLASH-ON control code. Improves compatibility with BBSs running Centipede 128 software.
  • Bugfix for the Commodore 64 ports: No more extraneous beep after streaming PCM audio.

v0.20 (02/01/2024):

  • Turbo56K v0.7
  • New Commodore Plus/4 port. Turbo56K v0.7 commands implemented, except for the ones regarding SID tune streaming.
  • Fixed bug in command $A3 which caused the parameter to be misread, or the terminal to hang
  • New command $86 to initiate a download to disk.
  • New command $B6 to scroll the text window up or down X number of rows.
  • SID streaming now better supports tunes using hardrestart, a special version of SIDdump and updated version of RetroBBS is required.
  • New compile target ultimate compiles with timings compatible with the Swiftlink emulation in the Ultimate1541-II/II+ and Ultimate64.
  • Basic configuration screen by pressing C= + F7, terminal screen is not preserved.
  • ACIA based versions now allow selection of the interface base address ($DE00 or $DF00).
  • Connected disk drives are scanned on first run, and can be selected when downloading a file with command $86.

v0.14 (13/04/2022):

  • Source code liberated
  • Turbo56K v0.6
  • Fixed small visual glitch when using the split screen mode
  • Better, more robust exit to BASIC
  • Disabled interrupts on command $A2, prevents crashes if (re)connecting to a BBS while the split screen mode is active
  • Fixed severe bug affecting the text output in early Commodore 64 Kernal revisions
  • Full digi-boost for 8580 SID
  • Intro screen exits automatically after ~2 seconds by default
  • Other small bugfixes.

v0.13 (16/08/2021):

  • Initial release
  • Turbo56K v0.5

1.2 The Turbo56K protocol

Turbo56k was created by Jorge Castillo as a simple protocol to provide high-speed file transfer functionality to his bit-banging 57600bps RS232 routine for the C64. Over time, the protocol has been extended to include 4-bit PCM audio streaming, bitmap graphics transfer and display, SID music streaming and more.

1.3 Features

Implements all commands of the Turbo56k v0.7 protocol.

  • Full duplex PETSCII (Commodore versions)/ASCII (MSX versions) color terminal
  • Turbo data transfers to custom/preset memory locations
  • Split Screen | Hi-res or Multicolor+Text
  • Up to 11520Hz 4-bit PCM audio streaming
  • Bitmap display | Hi-res + Multicolor (Commodore) | Screen 2 (MSX)
  • Consumes less than 5KB of memory (For the Commodore versions)
  • 1x speed SID music streaming (C64 versions only)
  • PSG music streaming (MSX versions)
  • Scrolling Text Windows
  • Set Cursor Position
  • Text Line Fill
  • Bidirectional scrolling
  • Download files to disk

1.4 Requirements

  • A Commodore 64, 128 or Plus/4 computer, or an emulator such as VICE or Z64K
  • Either an userport Wi-Fi modem with the Zimodem firmware or...
  • A SwiftLink or Turbo232 compatible cartridge connected to a Wi-Fi modem with the Zimodem firmware.
  • A MSX1 or superior computer with 64K of RAM. With either a built-in RS-232 port or an MSX standard RS-232 interface cartridge. Or openMSX 20.0RC1
  • ACME and PASMO crossassemblers for building the programs.

2 Usage

Retroterm is very simple to use, most of its functionality being controlled externally from a Turbo56k enabled BBS.

Retroterm comes in five variants:

  • rt-u.prg Userport version 57600bps
  • rt-sl.prg SwiftLink version 38400bps
  • rt-232.prg Turbo232 version 57600bps
  • rt-p4.prg Plus/4 version 19200bps
  • rt232.com MSX RS-232 version 19200bps
  • rt56k.com MSX parallel port version 57600bps

Retroterm lacks classic file transfer functions, when used to communicate with a normal PETSCII/ASCII BBS, file transfers are not available.

After LOADing and RUNning Retroterm, you can dial to your favorite BBS using your Modem commands as usual.

The modem should be setup to the correct baud rate before running Retroterm.

To exit Retroterm, just press RUN/STOP (Commodore) or CTRL-C (MSX), it will remain in memory, and you can recall it with SYS49152 (Commodore 64), or SYS28672 (Commodore Plus/4).

If you downloaded a program into memory from a BBS you can also RUN it (Commodore versions only).

On MSX pressing CTRL-U will reset the computer, if a ROM file was downloaded to RAM the system will try to execute it. ROMs that expect mirroring are not supported.

Retroterm beeps for every received character by default, you can toggle the sound by pressing CBM + M (Commodore) or CTRL-M (MSX).

2.1 Setup screen

A simple setup screen can be accessed by pressing CBM + F7 (Commodore) or CTRL-F5 (MSX), pressing F1 will exit back to the terminal.

The first setting, common to all Retroterm variants sets the RTS pulse width. Current values are known to work under VICE, or on real hardware with an userport modem using Zimodem firmware, and with the Ultimate Swiftlink emulation. Use the + and - keys to adjust.

For the ACIA versions there's a couple more settings.

The first one sets the base address for the Swiftlink or Turbo232 cartridge, press 1 for $DE00 or 2 for $DF00. Switching addresses will drop any current connection.

The second setting available for ACIA versions is the ability to keep the screen visible while transferring at turbo speeds. Turbo transfers are slightly slower with the screen enabled. Press B to toggle.

Important: Upon exiting the setup screen, Retroterm will default to full screen text mode. Only previous background and border colors will be restored.

3 Building Retroterm

The Commodore versions of Retroterm is written for the ACME cross-assembler, while PASMO is used for the MSX port, to compile use:

make

to compile all versions.

Or you can specify which version you want to compile, either userport, swiflink, turbo232, plus4, msx232 or msx56k.

ie:

make userport

All executables will be stored in the build directory.

You can also manually compile with:

acme retroterm_univ.asm

or:

pasmo -E IFACE=0 retrotermm1.asm rt232.com
pasmo -E IFACE=56 retrotermmm1.asm rt56k.com

from the source directory.
This will compile the default userport version of Retroterm with an intro screen that last a couple of seconds. In this case the resulting executable will be written to the source directory

3.1 Symbols

A number of compile time symbols are defined to customize the resulting executable. Specially if you're running the compiler directly instead of using the Makefile

_HARDTYPE_:

38: Compile for SwiftLink/Turbo232 cartridges at 38400bps

56: Compile for userport at 57600bps -- Default

232: Compile for Turbo232 cartridges at 57600bps

1541: Compile for the Ultimate 1541-II or Ultimate 64 Swiftlink emulation, same code as for 38 but different timing.

_INTRO_:

0: No intro screen

1: Include the intro screen -- Default

_SPACE_:

If defined wait for the user to press the space bar at the intro screen. Otherwise, the intro screen only last a couple of seconds.

Not defined by default

IFACE:

0: Compile for standard MSX RS232 ports 56: Compile for the MSX parallel port

Example:

acme -D_HARDTYPE_=232 -D_INTRO_=0 retroterm_univ.asm

Compiles Retroterm for the Turbo232 cartridge with no intro screen.

3.2 The intro screen

The intro screen is a screencode + colorRAM dump found in source/intro_sc.asm

This file is generated by exporting source/intro_sc.petmate to ACME format from Petmate.

3.3 Customizing

If you want to release a modified version of Retroterm which differs in functionality from the official release we recommend you use a custom ID string, respecting the maximum 22 character length and always starting in uppercase RT

IE, the normal ID string is:

IDstring:
!text "RTRETROTERM 0.20      "

but the string when compiling for the SwiftLink cartridge is:

IDstring:
!text "RTRETROTERM-SL 0.20   "

Note: The actual version number string is sourced from the file source/version.txt when using the makefile, or from source/version.asm when running the compiler directly

For compatibility reasons we ask you not to modify the behavior of existing Turbo56K commands, but you're welcomed to add new commands, or remove unwanted ones, as long as command $A3 correctly reports the existence or not of all queried commands.

In any case the Turbo56k version bytes that follow the ID string should remain the correct ones for the official version your modified code support.

4 Known bugs

  • Losing connection while streaming data or audio will hang the program
  • Exiting Retroterm, restarting it with SYS49152, exiting again and causing a BASIC error will crash the computer.

5 To-do

  • Extend the command parameter space to support more than 8 parameters per command.
  • Faster throughput when using any of the ACIA cartridges.

6 Acknowledgments

Beta Testers

  • Ezequiel Filgueiras
  • Thierry Kurt
  • Diego di Franceschi
  • ChrisKewl
  • Roberto Mandracchia
  • x1pepe

Thanks To

  • Willy Manilly for adding support to the Z64K emulator

  • ElectronicsArchiver for initial documentation rework

About

57600 bps Commodore 64 PETSCII terminal implementing the Turbo56K protocol

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •