2008-10-23 13:26:29 +08:00
|
|
|
#ifndef _ASM_X86_K8_H
|
|
|
|
#define _ASM_X86_K8_H
|
2006-06-26 19:56:40 +08:00
|
|
|
|
|
|
|
#include <linux/pci.h>
|
|
|
|
|
|
|
|
extern struct pci_device_id k8_nb_ids[];
|
2009-10-29 07:09:55 +08:00
|
|
|
struct bootnode;
|
2006-06-26 19:56:40 +08:00
|
|
|
|
|
|
|
extern int early_is_k8_nb(u32 value);
|
|
|
|
extern struct pci_dev **k8_northbridges;
|
|
|
|
extern int num_k8_northbridges;
|
|
|
|
extern int cache_k8_northbridges(void);
|
|
|
|
extern void k8_flush_garts(void);
|
2009-09-26 06:20:00 +08:00
|
|
|
extern int k8_get_nodes(struct bootnode *nodes);
|
|
|
|
extern int k8_numa_init(unsigned long start_pfn, unsigned long end_pfn);
|
|
|
|
extern int k8_scan_nodes(void);
|
2006-06-26 19:56:40 +08:00
|
|
|
|
2009-04-09 21:16:17 +08:00
|
|
|
#ifdef CONFIG_K8_NB
|
2010-04-24 15:56:53 +08:00
|
|
|
extern int num_k8_northbridges;
|
|
|
|
|
2009-04-15 01:34:37 +08:00
|
|
|
static inline struct pci_dev *node_to_k8_nb_misc(int node)
|
|
|
|
{
|
|
|
|
return (node < num_k8_northbridges) ? k8_northbridges[node] : NULL;
|
|
|
|
}
|
2010-04-24 15:56:53 +08:00
|
|
|
|
2009-04-09 21:16:17 +08:00
|
|
|
#else
|
2010-04-24 15:56:53 +08:00
|
|
|
#define num_k8_northbridges 0
|
|
|
|
|
2009-04-15 01:34:37 +08:00
|
|
|
static inline struct pci_dev *node_to_k8_nb_misc(int node)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
2009-04-09 21:16:17 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2008-10-23 13:26:29 +08:00
|
|
|
#endif /* _ASM_X86_K8_H */
|