2005-09-08 00:59:48 +04:00
# ifndef _ASM_POWERPC_TOPOLOGY_H
# define _ASM_POWERPC_TOPOLOGY_H
2005-12-17 00:43:46 +03:00
# ifdef __KERNEL__
2005-04-17 02:20:36 +04:00
2006-05-01 23:16:12 +04:00
struct sys_device ;
struct device_node ;
2005-04-17 02:20:36 +04:00
# ifdef CONFIG_NUMA
2005-09-08 00:59:48 +04:00
# include <asm/mmzone.h>
2005-04-17 02:20:36 +04:00
static inline int cpu_to_node ( int cpu )
{
2005-11-11 06:22:35 +03:00
return numa_cpu_lookup_table [ cpu ] ;
2005-04-17 02:20:36 +04:00
}
# define parent_node(node) (node)
static inline cpumask_t node_to_cpumask ( int node )
{
return numa_cpumask_lookup_table [ node ] ;
}
static inline int node_to_first_cpu ( int node )
{
cpumask_t tmp ;
tmp = node_to_cpumask ( node ) ;
return first_cpu ( tmp ) ;
}
2006-05-01 23:16:12 +04:00
int of_node_to_nid ( struct device_node * device ) ;
2006-06-10 14:53:06 +04:00
struct pci_bus ;
2006-11-27 21:19:00 +03:00
# ifdef CONFIG_PCI
2006-06-10 14:53:06 +04:00
extern int pcibus_to_node ( struct pci_bus * bus ) ;
2006-11-27 21:19:00 +03:00
# else
static inline int pcibus_to_node ( struct pci_bus * bus )
{
return - 1 ;
}
# endif
2006-06-10 14:53:06 +04:00
# define pcibus_to_cpumask(bus) (pcibus_to_node(bus) == -1 ? \
CPU_MASK_ALL : \
node_to_cpumask ( pcibus_to_node ( bus ) ) \
)
2005-04-17 02:20:36 +04:00
/* sched_domains SD_NODE_INIT for PPC64 machines */
# define SD_NODE_INIT (struct sched_domain) { \
. span = CPU_MASK_NONE , \
. parent = NULL , \
2006-10-03 12:14:08 +04:00
. child = NULL , \
2005-04-17 02:20:36 +04:00
. groups = NULL , \
. min_interval = 8 , \
. max_interval = 32 , \
. busy_factor = 32 , \
. imbalance_pct = 125 , \
. cache_nice_tries = 1 , \
2005-11-16 15:37:53 +03:00
. busy_idx = 3 , \
2005-11-17 12:34:35 +03:00
. idle_idx = 1 , \
2005-11-16 15:37:53 +03:00
. newidle_idx = 2 , \
. wake_idx = 1 , \
2005-04-17 02:20:36 +04:00
. flags = SD_LOAD_BALANCE \
| SD_BALANCE_EXEC \
| SD_BALANCE_NEWIDLE \
| SD_WAKE_IDLE \
2006-12-10 13:20:29 +03:00
| SD_SERIALIZE \
2005-04-17 02:20:36 +04:00
| SD_WAKE_BALANCE , \
. last_balance = jiffies , \
. balance_interval = 1 , \
. nr_balance_failed = 0 , \
}
2005-12-12 22:56:47 +03:00
extern void __init dump_numa_cpu_topology ( void ) ;
2006-05-01 23:16:12 +04:00
extern int sysfs_add_device_to_node ( struct sys_device * dev , int nid ) ;
extern void sysfs_remove_device_from_node ( struct sys_device * dev , int nid ) ;
2005-08-02 08:11:46 +04:00
# else
2005-04-17 02:20:36 +04:00
2006-05-01 23:16:12 +04:00
static inline int of_node_to_nid ( struct device_node * device )
{
return 0 ;
}
2005-12-12 22:56:47 +03:00
static inline void dump_numa_cpu_topology ( void ) { }
2006-05-01 23:16:12 +04:00
static inline int sysfs_add_device_to_node ( struct sys_device * dev , int nid )
{
return 0 ;
}
static inline void sysfs_remove_device_from_node ( struct sys_device * dev ,
int nid )
{
}
2008-03-31 19:41:55 +04:00
# endif /* CONFIG_NUMA */
2006-05-01 23:16:12 +04:00
2005-04-17 02:20:36 +04:00
# include <asm-generic/topology.h>
2006-06-27 13:54:42 +04:00
# ifdef CONFIG_SMP
# include <asm/cputable.h>
2006-11-13 06:51:46 +03:00
# define smt_capable() (cpu_has_feature(CPU_FTR_SMT))
# ifdef CONFIG_PPC64
# include <asm/smp.h>
2007-10-16 12:24:05 +04:00
# define topology_thread_siblings(cpu) (per_cpu(cpu_sibling_map, cpu))
2008-07-27 09:24:53 +04:00
# define topology_core_siblings(cpu) (per_cpu(cpu_core_map, cpu))
2008-07-27 09:24:54 +04:00
# define topology_core_id(cpu) (cpu_to_core_id(cpu))
2006-11-13 06:51:46 +03:00
# endif
2006-06-27 13:54:42 +04:00
# endif
2005-12-17 00:43:46 +03:00
# endif /* __KERNEL__ */
2005-09-08 00:59:48 +04:00
# endif /* _ASM_POWERPC_TOPOLOGY_H */