blob: e179728697d8c7c0ed1cb51809da8631a04c361a [file]
Future ABI changes
==================
This file collects items that require a libperf ABI bump. Each entry
should describe the current limitation, the desired end state, and the
scope of the change so that a future ABI revision can batch them
together.
1. Widen struct perf_cpu.cpu from int16_t to int
- Current limit: 32767 CPUs. No architecture exceeds this today
(x86_64 max is 8192, arm64 is 4096), but NR_CPUS limits keep
growing. perf clamps to INT16_MAX in set_max_cpu_num() as a
safety net.
- Code simplification: the int16_t forces defensive truncation
checks at every boundary where a wider CPU index (int from
sample->cpu, al->cpu, etc.) is narrowed into struct perf_cpu.
Without these checks, values > 32767 silently wrap to negative
numbers (two's complement), bypassing bounds validation.
Widening to int eliminates this entire class of silent
truncation bugs and removes the need for the INT16_MAX clamp
in set_max_cpu_num().
- Scope: struct perf_cpu is embedded everywhere — perf_cpu_map__cpu(),
perf_cpu_map__min(), perf_cpu_map__max(), perf_cpu_map__has(), the
for_each_cpu macros, and all internal callers. The perf_cpu_map
internal array (RC_CHK_ACCESS(map)->map[]) stores struct perf_cpu
directly. Widening changes the struct layout and every function
that returns or accepts struct perf_cpu by value.
- Migration: bump LIBPERF version in libperf.map, audit all
sizeof(struct perf_cpu) assumptions, update perf.data
serialization if needed.