mirror of
https://github.com/microsoft/mimalloc.git
synced 2025-01-15 01:29:11 +08:00
fix warnings for issues #709
This commit is contained in:
parent
65402836ae
commit
54ad5e76fd
13
src/heap.c
13
src/heap.c
@ -31,15 +31,18 @@ static bool mi_heap_visit_pages(mi_heap_t* heap, heap_page_visitor_fun* fn, void
|
|||||||
// visit all pages
|
// visit all pages
|
||||||
#if MI_DEBUG>1
|
#if MI_DEBUG>1
|
||||||
size_t total = heap->page_count;
|
size_t total = heap->page_count;
|
||||||
#endif
|
|
||||||
size_t count = 0;
|
size_t count = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
for (size_t i = 0; i <= MI_BIN_FULL; i++) {
|
for (size_t i = 0; i <= MI_BIN_FULL; i++) {
|
||||||
mi_page_queue_t* pq = &heap->pages[i];
|
mi_page_queue_t* pq = &heap->pages[i];
|
||||||
mi_page_t* page = pq->first;
|
mi_page_t* page = pq->first;
|
||||||
while(page != NULL) {
|
while(page != NULL) {
|
||||||
mi_page_t* next = page->next; // save next in case the page gets removed from the queue
|
mi_page_t* next = page->next; // save next in case the page gets removed from the queue
|
||||||
mi_assert_internal(mi_page_heap(page) == heap);
|
mi_assert_internal(mi_page_heap(page) == heap);
|
||||||
|
#if MI_DEBUG>1
|
||||||
count++;
|
count++;
|
||||||
|
#endif
|
||||||
if (!fn(heap, pq, page, arg1, arg2)) return false;
|
if (!fn(heap, pq, page, arg1, arg2)) return false;
|
||||||
page = next; // and continue
|
page = next; // and continue
|
||||||
}
|
}
|
||||||
@ -516,9 +519,13 @@ static bool mi_heap_area_visit_blocks(const mi_heap_area_ex_t* xarea, mi_block_v
|
|||||||
uintptr_t free_map[MI_MAX_BLOCKS / sizeof(uintptr_t)];
|
uintptr_t free_map[MI_MAX_BLOCKS / sizeof(uintptr_t)];
|
||||||
memset(free_map, 0, sizeof(free_map));
|
memset(free_map, 0, sizeof(free_map));
|
||||||
|
|
||||||
|
#if MI_DEBUG>1
|
||||||
size_t free_count = 0;
|
size_t free_count = 0;
|
||||||
|
#endif
|
||||||
for (mi_block_t* block = page->free; block != NULL; block = mi_block_next(page,block)) {
|
for (mi_block_t* block = page->free; block != NULL; block = mi_block_next(page,block)) {
|
||||||
|
#if MI_DEBUG>1
|
||||||
free_count++;
|
free_count++;
|
||||||
|
#endif
|
||||||
mi_assert_internal((uint8_t*)block >= pstart && (uint8_t*)block < (pstart + psize));
|
mi_assert_internal((uint8_t*)block >= pstart && (uint8_t*)block < (pstart + psize));
|
||||||
size_t offset = (uint8_t*)block - pstart;
|
size_t offset = (uint8_t*)block - pstart;
|
||||||
mi_assert_internal(offset % bsize == 0);
|
mi_assert_internal(offset % bsize == 0);
|
||||||
@ -531,7 +538,9 @@ static bool mi_heap_area_visit_blocks(const mi_heap_area_ex_t* xarea, mi_block_v
|
|||||||
mi_assert_internal(page->capacity == (free_count + page->used));
|
mi_assert_internal(page->capacity == (free_count + page->used));
|
||||||
|
|
||||||
// walk through all blocks skipping the free ones
|
// walk through all blocks skipping the free ones
|
||||||
|
#if MI_DEBUG>1
|
||||||
size_t used_count = 0;
|
size_t used_count = 0;
|
||||||
|
#endif
|
||||||
for (size_t i = 0; i < page->capacity; i++) {
|
for (size_t i = 0; i < page->capacity; i++) {
|
||||||
size_t bitidx = (i / sizeof(uintptr_t));
|
size_t bitidx = (i / sizeof(uintptr_t));
|
||||||
size_t bit = i - (bitidx * sizeof(uintptr_t));
|
size_t bit = i - (bitidx * sizeof(uintptr_t));
|
||||||
@ -540,7 +549,9 @@ static bool mi_heap_area_visit_blocks(const mi_heap_area_ex_t* xarea, mi_block_v
|
|||||||
i += (sizeof(uintptr_t) - 1); // skip a run of free blocks
|
i += (sizeof(uintptr_t) - 1); // skip a run of free blocks
|
||||||
}
|
}
|
||||||
else if ((m & ((uintptr_t)1 << bit)) == 0) {
|
else if ((m & ((uintptr_t)1 << bit)) == 0) {
|
||||||
|
#if MI_DEBUG>1
|
||||||
used_count++;
|
used_count++;
|
||||||
|
#endif
|
||||||
uint8_t* block = pstart + (i * bsize);
|
uint8_t* block = pstart + (i * bsize);
|
||||||
if (!visitor(mi_page_heap(page), area, block, ubsize, arg)) return false;
|
if (!visitor(mi_page_heap(page), area, block, ubsize, arg)) return false;
|
||||||
}
|
}
|
||||||
|
@ -699,12 +699,16 @@ static void mi_page_init(mi_heap_t* heap, mi_page_t* page, size_t block_size, mi
|
|||||||
static mi_page_t* mi_page_queue_find_free_ex(mi_heap_t* heap, mi_page_queue_t* pq, bool first_try)
|
static mi_page_t* mi_page_queue_find_free_ex(mi_heap_t* heap, mi_page_queue_t* pq, bool first_try)
|
||||||
{
|
{
|
||||||
// search through the pages in "next fit" order
|
// search through the pages in "next fit" order
|
||||||
|
#if MI_STAT
|
||||||
size_t count = 0;
|
size_t count = 0;
|
||||||
|
#endif
|
||||||
mi_page_t* page = pq->first;
|
mi_page_t* page = pq->first;
|
||||||
while (page != NULL)
|
while (page != NULL)
|
||||||
{
|
{
|
||||||
mi_page_t* next = page->next; // remember next
|
mi_page_t* next = page->next; // remember next
|
||||||
|
#if MI_STAT
|
||||||
count++;
|
count++;
|
||||||
|
#endif
|
||||||
|
|
||||||
// 0. collect freed blocks by us and other threads
|
// 0. collect freed blocks by us and other threads
|
||||||
_mi_page_free_collect(page, false);
|
_mi_page_free_collect(page, false);
|
||||||
|
18
src/stats.c
18
src/stats.c
@ -430,17 +430,19 @@ mi_msecs_t _mi_clock_end(mi_msecs_t start) {
|
|||||||
|
|
||||||
mi_decl_export void mi_process_info(size_t* elapsed_msecs, size_t* user_msecs, size_t* system_msecs, size_t* current_rss, size_t* peak_rss, size_t* current_commit, size_t* peak_commit, size_t* page_faults) mi_attr_noexcept
|
mi_decl_export void mi_process_info(size_t* elapsed_msecs, size_t* user_msecs, size_t* system_msecs, size_t* current_rss, size_t* peak_rss, size_t* current_commit, size_t* peak_commit, size_t* page_faults) mi_attr_noexcept
|
||||||
{
|
{
|
||||||
mi_process_info_t pinfo = { 0 };
|
mi_process_info_t pinfo;
|
||||||
pinfo.elapsed = _mi_clock_end(mi_process_start);
|
_mi_memzero(&pinfo,sizeof(pinfo));
|
||||||
pinfo.utime = 0;
|
pinfo.elapsed = _mi_clock_end(mi_process_start);
|
||||||
pinfo.stime = 0;
|
|
||||||
pinfo.current_commit = (size_t)(mi_atomic_loadi64_relaxed((_Atomic(int64_t)*)&_mi_stats_main.committed.current));
|
pinfo.current_commit = (size_t)(mi_atomic_loadi64_relaxed((_Atomic(int64_t)*)&_mi_stats_main.committed.current));
|
||||||
pinfo.peak_commit = (size_t)(mi_atomic_loadi64_relaxed((_Atomic(int64_t)*)&_mi_stats_main.committed.peak));
|
pinfo.peak_commit = (size_t)(mi_atomic_loadi64_relaxed((_Atomic(int64_t)*)&_mi_stats_main.committed.peak));
|
||||||
pinfo.current_rss = pinfo.current_commit;
|
pinfo.current_rss = pinfo.current_commit;
|
||||||
pinfo.peak_rss = pinfo.peak_commit;
|
pinfo.peak_rss = pinfo.peak_commit;
|
||||||
pinfo.page_faults = 0;
|
pinfo.utime = 0;
|
||||||
|
pinfo.stime = 0;
|
||||||
|
pinfo.page_faults = 0;
|
||||||
|
|
||||||
_mi_prim_process_info(&pinfo);
|
_mi_prim_process_info(&pinfo);
|
||||||
|
|
||||||
if (elapsed_msecs!=NULL) *elapsed_msecs = (pinfo.elapsed < 0 ? 0 : (pinfo.elapsed < (mi_msecs_t)PTRDIFF_MAX ? (size_t)pinfo.elapsed : PTRDIFF_MAX));
|
if (elapsed_msecs!=NULL) *elapsed_msecs = (pinfo.elapsed < 0 ? 0 : (pinfo.elapsed < (mi_msecs_t)PTRDIFF_MAX ? (size_t)pinfo.elapsed : PTRDIFF_MAX));
|
||||||
if (user_msecs!=NULL) *user_msecs = (pinfo.utime < 0 ? 0 : (pinfo.utime < (mi_msecs_t)PTRDIFF_MAX ? (size_t)pinfo.utime : PTRDIFF_MAX));
|
if (user_msecs!=NULL) *user_msecs = (pinfo.utime < 0 ? 0 : (pinfo.utime < (mi_msecs_t)PTRDIFF_MAX ? (size_t)pinfo.utime : PTRDIFF_MAX));
|
||||||
if (system_msecs!=NULL) *system_msecs = (pinfo.stime < 0 ? 0 : (pinfo.stime < (mi_msecs_t)PTRDIFF_MAX ? (size_t)pinfo.stime : PTRDIFF_MAX));
|
if (system_msecs!=NULL) *system_msecs = (pinfo.stime < 0 ? 0 : (pinfo.stime < (mi_msecs_t)PTRDIFF_MAX ? (size_t)pinfo.stime : PTRDIFF_MAX));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user