Dynamic memory allocation framework

Ioannis Koutras 97655dc9a9 Check directly in macros if file descriptors are initialized before using them 13 éve
cmake b385383b1a support 'make install' properly 13 éve
contrib 149a7774e2 introduce custom memcpy for realloc's 13 éve
doc 583546e6aa Support define macros in Doxygen and small documentation additions 13 éve
examples e2ddba7500 install configuration header file inside the dmmlib directory 13 éve
include ecbe29b832 include posix_memalign() declaration in dmmlib.h if needed 13 éve
private-include 97655dc9a9 Check directly in macros if file descriptors are initialized before using them 13 éve
scripts 44c5186338 add stress level parameter to the testbench generation script 13 éve
src 97655dc9a9 Check directly in macros if file descriptors are initialized before using them 13 éve
.hgignore 7e4c63ffd1 added build/* in the hgignore list 14 éve
CMakeLists.txt 826eb33856 add version numbers in the project 13 éve
DefineOptions.cmake d1c4bf913b rewrite the knobs initialization as a static one, rename fitpercentage to fit_percentage, min_coalesce_size to min_coal_size and max_splitting_size to max_split_size 13 éve
LICENSE 5fc32c7e67 All the source files are now released under the Apache 2.0 license. 14 éve
README.md f530d46558 update the readme file 13 éve
config.h.cmake 826eb33856 add version numbers in the project 13 éve
toolchain-sparc-elf.cmake a716fcaf2e Added -std=c99 CFLAG in sparc-elf-gcc toolchain. 14 éve
toolchain-stxp70v4.cmake a260b7c23f Set stxp70v4 build type to Release as default. 14 éve

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. Do cmake {DMMLIB Source Directory} -DLINUX=ON , e.g. cmake .. -DLINUX=ON
  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)