Files
hakmem/core/hakmem_sys.c
Moe Charm (CI) 52386401b3 Debug Counters Implementation - Clean History
Major Features:
- Debug counter infrastructure for Refill Stage tracking
- Free Pipeline counters (ss_local, ss_remote, tls_sll)
- Diagnostic counters for early return analysis
- Unified larson.sh benchmark runner with profiles
- Phase 6-3 regression analysis documentation

Bug Fixes:
- Fix SuperSlab disabled by default (HAKMEM_TINY_USE_SUPERSLAB)
- Fix profile variable naming consistency
- Add .gitignore patterns for large files

Performance:
- Phase 6-3: 4.79 M ops/s (has OOM risk)
- With SuperSlab: 3.13 M ops/s (+19% improvement)

This is a clean repository without large log files.

🤖 Generated with [Claude Code](https://claude.com/claude-code)
Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-05 12:31:14 +09:00

81 lines
1.8 KiB
C

// hakmem_sys.c - Syscall Wrappers Implementation
//
// License: MIT
// Date: 2025-10-21
#include "hakmem_sys.h"
#include "hakmem_debug.h"
#include <sys/mman.h>
#include <stdio.h>
#include <stdlib.h>
// madvise constants (Linux)
#ifndef MADV_DONTNEED
#define MADV_DONTNEED 4
#endif
#ifndef MADV_WILLNEED
#define MADV_WILLNEED 3
#endif
// ============================================================================
// Syscall Wrappers (計測付き)
// ============================================================================
void* hkm_sys_mmap(size_t size) {
HKM_TIME_START(t0);
void* ptr = mmap(NULL, size, PROT_READ | PROT_WRITE,
MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
HKM_TIME_END(HKM_CAT_SYSCALL_MMAP, t0);
if (ptr == MAP_FAILED) {
fprintf(stderr, "[HAKMEM SYS] mmap(%zu) failed\n", size);
return NULL;
}
return ptr;
}
void hkm_sys_munmap(void* ptr, size_t size) {
if (!ptr) return;
HKM_TIME_START(t0);
int ret = munmap(ptr, size);
HKM_TIME_END(HKM_CAT_SYSCALL_MUNMAP, t0);
if (ret != 0) {
fprintf(stderr, "[HAKMEM SYS] munmap(%p, %zu) failed\n", ptr, size);
}
}
void hkm_sys_madvise_dontneed(void* ptr, size_t size) {
if (!ptr) return;
HKM_TIME_START(t0);
int ret = madvise(ptr, size, MADV_DONTNEED);
HKM_TIME_END(HKM_CAT_SYSCALL_MADVISE, t0);
if (ret != 0) {
fprintf(stderr, "[HAKMEM SYS] madvise(DONTNEED, %p, %zu) failed\n", ptr, size);
}
}
void hkm_sys_madvise_willneed(void* ptr, size_t size) {
if (!ptr) return;
HKM_TIME_START(t0);
int ret = madvise(ptr, size, MADV_WILLNEED);
HKM_TIME_END(HKM_CAT_SYSCALL_MADVISE, t0);
if (ret != 0) {
fprintf(stderr, "[HAKMEM SYS] madvise(WILLNEED, %p, %zu) failed\n", ptr, size);
}
}