There are no reviews yet. Be the first to send feedback to the community and the maintainers!
Protothreads are extremely lightweight stackless threads designed for severely memory constrained systems such as small embedded systems or sensor network nodes. Protothreads can be used with or without an underlying operating system. Protothreads provides a blocking context on top of an event-driven system, without the overhead of per-thread stacks. The purpose of protothreads is to implement sequential flow of control without complex state machines or full multi-threading. Main features: * No machine specific code - the protothreads library is pure C * Does not use error-prone functions such as longjmp() * Very small RAM overhead - only two bytes per protothread * Can be used with or without an OS * Provides blocking wait without full multi-threading or stack-switching * Freely available under a BSD-like open source license Example applications: * Memory constrained systems * Event-driven protocol stacks * Small embedded systems * Sensor network nodes The protothreads library is released under an open source BSD-style license that allows for both non-commercial and commercial usage. The only requirement is that credit is given. The protothreads library was written by Adam Dunkels <[email protected]> with support from Oliver Schmidt <[email protected]>. More information and new versions can be found at the protothreads homepage: http://dunkels.com/adam/pt/ (was: http://www.sics.se/~adam/pt/ http://web.archive.org/web/20110610191935/http://www.sics.se/~adam/pt/index.html) Documentation can be found in the doc/ subdirectory. Two example programs illustrating the use of protothreads can be found in this directory: example-small.c A small example showing how to use protothreads example-buffer.c The bounded buffer problem with protothreads example-codelock.c A code lock with simulated key input To compile the examples, simply run "make". Adam Dunkels, 3 June 2006
libumem
This is the user space slab memory allocator, umem, first available in Solaris 9.gen_paxos
An Erlang/OTP-style implementation of the PAXOS distributed consensus protocollmdb
An Erlang NIF for the "Lightening MDB" BTREE used in OpenLDAPhamt
Ideal Hash Array Mapped Tries: an Erlang functional datatypeisync
isync/mbsync - a mailbox synchronization programcauchy
Cauchy-based Reed-Solomon codeswave
Mirror of Apache Waveriemann-nitro
A Web Dashboard for Riemann using Nitrogen/Erlang and Comet rather than Sinatra/Ruby and Pollingsbcl
Steel Bank Common Lisp (SBCL) with LLVM compilationlibdirectio
Disable the filesystem buffer cache by preloading this librarytestregex
A regex(3) test harness created by Glenn Fowler <[email protected]> but no longer available at research.att.comliblfds
a portable, license-free, lock-free data structure library written in Cwsim
Wooden Ships and Iron Menlibbtds
rbtree-c
left-leaning 2-3 red-black trees as C preprocessor macrosdbsql
A SQL database engine on top of Oracle Berkeley DBxqd
ABANDONED:: Berkeley DB XML Daemon - A network server for Oracle Berkeley DB XML.xv6
xv6 is a modern re-implementation of Sixth Edition Unix in ANSI C for multiprocessor x86/x86_64 systemssnappy
A fast compressor/decompressorgburd.github.com
Technical Bloglibperf
libperf exposes the Linux kernel performance counters subsystem to userspace codefsblksz
Output the block size for a given filesystemkdtree
a binary tree in which every node is a k-dimensional pointcv
My Curriculum Vitae (aka Resume)leveldb
Google's LevelDBLove Open Source and this site? Check out how you can help us