6 releases (breaking)

0.6.0 Dec 21, 2024
0.5.0 Dec 7, 2024
0.4.0 Dec 2, 2024
0.3.0 Nov 14, 2024
0.1.0 Oct 14, 2024

#379 in Programming languages

Download history 143/week @ 2024-10-09 39/week @ 2024-10-16 125/week @ 2024-10-23 5/week @ 2024-10-30 116/week @ 2024-11-13 8/week @ 2024-11-20 105/week @ 2024-11-27 169/week @ 2024-12-04 23/week @ 2024-12-11 127/week @ 2024-12-18 6/week @ 2024-12-25

360 downloads per month

Apache-2.0 WITH LLVM-exception

305KB
8K SLoC

xrcf

Easy(ier)-to-use infrastructure for building compilers.

You may be looking for:


lib.rs:

xrcf is an easy(ier)-to-use infrastructure for building compilers.

Below is a a high-level overview of xrcf. To instead see the code in action, see the example compiler in the arnoldc directory.

What follows is some background on compilers and how this project can help you:

Say you want to write a compiler for a new programming language. The compiler should take the source code in your language and convert it to platform that can execute it such as a CPU or GPU. Now you could do this via string manipulation. To sum two matrices, you read a string like x = a + b, but then you realize that converting this to say LLVM via string manipulation is not that easy. That's why compilers first scan and parse the source code into an intermediate representation (IR). Unlike strings, the IR provides common methods to interact with the code. For example, this project defines a insert_before method for operations. Whereas with strings you would need to manually search for the line where to insert the new operation, with the IR you can just call add_op.insert_before(new_op).

Next you decide that you want to compile this code to another platform such as a GPU. Then you would need to convert some of the operations to GPU-specific operations. This is where passes come in. A pass is a group of transformations that are applied to the IR. For example, to compile to CPU via LLVM, you would use the passes --convert-func-to-llvm and --convert-llvm-to-llvm-ir. And to compile to GPU, you would use --convert-func-to-gpu.

This project gives you these building blocks. It contains some default IR and default passes, but more importantly you can also add your own. This means that if you want to write your own compiler for your language, you only have to convert your code into the default IR that is inside this project, and then you can choose which passes you want to use in which situation.

Long-term Goal

It is unclear where computations will be done in the future. Will it be on CPUs, GPUs, TPUs, or something else? But this is not what this project should focus on. This project focuses on what does not change: transformations. It's very likely that we still need to transform code in the future. There will probably always be a gap between code that is easy to read for humans and code that can be efficiently executed by the hardware.

So, the long-term goal of this project is to provide an easy-to-use set of tools that can be used to build your own compiler. In other words, it should be easy to build a compiler that can transform your favorite language to this project's core IR, and then it should be easy to transform this to various platforms such as GPUs, CPUs, and TPUs.

Dependencies

~7–14MB
~162K SLoC