Dynamic memory allocation framework

Ioannis Koutras 64ea3e8f66 fix the release build type 11 anni fa
cmake b385383b1a support 'make install' properly 12 anni fa
contrib 149a7774e2 introduce custom memcpy for realloc's 12 anni fa
doc 1fddd761fc updated Doxygen file for v1.8.4 12 anni fa
examples e2ddba7500 install configuration header file inside the dmmlib directory 12 anni fa
include 64ea3e8f66 fix the release build type 11 anni fa
private-include 554909b120 fixes for compatibility with the STHORM SDK 12 anni fa
scripts 44c5186338 add stress level parameter to the testbench generation script 12 anni fa
src 0b17d0f2c5 freelist_memalign: fix the address of the previous memory block 11 anni fa
.hgignore 7e4c63ffd1 added build/* in the hgignore list 13 anni fa
CMakeLists.txt c7098fcd60 clean cmake variables and create separate platform presets 12 anni fa
DefineOptions.cmake c7098fcd60 clean cmake variables and create separate platform presets 12 anni fa
LICENSE 5fc32c7e67 All the source files are now released under the Apache 2.0 license. 13 anni fa
README.md c7098fcd60 clean cmake variables and create separate platform presets 12 anni fa
config.h.cmake cdd31f61db fix data alignment issues; freelist/realloc(): wrong size on memcpy 12 anni fa
leon3.preset c7098fcd60 clean cmake variables and create separate platform presets 12 anni fa
linux.preset c7098fcd60 clean cmake variables and create separate platform presets 12 anni fa
sthorm.preset c7098fcd60 clean cmake variables and create separate platform presets 12 anni fa
toolchain-sparc-elf.cmake a716fcaf2e Added -std=c99 CFLAG in sparc-elf-gcc toolchain. 13 anni fa
toolchain-stxp70v4.cmake 6b03d06973 [P2012] move some rule variables outside of the toolchain file 12 anni fa

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)