kexec.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. #ifndef _ASM_IA64_KEXEC_H
  2. #define _ASM_IA64_KEXEC_H
  3. /* Maximum physical address we can use pages from */
  4. #define KEXEC_SOURCE_MEMORY_LIMIT (-1UL)
  5. /* Maximum address we can reach in physical address mode */
  6. #define KEXEC_DESTINATION_MEMORY_LIMIT (-1UL)
  7. /* Maximum address we can use for the control code buffer */
  8. #define KEXEC_CONTROL_MEMORY_LIMIT TASK_SIZE
  9. #define KEXEC_CONTROL_CODE_SIZE (8192 + 8192 + 4096)
  10. /* The native architecture */
  11. #define KEXEC_ARCH KEXEC_ARCH_IA_64
  12. #define MAX_NOTE_BYTES 1024
  13. #define kexec_flush_icache_page(page) do { \
  14. unsigned long page_addr = (unsigned long)page_address(page); \
  15. flush_icache_range(page_addr, page_addr + PAGE_SIZE); \
  16. } while(0)
  17. extern struct kimage *ia64_kimage;
  18. DECLARE_PER_CPU(u64, ia64_mca_pal_base);
  19. const extern unsigned int relocate_new_kernel_size;
  20. extern void relocate_new_kernel(unsigned long, unsigned long,
  21. struct ia64_boot_param *, unsigned long);
  22. static inline void
  23. crash_setup_regs(struct pt_regs *newregs, struct pt_regs *oldregs)
  24. {
  25. }
  26. extern struct resource efi_memmap_res;
  27. extern struct resource boot_param_res;
  28. extern void kdump_smp_send_stop(void);
  29. extern void kdump_smp_send_init(void);
  30. extern void kexec_disable_iosapic(void);
  31. extern void crash_save_this_cpu(void);
  32. struct rsvd_region;
  33. extern unsigned long kdump_find_rsvd_region(unsigned long size,
  34. struct rsvd_region *rsvd_regions, int n);
  35. extern void kdump_cpu_freeze(struct unw_frame_info *info, void *arg);
  36. extern int kdump_status[];
  37. extern atomic_t kdump_cpu_freezed;
  38. extern atomic_t kdump_in_progress;
  39. #endif /* _ASM_IA64_KEXEC_H */