From mboxrd@z Thu Jan 1 00:00:00 1970 From: Khalid Aziz Date: Fri, 28 Apr 2006 16:10:37 +0000 Subject: [PATCH] Updated patch for kexec on ia64 Message-Id: <1146240637.14803.35.camel@lyra.fc.hp.com> List-Id: MIME-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable To: linux-ia64@vger.kernel.org This is an updated version of patch to add kexec support on ia64. Signed-off-by: Khalid Aziz Signed-off-by: Nanhai Zou --- diff -urNp linux-2.6.16/arch/ia64/hp/common/sba_iommu.c linux-2.6.16-kexec/= arch/ia64/hp/common/sba_iommu.c --- linux-2.6.16/arch/ia64/hp/common/sba_iommu.c 2006-03-19 22:53:29.000000= 000 -0700 +++ linux-2.6.16-kexec/arch/ia64/hp/common/sba_iommu.c 2006-03-27 15:42:47.= 000000000 -0700 @@ -1624,6 +1624,28 @@ ioc_iova_init(struct ioc *ioc) READ_REG(ioc->ioc_hpa + IOC_IBASE); } =20 +#ifdef CONFIG_KEXEC +void +ioc_iova_disable(void) +{ + struct ioc *ioc; + + ioc =3D ioc_list; + + while (ioc !=3D NULL) { + /* Disable IOVA translation */ + WRITE_REG(ioc->ibase & 0xfffffffffffffffe, ioc->ioc_hpa + IOC_IBASE); + READ_REG(ioc->ioc_hpa + IOC_IBASE); + + /* Clear I/O TLB of any possible entries */ + WRITE_REG(ioc->ibase | (get_iovp_order(ioc->iov_size) + iovp_shift), ioc= ->ioc_hpa + IOC_PCOM); + READ_REG(ioc->ioc_hpa + IOC_PCOM); + + ioc =3D ioc->next; + } +} +#endif + static void __init ioc_resource_init(struct ioc *ioc) { diff -urNp linux-2.6.16/arch/ia64/Kconfig linux-2.6.16-kexec/arch/ia64/Kcon= fig --- linux-2.6.16/arch/ia64/Kconfig 2006-03-19 22:53:29.000000000 -0700 +++ linux-2.6.16-kexec/arch/ia64/Kconfig 2006-03-27 15:42:47.000000000 -0700 @@ -376,6 +376,23 @@ config IA64_PALINFO config SGI_SN def_bool y if (IA64_SGI_SN2 || IA64_GENERIC) =20 +config KEXEC + bool "kexec system call (EXPERIMENTAL)" + depends on EXPERIMENTAL + help + kexec is a system call that implements the ability to shutdown your + current kernel, and to start another kernel. It is like a reboot + but it is indepedent of the system firmware. And like a reboot + you can start any kernel with it, not just Linux. + + The name comes from the similiarity to the exec system call. + + It is an ongoing process to be certain the hardware in a machine + is properly shutdown, so do not be surprised if this code does not + initially work for you. It may help to enable device hotplugging + support. As of this writing the exact hardware interface is + strongly in flux, so no good recommendation can be made. + source "drivers/firmware/Kconfig" =20 source "fs/Kconfig.binfmt" diff -urNp linux-2.6.16/arch/ia64/kernel/crash.c linux-2.6.16-kexec/arch/ia= 64/kernel/crash.c --- linux-2.6.16/arch/ia64/kernel/crash.c 1969-12-31 17:00:00.000000000 -07= 00 +++ linux-2.6.16-kexec/arch/ia64/kernel/crash.c 2006-04-28 09:54:52.0000000= 00 -0600 @@ -0,0 +1,43 @@ +/* + * arch/ia64/kernel/crash.c + * + * Architecture specific (ia64) functions for kexec based crash dumps. + * + * Created by: Khalid Aziz + * + * Copyright (C) 2005 Hewlett-Packard Development Company, L.P. + * + */ +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +void +machine_crash_shutdown(struct pt_regs *pt) +{ + /* This function is only called after the system + * has paniced or is otherwise in a critical state. + * The minimum amount of code to allow a kexec'd kernel + * to run successfully needs to happen here. + * + * In practice this means shooting down the other cpus in + * an SMP system. + */ + if (in_interrupt())=20 + ia64_eoi(); +#ifdef CONFIG_SMP + smp_send_stop(); +#endif +#ifdef CONFIG_IA64_HP_ZX1 + ioc_iova_disable(); +#endif +} diff -urNp linux-2.6.16/arch/ia64/kernel/entry.S linux-2.6.16-kexec/arch/ia= 64/kernel/entry.S --- linux-2.6.16/arch/ia64/kernel/entry.S 2006-03-19 22:53:29.000000000 -07= 00 +++ linux-2.6.16-kexec/arch/ia64/kernel/entry.S 2006-03-27 15:42:47.0000000= 00 -0700 @@ -1590,7 +1590,7 @@ sys_call_table: data8 sys_mq_timedreceive // 1265 data8 sys_mq_notify data8 sys_mq_getsetattr - data8 sys_ni_syscall // reserved for kexec_load + data8 sys_kexec_load data8 sys_ni_syscall // reserved for vserver data8 sys_waitid // 1270 data8 sys_add_key diff -urNp linux-2.6.16/arch/ia64/kernel/machine_kexec.c linux-2.6.16-kexec= /arch/ia64/kernel/machine_kexec.c --- linux-2.6.16/arch/ia64/kernel/machine_kexec.c 1969-12-31 17:00:00.00000= 0000 -0700 +++ linux-2.6.16-kexec/arch/ia64/kernel/machine_kexec.c 2006-04-27 14:08:03= .000000000 -0600 @@ -0,0 +1,140 @@ +/* + * arch/ia64/kernel/machine_kexec.c=20 + * + * Handle transition of Linux booting another kernel + * Copyright (C) 2005 Hewlett-Packard Development Comapny, L.P. + * Copyright (C) 2005 Khalid Aziz + * Copyright (C) 2006 Intel Corp, Zou Nan hai + * + * This source code is licensed under the GNU General Public License, + * Version 2. See the file COPYING for more details. + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +extern unsigned long ia64_iobase; + +typedef void (*relocate_new_kernel_t)( unsigned long, unsigned long,=20 + struct ia64_boot_param *, unsigned long); + +/* + * Do what every setup is needed on image and the + * reboot code buffer to allow us to avoid allocations + * later. + */ +int machine_kexec_prepare(struct kimage *image) +{ + void *control_code_buffer; + const unsigned long *func; + + func =3D (unsigned long *)&relocate_new_kernel; + /* Pre-load control code buffer to minimize work in kexec path */ + control_code_buffer =3D page_address(image->control_code_page); + memcpy((void *)control_code_buffer, (const void *)func[0],=20 + relocate_new_kernel_size); + flush_icache_range((unsigned long)control_code_buffer,=20 + (unsigned long)control_code_buffer + relocate_new_kernel_size); + + return 0; +} + +void machine_kexec_cleanup(struct kimage *image) +{ +} + +void machine_shutdown(void) +{ +#ifdef CONFIG_PCI + struct pci_dev *dev =3D NULL; + irq_desc_t *idesc; + cpumask_t mask =3D CPU_MASK_NONE; + + /* Disable all PCI devices */ + while ((dev =3D pci_get_device(PCI_ANY_ID, PCI_ANY_ID, dev)) !=3D NULL) { + if (!(dev->is_enabled)) + continue; + idesc =3D irq_descp(dev->irq); + if (!idesc) + continue; + cpu_set(0, mask); + disable_irq_nosync(dev->irq); + idesc->handler->end(dev->irq); + idesc->handler->set_affinity(dev->irq, mask); + idesc->action =3D NULL; + pci_disable_device(dev); + } +#endif + +#ifdef CONFIG_HOTPLUG_CPU + { + int cpu; + + for_each_online_cpu(cpu) { + if (cpu !=3D smp_processor_id()) + cpu_down(cpu); + } + } +#elif defined(CONFIG_SMP) + smp_call_function(kexec_stop_this_cpu, (void *)image->start, 0, 0); +#endif + + ia64_set_itv(1<<16); + +#ifdef CONFIG_IA64_HP_ZX1 + ioc_iova_disable(); +#endif +} + +/* + * Do not allocate memory (or fail in any way) in machine_kexec(). + * We are past the point of no return, committed to rebooting now.=20 + */ +void machine_kexec(struct kimage *image) +{ + unsigned long indirection_page; + relocate_new_kernel_t rnk; + unsigned long pta, impl_va_bits; + void *pal_addr =3D efi_get_pal_addr(); + unsigned long code_addr =3D (unsigned long)page_address(image->control_co= de_page); + + /* Interrupts aren't acceptable while we reboot */ + local_irq_disable(); + + /* Disable VHPT */ + impl_va_bits =3D ffz(~(local_cpu_data->unimpl_va_mask | (7UL << 61))); + pta =3D POW2(61) - POW2(vmlpt_bits); + ia64_set_pta(pta | (0 << 8) | (vmlpt_bits << 2) | 0); + + /* now execute the control code. + * We will start by executing the control code linked into the=20 + * kernel as opposed to the code we copied in control code buffer * pag= e. When this code switches to physical mode, we will start + * executing the code in control code buffer page. Reason for + * doing this is we start code execution in virtual address space. + * If we were to try to execute the newly copied code in virtual + * address space, we will need to make an ITLB entry to avoid ITLB=20 + * miss. By executing the code linked into kernel, we take advantage + * of the ITLB entry already in place for kernel and avoid making + * a new entry. + */ + indirection_page =3D image->head & PAGE_MASK; + + rnk =3D (relocate_new_kernel_t)&code_addr; + (*rnk)(indirection_page, image->start, ia64_boot_param, + GRANULEROUNDDOWN((unsigned long) pal_addr)); + BUG(); + for (;;) + ; +} diff -urNp linux-2.6.16/arch/ia64/kernel/Makefile linux-2.6.16-kexec/arch/i= a64/kernel/Makefile --- linux-2.6.16/arch/ia64/kernel/Makefile 2006-03-19 22:53:29.000000000 -0= 700 +++ linux-2.6.16-kexec/arch/ia64/kernel/Makefile 2006-03-27 15:42:47.000000= 000 -0700 @@ -28,6 +28,7 @@ obj-$(CONFIG_IA64_CYCLONE) +=3D cyclone.o obj-$(CONFIG_CPU_FREQ) +=3D cpufreq/ obj-$(CONFIG_IA64_MCA_RECOVERY) +=3D mca_recovery.o obj-$(CONFIG_KPROBES) +=3D kprobes.o jprobes.o +obj-$(CONFIG_KEXEC) +=3D machine_kexec.o relocate_kernel.o crash.o obj-$(CONFIG_IA64_UNCACHED_ALLOCATOR) +=3D uncached.o mca_recovery-y +=3D mca_drv.o mca_drv_asm.o =20 diff -urNp linux-2.6.16/arch/ia64/kernel/relocate_kernel.S linux-2.6.16-kex= ec/arch/ia64/kernel/relocate_kernel.S --- linux-2.6.16/arch/ia64/kernel/relocate_kernel.S 1969-12-31 17:00:00.000= 000000 -0700 +++ linux-2.6.16-kexec/arch/ia64/kernel/relocate_kernel.S 2006-03-31 09:04:= 10.000000000 -0700 @@ -0,0 +1,359 @@ +/* + * arch/ia64/kernel/relocate_kernel.S=20 + * + * Relocate kexec'able kernel and start it + * + * Copyright (C) 2005 Hewlett-Packard Development Company, L.P. + * Copyright (C) 2005 Khalid Aziz + * Copyright (C) 2005 Intel Corp, Zou Nan hai + * + * This source code is licensed under the GNU General Public License, + * Version 2. See the file COPYING for more details. + */ +#include +#include +#include +#include +#include +#include + + /* Must be relocatable PIC code callable as a C function, that once + * it starts can not use the previous processes stack. + * + */ +GLOBAL_ENTRY(relocate_new_kernel) + .prologue + alloc r31=3Dar.pfs,4,0,0,0 + .body +.reloc_entry: +{ + rsm psr.i| psr.ic + mov r2=3Dip +} + ;; +{ + flushrs // must be first insn in group + srlz.i +} + ;; + + //first switch to physical mode + add r3=1F-.reloc_entry, r2 + movl r16 =3D IA64_PSR_AC|IA64_PSR_BN|IA64_PSR_IC|IA64_PSR_MFL + mov ar.rsc=3D0 // put RSE in enforced lazy mode + ;; + add r2=3D(memory_stack-.reloc_entry), r2 + ;; + add sp=3D(memory_stack_end - .reloc_entry),r2 + add r8=3D(register_stack - .reloc_entry),r2 + ;; + tpa sp=3Dsp + tpa r3=3Dr3 + ;; + loadrs + ;; + mov r18=3Dar.rnat + mov ar.bspstore=3Dr8 + ;; + mov cr.ipsr=3Dr16 + mov cr.iip=3Dr3 + mov cr.ifs=3Dr0 + srlz.i + ;; + mov ar.rnat=3Dr18 + rfi + ;; +1: + //physical mode code begin + mov b6=3Din1 + tpa r28=3Din2 // tpa must before TLB purge + + // purge all TC entries +#define O(member) IA64_CPUINFO_##member##_OFFSET + GET_THIS_PADDR(r2, cpu_info) // load phys addr of cpu_info into= r2 + ;; + addl r17=3DO(PTCE_STRIDE),r2 + addl r2=3DO(PTCE_BASE),r2 + ;; + ld8 r18=3D[r2],(O(PTCE_COUNT)-O(PTCE_BASE));; // r18=3Dptce_ba= se + ld4 r19=3D[r2],4 // r19=3Dptce_co= unt[0] + ld4 r21=3D[r17],4 // r21=3Dptce_st= ride[0] + ;; + ld4 r20=3D[r2] // r20=3Dptce_co= unt[1] + ld4 r22=3D[r17] // r22=3Dptce_st= ride[1] + mov r24=3Dr0 + ;; + adds r20=3D-1,r20 + ;; +#undef O +2: + cmp.ltu p6,p7=3Dr24,r19 +(p7) br.cond.dpnt.few 4f + mov ar.lc=3Dr20 +3: + ptc.e r18 + ;; + add r18=3Dr22,r18 + br.cloop.sptk.few 3b + ;; + add r18=3Dr21,r18 + add r24=3D1,r24 + ;; + br.sptk.few 2b +4: + srlz.i + ;; + //purge TR entry for kernel text and data + movl r16=3DKERNEL_START + mov r18=3DKERNEL_TR_PAGE_SHIFT<<2 + ;; + ptr.i r16, r18 + ptr.d r16, r18 + ;; + srlz.i + ;; + + // purge TR entry for percpu data + movl r16=3DPERCPU_ADDR + mov r18=3DPERCPU_PAGE_SHIFT<<2 + ;; + ptr.d r16,r18 + ;; + srlz.d + ;; + + // purge TR entry for pal code + mov r16=3Din3 + mov r18=3DIA64_GRANULE_SHIFT<<2 + ;; + ptr.i r16,r18 + ;; + srlz.i + ;; + + // purge TR entry for stack + mov r16=3DIA64_KR(CURRENT_STACK) + ;; + shl r16=3Dr16,IA64_GRANULE_SHIFT + movl r19=3DPAGE_OFFSET + ;; + add r16=3Dr19,r16 + mov r18=3DIA64_GRANULE_SHIFT<<2 + ;; + ptr.d r16,r18 + ;; + srlz.i + ;; + + // copy kexec kernel segments + movl r16=3DPAGE_MASK + ld8 r30=3D[in0],8;; // in0 is page_list + br.sptk.few .dest_page + ;; +.loop: + ld8 r30=3D[in0], 8;; +.dest_page: + tbit.z p0, p6=3Dr30, 0;; // 0x1 dest page +(p6) and r17=3Dr30, r16 +(p6) br.cond.sptk.few .loop;; + + tbit.z p0, p6=3Dr30, 1;; // 0x2 indirect page +(p6) and in0=3Dr30, r16 +(p6) br.cond.sptk.few .loop;; + + tbit.z p0, p6=3Dr30, 2;; // 0x4 end flag +(p6) br.cond.sptk.few .end_loop;; + + tbit.z p6, p0=3Dr30, 3;; // 0x8 source page +(p6) br.cond.sptk.few .loop + + and r18=3Dr30, r16 + + // simple copy page, may optimize later + movl r14=3DPAGE_SIZE/8 - 1;; + mov ar.lc=3Dr14;; +1: + ld8 r14=3D[r18], 8;; + st8 [r17]=3Dr14, 8;; + fc.i r17 + br.ctop.sptk.few 1b + br.sptk.few .loop + ;; + +.end_loop: + sync.i // for fc.i + ;; + srlz.i + ;; + srlz.d + ;; + br.call.sptk.many b0=B6;; +memory_stack: + .fill 8192, 1, 0 +memory_stack_end: +register_stack: + .fill 8192, 1, 0 +register_stack_end: +relocate_new_kernel_end: +END(relocate_new_kernel) + +GLOBAL_ENTRY(kexec_fake_sal_rendez) + .prologue + alloc r31=3Dar.pfs,3,0,0,0 + .body +.rendez_entry: + rsm psr.i | psr.ic + mov r25=3Dip + ;; + { + flushrs + srlz.i + } + ;; + /* See where I am running, and compute gp */ + { + mov ar.rsc =3D 0 /* Put RSE in enforce lacy, LE mode */ + mov gp =3D ip /* gp =3D relocate_new_kernel */ + } + + movl r8=3D0x00000100000000 + ;; + mov cr.iva=3Dr8 + /* Transition from virtual to physical mode */ + srlz.i + ;; + add r17_-.rendez_entry, r25 + movl r16=3D(IA64_PSR_AC | IA64_PSR_BN | IA64_PSR_IC | IA64_PSR_MFL) + ;; + tpa r17=3Dr17 + mov cr.ipsr=3Dr16 + ;; + mov cr.iip=3Dr17 + mov cr.ifs=3Dr0 + ;; + rfi + ;; +5: + mov b6=3Din0 /* _start addr */ + mov r8=3Din1 /* ap_wakeup_vector */ + mov r26=3Din2 /* PAL addr */ + ;; + /* Purge kernel TRs */ + movl r16=3DKERNEL_START + mov r18=3DKERNEL_TR_PAGE_SHIFT<<2 + ;; + ptr.i r16,r18 + ptr.d r16,r18 + ;; + srlz.i + ;; + srlz.d + ;; + /* Purge percpu TR */ + movl r16=3DPERCPU_ADDR + mov r18=3DPERCPU_PAGE_SHIFT<<2 + ;; + ptr.d r16,r18 + ;; + srlz.d + ;; + /* Purge PAL TR */ + mov r18=3DIA64_GRANULE_SHIFT<<2 + ;; + ptr.i r26,r18 + ;; + srlz.i + ;; + /* Purge stack TR */ + mov r16=3DIA64_KR(CURRENT_STACK) + ;; + shl r16=3Dr16,IA64_GRANULE_SHIFT + movl r19=3DPAGE_OFFSET + ;; + add r16=3Dr19,r16 + mov r18=3DIA64_GRANULE_SHIFT<<2 + ;; + ptr.d r16,r18 + ;; + srlz.i + ;; + + /* Ensure we can read and clear external interrupts */ + mov cr.tpr=3Dr0 + srlz.d + + shr.u r9=3Dr8,6 /* which irr */ + ;; + and r8c,r8 /* bit offset into irr */ + ;; + mov r10=3D1;; + ;; + shl r10=3Dr10,r8 /* bit mask off irr we want */ + cmp.eq p6,p0=3D0,r9 + ;; +(p6) br.cond.sptk.few check_irr0 + cmp.eq p7,p0=3D1,r9 + ;; +(p7) br.cond.sptk.few check_irr1 + cmp.eq p8,p0=3D2,r9 + ;; +(p8) br.cond.sptk.few check_irr2 + cmp.eq p9,p0=3D3,r9 + ;; +(p9) br.cond.sptk.few check_irr3 + +check_irr0: + mov r8=3Dcr.irr0 + ;; + and r8=3Dr8,r10 + ;; + cmp.eq p6,p0=3D0,r8 +(p6) br.cond.sptk.few check_irr0 + br.few call_start +=09 +check_irr1: + mov r8=3Dcr.irr1 + ;; + and r8=3Dr8,r10 + ;; + cmp.eq p6,p0=3D0,r8 +(p6) br.cond.sptk.few check_irr1 + br.few call_start +=09 +check_irr2: + mov r8=3Dcr.irr2 + ;; + and r8=3Dr8,r10 + ;; + cmp.eq p6,p0=3D0,r8 +(p6) br.cond.sptk.few check_irr2 + br.few call_start +=09 +check_irr3: + mov r8=3Dcr.irr3 + ;; + and r8=3Dr8,r10 + ;; + cmp.eq p6,p0=3D0,r8 +(p6) br.cond.sptk.few check_irr3 + br.few call_start +=09 +call_start: + mov cr.eoi=3Dr0 + ;; + srlz.d + ;; + mov r8=3Dcr.ivr + ;; + srlz.d + ;; + cmp.eq p0,p6=15,r8 +(p6) br.cond.sptk.few call_start + br.sptk.few b6 +kexec_fake_sal_rendez_end: +END(kexec_fake_sal_rendez) + + .global relocate_new_kernel_size +relocate_new_kernel_size: + data8 kexec_fake_sal_rendez_end - relocate_new_kernel + diff -urNp linux-2.6.16/arch/ia64/kernel/smp.c linux-2.6.16-kexec/arch/ia64= /kernel/smp.c --- linux-2.6.16/arch/ia64/kernel/smp.c 2006-03-19 22:53:29.000000000 -0700 +++ linux-2.6.16-kexec/arch/ia64/kernel/smp.c 2006-03-27 17:14:04.000000000= -0700 @@ -30,6 +30,7 @@ #include #include #include +#include =20 #include #include @@ -84,6 +85,34 @@ unlock_ipi_calllock(void) spin_unlock_irq(&call_lock); } =20 +#ifdef CONFIG_KEXEC +/* + * Stop the CPU and put it in fake SAL rendezvous. This allows CPU to wake + * up with IPI from boot processor + */ +void +kexec_stop_this_cpu (void *func) +{ + unsigned long pta, impl_va_bits, pal_base; + + /* + * Remove this CPU by putting it into fake SAL rendezvous + */ + cpu_clear(smp_processor_id(), cpu_online_map); + max_xtp(); + ia64_eoi(); + + /* Disable VHPT */ + impl_va_bits =3D ffz(~(local_cpu_data->unimpl_va_mask | (7UL << 61))); + pta =3D POW2(61) - POW2(vmlpt_bits); + ia64_set_pta(pta | (0 << 8) | (vmlpt_bits << 2) | 0); + + local_irq_disable(); + pal_base =3D __get_cpu_var(ia64_mca_pal_base); + kexec_fake_sal_rendez(func, ap_wakeup_vector, pal_base); +} +#endif + static void stop_this_cpu (void) { diff -urNp linux-2.6.16/include/asm-ia64/kexec.h linux-2.6.16-kexec/include= /asm-ia64/kexec.h --- linux-2.6.16/include/asm-ia64/kexec.h 1969-12-31 17:00:00.000000000 -07= 00 +++ linux-2.6.16-kexec/include/asm-ia64/kexec.h 2006-03-30 11:46:46.0000000= 00 -0700 @@ -0,0 +1,36 @@ +#ifndef _ASM_IA64_KEXEC_H +#define _ASM_IA64_KEXEC_H + + +/* Maximum physical address we can use pages from */ +#define KEXEC_SOURCE_MEMORY_LIMIT (-1UL) +/* Maximum address we can reach in physical address mode */ +#define KEXEC_DESTINATION_MEMORY_LIMIT (-1UL) +/* Maximum address we can use for the control code buffer */ +#define KEXEC_CONTROL_MEMORY_LIMIT TASK_SIZE + +#define KEXEC_CONTROL_CODE_SIZE (8192 + 8192 + 4096) + +/* The native architecture */ +#define KEXEC_ARCH KEXEC_ARCH_IA_64 + +#define MAX_NOTE_BYTES 1024 + +#define pte_bits 3 +#define vmlpt_bits (impl_va_bits - PAGE_SHIFT + pte_bits) +#define POW2(n) (1ULL << (n)) + +DECLARE_PER_CPU(u64, ia64_mca_pal_base); + +const extern unsigned int relocate_new_kernel_size; +volatile extern long kexec_rendez; +extern void relocate_new_kernel(unsigned long, unsigned long,=20 + struct ia64_boot_param *, unsigned long); +extern void kexec_fake_sal_rendez(void *start, unsigned long wake_up, + unsigned long pal_base); + +static inline void +crash_setup_regs(struct pt_regs *newregs, struct pt_regs *oldregs) +{ +} +#endif /* _ASM_IA64_KEXEC_H */ diff -urNp linux-2.6.16/include/asm-ia64/machvec_hpzx1.h linux-2.6.16-kexec= /include/asm-ia64/machvec_hpzx1.h --- linux-2.6.16/include/asm-ia64/machvec_hpzx1.h 2006-03-19 22:53:29.00000= 0000 -0700 +++ linux-2.6.16-kexec/include/asm-ia64/machvec_hpzx1.h 2006-03-27 15:58:38= .000000000 -0700 @@ -34,4 +34,6 @@ extern ia64_mv_dma_mapping_error sba_dma #define platform_dma_supported sba_dma_supported #define platform_dma_mapping_error sba_dma_mapping_error =20 +extern void ioc_iova_disable(void); + #endif /* _ASM_IA64_MACHVEC_HPZX1_h */ diff -urNp linux-2.6.16/include/asm-ia64/smp.h linux-2.6.16-kexec/include/a= sm-ia64/smp.h --- linux-2.6.16/include/asm-ia64/smp.h 2006-03-19 22:53:29.000000000 -0700 +++ linux-2.6.16-kexec/include/asm-ia64/smp.h 2006-03-27 15:52:51.000000000= -0700 @@ -129,6 +129,9 @@ extern void smp_send_reschedule (int cpu extern void lock_ipi_calllock(void); extern void unlock_ipi_calllock(void); extern void identify_siblings (struct cpuinfo_ia64 *); +#ifdef CONFIG_KEXEC +extern void kexec_stop_this_cpu(void *); +#endif =20 #else =20 --- =20 =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D=3D=3D=3D Khalid Aziz Open Source and Linux Organization (970)898-9214 Hewlett-Packard khalid.aziz@hp.com Fort Collins, CO "The Linux kernel is subject to relentless development"=20 - Alessandro Rubini