From 8af1725e7fbe6db685f25e1c011c9bc0b042b083 Mon Sep 17 00:00:00 2001 From: Ruy Contributors Date: Thu, 11 Aug 2022 08:56:27 -0700 Subject: [PATCH] Null check each cpuinfo_get_processor call. Add null checks in cases the cpuinfo could be faked and therefore not consistent. For example, the number of processors would be faked to be 8 but the rest of the processor info could be missing. PiperOrigin-RevId: 466965492 --- ruy/cpuinfo.cc | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/ruy/cpuinfo.cc b/ruy/cpuinfo.cc index 8a0e91209a..4e9bc5cf54 100644 --- a/ruy/cpuinfo.cc +++ b/ruy/cpuinfo.cc @@ -48,6 +48,7 @@ void QueryCacheParams(CpuCacheParams* cache_params) { int local_cache_size = 0; int last_level_cache_size = 0; const cpuinfo_processor* processor = cpuinfo_get_processor(i); + if (!processor) continue; // Loop over cache levels. Ignoring L4 for now: it seems that in CPUs that // have L4, we would still prefer to stay in lower-latency L3. for (const cpuinfo_cache* cache : @@ -56,14 +57,16 @@ void QueryCacheParams(CpuCacheParams* cache_params) { continue; // continue, not break, it is possible to have L1+L3 but no // L2. } - if (!cache->processor_count) { + if (!cache->processor_count || !cache->processor_start) { continue; // crashes from Chrome on Android suggests that might happen? } - const bool is_local = - cpuinfo_get_processor(cache->processor_start)->core == - cpuinfo_get_processor(cache->processor_start + - cache->processor_count - 1) - ->core; + const cpuinfo_processor* start_processor = + cpuinfo_get_processor(cache->processor_start); + const cpuinfo_processor* end_processor = cpuinfo_get_processor( + cache->processor_start + cache->processor_count - 1); + if (!start_processor || !end_processor) continue; + const bool is_local = start_processor->core == end_processor->core; + if (is_local) { local_cache_size = cache->size; }