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.