Dynamic memory allocation framework

Ioannis Koutras 796e84f6fa statistics: include dmmlib.h to access system allocator лет назад: 13
cmake b385383b1a support 'make install' properly лет назад: 13
contrib 149a7774e2 introduce custom memcpy for realloc's лет назад: 13
doc 583546e6aa Support define macros in Doxygen and small documentation additions лет назад: 13
examples 37edd3693d fix last warnings in larson лет назад: 13
include de291a685f dummy dmm_notify_cycle(), move dmm_set_knobs() declaration to a header file лет назад: 13
private-include 9c496bf224 capitalize the lock macros лет назад: 13
scripts 82e8ffaef8 memalign() implementation for free-list organised raw blocks лет назад: 13
src 796e84f6fa statistics: include dmmlib.h to access system allocator лет назад: 13
.hgignore 7e4c63ffd1 added build/* in the hgignore list лет назад: 14
CMakeLists.txt 82e8ffaef8 memalign() implementation for free-list organised raw blocks лет назад: 13
DefineOptions.cmake a616349758 use knobs by default лет назад: 13
LICENSE 5fc32c7e67 All the source files are now released under the Apache 2.0 license. лет назад: 14
README.md f530d46558 update the readme file лет назад: 13
dmm_config.h.in 82e8ffaef8 memalign() implementation for free-list organised raw blocks лет назад: 13
toolchain-sparc-elf.cmake a716fcaf2e Added -std=c99 CFLAG in sparc-elf-gcc toolchain. лет назад: 14
toolchain-stxp70v4.cmake a260b7c23f Set stxp70v4 build type to Release as default. лет назад: 14

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)