aboutsummaryrefslogtreecommitdiff
path: root/arch/x86_64/mm/extable_64.c
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2007-10-11 11:16:15 +0200
committerThomas Gleixner <tglx@linutronix.de>2007-10-11 11:16:15 +0200
commitc559b6fdd148b28358862c68d835e67dab997080 (patch)
treedb3b11fb920b5558c126c23980fb5910fe1e1487 /arch/x86_64/mm/extable_64.c
parent4d381b582896529c3ab0f5ba815b8133a4e6d5fa (diff)
x86_64: prepare shared mm/extable.c
Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86_64/mm/extable_64.c')
-rw-r--r--arch/x86_64/mm/extable_64.c34
1 files changed, 34 insertions, 0 deletions
diff --git a/arch/x86_64/mm/extable_64.c b/arch/x86_64/mm/extable_64.c
new file mode 100644
index 00000000000..79ac6e7100a
--- /dev/null
+++ b/arch/x86_64/mm/extable_64.c
@@ -0,0 +1,34 @@
+/*
+ * linux/arch/x86_64/mm/extable.c
+ */
+
+#include <linux/module.h>
+#include <linux/spinlock.h>
+#include <linux/init.h>
+#include <asm/uaccess.h>
+
+/* Simple binary search */
+const struct exception_table_entry *
+search_extable(const struct exception_table_entry *first,
+ const struct exception_table_entry *last,
+ unsigned long value)
+{
+ /* Work around a B stepping K8 bug */
+ if ((value >> 32) == 0)
+ value |= 0xffffffffUL << 32;
+
+ while (first <= last) {
+ const struct exception_table_entry *mid;
+ long diff;
+
+ mid = (last - first) / 2 + first;
+ diff = mid->insn - value;
+ if (diff == 0)
+ return mid;
+ else if (diff < 0)
+ first = mid+1;
+ else
+ last = mid-1;
+ }
+ return NULL;
+}