Limbo supports the following features:
The Dis virtual machine that executes Limbo code is a CISC-like VM, with instructions for arithmetic, control flow, data motion, process creation, synchronizing and communicating between processes, loading modules of code, and support for higher-level data-types: strings, arrays, lists, and communication channels.2 It uses a hybrid of reference counting and a real-time garbage-collector for cyclic data.3
Aspects of the design of Dis were inspired by the AT&T Hobbit microprocessor, as used in the original BeBox.
Limbo uses Ada-style definitions as in:
The 3rd edition of the Inferno operating system and Limbo programming language are described in the textbook Inferno Programming with Limbo ISBN 0-470-84352-7 (Chichester: John Wiley & Sons, 2003), by Phillip Stanley-Marbell. Another textbook The Inferno Programming Book: An Introduction to Programming for the Inferno Distributed System, by Martin Atkins, Charles Forsyth, Rob Pike and Howard Trickey, was started, but never released.
"Inferno Application Programming". vitanuova. vitanuova. Retrieved January 26, 2021. http://www.vitanuova.com/inferno/limbo.html ↩
"Dis Virtual Machine Specification". Vita Nuova. 2000. Retrieved 2 February 2015. https://web.archive.org/web/20250220003220/https://www.vitanuova.com/inferno/papers/dis.html ↩
Lorenz Huelsbergen and Phil Winterbottom (1998). "Very Concurrent Mark and Sweep Garbage Collection without Fine-Grain Synchronization" (PDF). 1998 International Symposium on Memory Management. http://doc.cat-v.org/inferno/concurrent_gc/concurrent_gc.pdf ↩