diff options
author | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2014-01-03 03:06:25 +0200 |
---|---|---|
committer | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2014-01-03 18:55:24 +0200 |
commit | ef18102b9ec9634653fd4a8286990e9e21ce2ae0 (patch) | |
tree | a007649e7168dc63700d7e5b58f12f289c7bc417 | |
parent | 780f555b2e36b0d468209e0ad741e8261faf63e5 (diff) | |
download | micropython-ef18102b9ec9634653fd4a8286990e9e21ce2ae0.tar.gz micropython-ef18102b9ec9634653fd4a8286990e9e21ce2ae0.zip |
Make it possible to turn off collecting memory stats (MICROPY_MEM_STATS).
-rw-r--r-- | py/defaultconfig.h | 7 | ||||
-rw-r--r-- | py/malloc.c | 24 |
2 files changed, 31 insertions, 0 deletions
diff --git a/py/defaultconfig.h b/py/defaultconfig.h new file mode 100644 index 0000000000..9829bf707d --- /dev/null +++ b/py/defaultconfig.h @@ -0,0 +1,7 @@ +// This file contains default configuration settings for MicroPython. +// You can override any of these options in mpconfig.h for your port. + +// Whether to collect memory allocation stats +#ifndef MICROPY_MEM_STATS +#define MICROPY_MEM_STATS (1) +#endif diff --git a/py/malloc.c b/py/malloc.c index a3736cde4d..1765eb6743 100644 --- a/py/malloc.c +++ b/py/malloc.c @@ -2,12 +2,16 @@ #include <stdlib.h> #include "misc.h" +#include "mpconfig.h" +#include "defaultconfig.h" +#if MICROPY_MEM_STATS static int total_bytes_allocated = 0; static int current_bytes_allocated = 0; static int peak_bytes_allocated = 0; #define UPDATE_PEAK() { if (current_bytes_allocated > peak_bytes_allocated) peak_bytes_allocated = current_bytes_allocated; } +#endif void *m_malloc(int num_bytes) { if (num_bytes == 0) { @@ -18,9 +22,11 @@ void *m_malloc(int num_bytes) { printf("could not allocate memory, allocating %d bytes\n", num_bytes); return NULL; } +#if MICROPY_MEM_STATS total_bytes_allocated += num_bytes; current_bytes_allocated += num_bytes; UPDATE_PEAK(); +#endif return ptr; } @@ -33,9 +39,11 @@ void *m_malloc0(int num_bytes) { printf("could not allocate memory, allocating %d bytes\n", num_bytes); return NULL; } +#if MICROPY_MEM_STATS total_bytes_allocated += num_bytes; current_bytes_allocated += num_bytes; UPDATE_PEAK(); +#endif return ptr; } @@ -49,6 +57,7 @@ void *m_realloc(void *ptr, int old_num_bytes, int new_num_bytes) { printf("could not allocate memory, reallocating %d bytes\n", new_num_bytes); return NULL; } +#if MICROPY_MEM_STATS // At first thought, "Total bytes allocated" should only grow, // after all, it's *total*. But consider for example 2K block // shrunk to 1K and then grown to 2K again. It's still 2K @@ -58,6 +67,7 @@ void *m_realloc(void *ptr, int old_num_bytes, int new_num_bytes) { total_bytes_allocated += diff; current_bytes_allocated += diff; UPDATE_PEAK(); +#endif return ptr; } @@ -65,17 +75,31 @@ void m_free(void *ptr, int num_bytes) { if (ptr != NULL) { free(ptr); } +#if MICROPY_MEM_STATS current_bytes_allocated -= num_bytes; +#endif } int m_get_total_bytes_allocated(void) { +#if MICROPY_MEM_STATS return total_bytes_allocated; +#else + return -1; +#endif } int m_get_current_bytes_allocated(void) { +#if MICROPY_MEM_STATS return current_bytes_allocated; +#else + return -1; +#endif } int m_get_peak_bytes_allocated(void) { +#if MICROPY_MEM_STATS return peak_bytes_allocated; +#else + return -1; +#endif } |