Skip to content

realglobe-Inc/AtomVM

This branch is 318 commits behind atomvm/AtomVM:main.

Folders and files

NameName
Last commit message
Last commit date
Oct 14, 2024
Mar 9, 2022
Dec 8, 2023
Mar 21, 2022
Jun 20, 2023
Oct 13, 2024
Oct 12, 2024
Oct 13, 2024
Oct 14, 2024
Oct 11, 2024
Apr 21, 2024
Sep 18, 2022
Aug 11, 2023
Jul 11, 2024
Oct 14, 2024
Apr 21, 2024
Mar 17, 2022
Feb 17, 2024
Jan 27, 2022
Jun 10, 2024
Mar 5, 2024
Oct 14, 2024
Oct 14, 2024

AtomVM

Brings Erlang, Elixir and other functional languages to really small systems.

AtomVM implements from scratch a minimal Erlang VM that supports a subset of ErlangVM features and that is able to run unmodified BEAM binaries on really small systems like MCUs.

Supported Platforms

  • Linux, macOS, FreeBSD, DragonFly (generic_unix)
  • ESP32 SoC (with IDF/FreeRTOS, see esp32)
  • STM32 MCUs (with LibOpenCM3, see stm32)
  • Raspberry Pi Pico (see rp2040)
  • Browsers and NodeJS with WebAssembly (see emscripten)

AtomVM aims to be easily portable to new platforms with a minimum effort, so additional platforms might be supported in a near future.

Getting Started

There is much more information, including a more complete "Getting Started Guide", examples, detailed build instructions, and contact information available on the AtomVM project website.

Don't forget to check out the examples repository to help get you started on your next IoT project.

Dependencies

Required for building:

Documentation and Coverage:

  • gcov and lcov are optionally required to generate coverage report (make coverage).
  • For documentation build requirements consult the Documentation README.

Step-by-Step Build Instructions (generic unix platform)

$ mkdir build
$ cd build
$ cmake ..
$ make
$ ./src/AtomVM ./examples/erlang/hello_world.avm

Run tests within build directory with:

$ ./tests/test-erlang
$ ./tests/test-enif
$ ./tests/test-mailbox
$ ./tests/test-structs
$ ./src/AtomVM ./tests/libs/estdlib/test_estdlib.avm
$ ./src/AtomVM ./tests/libs/eavmlib/test_eavmlib.avm
$ ./src/AtomVM ./tests/libs/alisp/test_alisp.avm

Complete Build Instructions are available in the documentation for Generic UNIX (Linux, MacOS, FreeBSD, DragonFly), ESP32, STM32, Raspberry Pi Pico (rp2040), and WASM (NodeJS/Web).

Project Status

Build and Test

AtomVM is still in its early stages, but it can run simple applications similar to those available in examples and tests.

AtomVM might crash with a similar message:

Undecoded opcode: 15
Aborted (core dumped)

This basically means that an instruction has not been implemented yet, or that an outdated version has been used. Please, make sure to always run AtomVM using latest version.

Known Limitations

This project is a work in progress, so there are several known limitations, that will prevent to run unmodified software, some of them are:

  • There is a minimal standard library, so several standard functions are missing.
  • Several instructions are not yet implemented.

All of these limitations are going to be fixed in a reasonable amount of time.

About This Project

This project has been created by Davide Bettio, and now is developed from a growing number of contributors.

How to Contribute

Any kind of contribution is welcome, you can either contribute to this repository by improving the virtual machine, the core libraries or the documentation or by contributing to any of the organization repositories.

License

This project is under the terms of the Apache 2.0 license.

Packages

No packages published

Languages

  • C 45.1%
  • Erlang 44.7%
  • Elixir 5.1%
  • CMake 4.0%
  • JavaScript 0.5%
  • Shell 0.3%
  • Other 0.3%