Dynamic memory allocation framework

Ioannis Koutras 075a2ade46 Give RDS copyright to ICCS 9 gadi atpakaļ
cmake b385383b1a support 'make install' properly 12 gadi atpakaļ
contrib 149a7774e2 introduce custom memcpy for realloc's 12 gadi atpakaļ
doc 1fddd761fc updated Doxygen file for v1.8.4 12 gadi atpakaļ
examples 97fbea0bb8 allocator space for allocator state on the heap 11 gadi atpakaļ
include 96a3a76457 introducing slab raw blocks 11 gadi atpakaļ
private-include 075a2ade46 Give RDS copyright to ICCS 9 gadi atpakaļ
scripts 44c5186338 add stress level parameter to the testbench generation script 12 gadi atpakaļ
src 075a2ade46 Give RDS copyright to ICCS 9 gadi atpakaļ
.hgignore 7e4c63ffd1 added build/* in the hgignore list 13 gadi atpakaļ
CMakeLists.txt 733fab53d2 estimate pagesize before compile time 11 gadi atpakaļ
DefineOptions.cmake 52b135e316 option to use a trylock on malloc() instead of a lock 11 gadi atpakaļ
LICENSE 5fc32c7e67 All the source files are now released under the Apache 2.0 license. 13 gadi atpakaļ
README.md c7098fcd60 clean cmake variables and create separate platform presets 12 gadi atpakaļ
config.h.cmake 733fab53d2 estimate pagesize before compile time 11 gadi atpakaļ
leon3.preset 05c7f86678 add support for glibc hooks, currently the memalign one only 11 gadi atpakaļ
linux.preset cb32ee8a4a switch to Herc's recommended presets 11 gadi atpakaļ
osx.preset 52b135e316 option to use a trylock on malloc() instead of a lock 11 gadi atpakaļ
sthorm.preset 05c7f86678 add support for glibc hooks, currently the memalign one only 11 gadi atpakaļ
toolchain-sparc-elf.cmake 4cef849c2e make dmmlib work with sparc-elf-4.6 11 gadi atpakaļ
toolchain-stxp70v4.cmake 6b03d06973 [P2012] move some rule variables outside of the toolchain file 12 gadi atpakaļ

README.md

NTUA / ICCS dmmlib

dmmlib is a a dynamic memory management framework developped in C. For more information please visit the official site of the project. dmmlib is currently distributed within the context of the 2PARMA project.

Requirements

  • cmake v2.6 or higher
  • C99-compliant compiler (tested on GCC toolchains of version 3.4 or higher)

Usage

  1. Create the build directory, e.g. mkdir build
  2. Go to the build directory, e.g. cd build
  3. Generate the makefiles via cmake. Feel free to use one of the available presets, e.g. cmake -C../linux.preset ..
  4. make

Linking with applications

There are currently three options:

  • Link the library statically to your application
    gcc -I{DMMLIB Source Directory}/include -I{DMMLIB Build Directory} {DMMLIB Build Directory}/libdmm_static.a yourapp.c -o yourapp
  • Link the library dynamically to your application gcc -I{DMMLIB Source Directory}/include -L{DMMLIB Build Directory}/src -ldmm yourapp.c -o yourapp
  • Use the dynamic linker to preload dmmlib during application's execution:
    LD_PRELOAD={DMMLIB Build Directory}/src/libdmm_shared.so application

Contact Information

Ioannis Koutras (joko@microlab.ntua.gr)
Alex Bartzas (alexis@microlab.ntua.gr)