Python bindings for GNU Lightning JIT
_Lyn_ provides Python bindings for GNU Lightning, the light-weight just-in-time compiler that translates RISC instructions to native machine code.
The bindings are made through ctypes, so all of the Lyn source code is in pure Python: All you need is liblightning.so/dylib/dll!
“Lyn” is the Norwegian word for “lightning”.
NOTE: This project is currently in extremely early stages (hours in!)
As mentioned above, Lyn is fledgling: I’ve just spent a few hours on it, so almost nothing is supported and — in particular — I’ve only targeted x86-64 opcodes just yet.
In spite of this, I’ve managed to create a really simple program in Python that is JIT-compiled to native x86-64 machine code: A glorious function that returns the value of 123! Here’s the code:
#!/usr/bin/env python from lyn import * lib = Lightning() with lib.state() as jit: jit.prolog() # The actual code jit.movi(Register.V0, 123) jit.retr(Register.V0) function = jit.emit_function() print("Should get 123 here: %s" % function())
I’m using ctypes for creating the bindings, which comes with some challenges: GNU Lightning is written in C, and relies heavily on compile-time macros that define machine specific opcodes, register values and so on. Because of this, it would be more natural to simply create bindings through a C extension. On the other hand, though, ctypes makes it possible to ship Lyn as a platform independent, pure Python source. I’ll chew on this for a while, and we’ll see what happens.
You need GNU Lightning. Lyn was made specifically for version 2.1.0, but may also work on later versions. It currently does not support earlier versions.
To download and install GNU Lightning, see
Since Lyn loads Lightning using the ctypes foreign-function interface, you will most likely need to build a shared library. To do that, configure Lightning with --enable-shared.
If you want to be able to disassemble your compiled code, you also need GNU Binutils, along with a --enable-disassembler option to GNU Lightning’s configure. Consult its documentation for more information.
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size||File type||Python version||Upload date||Hashes|
|Filename, size lyn-0.0.1-py2.py3-none-any.whl (9.4 kB)||File type Wheel||Python version py2.py3||Upload date||Hashes View|
|Filename, size lyn-0.0.1.tar.gz (15.9 kB)||File type Source||Python version None||Upload date||Hashes View|