restart_table.c 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. #include <asm/interrupt.h>
  2. #include <asm/kprobes.h>
  3. struct soft_mask_table_entry {
  4. unsigned long start;
  5. unsigned long end;
  6. };
  7. struct restart_table_entry {
  8. unsigned long start;
  9. unsigned long end;
  10. unsigned long fixup;
  11. };
  12. extern struct soft_mask_table_entry __start___soft_mask_table[];
  13. extern struct soft_mask_table_entry __stop___soft_mask_table[];
  14. extern struct restart_table_entry __start___restart_table[];
  15. extern struct restart_table_entry __stop___restart_table[];
  16. /* Given an address, look for it in the soft mask table */
  17. bool search_kernel_soft_mask_table(unsigned long addr)
  18. {
  19. struct soft_mask_table_entry *smte = __start___soft_mask_table;
  20. while (smte < __stop___soft_mask_table) {
  21. unsigned long start = smte->start;
  22. unsigned long end = smte->end;
  23. if (addr >= start && addr < end)
  24. return true;
  25. smte++;
  26. }
  27. return false;
  28. }
  29. NOKPROBE_SYMBOL(search_kernel_soft_mask_table);
  30. /* Given an address, look for it in the kernel exception table */
  31. unsigned long search_kernel_restart_table(unsigned long addr)
  32. {
  33. struct restart_table_entry *rte = __start___restart_table;
  34. while (rte < __stop___restart_table) {
  35. unsigned long start = rte->start;
  36. unsigned long end = rte->end;
  37. unsigned long fixup = rte->fixup;
  38. if (addr >= start && addr < end)
  39. return fixup;
  40. rte++;
  41. }
  42. return 0;
  43. }
  44. NOKPROBE_SYMBOL(search_kernel_restart_table);