Go to file
Benjamin Vedder 25010609df Squashed 'lispBM/lispBM/' changes from 0a69a489..83d186cc
83d186cc define can now be used to bind #var variables
3012709f Spawn takes an optional first argument that specifies stack size

git-subtree-dir: lispBM/lispBM
git-subtree-split: 83d186cc62a82fc333a15677a876a7a5cd7e8253
2022-02-16 12:24:45 +01:00
benchmarks Squashed 'lispBM/lispBM/' changes from 1108de58..0535cf11 2022-02-13 14:25:39 +01:00
chibios-examples Squashed 'lispBM/lispBM/' changes from 0c09634e..1c2be895 2022-02-15 09:29:40 +01:00
doc Squashed 'lispBM/lispBM/' changes from 1108de58..0535cf11 2022-02-13 14:25:39 +01:00
docker Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
examples Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
include Squashed 'lispBM/lispBM/' changes from 0a69a489..83d186cc 2022-02-16 12:24:45 +01:00
mascot Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
notes Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
old Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
platform Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
repl-cps Squashed 'lispBM/lispBM/' changes from 1c2be895..c6d5de99 2022-02-15 19:09:10 +01:00
src Squashed 'lispBM/lispBM/' changes from 0a69a489..83d186cc 2022-02-16 12:24:45 +01:00
tests Squashed 'lispBM/lispBM/' changes from 0a69a489..83d186cc 2022-02-16 12:24:45 +01:00
utils Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
videos Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
zephyr-examples Squashed 'lispBM/lispBM/' changes from 1108de58..0535cf11 2022-02-13 14:25:39 +01:00
.gitignore Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
.travis.yml Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
LICENSE Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
Makefile Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
README.md Squashed 'lispBM/lispBM/' changes from 1108de58..0535cf11 2022-02-13 14:25:39 +01:00
flash_nrf52_with_stlink.sh Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
lispbm.mk Squashed 'lispBM/lispBM/' changes from 1c2be895..c6d5de99 2022-02-15 19:09:10 +01:00
runinfer.sh Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
runsa.sh Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
setup_fw_build.sh Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00
zephyr-source-me.sh Squashed 'lispBM/lispBM/' content from commit 748477b9 2022-01-29 17:26:45 +01:00

README.md

lispBM (Lisp Black Magic)

A concurrent lisp-like language with message-passing and pattern-matching implemented in C for 32-bit platforms.

LispBM mascot

All programming languages need a mascot, so here is the LispBM llama by PixiLady.

Purpose

  1. Have fun.
  2. Learn about lisp.
  3. Learn about microcontrollers.
  4. An interactive REPL for devboards.
  5. ...

Features

  1. heap consisting of cons-cells with mark and sweep garbage collection.
  2. Built-in functions: cons, car, cdr, eval, list, +, -, >, <, = and more.
  3. Some special forms: Lambdas, closures, lets (letrecs), define and quote.
  4. 28-Bit signed/unsigned integers and boxed 32-Bit Float, 32-Bit signed/unsigned values.
  5. Arrays (in progress), string is an array.
  6. Compiles for, and runs on linux-x86 (builds 32bit library, runs on 32/64 bit).
  7. Compiles for, and runs on Zynq 7000.
  8. Compiles for, and runs on STM32f4.
  9. Compiles for, and runs on NRF52840.
  10. Compiles for, and runs on ESP32 (ARM - WROOM).
  11. Compiles for, and runs on ESP32C3 (RISC-V).
  12. Compiles for, and runs on Raspberry PI (Tested on 32bit Raspbian OS)
  13. Quasiquotation.
  14. Concurrency.
  15. Message-passing.
  16. Pattern-matching

Documentation

Work in progress language reference and C code documentation can be found here.

LispBM's internals are documented as a series of blog posts.

There are demonstrations on YouTube.

Want to get involved and help out?

  1. Are you interested in microcontrollers and programming languages?
  2. You find it fun to mess around in C code with close to zero comments?
  3. Then join in the fun. Lots to do, so little time!
  4. Poke me by mail bo(dot)joel(dot)svensson(whirly-a)gmail(dot)com

TODOs

  1. (DONE) Write some tests that stresses the Garbage collector.
  2. (DONE) Implement some "reference to X type", for uint32, int32.
  3. (DONE) Write a small library of useful hofs.
  4. (DONE) Improve handling of arguments in eval-cps.
  5. (DONE) Code improvements with simplicity, clarity and readability in mind.
  6. (DONE) Implement a small dedicated lisp reader/parser to replace MPC. MPC eats way to much memory for small platforms.
  7. (DONE) Port to STM32f4 - 128K ram platform (will need big changes). (surely there will be some more bugs)
  8. (DONE) Add STM32f4 example code (repl implementation)
  9. (DONE) Port to nrf52840_pca10056 - 256k ram platform (same changes as above).
  10. (DONE) Reduce size of builtins.c and put platform specific built in functions elsewhere. (Builtins.c will be removed an replaced by fundamentals.c)
  11. (DONE) Implement 'progn' facility.
  12. (DONE) Remove the "gensym" functionality havent found a use for it so far and it only complicates things.
  13. (DONE) Add NRF52 example repl to repository
  14. (DONE) Update all example REPLs after adding quasiquotation
  15. (DONE) The parser allocates heap memory, but there is no interfacing with the GC there.
  16. (DONE) The parser uses a lot of stack memory, fix by making tail recursive and accumulating lists onto heap directly.
  17. (DONE) Rename files with names that may conflict with common stuff (memory.h, memory.c).
  18. (DONE) It should be possible to reset the runtime system.
  19. (DONE) Add messages to lisp process mailbox from C to unlock blocked proc.
  20. Spawn closures specifically instead of expressions in general.
  21. Implement some looping structure for speed or just ease of use.

Vague or continuosly ongoing todos

  1. Doxygen?
  2. Tutorials?
  3. Be much more stringent on checking of error conditions etc.
  4. More built in arithmetic.
  5. More built in comparisons.
  6. Make uniform how to return success or failure. It is sometimes bool and sometimes int right now.

Compile for linux (Requires 32bit libraries. May need something like "multilib" on a 64bit linux)

  1. Build the library: make

  2. Build the repl: cd repl-cps and then make

  3. Run the repl: ./repl

Compile on Raspberry Pi

To build the library exeute the following command in the lispbm folder:

PLATFORM=pi make

To build the repl-cps example repl do:

cd repl-cps
make pirepl

Then start it up using ./repl Building the library is not a prerequisite for building the repl anymore.