summaryrefslogtreecommitdiff
path: root/include/linux/smp.h
diff options
context:
space:
mode:
authorRusty Russell <rusty@rustcorp.com.au>2002-03-04 23:04:15 -0800
committerLinus Torvalds <torvalds@penguin.transmeta.com>2002-03-04 23:04:15 -0800
commit3d7af07825c07ddb3fbc27245ff01caae7ce764f (patch)
treef151f055c01f6cbf1b4f0b5f6e261ed41f71743b /include/linux/smp.h
parent09c1076ece2d7abd60356986436cc64c5253eb09 (diff)
[PATCH] per-cpu areas
This is the Richard Henderson-approved, cleaner, brighter per-cpu patch.
Diffstat (limited to 'include/linux/smp.h')
-rw-r--r--include/linux/smp.h16
1 files changed, 15 insertions, 1 deletions
diff --git a/include/linux/smp.h b/include/linux/smp.h
index 43bef9087932..5290555e8101 100644
--- a/include/linux/smp.h
+++ b/include/linux/smp.h
@@ -11,6 +11,7 @@
#ifdef CONFIG_SMP
#include <linux/kernel.h>
+#include <linux/compiler.h>
#include <asm/smp.h>
/*
@@ -71,7 +72,17 @@ extern volatile int smp_msg_id;
#define MSG_RESCHEDULE 0x0003 /* Reschedule request from master CPU*/
#define MSG_CALL_FUNCTION 0x0004 /* Call function on all other CPUs */
-#else
+#define __per_cpu_data __attribute__((section(".data.percpu")))
+
+#ifndef __HAVE_ARCH_PER_CPU
+extern unsigned long __per_cpu_offset[NR_CPUS];
+
+/* var is in discarded region: offset to particular copy we want */
+#define per_cpu(var, cpu) RELOC_HIDE(var, per_cpu_offset(cpu))
+
+#define this_cpu(var) per_cpu(var, smp_processor_id())
+#endif /* !__HAVE_ARCH_PER_CPU */
+#else /* !SMP */
/*
* These macros fold the SMP functionality into a single CPU system
@@ -90,6 +101,9 @@ extern volatile int smp_msg_id;
#define cpu_online_map 1
static inline void smp_send_reschedule(int cpu) { }
static inline void smp_send_reschedule_all(void) { }
+#define __per_cpu_data
+#define per_cpu(var, cpu) var
+#define this_cpu(var) var
#endif
#endif