honey-potion
pl0c
Our great sponsors
honey-potion | pl0c | |
---|---|---|
6 | 5 | |
234 | 122 | |
2.1% | - | |
6.4 | 0.0 | |
about 2 months ago | over 2 years ago | |
C | C | |
GNU General Public License v3.0 only | ISC License |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
honey-potion
-
Honey Potion: an eBPF backend for Elixir
Hi all! We are working on an eBPF backend for Elixir. It's called Honey Potion. The project is under development, but it is possible to write some useful programs at this point. For instance, in this video, one of the guys involved explains how to write a program to count system calls.
We have been working on an eBPF backend for the Elixir programming language. The current implementation is on this branch. EBPF is a bit like a virtual machine that runs on the Linux kernel. EBPF programs are typically used to implement network applications. The most interesting aspect of the backend is that Linux uses a verifier to ensure that eBPF programs always terminate and only access memory within allocated bounds.
-
Targetting C
Hi! We have been translating Elixir to C (which we translate to eBPF) in HoneyPotion. We used mostly Chapter 15 of Appel's Modern Compiler Implementation in Java to implement the code generator (that's "15. Functional Programming Languages"). I think the choice of C has been good thus far. The implementation of Elixir's pattern matching took much work, but if we had chosen a higher level target, we would still have to translate that to eBPF. Here's the entry point for the translator.
- Writing eBPF Programs with Elixir
-
Suggestion for a backend?
We have been working on a tool that translates Elixir to eBPF. We actually translate eBPF to C. Now that we have more stuff working, I really wonder if generating C was a good choice.
-
Intersection of PLs with the OS
That's exactly what Honey Potion does, when we translate Elixir into Linux' eBPF!
pl0c
-
The Super Tiny Compiler
> Some compilers tokenize while parsing, but for a different reason: it's faster and uses less memory to generate the AST
And some don't even generate an AST. :) Just read in and emit or interpret.
https://briancallahan.net/blog/20210814.html
-
single pass compilers (basic questions)
Single-pass compiler tutorial
-
Compiler tutorials.
Let's Write a Compiler
-
Let's write a compiler, part 3: A parser
I don’t think there will be an AST. https://briancallahan.net/blog/20210814.html: “We will be writing a single-pass compiler for a simple language and immediately output our final output code as soon as our compiler has enough information to do so”
That “as soon as” implies code will be generated before the entire program has been parsed.
Also, for me single-pass implies “no AST”, as you would need at least one pass to construct one, and iterating over an AST counts as another pass for me.
What are some alternatives?
fping - High performance ping tool
cproc - C11 compiler (mirror)
TripleCross - A Linux eBPF rootkit with a backdoor, C2, library injection, execution hijacking, persistence and stealth capabilities.
pegasus - A parser generator for C and Crystal.
linux-nitrous - Mirror of https://gitlab.com/xdevs23/linux-nitrous
Understanding-Unix-Linux-Programming - Source code of Understanding Unix/Linux Programming. The book provides example code in C, I would like to replicate it in Rust.
libfirm - graph based intermediate representation and backend for optimising compilers
swifties - a custom language construction kit
amacc - Small C Compiler generating ELF executable Arm architecture, supporting JIT execution
mini-c - Dr Strangehack, or: how to write a self-hosting C compiler in 10 hours
oberon-risc-emu - Emulator for the Oberon RISC machine
rawhide - find files using pretty C expressions