6d22d85a85
The kexec boot is not successful on some power machines since all CPUs are getting removed from global interrupt queue (GIQ) before kexec boot. Some systems always expect at least one CPU in GIQ. Hence, this patch will make sure that only secondary CPUs are removed from GIQ. Signed-off-by: Haren Myneni <hbabu@us.ibm.com> Signed-off-by: Paul Mackerras <paulus@samba.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
35 lines
924 B
C
35 lines
924 B
C
/*
|
|
* arch/ppc64/kernel/xics.h
|
|
*
|
|
* Copyright 2000 IBM Corporation.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version
|
|
* 2 of the License, or (at your option) any later version.
|
|
*/
|
|
|
|
#ifndef _PPC64_KERNEL_XICS_H
|
|
#define _PPC64_KERNEL_XICS_H
|
|
|
|
#include <linux/cache.h>
|
|
|
|
void xics_init_IRQ(void);
|
|
int xics_get_irq(struct pt_regs *);
|
|
void xics_setup_cpu(void);
|
|
void xics_teardown_cpu(int secondary);
|
|
void xics_cause_IPI(int cpu);
|
|
void xics_request_IPIs(void);
|
|
void xics_migrate_irqs_away(void);
|
|
|
|
/* first argument is ignored for now*/
|
|
void pSeriesLP_cppr_info(int n_cpu, u8 value);
|
|
|
|
struct xics_ipi_struct {
|
|
volatile unsigned long value;
|
|
} ____cacheline_aligned;
|
|
|
|
extern struct xics_ipi_struct xics_ipi_message[NR_CPUS] __cacheline_aligned;
|
|
|
|
#endif /* _PPC64_KERNEL_XICS_H */
|