Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/windelbouwman/ppci
A compiler for ARM, X86, MSP430, xtensa and more implemented in pure Python
https://github.com/windelbouwman/ppci
arm assembler c-compiler c-preprocessor compiler m68k msp430 python riscv webassembly x86-64 xtensa
Last synced: 28 days ago
JSON representation
A compiler for ARM, X86, MSP430, xtensa and more implemented in pure Python
- Host: GitHub
- URL: https://github.com/windelbouwman/ppci
- Owner: windelbouwman
- License: bsd-2-clause
- Created: 2016-11-27T12:01:09.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2022-07-01T00:57:49.000Z (over 2 years ago)
- Last Synced: 2024-09-30T06:01:27.338Z (about 1 month ago)
- Topics: arm, assembler, c-compiler, c-preprocessor, compiler, m68k, msp430, python, riscv, webassembly, x86-64, xtensa
- Language: Python
- Homepage: https://ppci.readthedocs.io/en/latest/
- Size: 12.4 MB
- Stars: 335
- Watchers: 15
- Forks: 35
- Open Issues: 62
-
Metadata Files:
- Readme: readme.rst
- Contributing: docs/contributing/communication.rst
- License: license.txt
Awesome Lists containing this project
README
Introduction
============The PPCI (Pure Python Compiler Infrastructure) project is a compiler
written entirely in the `Python `_ programming
language. It contains front-ends for various programming languages as
well as machine code generation functionality. With this library you can
generate (working!) machine code using Python (and thus very easy to
explore, extend, etc.)!The project contains:
- Language frontends for C, Python, Pascal, Basic and Brainfuck
- Code generation for several architectures: 6500, arm, avr, m68k, microblaze, msp430, openrisc, risc-v, stm8, x86_64, xtensa
- Command line utilities, such as ppci-cc, ppci-ld and ppci-opt
- WebAssembly, JVM, OCaml support
- Support for ELF, EXE, S-record and hexfile formats
- An intermediate representation (IR) which can be serialized in json
- The project can be used as a library so you can script the compilation processInstallation
------------Since the compiler is a python package, you can install it with pip:
.. code:: bash
$ pip install ppci
Usage
-----An example of commandline usage:
.. code:: bash
$ cd examples/linux64/hello-make
$ ppci-cc -c -O1 -o hello.o hello.c
...
$ ppci-ld --entry main --layout linux64.ld hello.o -o hello
...
$ ./hello
Hello, World!API example to compile C code:
.. code-block:: python
>>> import io
>>> from ppci.api import cc, link
>>> source_file = io.StringIO("""
... int printf(char* fmt) { }
...
... void main() {
... printf("Hello world!\n");
... }
... """)
>>> obj = cc(source_file, 'arm')
>>> obj = link([obj])Example how to assemble some assembly code:
.. code-block:: python
>>> import io
>>> from ppci.api import asm
>>> source_file = io.StringIO("""section code
... pop rbx
... push r10
... mov rdi, 42""")
>>> obj = asm(source_file, 'x86_64')
>>> obj.get_section('code').data
bytearray(b'[ARH\xbf*\x00\x00\x00\x00\x00\x00\x00')Example of the low level api usage:
.. code-block:: python
>>> from ppci.arch.x86_64 import instructions, registers
>>> i = instructions.Pop(registers.rbx)
>>> i.encode()
b'['Functionality
-------------- `Command line utilities `_:
- `ppci-cc `_
- `ppci-ld `_
- and many more.
- Can be used with tools like make or other build tools.
- `Language support `_:
- `C `_
- Pascal
- Python
- Basic
- Brainfuck
- `C3 `_
(PPCI's own systems language, intended to address some pitfalls of C)
- CPU support:
- 6500, arm, avr, m68k, microblaze, msp430, openrisc, risc-v, stm8, x86_64, xtensa
- Support for:
- `WebAssembly `_
- JVM
- OCaml bytecode
- LLVM IR
- DWARF debugging format
- `File formats `_:
- ELF files
- COFF PE (EXE) files
- hex files
- S-record files
- Uses well known human-readable and machine-processable formats like JSON and XML as
its tools' formats.Documentation
-------------Documentation can be found here:
- https://ppci.readthedocs.io/
.. warning::
**This project is in alpha state and not ready for production use!**
You can try out PPCI at godbolt.org, a site which offers Web access to
various compilers: https://godbolt.org/g/eooaPP|gitter|_
|appveyor|_
|codecov|_
|docstate|_
|travis|_
|codacygrade|_
|codacycoverage|_
|downloads|_
|conda|_.. |codecov| image:: https://codecov.io/bb/windel/ppci/branch/default/graph/badge.svg
.. _codecov: https://codecov.io/bb/windel/ppci/branch/default.. |appveyor| image:: https://ci.appveyor.com/api/projects/status/h0h5huliflrac65o?svg=true
.. _appveyor: https://ci.appveyor.com/project/WindelBouwman/ppci-786.. |docstate| image:: https://readthedocs.org/projects/ppci/badge/?version=latest
.. _docstate: https://ppci.readthedocs.io/en/latest.. |travis| image:: https://travis-ci.org/windelbouwman/ppci.svg?branch=master
.. _travis: https://travis-ci.org/windelbouwman/ppci.. |codacygrade| image:: https://api.codacy.com/project/badge/Grade/a178be14a54243be81c27172031dc82c
.. _codacygrade: https://www.codacy.com/app/windel-bouwman/ppci-mirror.. |codacycoverage| image:: https://api.codacy.com/project/badge/Coverage/a178be14a54243be81c27172031dc82c
.. _codacycoverage: https://www.codacy.com/app/windel-bouwman/ppci-mirror.. |downloads| image:: https://anaconda.org/conda-forge/ppci/badges/downloads.svg
.. _downloads: https://anaconda.org/conda-forge/ppci.. |conda| image:: https://anaconda.org/conda-forge/ppci/badges/version.svg
.. _conda: https://anaconda.org/conda-forge/ppci.. |gitter| image:: https://badges.gitter.im/ppci-chat/Lobby.svg
.. _gitter: https://gitter.im/ppci-chat/Lobby