|
version 1.3.2.1, 2015/06/25 16:49:33
|
version 1.6, 2024/04/15 10:42:26
|
|
Line 4
|
Line 4
|
| #include <elwix.h> |
#include <elwix.h> |
| |
|
| |
|
| void show(u_int size, u_int act, u_int inact) | int show(unsigned int size, unsigned int act, unsigned int inact, void *data, unsigned int dlen) |
| { |
{ |
| if (!act && !inact) |
if (!act && !inact) |
| return; | return -1; |
| |
|
| if (size < 1024) |
if (size < 1024) |
| printf("Statistics:: BUCKET %uB size, %u active, %u inactive\n", size, act, inact); |
printf("Statistics:: BUCKET %uB size, %u active, %u inactive\n", size, act, inact); |
|
Line 15 void show(u_int size, u_int act, u_int inact)
|
Line 15 void show(u_int size, u_int act, u_int inact)
|
| printf("Statistics:: BUCKET %uKB size, %u active, %u inactive\n", size / 1024, act, inact); |
printf("Statistics:: BUCKET %uKB size, %u active, %u inactive\n", size / 1024, act, inact); |
| else |
else |
| printf("Statistics:: BUCKET %uMB size, %u active, %u inactive\n", size / (1024 * 1024), act, inact); |
printf("Statistics:: BUCKET %uMB size, %u active, %u inactive\n", size / (1024 * 1024), act, inact); |
| |
|
| |
return 0; |
| } |
} |
| |
|
| int |
int |
|
Line 43 main(int argc, char **argv)
|
Line 45 main(int argc, char **argv)
|
| printf("___current=%lu\n", curr); |
printf("___current=%lu\n", curr); |
| */ |
*/ |
| |
|
| |
printf(">>> get 3 allocs\n"); |
| for (i = 0; i < 3; i++) { |
for (i = 0; i < 3; i++) { |
| addr = mpool_malloc(mp, 4000, "mdaaa 4000"); |
addr = mpool_malloc(mp, 4000, "mdaaa 4000"); |
| if (!addr) { |
if (!addr) { |
|
Line 63 main(int argc, char **argv)
|
Line 66 main(int argc, char **argv)
|
| printf("0) calls.act=%lu calls.inact=%lu calls.free=%lu; bytes.act=%lu bytes.inact=%lu bytes.free=%lu;\n", |
printf("0) calls.act=%lu calls.inact=%lu calls.free=%lu; bytes.act=%lu bytes.inact=%lu bytes.free=%lu;\n", |
| mp->pool_calls.alloc, mp->pool_calls.cache, mp->pool_calls.free, |
mp->pool_calls.alloc, mp->pool_calls.cache, mp->pool_calls.free, |
| mp->pool_bytes.alloc, mp->pool_bytes.cache, mp->pool_bytes.free); |
mp->pool_bytes.alloc, mp->pool_bytes.cache, mp->pool_bytes.free); |
| mpool_statistics(mp, show); | mpool_statistics(mp, show, NULL, 0); |
| |
|
| |
printf(">>> realloc 4000 to 5010 addr=%p\n", addr); |
| addr = mpool_realloc(mp, addr, 5010, "|||||||||||||"); |
addr = mpool_realloc(mp, addr, 5010, "|||||||||||||"); |
| if (!addr) |
if (!addr) |
| printf("Error:: #%d - %s\n", elwix_GetErrno(), elwix_GetError()); |
printf("Error:: #%d - %s\n", elwix_GetErrno(), elwix_GetError()); |
|
Line 74 main(int argc, char **argv)
|
Line 78 main(int argc, char **argv)
|
| printf("1) calls.act=%lu calls.inact=%lu calls.free=%lu; bytes.act=%lu bytes.inact=%lu bytes.free=%lu;\n", |
printf("1) calls.act=%lu calls.inact=%lu calls.free=%lu; bytes.act=%lu bytes.inact=%lu bytes.free=%lu;\n", |
| mp->pool_calls.alloc, mp->pool_calls.cache, mp->pool_calls.free, |
mp->pool_calls.alloc, mp->pool_calls.cache, mp->pool_calls.free, |
| mp->pool_bytes.alloc, mp->pool_bytes.cache, mp->pool_bytes.free); |
mp->pool_bytes.alloc, mp->pool_bytes.cache, mp->pool_bytes.free); |
| mpool_statistics(mp, show); | mpool_statistics(mp, show, NULL, 0); |
| |
|
| |
|
| |
printf(">>> free addr=%p\n", addr); |
| if (addr) |
if (addr) |
| mpool_free(mp, addr, 0); |
mpool_free(mp, addr, 0); |
| |
|
| printf("2) calls.act=%lu calls.inact=%lu calls.free=%lu; bytes.act=%lu bytes.inact=%lu bytes.free=%lu;\n", |
printf("2) calls.act=%lu calls.inact=%lu calls.free=%lu; bytes.act=%lu bytes.inact=%lu bytes.free=%lu;\n", |
| mp->pool_calls.alloc, mp->pool_calls.cache, mp->pool_calls.free, |
mp->pool_calls.alloc, mp->pool_calls.cache, mp->pool_calls.free, |
| mp->pool_bytes.alloc, mp->pool_bytes.cache, mp->pool_bytes.free); |
mp->pool_bytes.alloc, mp->pool_bytes.cache, mp->pool_bytes.free); |
| mpool_statistics(mp, show); | mpool_statistics(mp, show, NULL, 0); |
| |
|
| |
printf(">>> purge inactive memory\n"); |
| mpool_purge(mp, 0); |
mpool_purge(mp, 0); |
| |
|
| mpool_getquota(mp, &curr, &real, NULL); |
mpool_getquota(mp, &curr, &real, NULL); |
|
Line 93 main(int argc, char **argv)
|
Line 99 main(int argc, char **argv)
|
| printf("3) calls.act=%lu calls.inact=%lu calls.free=%lu; bytes.act=%lu bytes.inact=%lu bytes.free=%lu;\n", |
printf("3) calls.act=%lu calls.inact=%lu calls.free=%lu; bytes.act=%lu bytes.inact=%lu bytes.free=%lu;\n", |
| mp->pool_calls.alloc, mp->pool_calls.cache, mp->pool_calls.free, |
mp->pool_calls.alloc, mp->pool_calls.cache, mp->pool_calls.free, |
| mp->pool_bytes.alloc, mp->pool_bytes.cache, mp->pool_bytes.free); |
mp->pool_bytes.alloc, mp->pool_bytes.cache, mp->pool_bytes.free); |
| mpool_statistics(mp, show); | mpool_statistics(mp, show, NULL, 0); |
| |
|
| |
printf(">>> alloc new 4000\n"); |
| addr = mpool_malloc(mp, 4000, "mdaaa 4000"); |
addr = mpool_malloc(mp, 4000, "mdaaa 4000"); |
| if (!addr) { |
if (!addr) { |
| printf("Error:: #%d - %s\n", elwix_GetErrno(), elwix_GetError()); |
printf("Error:: #%d - %s\n", elwix_GetErrno(), elwix_GetError()); |
|
Line 102 main(int argc, char **argv)
|
Line 109 main(int argc, char **argv)
|
| return 2; |
return 2; |
| } |
} |
| printf("addr=%p chkaddr=%d addr_size=%d\n", addr, mpool_chkaddr(addr), mpool_getsizebyaddr(addr)); |
printf("addr=%p chkaddr=%d addr_size=%d\n", addr, mpool_chkaddr(addr), mpool_getsizebyaddr(addr)); |
| |
printf(">>> and free new 4000 addr=%p\n", addr); |
| mpool_free(mp, addr, 0); |
mpool_free(mp, addr, 0); |
| |
|
| printf("4) calls.act=%lu calls.inact=%lu calls.free=%lu; bytes.act=%lu bytes.inact=%lu bytes.free=%lu;\n", |
printf("4) calls.act=%lu calls.inact=%lu calls.free=%lu; bytes.act=%lu bytes.inact=%lu bytes.free=%lu;\n", |
| mp->pool_calls.alloc, mp->pool_calls.cache, mp->pool_calls.free, |
mp->pool_calls.alloc, mp->pool_calls.cache, mp->pool_calls.free, |
| mp->pool_bytes.alloc, mp->pool_bytes.cache, mp->pool_bytes.free); |
mp->pool_bytes.alloc, mp->pool_bytes.cache, mp->pool_bytes.free); |
| mpool_statistics(mp, show); | mpool_statistics(mp, show, NULL, 0); |
| | |
| | |
| | printf("realloc 4000 to 100000 and to 2000000\n"); |
| | addr = mpool_malloc(mp, 4000, "mdaaa 4000"); |
| | printf("malloc addr=%p chkaddr=%d addr_size=%d\n", addr, mpool_chkaddr(addr), mpool_getsizebyaddr(addr)); |
| | addr = mpool_realloc(mp, addr, 100000, "ohche"); |
| | printf("realloc addr=%p chkaddr=%d addr_size=%d\n", addr, mpool_chkaddr(addr), mpool_getsizebyaddr(addr)); |
| | addr = mpool_realloc(mp, addr, 2000000, NULL); |
| | printf("realloc addr=%p chkaddr=%d addr_size=%d\n", addr, mpool_chkaddr(addr), mpool_getsizebyaddr(addr)); |
| | mpool_free(mp, addr, 0); |
| | printf("5) calls.act=%lu calls.inact=%lu calls.free=%lu; bytes.act=%lu bytes.inact=%lu bytes.free=%lu;\n", |
| | mp->pool_calls.alloc, mp->pool_calls.cache, mp->pool_calls.free, |
| | mp->pool_bytes.alloc, mp->pool_bytes.cache, mp->pool_bytes.free); |
| | mpool_statistics(mp, show, NULL, 0); |
| | |
| | |
| | mpool_dump(mp, NULL); |
| mpool_destroy(&mp); |
mpool_destroy(&mp); |
| return 0; |
return 0; |
| } |
} |