|  | /* | 
|  | * 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; | 
|  | } |