Build tool: Bake
ELF loader: VDL
Simulator: ns-3
Simulator: YANS
Profiler: Bozo
Misc old stuff

Some of the following projects are now extensively used and extended by many others, while others are just fun things I hacked together.


Bake is a build tool which is similar in scope to jhbuild. Its distinctive feature is to provide more flexibility than other similar tools in setting up a specific build. It uses XML-based metadata about a set of software packages to automate the process of downloading, and building in the right order a selected subset of these packages. Bake is written is python. I originally designed it to replace the ns-3 build system and to provide an integration framework for the many ns-3 simulation modules maintained by third-parties.

VDL ELF loader

I originally implemented VDL (Virtualization ELF Loader) to virtualize global and static variables for the ns-3 DCE module. Later on, I added simpler virtualization techniques to ns-3 to avoid the complexity of maintaining this project but VDL is still the most efficient (cpu and memory wise, by an order of magnitude) way to virtualize applications within ns-3.

This loader is source and binary compatible with the GNU ELF loader which ships with the glibc library used in most Linux distributions.


ns-3 is a discrete-time event-driven network simulator which is slowly replacing ns2 as the reference network simulator for networking research. While they share the same name, these two projects are in fact entirely different codebases. I served a software lead for ns-3 so, if you feel it sucks, it is probably my fault.


A couple of years ago, I was fed up with the many architectural flaws of ns2 which made it hard to develop new simulation modules so I built Yans (Yet Another Network Simulator), a prototype network simulator to demonstrate how I felt it could be done better. A lot of ideas and concepts originally implemented within Yans were later integrated in ns-3.


The bozo-profiler is not really a profiler. It is a library to perform in-process debugging and code path analysis. If your application has been recompiled with the right flags, bozo provides hooks to record every call to every function, and serializes this information in a binary log file which can then be read and decoded by a post-processing tool to produce dynamic call graphs.


A number of much smaller projects I hacked over the years and which I do not maintain/use anymore:

Design by Arnaud Waqué