mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-26 07:35:44 +08:00
23f73a5fb0
Create a dummy irq_host using the generic dummy irq chip for the secondary cpus to use. Create a direct irq mapping for the ipi and register the ipi action handler against it. If for some unlikely reason part of this fails then don't detect the secondary cpus. This removes another instance of NO_IRQ_IGNORE, records the ipi stats for the secondary cpus, and runs the ipi on the interrupt stack. Signed-off-by: Milton Miller <miltonm@bga.com> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
43 lines
1.2 KiB
C
43 lines
1.2 KiB
C
#ifndef __PMAC_H__
|
|
#define __PMAC_H__
|
|
|
|
#include <linux/pci.h>
|
|
#include <linux/irq.h>
|
|
|
|
/*
|
|
* Declaration for the various functions exported by the
|
|
* pmac_* files. Mostly for use by pmac_setup
|
|
*/
|
|
|
|
struct rtc_time;
|
|
|
|
extern int pmac_newworld;
|
|
|
|
extern long pmac_time_init(void);
|
|
extern unsigned long pmac_get_boot_time(void);
|
|
extern void pmac_get_rtc_time(struct rtc_time *);
|
|
extern int pmac_set_rtc_time(struct rtc_time *);
|
|
extern void pmac_read_rtc_time(void);
|
|
extern void pmac_calibrate_decr(void);
|
|
extern void pmac_pci_irq_fixup(struct pci_dev *);
|
|
extern void pmac_pci_init(void);
|
|
|
|
extern void pmac_nvram_update(void);
|
|
extern unsigned char pmac_nvram_read_byte(int addr);
|
|
extern void pmac_nvram_write_byte(int addr, unsigned char val);
|
|
extern int pmac_pci_enable_device_hook(struct pci_dev *dev);
|
|
extern void pmac_pcibios_after_init(void);
|
|
extern int of_show_percpuinfo(struct seq_file *m, int i);
|
|
|
|
extern void pmac_setup_pci_dma(void);
|
|
extern void pmac_check_ht_link(void);
|
|
|
|
extern void pmac_setup_smp(void);
|
|
extern int psurge_secondary_virq;
|
|
extern void low_cpu_die(void) __attribute__((noreturn));
|
|
|
|
extern int pmac_nvram_init(void);
|
|
extern void pmac_pic_init(void);
|
|
|
|
#endif /* __PMAC_H__ */
|