Files
hakmem/core
Moe Charm (CI) 24beb34de6 Fix: Phase 7-1.2 - Page boundary SEGV in fast free path
## Problem
`bench_random_mixed` crashed with SEGV when freeing malloc allocations
at page boundaries (e.g., ptr=0x7ffff6e00000, ptr-1 unmapped).

## Root Cause
Phase 7 fast free path reads 1-byte header at `ptr-1` without checking
if memory is accessible. When malloc returns page-aligned pointer with
previous page unmapped, reading `ptr-1` causes SEGV.

## Solution
Added `hak_is_memory_readable(ptr-1)` check BEFORE reading header in
`core/tiny_free_fast_v2.inc.h`. Page-boundary allocations route to
slow path (dual-header dispatch) which correctly handles malloc via
__libc_free().

## Verification
- bench_random_mixed (1024B): SEGV → 692K ops/s 
- bench_random_mixed (2048B/4096B): SEGV → 697K/643K ops/s 
- All sizes stable across 3 runs

## Performance Impact
<1% overhead (mincore() only on fast path miss, ~1-3% of frees)

## Related
- Phase 7-1.1: Dual-header dispatch (Task Agent)
- Phase 7-1.2: Page boundary safety (this fix)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-08 03:46:35 +09:00
..