Dynamic memory allocation framework

Ioannis Koutras 9a3d9dab96 unify WITH_DEBUG with CMAKE_BUILD_TYPE; show TRACE_LEVEL in status %!s(int64=12) %!d(string=hai) anos
cmake b385383b1a support 'make install' properly %!s(int64=12) %!d(string=hai) anos
doc 583546e6aa Support define macros in Doxygen and small documentation additions %!s(int64=12) %!d(string=hai) anos
examples 37edd3693d fix last warnings in larson %!s(int64=12) %!d(string=hai) anos
include e9b19183d2 add dummy knobs header file %!s(int64=12) %!d(string=hai) anos
private-include 9da89b0eb8 small fix on adding blocks to address- and size-ordered lists %!s(int64=12) %!d(string=hai) anos
scripts a7664bbee0 generate_c_testbench: support for realloc() calls %!s(int64=12) %!d(string=hai) anos
src 9a3d9dab96 unify WITH_DEBUG with CMAKE_BUILD_TYPE; show TRACE_LEVEL in status %!s(int64=12) %!d(string=hai) anos
.hgignore 7e4c63ffd1 added build/* in the hgignore list %!s(int64=13) %!d(string=hai) anos
CMakeLists.txt 9a3d9dab96 unify WITH_DEBUG with CMAKE_BUILD_TYPE; show TRACE_LEVEL in status %!s(int64=12) %!d(string=hai) anos
DefineOptions.cmake 9a3d9dab96 unify WITH_DEBUG with CMAKE_BUILD_TYPE; show TRACE_LEVEL in status %!s(int64=12) %!d(string=hai) anos
LICENSE 5fc32c7e67 All the source files are now released under the Apache 2.0 license. %!s(int64=13) %!d(string=hai) anos
README.md f530d46558 update the readme file %!s(int64=12) %!d(string=hai) anos
dmm_config.h.in 7ecf85adf2 freelist refactoring %!s(int64=12) %!d(string=hai) anos
toolchain-sparc-elf.cmake a716fcaf2e Added -std=c99 CFLAG in sparc-elf-gcc toolchain. %!s(int64=13) %!d(string=hai) anos
toolchain-stxp70v4.cmake a260b7c23f Set stxp70v4 build type to Release as default. %!s(int64=13) %!d(string=hai) anos

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)