Skip to content

Latest commit

 

History

History
81 lines (63 loc) · 3.77 KB

README.md

File metadata and controls

81 lines (63 loc) · 3.77 KB

compilation workflow

TOS/libc is a 32-bit C standard library to compile programs for Atari TOS and the Atari ST family of computers.

Many, if not most, other libc for Atari TOS are 16-bit. There are two significant advantages with a 32-bit libc:

  • the GNU compiler collection (GCC) for the m68k-elf target works unmodified also for Atari TOS;

  • modern C programs and libraries often assume the C integer type int is at least 32 bits, since that has been the case for most modern operating systems in use during at least 25 years.

The are also two potentially significant disadvantages compared with a 16-bit libc: lower performance and greater memory use. However, with judicious optimisations such losses can often be recovered.

Programs linked with TOS/libc can use the --gc-sections option to the GNU linker and thereby drastically reduce their size. The supplied example programs compile to a few kilobytes each, for instance, which make them several times smaller than had the whole TOS/libc been linked.

TOS/libc includes interfaces for the following Atari TOS specific libraries:

  • BIOS (basic input/output system),
  • XBIOS (extended BIOS),
  • GEMDOS (graphics environment manager disk operating system),
  • XGEMDOS (extended GEMDOS),
  • AES (application environment services),
  • VDI (virtual device interface).

The AES and VDI interfaces are part of the GEM desktop environment.

Examples

The example directory contains applications of TOS/libc:

ALERT.PRG HELLO.PRG WINDOW.PRG XBRA.PRG

How to build

Review the file INSTALL for installation instructions. A working GCC/m68k compiler is required. Assuming the compiler is m68k-elf-gcc, build TOS/libc with make TARGET_COMPILE=m68k-elf- to produce a lib/toslibc.a static library, and example applications.

Precompiled example applications are available for download under the Github actions tab. These are automatically built with .github/workflows/compilation.yml.

How it works

TOS/libc automatically converts between 32-bit and 16-bit integers for Atari TOS. The main complication is the trap system call with its stack arguments, which must handle reentrancy. This conversion is done in include/toslibc/tos/trap.S. Integers in structures for Atari TOS are generally defined as int16_t or uint16_t. Bit fields are generally used to improve notation with modern C standards.

A standard, unmodified, GCC/m68k package is used to compile ELF object files, having a specific structure defined in script/prg.ld. The tool/toslink linker is used to produce the final Atari TOS program files.