summaryrefslogtreecommitdiffstats
path: root/bsps/i386/pc386/clock/ckinit.c
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2019-04-18 07:38:13 +0200
committerSebastian Huber <sebastian.huber@embedded-brains.de>2019-05-20 08:49:39 +0200
commit1a971d836cdb4b9b642b69a71817e2b14484f20d (patch)
treeec643ebabe7e37cadf4cee82b4ff9e2a9e0114ca /bsps/i386/pc386/clock/ckinit.c
parentscore: Simplify _SMP_Multicast_action() (diff)
downloadrtems-1a971d836cdb4b9b642b69a71817e2b14484f20d.tar.bz2
score: Remove SMP_MESSAGE_CLOCK_TICK
Use _SMP_Multicast_action() instead.
Diffstat (limited to 'bsps/i386/pc386/clock/ckinit.c')
-rw-r--r--bsps/i386/pc386/clock/ckinit.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/bsps/i386/pc386/clock/ckinit.c b/bsps/i386/pc386/clock/ckinit.c
index afd5d01f1e..478a37f5d7 100644
--- a/bsps/i386/pc386/clock/ckinit.c
+++ b/bsps/i386/pc386/clock/ckinit.c
@@ -29,6 +29,9 @@
#include <libcpu/cpuModel.h>
#include <assert.h>
#include <rtems/timecounter.h>
+#ifdef RTEMS_SMP
+#include <rtems/score/smpimpl.h>
+#endif
#define CLOCK_VECTOR 0
@@ -66,7 +69,12 @@ extern volatile uint32_t Clock_driver_ticks;
#ifdef RTEMS_SMP
#define Clock_driver_support_at_tick() \
- _SMP_Send_message_broadcast(SMP_MESSAGE_CLOCK_TICK)
+ do { \
+ Processor_mask targets; \
+ _Processor_mask_Assign(&targets, _SMP_Get_online_processors()); \
+ _Processor_mask_Clear(&targets, _SMP_Get_current_processor()); \
+ _SMP_Multicast_action(&targets, Clock_isr, NULL); \
+ } while (0)
#endif
static uint32_t pc386_get_timecount_tsc(struct timecounter *tc)