From f4fced0e242cae1ad6caad8e36472e751a871816 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erik=20=C3=96sterlund?= Date: Mon, 25 Nov 2019 09:10:41 +0000 Subject: [PATCH] 8234509: Race in macOS os::processor_id() Reviewed-by: dholmes, pliden, rehn --- src/hotspot/os/bsd/os_bsd.cpp | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/hotspot/os/bsd/os_bsd.cpp b/src/hotspot/os/bsd/os_bsd.cpp index 0d12bf412d9..a209dad1236 100644 --- a/src/hotspot/os/bsd/os_bsd.cpp +++ b/src/hotspot/os/bsd/os_bsd.cpp @@ -3264,12 +3264,14 @@ uint os::processor_id() { int processor_id = Atomic::load(&mapping[apic_id]); while (processor_id < 0) { - if (Atomic::cmpxchg(-2, &mapping[apic_id], -1)) { + if (Atomic::cmpxchg(-2, &mapping[apic_id], -1) == -1) { Atomic::store(Atomic::add(1, &next_processor_id) - 1, &mapping[apic_id]); } processor_id = Atomic::load(&mapping[apic_id]); } + assert(processor_id >= 0 && processor_id < os::processor_count(), "invalid processor id"); + return (uint)processor_id; } #endif