💾 Archived View for gemini.ucant.org › notes › beetle-mit.gmi captured on 2023-11-04 at 11:39:21. Gemini links have been rewritten to link to archived content

View Raw

More Information

⬅️ Previous capture (2023-03-20)

➡️ Next capture (2023-12-28)

-=-=-=-=-=-=-

What are Beetle, Mit, Welly, etc?

There are these projects:

Virtual machines

Reuben Thomas is trying to write a general-purpose virtual machine. Some of his attempts are as follows:

Beetle

Beetle, written in C, is an early version of this (for his degree). Beetle has two stacks, being designed to run Forth. Reuben ported pForth to run on Beetle. pForth is ANSI Forth compatible. Both Beetle and pForth are frozen in amber.

Direct descendants of Beetle are:

https://github.com/rrthomas/beetle

Bee

Bee, written in C, but simpler than Beetle and general purpose. It also runs a Forth-ish compiler (called Gnat; no connected with GNU Ada compiler). Bee has two stacks but it is intended to reduce this to one. Bee's instruction set is massively reduced compared to Beetle, and the semantics are much more C-like than the Forth-like model of Beetle.

https://github.com/rrthomas/bee

Mit

Mit, written in C. It also descends from Beetle in a code sense. It is effectively an earlier incarnation of Bee. It is a single stack VM that also ran a Forth compiler. It had an ancestor of Mijit written for it. Mit had 30 instructions. As of right now (Mar 2023), Mit is the most sophisticated and complete general purpose of VM of Reuben's stable, but he dislikes how it is implemented.

https://github.com/rrthomas/mit

While Mit has the more complete VM functionality, Bee interoperates better with the conventional binutils ecosystem.

Mite

The other root of Reuben's system is Mite. Mite is a completely different implementation approach from Beetle, designed specifically for AOT compilation, with load-time conversion from virtual code to machine code. This makes it a notional direct competitor of the JVM, of which it is a contemporary. Mite had a C-compiler backend that targeted it. It only runs on RiscOS.

https://github.com/rrthomas/mite

Languages

Welly

Welly is a language by Alistair Turnbull and Tom Lynn. It is a compromise

between Python, C, Java and OCaml.

Welly website

Welly should provide a different lingua franca for languages to interoperate. Welly has a REPL.

Welly ought to include a virtual machine.

pForth

pForth was implemented in the 1990s alongside Beetle. Originally targeted 26-bit ARM, ported to Beetle and Mit and the various other systems.

https://github.com/rrthomas/pforth

Gnat

pForth with the brakes of backward compatibility removed.

https://github.com/rrthomas/gnat

Tooling

Mijit - a JIT-compiler generator, written in Rust, but callable from other languages, and it works with C. It developed out of ideas in Mit. So far it has been used to write JIT compilers for Beetle and Bee. The intention is to use it as the JIT compiler for Welly. Mijit has backends for x86-64 and aarch64.

https://github.com/apt1002/mijit

Future plans

Work on Bee. Conform it to Mit.

The plan for Welly is to have a calling convention which acknowledges garbage collection. The JIT compiler and GC will be below that calling convention, the advantage being that when languages call across to each other you can inline from one to the other.

Gnat will mostly be done away with, to be replaced with a high-level language

The Mit programme is implementing the core of Mite approach on the basis of the more traditional approach of Beetle.