Skip to main content

Highly optimizing PL/M-80 compiler targeting 8080/Z80

Project description

uplm80 - PL/M-80 Compiler

PyPI version License: GPL v3

A modern PL/M-80 compiler targeting Intel 8080 and Zilog Z80 assembly language.

PL/M-80 was the primary systems programming language for CP/M and other 8080/Z80 operating systems. This compiler can rebuild original CP/M utilities from their PL/M source code.

Repository: https://github.com/avwohl/uplm80

Features

  • Full PL/M-80 language support
  • Targets both 8080 and Z80 instruction sets
  • Multiple optimization passes (peephole, post-assembly tail merging)
  • Generates relocatable object files compatible with standard CP/M linkers
  • Produces code competitive with the original Digital Research compiler

Code Quality

Compiled output is comparable to the original Digital Research PL/M-80 compiler:

Program DR PL/M-80 uplm80 Difference
PIP.COM 7424 bytes 7127 bytes -4.0%

Installation

Install from PyPI:

pip install uplm80

Or install from source:

git clone https://github.com/avwohl/uplm80.git
cd uplm80
pip install -e .

Usage

Compile PL/M-80 to Assembly

uplm80 input.plm -o output.mac

Or run as a module:

python -m uplm80.compiler input.plm -o output.mac

Options:

  • -t 8080 or -t z80 - Target CPU (default: Z80)
  • -o output.mac - Output file name

Post-Assembly Optimization (Optional)

python -m uplm80.postopt output.mac -o output_opt.mac

Performs multi-pass tail merging and skip trick optimizations.

Assemble and Link

Use your preferred 8080/Z80 assembler and linker. Example with um80/ul80:

um80 output.mac                              # Assemble to .rel
ul80 -o program.com output.rel runtime.rel   # Link to CP/M .com

Language Reference

PL/M-80 is a typed systems programming language with:

  • Data types: BYTE (8-bit), ADDRESS (16-bit)
  • Variables: Scalars, arrays, structures, BASED variables (pointers)
  • Control flow: DO/END, DO WHILE, DO CASE, IF/THEN/ELSE
  • Procedures: With parameters, local variables, recursion
  • Built-in functions: HIGH, LOW, DOUBLE, SHL, SHR, ROL, ROR, etc.
  • I/O: INPUT, OUTPUT for port access

Example:

hello: DO;
    DECLARE message DATA ('Hello, World!$');
    DECLARE i BYTE;

    print: PROCEDURE(addr) PUBLIC;
        DECLARE addr ADDRESS;
        /* CP/M BDOS print string */
        CALL mon1(9, addr);
    END print;

    CALL print(.message);
END hello;

Runtime Library

The compiler generates calls to these runtime routines (provide in a separate .rel file):

Routine Description
??MUL 16-bit unsigned multiply
??DIV 16-bit unsigned divide
??MOD 16-bit unsigned modulo
??SHL 16-bit shift left
??SHR 16-bit logical shift right
??SHRS 16-bit arithmetic shift right
??MOVE Block memory move

CP/M Programs

For CP/M programs, provide stubs for:

  • MON1, MON2, MON3 - BDOS calls
  • BOOT - Warm boot
  • BDISK, MAXB, FCB, BUFF, IOBYTE - System variables

Project Structure

uplm80/
├── compiler.py    # Main compiler driver
├── lexer.py       # Tokenizer
├── parser.py      # PL/M-80 parser
├── ast_nodes.py   # AST definitions
├── codegen.py     # Code generator
├── peephole.py    # Peephole optimizer
├── postopt.py     # Post-assembly optimizer
└── symbols.py     # Symbol table

License

This project is licensed under the GNU General Public License v3.0 or later - see the LICENSE file for details.

Contributing

Contributions are welcome! Please feel free to submit issues and pull requests.

Acknowledgments

  • Intel for creating PL/M-80
  • Digital Research for creating CP/M
  • The CP/M source code preservation efforts that made the original PL/M sources available

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

uplm80-0.2.4.tar.gz (116.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

uplm80-0.2.4-py3-none-any.whl (117.3 kB view details)

Uploaded Python 3

File details

Details for the file uplm80-0.2.4.tar.gz.

File metadata

  • Download URL: uplm80-0.2.4.tar.gz
  • Upload date:
  • Size: 116.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for uplm80-0.2.4.tar.gz
Algorithm Hash digest
SHA256 81839ec12998c350912566c9292e3aaff4a8b05e35ddeabcf251d0808334a553
MD5 8d53f627c7db3b6551feb930a174a11b
BLAKE2b-256 4073fbf897143e1f2057fbd85d48b023694a16aaab7267f7b56138559b0225c6

See more details on using hashes here.

File details

Details for the file uplm80-0.2.4-py3-none-any.whl.

File metadata

  • Download URL: uplm80-0.2.4-py3-none-any.whl
  • Upload date:
  • Size: 117.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for uplm80-0.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 4f5f1ed0dde560b8cda1ab9db9db42e58bb05159fa40abe31abb36b2550f2fc3
MD5 7bff8ae890295189522d6f0b6cc829ed
BLAKE2b-256 0ea1a9f3d59faa3f242fe4db473d6c0fff549f797d7a717bd5a150c2b6a5ce3a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page