diff options
| author | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
|---|---|---|
| committer | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
| commit | ee3e542fec6e69bc9fb668698889a37d93950ddf (patch) | |
| tree | e74ee766a4764769ef1d3d45d266b4dea64101d3 /arch/arm/include/asm/smp_plat.h | |
| parent | fe2a801b50c0bb8039d627e5ae1fec249d10ff39 (diff) | |
| parent | f1d6e17f540af37bb1891480143669ba7636c4cf (diff) | |
Merge remote-tracking branch 'linus/master' into testing
Diffstat (limited to 'arch/arm/include/asm/smp_plat.h')
| -rw-r--r-- | arch/arm/include/asm/smp_plat.h | 22 | 
1 files changed, 22 insertions, 0 deletions
| diff --git a/arch/arm/include/asm/smp_plat.h b/arch/arm/include/asm/smp_plat.h index e7898320273..6462a721ebd 100644 --- a/arch/arm/include/asm/smp_plat.h +++ b/arch/arm/include/asm/smp_plat.h @@ -26,6 +26,9 @@ static inline bool is_smp(void)  }  /* all SMP configurations have the extended CPUID registers */ +#ifndef CONFIG_MMU +#define tlb_ops_need_broadcast()	0 +#else  static inline int tlb_ops_need_broadcast(void)  {  	if (!is_smp()) @@ -33,6 +36,7 @@ static inline int tlb_ops_need_broadcast(void)  	return ((read_cpuid_ext(CPUID_EXT_MMFR3) >> 12) & 0xf) < 2;  } +#endif  #if !defined(CONFIG_SMP) || __LINUX_ARM_ARCH__ >= 7  #define cache_ops_need_broadcast()	0 @@ -66,4 +70,22 @@ static inline int get_logical_index(u32 mpidr)  	return -EINVAL;  } +/* + * NOTE ! Assembly code relies on the following + * structure memory layout in order to carry out load + * multiple from its base address. For more + * information check arch/arm/kernel/sleep.S + */ +struct mpidr_hash { +	u32	mask; /* used by sleep.S */ +	u32	shift_aff[3]; /* used by sleep.S */ +	u32	bits; +}; + +extern struct mpidr_hash mpidr_hash; + +static inline u32 mpidr_hash_size(void) +{ +	return 1 << mpidr_hash.bits; +}  #endif | 
