From 6390df300e6795e557f824e55b138837dabcf74b Mon Sep 17 00:00:00 2001 From: Kevin Wang Date: Fri, 8 Dec 2017 13:43:27 +0800 Subject: implement clib_smp_pause() for arm and aarch64 platform Change-Id: Ic9c1c70e06b953538ed43fc91ed26b6be82ce812 Signed-off-by: Kevin Wang --- src/vppinfra/smp.h | 2 ++ src/vppinfra/timer.c | 3 ++- 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/src/vppinfra/smp.h b/src/vppinfra/smp.h index 7e703b3d6aa..e4ab66ad5c3 100644 --- a/src/vppinfra/smp.h +++ b/src/vppinfra/smp.h @@ -47,6 +47,8 @@ #if defined (i386) || defined (__x86_64__) #define clib_smp_pause() do { asm volatile ("pause"); } while (0) +#elif defined (__aarch64__) || defined (__arm__) +#define clib_smp_pause() do { asm volatile ("isb" ::: "memory"); } while (0) #endif #ifndef clib_smp_pause diff --git a/src/vppinfra/timer.c b/src/vppinfra/timer.c index 0221cb749a1..85149dc6b00 100644 --- a/src/vppinfra/timer.c +++ b/src/vppinfra/timer.c @@ -41,6 +41,7 @@ #include #include +#include #include #include #include @@ -283,7 +284,7 @@ bar_t b = { limit:10 }; timer_call (bar, (any) & b, random_f64 ()); while (vec_len (timers) > 0) - sched_yield (); + os_sched_yield (); if (vec_len (foos) > 0) { -- cgit 1.2.3-korg