1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
|
/* smp.h: PPC specific SMP stuff.
*
* Taken from asm-sparc/smp.h
*/
#ifndef _PPC_SMP_H
#define _PPC_SMP_H
#include <linux/kernel.h> /* for panic */
#include <linux/tasks.h> /* for NR_CPUS */
#ifdef __SMP__
#ifndef __ASSEMBLY__
extern int first_cpu_booted;
extern unsigned long smp_proc_in_lock[NR_CPUS];
extern void smp_message_pass(int target, int msg, unsigned long data, int wait);
extern void smp_store_cpu_info(int id);
#define NO_PROC_ID 0xFF /* No processor magic marker */
#define PROC_CHANGE_PENALTY 2000
/* 1 to 1 mapping on PPC -- Cort */
#define cpu_logical_map(cpu) (cpu)
extern int cpu_number_map[NR_CPUS];
extern volatile unsigned long cpu_callin_map[NR_CPUS];
#define hard_smp_processor_id() (0)
#define smp_processor_id() (current->processor)
/* per processor PPC parameters we need. */
struct cpuinfo_PPC {
unsigned long loops_per_sec;
unsigned long pvr;
unsigned long *pgd_quick;
unsigned long *pte_quick;
unsigned long pgtable_cache_sz;
};
extern struct cpuinfo_PPC cpu_data[NR_CPUS];
struct klock_info_struct {
unsigned long kernel_flag;
unsigned char akp;
};
extern struct klock_info_struct klock_info;
#define KLOCK_HELD 0xffffffff
#define KLOCK_CLEAR 0x0
#endif /* __ASSEMBLY__ */
#else /* !(__SMP__) */
#endif /* !(__SMP__) */
#endif /* !(_PPC_SMP_H) */
|