diff options
Diffstat (limited to 'arch/arm/include')
| -rw-r--r-- | arch/arm/include/asm/Kbuild | 2 | ||||
| -rw-r--r-- | arch/arm/include/asm/cacheflush.h | 1 | ||||
| -rw-r--r-- | arch/arm/include/asm/checksum.h | 14 | ||||
| -rw-r--r-- | arch/arm/include/asm/clkdev.h | 31 | ||||
| -rw-r--r-- | arch/arm/include/asm/div64.h | 14 | ||||
| -rw-r--r-- | arch/arm/include/asm/exception.h | 2 | ||||
| -rw-r--r-- | arch/arm/include/asm/kvm_asm.h | 43 | ||||
| -rw-r--r-- | arch/arm/include/asm/kvm_emulate.h | 20 | ||||
| -rw-r--r-- | arch/arm/include/asm/kvm_host.h | 80 | ||||
| -rw-r--r-- | arch/arm/include/asm/kvm_hyp.h | 139 | ||||
| -rw-r--r-- | arch/arm/include/asm/kvm_mmu.h | 2 | ||||
| -rw-r--r-- | arch/arm/include/asm/memory.h | 35 | ||||
| -rw-r--r-- | arch/arm/include/asm/mmu_context.h | 14 | ||||
| -rw-r--r-- | arch/arm/include/asm/page-nommu.h | 3 | ||||
| -rw-r--r-- | arch/arm/include/asm/pci.h | 4 | ||||
| -rw-r--r-- | arch/arm/include/asm/sections.h | 8 | ||||
| -rw-r--r-- | arch/arm/include/asm/sparsemem.h | 7 | ||||
| -rw-r--r-- | arch/arm/include/asm/virt.h | 9 | ||||
| -rw-r--r-- | arch/arm/include/asm/xen/hypercall.h | 2 | ||||
| -rw-r--r-- | arch/arm/include/debug/at91.S | 4 | ||||
| -rw-r--r-- | arch/arm/include/debug/imx.S | 3 | ||||
| -rw-r--r-- | arch/arm/include/debug/palmchip.S | 11 | ||||
| -rw-r--r-- | arch/arm/include/debug/zynq.S | 4 | 
23 files changed, 312 insertions, 140 deletions
| diff --git a/arch/arm/include/asm/Kbuild b/arch/arm/include/asm/Kbuild index 16da6380eb85..55e0e3ea9cb6 100644 --- a/arch/arm/include/asm/Kbuild +++ b/arch/arm/include/asm/Kbuild @@ -1,6 +1,7 @@  generic-y += bitsperlong.h +generic-y += clkdev.h  generic-y += cputime.h  generic-y += current.h  generic-y += early_ioremap.h @@ -23,7 +24,6 @@ generic-y += preempt.h  generic-y += resource.h  generic-y += rwsem.h  generic-y += seccomp.h -generic-y += sections.h  generic-y += segment.h  generic-y += sembuf.h  generic-y += serial.h diff --git a/arch/arm/include/asm/cacheflush.h b/arch/arm/include/asm/cacheflush.h index d5525bfc7e3e..9156fc303afd 100644 --- a/arch/arm/include/asm/cacheflush.h +++ b/arch/arm/include/asm/cacheflush.h @@ -491,7 +491,6 @@ static inline int set_memory_nx(unsigned long addr, int numpages) { return 0; }  #endif  #ifdef CONFIG_DEBUG_RODATA -void mark_rodata_ro(void);  void set_kernel_text_rw(void);  void set_kernel_text_ro(void);  #else diff --git a/arch/arm/include/asm/checksum.h b/arch/arm/include/asm/checksum.h index 523315115478..524692f4acab 100644 --- a/arch/arm/include/asm/checksum.h +++ b/arch/arm/include/asm/checksum.h @@ -84,10 +84,10 @@ ip_fast_csum(const void *iph, unsigned int ihl)  }  static inline __wsum -csum_tcpudp_nofold(__be32 saddr, __be32 daddr, unsigned short len, -		   unsigned short proto, __wsum sum) +csum_tcpudp_nofold(__be32 saddr, __be32 daddr, __u32 len, +		   __u8 proto, __wsum sum)  { -	u32 lenprot = len | proto << 16; +	u32 lenprot = len + proto;  	if (__builtin_constant_p(sum) && sum == 0) {  		__asm__(  		"adds	%0, %1, %2	@ csum_tcpudp_nofold0	\n\t" @@ -121,8 +121,8 @@ csum_tcpudp_nofold(__be32 saddr, __be32 daddr, unsigned short len,   * returns a 16-bit checksum, already complemented   */  static inline __sum16 -csum_tcpudp_magic(__be32 saddr, __be32 daddr, unsigned short len, -		  unsigned short proto, __wsum sum) +csum_tcpudp_magic(__be32 saddr, __be32 daddr, __u32 len, +		  __u8 proto, __wsum sum)  {  	return csum_fold(csum_tcpudp_nofold(saddr, daddr, len, proto, sum));  } @@ -144,8 +144,8 @@ __csum_ipv6_magic(const struct in6_addr *saddr, const struct in6_addr *daddr, __  		__be32 proto, __wsum sum);  static inline __sum16 -csum_ipv6_magic(const struct in6_addr *saddr, const struct in6_addr *daddr, __u32 len, -		unsigned short proto, __wsum sum) +csum_ipv6_magic(const struct in6_addr *saddr, const struct in6_addr *daddr, +		__u32 len, __u8 proto, __wsum sum)  {  	return csum_fold(__csum_ipv6_magic(saddr, daddr, htonl(len),  					   htonl(proto), sum)); diff --git a/arch/arm/include/asm/clkdev.h b/arch/arm/include/asm/clkdev.h deleted file mode 100644 index 4e8a4b27d7c7..000000000000 --- a/arch/arm/include/asm/clkdev.h +++ /dev/null @@ -1,31 +0,0 @@ -/* - *  arch/arm/include/asm/clkdev.h - * - *  Copyright (C) 2008 Russell King. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License version 2 as - * published by the Free Software Foundation. - * - * Helper for the clk API to assist looking up a struct clk. - */ -#ifndef __ASM_CLKDEV_H -#define __ASM_CLKDEV_H - -#include <linux/slab.h> - -#ifndef CONFIG_COMMON_CLK -#ifdef CONFIG_HAVE_MACH_CLKDEV -#include <mach/clkdev.h> -#else -#define __clk_get(clk)	({ 1; }) -#define __clk_put(clk)	do { } while (0) -#endif -#endif - -static inline struct clk_lookup_alloc *__clkdev_alloc(size_t size) -{ -	return kzalloc(size, GFP_KERNEL); -} - -#endif diff --git a/arch/arm/include/asm/div64.h b/arch/arm/include/asm/div64.h index e1f07764b0d6..7d919a9b32e5 100644 --- a/arch/arm/include/asm/div64.h +++ b/arch/arm/include/asm/div64.h @@ -74,7 +74,7 @@ static inline uint32_t __div64_32(uint64_t *n, uint32_t base)  static inline uint64_t __arch_xprod_64(uint64_t m, uint64_t n, bool bias)  {  	unsigned long long res; -	unsigned int tmp = 0; +	register unsigned int tmp asm("ip") = 0;  	if (!bias) {  		asm (	"umull	%Q0, %R0, %Q1, %Q2\n\t" @@ -90,12 +90,12 @@ static inline uint64_t __arch_xprod_64(uint64_t m, uint64_t n, bool bias)  			: "r" (m), "r" (n)  			: "cc");  	} else { -		asm (	"umull	%Q0, %R0, %Q1, %Q2\n\t" -			"cmn	%Q0, %Q1\n\t" -			"adcs	%R0, %R0, %R1\n\t" -			"adc	%Q0, %3, #0" -			: "=&r" (res) -			: "r" (m), "r" (n), "r" (tmp) +		asm (	"umull	%Q0, %R0, %Q2, %Q3\n\t" +			"cmn	%Q0, %Q2\n\t" +			"adcs	%R0, %R0, %R2\n\t" +			"adc	%Q0, %1, #0" +			: "=&r" (res), "+&r" (tmp) +			: "r" (m), "r" (n)  			: "cc");  	} diff --git a/arch/arm/include/asm/exception.h b/arch/arm/include/asm/exception.h index 5abaf5bbd985..bf1991263d2d 100644 --- a/arch/arm/include/asm/exception.h +++ b/arch/arm/include/asm/exception.h @@ -7,7 +7,7 @@  #ifndef __ASM_ARM_EXCEPTION_H  #define __ASM_ARM_EXCEPTION_H -#include <linux/ftrace.h> +#include <linux/interrupt.h>  #define __exception	__attribute__((section(".exception.text")))  #ifdef CONFIG_FUNCTION_GRAPH_TRACER diff --git a/arch/arm/include/asm/kvm_asm.h b/arch/arm/include/asm/kvm_asm.h index 194c91b610ff..3d5a5cd071bd 100644 --- a/arch/arm/include/asm/kvm_asm.h +++ b/arch/arm/include/asm/kvm_asm.h @@ -19,38 +19,7 @@  #ifndef __ARM_KVM_ASM_H__  #define __ARM_KVM_ASM_H__ -/* 0 is reserved as an invalid value. */ -#define c0_MPIDR	1	/* MultiProcessor ID Register */ -#define c0_CSSELR	2	/* Cache Size Selection Register */ -#define c1_SCTLR	3	/* System Control Register */ -#define c1_ACTLR	4	/* Auxiliary Control Register */ -#define c1_CPACR	5	/* Coprocessor Access Control */ -#define c2_TTBR0	6	/* Translation Table Base Register 0 */ -#define c2_TTBR0_high	7	/* TTBR0 top 32 bits */ -#define c2_TTBR1	8	/* Translation Table Base Register 1 */ -#define c2_TTBR1_high	9	/* TTBR1 top 32 bits */ -#define c2_TTBCR	10	/* Translation Table Base Control R. */ -#define c3_DACR		11	/* Domain Access Control Register */ -#define c5_DFSR		12	/* Data Fault Status Register */ -#define c5_IFSR		13	/* Instruction Fault Status Register */ -#define c5_ADFSR	14	/* Auxilary Data Fault Status R */ -#define c5_AIFSR	15	/* Auxilary Instrunction Fault Status R */ -#define c6_DFAR		16	/* Data Fault Address Register */ -#define c6_IFAR		17	/* Instruction Fault Address Register */ -#define c7_PAR		18	/* Physical Address Register */ -#define c7_PAR_high	19	/* PAR top 32 bits */ -#define c9_L2CTLR	20	/* Cortex A15/A7 L2 Control Register */ -#define c10_PRRR	21	/* Primary Region Remap Register */ -#define c10_NMRR	22	/* Normal Memory Remap Register */ -#define c12_VBAR	23	/* Vector Base Address Register */ -#define c13_CID		24	/* Context ID Register */ -#define c13_TID_URW	25	/* Thread ID, User R/W */ -#define c13_TID_URO	26	/* Thread ID, User R/O */ -#define c13_TID_PRIV	27	/* Thread ID, Privileged */ -#define c14_CNTKCTL	28	/* Timer Control Register (PL1) */ -#define c10_AMAIR0	29	/* Auxilary Memory Attribute Indirection Reg0 */ -#define c10_AMAIR1	30	/* Auxilary Memory Attribute Indirection Reg1 */ -#define NR_CP15_REGS	31	/* Number of regs (incl. invalid) */ +#include <asm/virt.h>  #define ARM_EXCEPTION_RESET	  0  #define ARM_EXCEPTION_UNDEFINED   1 @@ -79,6 +48,8 @@  #define rr_lo_hi(a1, a2) a1, a2  #endif +#define kvm_ksym_ref(kva)	(kva) +  #ifndef __ASSEMBLY__  struct kvm;  struct kvm_vcpu; @@ -86,19 +57,15 @@ struct kvm_vcpu;  extern char __kvm_hyp_init[];  extern char __kvm_hyp_init_end[]; -extern char __kvm_hyp_exit[]; -extern char __kvm_hyp_exit_end[]; -  extern char __kvm_hyp_vector[]; -extern char __kvm_hyp_code_start[]; -extern char __kvm_hyp_code_end[]; -  extern void __kvm_flush_vm_context(void);  extern void __kvm_tlb_flush_vmid_ipa(struct kvm *kvm, phys_addr_t ipa);  extern void __kvm_tlb_flush_vmid(struct kvm *kvm);  extern int __kvm_vcpu_run(struct kvm_vcpu *vcpu); + +extern void __init_stage2_translation(void);  #endif  #endif /* __ARM_KVM_ASM_H__ */ diff --git a/arch/arm/include/asm/kvm_emulate.h b/arch/arm/include/asm/kvm_emulate.h index 3095df091ff8..ee5328fc4b06 100644 --- a/arch/arm/include/asm/kvm_emulate.h +++ b/arch/arm/include/asm/kvm_emulate.h @@ -68,12 +68,12 @@ static inline bool vcpu_mode_is_32bit(struct kvm_vcpu *vcpu)  static inline unsigned long *vcpu_pc(struct kvm_vcpu *vcpu)  { -	return &vcpu->arch.regs.usr_regs.ARM_pc; +	return &vcpu->arch.ctxt.gp_regs.usr_regs.ARM_pc;  }  static inline unsigned long *vcpu_cpsr(struct kvm_vcpu *vcpu)  { -	return &vcpu->arch.regs.usr_regs.ARM_cpsr; +	return &vcpu->arch.ctxt.gp_regs.usr_regs.ARM_cpsr;  }  static inline void vcpu_set_thumb(struct kvm_vcpu *vcpu) @@ -83,13 +83,13 @@ static inline void vcpu_set_thumb(struct kvm_vcpu *vcpu)  static inline bool mode_has_spsr(struct kvm_vcpu *vcpu)  { -	unsigned long cpsr_mode = vcpu->arch.regs.usr_regs.ARM_cpsr & MODE_MASK; +	unsigned long cpsr_mode = vcpu->arch.ctxt.gp_regs.usr_regs.ARM_cpsr & MODE_MASK;  	return (cpsr_mode > USR_MODE && cpsr_mode < SYSTEM_MODE);  }  static inline bool vcpu_mode_priv(struct kvm_vcpu *vcpu)  { -	unsigned long cpsr_mode = vcpu->arch.regs.usr_regs.ARM_cpsr & MODE_MASK; +	unsigned long cpsr_mode = vcpu->arch.ctxt.gp_regs.usr_regs.ARM_cpsr & MODE_MASK;  	return cpsr_mode > USR_MODE;;  } @@ -108,11 +108,6 @@ static inline phys_addr_t kvm_vcpu_get_fault_ipa(struct kvm_vcpu *vcpu)  	return ((phys_addr_t)vcpu->arch.fault.hpfar & HPFAR_MASK) << 8;  } -static inline unsigned long kvm_vcpu_get_hyp_pc(struct kvm_vcpu *vcpu) -{ -	return vcpu->arch.fault.hyp_pc; -} -  static inline bool kvm_vcpu_dabt_isvalid(struct kvm_vcpu *vcpu)  {  	return kvm_vcpu_get_hsr(vcpu) & HSR_ISV; @@ -143,6 +138,11 @@ static inline bool kvm_vcpu_dabt_iss1tw(struct kvm_vcpu *vcpu)  	return kvm_vcpu_get_hsr(vcpu) & HSR_DABT_S1PTW;  } +static inline bool kvm_vcpu_dabt_is_cm(struct kvm_vcpu *vcpu) +{ +	return !!(kvm_vcpu_get_hsr(vcpu) & HSR_DABT_CM); +} +  /* Get Access Size from a data abort */  static inline int kvm_vcpu_dabt_get_as(struct kvm_vcpu *vcpu)  { @@ -192,7 +192,7 @@ static inline u32 kvm_vcpu_hvc_get_imm(struct kvm_vcpu *vcpu)  static inline unsigned long kvm_vcpu_get_mpidr_aff(struct kvm_vcpu *vcpu)  { -	return vcpu->arch.cp15[c0_MPIDR] & MPIDR_HWID_BITMASK; +	return vcpu_cp15(vcpu, c0_MPIDR) & MPIDR_HWID_BITMASK;  }  static inline void kvm_vcpu_set_be(struct kvm_vcpu *vcpu) diff --git a/arch/arm/include/asm/kvm_host.h b/arch/arm/include/asm/kvm_host.h index f9f27792d8ed..385070180c25 100644 --- a/arch/arm/include/asm/kvm_host.h +++ b/arch/arm/include/asm/kvm_host.h @@ -85,20 +85,61 @@ struct kvm_vcpu_fault_info {  	u32 hsr;		/* Hyp Syndrome Register */  	u32 hxfar;		/* Hyp Data/Inst. Fault Address Register */  	u32 hpfar;		/* Hyp IPA Fault Address Register */ -	u32 hyp_pc;		/* PC when exception was taken from Hyp mode */  }; -typedef struct vfp_hard_struct kvm_cpu_context_t; +/* + * 0 is reserved as an invalid value. + * Order should be kept in sync with the save/restore code. + */ +enum vcpu_sysreg { +	__INVALID_SYSREG__, +	c0_MPIDR,		/* MultiProcessor ID Register */ +	c0_CSSELR,		/* Cache Size Selection Register */ +	c1_SCTLR,		/* System Control Register */ +	c1_ACTLR,		/* Auxiliary Control Register */ +	c1_CPACR,		/* Coprocessor Access Control */ +	c2_TTBR0,		/* Translation Table Base Register 0 */ +	c2_TTBR0_high,		/* TTBR0 top 32 bits */ +	c2_TTBR1,		/* Translation Table Base Register 1 */ +	c2_TTBR1_high,		/* TTBR1 top 32 bits */ +	c2_TTBCR,		/* Translation Table Base Control R. */ +	c3_DACR,		/* Domain Access Control Register */ +	c5_DFSR,		/* Data Fault Status Register */ +	c5_IFSR,		/* Instruction Fault Status Register */ +	c5_ADFSR,		/* Auxilary Data Fault Status R */ +	c5_AIFSR,		/* Auxilary Instrunction Fault Status R */ +	c6_DFAR,		/* Data Fault Address Register */ +	c6_IFAR,		/* Instruction Fault Address Register */ +	c7_PAR,			/* Physical Address Register */ +	c7_PAR_high,		/* PAR top 32 bits */ +	c9_L2CTLR,		/* Cortex A15/A7 L2 Control Register */ +	c10_PRRR,		/* Primary Region Remap Register */ +	c10_NMRR,		/* Normal Memory Remap Register */ +	c12_VBAR,		/* Vector Base Address Register */ +	c13_CID,		/* Context ID Register */ +	c13_TID_URW,		/* Thread ID, User R/W */ +	c13_TID_URO,		/* Thread ID, User R/O */ +	c13_TID_PRIV,		/* Thread ID, Privileged */ +	c14_CNTKCTL,		/* Timer Control Register (PL1) */ +	c10_AMAIR0,		/* Auxilary Memory Attribute Indirection Reg0 */ +	c10_AMAIR1,		/* Auxilary Memory Attribute Indirection Reg1 */ +	NR_CP15_REGS		/* Number of regs (incl. invalid) */ +}; + +struct kvm_cpu_context { +	struct kvm_regs	gp_regs; +	struct vfp_hard_struct vfp; +	u32 cp15[NR_CP15_REGS]; +}; + +typedef struct kvm_cpu_context kvm_cpu_context_t;  struct kvm_vcpu_arch { -	struct kvm_regs regs; +	struct kvm_cpu_context ctxt;  	int target; /* Processor target */  	DECLARE_BITMAP(features, KVM_VCPU_MAX_FEATURES); -	/* System control coprocessor (cp15) */ -	u32 cp15[NR_CP15_REGS]; -  	/* The CPU type we expose to the VM */  	u32 midr; @@ -111,9 +152,6 @@ struct kvm_vcpu_arch {  	/* Exception Information */  	struct kvm_vcpu_fault_info fault; -	/* Floating point registers (VFP and Advanced SIMD/NEON) */ -	struct vfp_hard_struct vfp_guest; -  	/* Host FP context */  	kvm_cpu_context_t *host_cpu_context; @@ -158,12 +196,14 @@ struct kvm_vcpu_stat {  	u64 exits;  }; +#define vcpu_cp15(v,r)	(v)->arch.ctxt.cp15[r] +  int kvm_vcpu_preferred_target(struct kvm_vcpu_init *init);  unsigned long kvm_arm_num_regs(struct kvm_vcpu *vcpu);  int kvm_arm_copy_reg_indices(struct kvm_vcpu *vcpu, u64 __user *indices);  int kvm_arm_get_reg(struct kvm_vcpu *vcpu, const struct kvm_one_reg *reg);  int kvm_arm_set_reg(struct kvm_vcpu *vcpu, const struct kvm_one_reg *reg); -u64 kvm_call_hyp(void *hypfn, ...); +unsigned long kvm_call_hyp(void *hypfn, ...);  void force_vm_exit(const cpumask_t *mask);  #define KVM_ARCH_WANT_MMU_NOTIFIER @@ -220,6 +260,11 @@ static inline void __cpu_init_hyp_mode(phys_addr_t boot_pgd_ptr,  	kvm_call_hyp((void*)hyp_stack_ptr, vector_ptr, pgd_ptr);  } +static inline void __cpu_init_stage2(void) +{ +	kvm_call_hyp(__init_stage2_translation); +} +  static inline int kvm_arch_dev_ioctl_check_extension(long ext)  {  	return 0; @@ -242,5 +287,20 @@ static inline void kvm_arm_init_debug(void) {}  static inline void kvm_arm_setup_debug(struct kvm_vcpu *vcpu) {}  static inline void kvm_arm_clear_debug(struct kvm_vcpu *vcpu) {}  static inline void kvm_arm_reset_debug_ptr(struct kvm_vcpu *vcpu) {} +static inline int kvm_arm_vcpu_arch_set_attr(struct kvm_vcpu *vcpu, +					     struct kvm_device_attr *attr) +{ +	return -ENXIO; +} +static inline int kvm_arm_vcpu_arch_get_attr(struct kvm_vcpu *vcpu, +					     struct kvm_device_attr *attr) +{ +	return -ENXIO; +} +static inline int kvm_arm_vcpu_arch_has_attr(struct kvm_vcpu *vcpu, +					     struct kvm_device_attr *attr) +{ +	return -ENXIO; +}  #endif /* __ARM_KVM_HOST_H__ */ diff --git a/arch/arm/include/asm/kvm_hyp.h b/arch/arm/include/asm/kvm_hyp.h new file mode 100644 index 000000000000..f0e860761380 --- /dev/null +++ b/arch/arm/include/asm/kvm_hyp.h @@ -0,0 +1,139 @@ +/* + * Copyright (C) 2015 - ARM Ltd + * Author: Marc Zyngier <marc.zyngier@arm.com> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program.  If not, see <http://www.gnu.org/licenses/>. + */ + +#ifndef __ARM_KVM_HYP_H__ +#define __ARM_KVM_HYP_H__ + +#include <linux/compiler.h> +#include <linux/kvm_host.h> +#include <asm/kvm_mmu.h> +#include <asm/vfp.h> + +#define __hyp_text __section(.hyp.text) notrace + +#define kern_hyp_va(v) (v) +#define hyp_kern_va(v) (v) + +#define __ACCESS_CP15(CRn, Op1, CRm, Op2)	\ +	"mrc", "mcr", __stringify(p15, Op1, %0, CRn, CRm, Op2), u32 +#define __ACCESS_CP15_64(Op1, CRm)		\ +	"mrrc", "mcrr", __stringify(p15, Op1, %Q0, %R0, CRm), u64 +#define __ACCESS_VFP(CRn)			\ +	"mrc", "mcr", __stringify(p10, 7, %0, CRn, cr0, 0), u32 + +#define __write_sysreg(v, r, w, c, t)	asm volatile(w " " c : : "r" ((t)(v))) +#define write_sysreg(v, ...)		__write_sysreg(v, __VA_ARGS__) + +#define __read_sysreg(r, w, c, t) ({				\ +	t __val;						\ +	asm volatile(r " " c : "=r" (__val));			\ +	__val;							\ +}) +#define read_sysreg(...)		__read_sysreg(__VA_ARGS__) + +#define write_special(v, r)					\ +	asm volatile("msr " __stringify(r) ", %0" : : "r" (v)) +#define read_special(r) ({					\ +	u32 __val;						\ +	asm volatile("mrs %0, " __stringify(r) : "=r" (__val));	\ +	__val;							\ +}) + +#define TTBR0		__ACCESS_CP15_64(0, c2) +#define TTBR1		__ACCESS_CP15_64(1, c2) +#define VTTBR		__ACCESS_CP15_64(6, c2) +#define PAR		__ACCESS_CP15_64(0, c7) +#define CNTV_CVAL	__ACCESS_CP15_64(3, c14) +#define CNTVOFF		__ACCESS_CP15_64(4, c14) + +#define MIDR		__ACCESS_CP15(c0, 0, c0, 0) +#define CSSELR		__ACCESS_CP15(c0, 2, c0, 0) +#define VPIDR		__ACCESS_CP15(c0, 4, c0, 0) +#define VMPIDR		__ACCESS_CP15(c0, 4, c0, 5) +#define SCTLR		__ACCESS_CP15(c1, 0, c0, 0) +#define CPACR		__ACCESS_CP15(c1, 0, c0, 2) +#define HCR		__ACCESS_CP15(c1, 4, c1, 0) +#define HDCR		__ACCESS_CP15(c1, 4, c1, 1) +#define HCPTR		__ACCESS_CP15(c1, 4, c1, 2) +#define HSTR		__ACCESS_CP15(c1, 4, c1, 3) +#define TTBCR		__ACCESS_CP15(c2, 0, c0, 2) +#define HTCR		__ACCESS_CP15(c2, 4, c0, 2) +#define VTCR		__ACCESS_CP15(c2, 4, c1, 2) +#define DACR		__ACCESS_CP15(c3, 0, c0, 0) +#define DFSR		__ACCESS_CP15(c5, 0, c0, 0) +#define IFSR		__ACCESS_CP15(c5, 0, c0, 1) +#define ADFSR		__ACCESS_CP15(c5, 0, c1, 0) +#define AIFSR		__ACCESS_CP15(c5, 0, c1, 1) +#define HSR		__ACCESS_CP15(c5, 4, c2, 0) +#define DFAR		__ACCESS_CP15(c6, 0, c0, 0) +#define IFAR		__ACCESS_CP15(c6, 0, c0, 2) +#define HDFAR		__ACCESS_CP15(c6, 4, c0, 0) +#define HIFAR		__ACCESS_CP15(c6, 4, c0, 2) +#define HPFAR		__ACCESS_CP15(c6, 4, c0, 4) +#define ICIALLUIS	__ACCESS_CP15(c7, 0, c1, 0) +#define ATS1CPR		__ACCESS_CP15(c7, 0, c8, 0) +#define TLBIALLIS	__ACCESS_CP15(c8, 0, c3, 0) +#define TLBIALLNSNHIS	__ACCESS_CP15(c8, 4, c3, 4) +#define PRRR		__ACCESS_CP15(c10, 0, c2, 0) +#define NMRR		__ACCESS_CP15(c10, 0, c2, 1) +#define AMAIR0		__ACCESS_CP15(c10, 0, c3, 0) +#define AMAIR1		__ACCESS_CP15(c10, 0, c3, 1) +#define VBAR		__ACCESS_CP15(c12, 0, c0, 0) +#define CID		__ACCESS_CP15(c13, 0, c0, 1) +#define TID_URW		__ACCESS_CP15(c13, 0, c0, 2) +#define TID_URO		__ACCESS_CP15(c13, 0, c0, 3) +#define TID_PRIV	__ACCESS_CP15(c13, 0, c0, 4) +#define HTPIDR		__ACCESS_CP15(c13, 4, c0, 2) +#define CNTKCTL		__ACCESS_CP15(c14, 0, c1, 0) +#define CNTV_CTL	__ACCESS_CP15(c14, 0, c3, 1) +#define CNTHCTL		__ACCESS_CP15(c14, 4, c1, 0) + +#define VFP_FPEXC	__ACCESS_VFP(FPEXC) + +/* AArch64 compatibility macros, only for the timer so far */ +#define read_sysreg_el0(r)		read_sysreg(r##_el0) +#define write_sysreg_el0(v, r)		write_sysreg(v, r##_el0) + +#define cntv_ctl_el0			CNTV_CTL +#define cntv_cval_el0			CNTV_CVAL +#define cntvoff_el2			CNTVOFF +#define cnthctl_el2			CNTHCTL + +void __timer_save_state(struct kvm_vcpu *vcpu); +void __timer_restore_state(struct kvm_vcpu *vcpu); + +void __vgic_v2_save_state(struct kvm_vcpu *vcpu); +void __vgic_v2_restore_state(struct kvm_vcpu *vcpu); + +void __sysreg_save_state(struct kvm_cpu_context *ctxt); +void __sysreg_restore_state(struct kvm_cpu_context *ctxt); + +void asmlinkage __vfp_save_state(struct vfp_hard_struct *vfp); +void asmlinkage __vfp_restore_state(struct vfp_hard_struct *vfp); +static inline bool __vfp_enabled(void) +{ +	return !(read_sysreg(HCPTR) & (HCPTR_TCP(11) | HCPTR_TCP(10))); +} + +void __hyp_text __banked_save_state(struct kvm_cpu_context *ctxt); +void __hyp_text __banked_restore_state(struct kvm_cpu_context *ctxt); + +int asmlinkage __guest_enter(struct kvm_vcpu *vcpu, +			     struct kvm_cpu_context *host); +int asmlinkage __hyp_do_panic(const char *, int, u32); + +#endif /* __ARM_KVM_HYP_H__ */ diff --git a/arch/arm/include/asm/kvm_mmu.h b/arch/arm/include/asm/kvm_mmu.h index a520b7987a29..da44be9db4fa 100644 --- a/arch/arm/include/asm/kvm_mmu.h +++ b/arch/arm/include/asm/kvm_mmu.h @@ -179,7 +179,7 @@ struct kvm;  static inline bool vcpu_has_cache_enabled(struct kvm_vcpu *vcpu)  { -	return (vcpu->arch.cp15[c1_SCTLR] & 0b101) == 0b101; +	return (vcpu_cp15(vcpu, c1_SCTLR) & 0b101) == 0b101;  }  static inline void __coherent_cache_guest_page(struct kvm_vcpu *vcpu, diff --git a/arch/arm/include/asm/memory.h b/arch/arm/include/asm/memory.h index c79b57bf71c4..9427fd632552 100644 --- a/arch/arm/include/asm/memory.h +++ b/arch/arm/include/asm/memory.h @@ -134,6 +134,21 @@   */  #define PLAT_PHYS_OFFSET	UL(CONFIG_PHYS_OFFSET) +#ifdef CONFIG_XIP_KERNEL +/* + * When referencing data in RAM from the XIP region in a relative manner + * with the MMU off, we need the relative offset between the two physical + * addresses.  The macro below achieves this, which is: + *    __pa(v_data) - __xip_pa(v_text) + */ +#define PHYS_RELATIVE(v_data, v_text) \ +	(((v_data) - PAGE_OFFSET + PLAT_PHYS_OFFSET) - \ +	 ((v_text) - XIP_VIRT_ADDR(CONFIG_XIP_PHYS_ADDR) + \ +          CONFIG_XIP_PHYS_ADDR)) +#else +#define PHYS_RELATIVE(v_data, v_text) ((v_data) - (v_text)) +#endif +  #ifndef __ASSEMBLY__  /* @@ -273,14 +288,14 @@ static inline void *phys_to_virt(phys_addr_t x)  #define __va(x)			((void *)__phys_to_virt((phys_addr_t)(x)))  #define pfn_to_kaddr(pfn)	__va((phys_addr_t)(pfn) << PAGE_SHIFT) -extern phys_addr_t (*arch_virt_to_idmap)(unsigned long x); +extern unsigned long (*arch_virt_to_idmap)(unsigned long x);  /*   * These are for systems that have a hardware interconnect supported alias of   * physical memory for idmap purposes.  Most cases should leave these - * untouched. + * untouched.  Note: this can only return addresses less than 4GiB.   */ -static inline phys_addr_t __virt_to_idmap(unsigned long x) +static inline unsigned long __virt_to_idmap(unsigned long x)  {  	if (IS_ENABLED(CONFIG_MMU) && arch_virt_to_idmap)  		return arch_virt_to_idmap(x); @@ -303,20 +318,6 @@ static inline phys_addr_t __virt_to_idmap(unsigned long x)  #define __bus_to_pfn(x)	__phys_to_pfn(x)  #endif -#ifdef CONFIG_VIRT_TO_BUS -#define virt_to_bus virt_to_bus -static inline __deprecated unsigned long virt_to_bus(void *x) -{ -	return __virt_to_bus((unsigned long)x); -} - -#define bus_to_virt bus_to_virt -static inline __deprecated void *bus_to_virt(unsigned long x) -{ -	return (void *)__bus_to_virt(x); -} -#endif -  /*   * Conversion between a struct page and a physical address.   * diff --git a/arch/arm/include/asm/mmu_context.h b/arch/arm/include/asm/mmu_context.h index 432ce8176498..fa5b42d44985 100644 --- a/arch/arm/include/asm/mmu_context.h +++ b/arch/arm/include/asm/mmu_context.h @@ -26,7 +26,12 @@ void __check_vmalloc_seq(struct mm_struct *mm);  #ifdef CONFIG_CPU_HAS_ASID  void check_and_switch_context(struct mm_struct *mm, struct task_struct *tsk); -#define init_new_context(tsk,mm)	({ atomic64_set(&(mm)->context.id, 0); 0; }) +static inline int +init_new_context(struct task_struct *tsk, struct mm_struct *mm) +{ +	atomic64_set(&mm->context.id, 0); +	return 0; +}  #ifdef CONFIG_ARM_ERRATA_798181  void a15_erratum_get_cpumask(int this_cpu, struct mm_struct *mm, @@ -85,7 +90,12 @@ static inline void finish_arch_post_lock_switch(void)  #endif	/* CONFIG_MMU */ -#define init_new_context(tsk,mm)	0 +static inline int +init_new_context(struct task_struct *tsk, struct mm_struct *mm) +{ +	return 0; +} +  #endif	/* CONFIG_CPU_HAS_ASID */ diff --git a/arch/arm/include/asm/page-nommu.h b/arch/arm/include/asm/page-nommu.h index d1b162a18dcb..503f488053de 100644 --- a/arch/arm/include/asm/page-nommu.h +++ b/arch/arm/include/asm/page-nommu.h @@ -17,9 +17,6 @@  #define KTHREAD_SIZE PAGE_SIZE  #endif -#define get_user_page(vaddr)		__get_free_page(GFP_KERNEL) -#define free_user_page(page, addr)	free_page(addr) -  #define clear_page(page)	memset((page), 0, PAGE_SIZE)  #define copy_page(to,from)	memcpy((to), (from), PAGE_SIZE) diff --git a/arch/arm/include/asm/pci.h b/arch/arm/include/asm/pci.h index a5635444ca41..057d381f4e57 100644 --- a/arch/arm/include/asm/pci.h +++ b/arch/arm/include/asm/pci.h @@ -2,9 +2,6 @@  #define ASMARM_PCI_H  #ifdef __KERNEL__ -#include <asm-generic/pci-dma-compat.h> -#include <asm-generic/pci-bridge.h> -  #include <asm/mach/pci.h> /* for pci_sys_data */  extern unsigned long pcibios_min_io; @@ -41,5 +38,4 @@ static inline int pci_get_legacy_ide_irq(struct pci_dev *dev, int channel)  }  #endif /* __KERNEL__ */ -   #endif diff --git a/arch/arm/include/asm/sections.h b/arch/arm/include/asm/sections.h new file mode 100644 index 000000000000..803bbf2b20b8 --- /dev/null +++ b/arch/arm/include/asm/sections.h @@ -0,0 +1,8 @@ +#ifndef _ASM_ARM_SECTIONS_H +#define _ASM_ARM_SECTIONS_H + +#include <asm-generic/sections.h> + +extern char _exiprom[]; + +#endif	/* _ASM_ARM_SECTIONS_H */ diff --git a/arch/arm/include/asm/sparsemem.h b/arch/arm/include/asm/sparsemem.h index 00098615c6f0..73e5e8513751 100644 --- a/arch/arm/include/asm/sparsemem.h +++ b/arch/arm/include/asm/sparsemem.h @@ -15,10 +15,11 @@   * Eg, if you have 2 banks of up to 64MB at 0x80000000, 0x84000000,   * then MAX_PHYSMEM_BITS is 32, SECTION_SIZE_BITS is 26.   * - * Define these in your mach/memory.h. + * These can be overridden in your mach/memory.h.   */ -#if !defined(SECTION_SIZE_BITS) || !defined(MAX_PHYSMEM_BITS) -#error Sparsemem is not supported on this platform +#if !defined(MAX_PHYSMEM_BITS) || !defined(SECTION_SIZE_BITS) +#define MAX_PHYSMEM_BITS	36 +#define SECTION_SIZE_BITS	28  #endif  #endif diff --git a/arch/arm/include/asm/virt.h b/arch/arm/include/asm/virt.h index 4371f45c5784..d4ceaf5f299b 100644 --- a/arch/arm/include/asm/virt.h +++ b/arch/arm/include/asm/virt.h @@ -74,6 +74,15 @@ static inline bool is_hyp_mode_mismatched(void)  {  	return !!(__boot_cpu_mode & BOOT_CPU_MODE_MISMATCH);  } + +static inline bool is_kernel_in_hyp_mode(void) +{ +	return false; +} + +/* The section containing the hypervisor text */ +extern char __hyp_text_start[]; +extern char __hyp_text_end[];  #endif  #endif /* __ASSEMBLY__ */ diff --git a/arch/arm/include/asm/xen/hypercall.h b/arch/arm/include/asm/xen/hypercall.h index d769972db8cb..b6b962d70db9 100644 --- a/arch/arm/include/asm/xen/hypercall.h +++ b/arch/arm/include/asm/xen/hypercall.h @@ -33,6 +33,8 @@  #ifndef _ASM_ARM_XEN_HYPERCALL_H  #define _ASM_ARM_XEN_HYPERCALL_H +#include <linux/bug.h> +  #include <xen/interface/xen.h>  #include <xen/interface/sched.h>  #include <xen/interface/platform.h> diff --git a/arch/arm/include/debug/at91.S b/arch/arm/include/debug/at91.S index 43243be94cfc..d4ae3b8e2426 100644 --- a/arch/arm/include/debug/at91.S +++ b/arch/arm/include/debug/at91.S @@ -15,7 +15,7 @@  #define AT91_IO_P2V(x) (x)  #endif -#define CONFIG_DEBUG_UART_VIRT AT91_IO_P2V(CONFIG_DEBUG_UART_PHYS) +#define AT91_DEBUG_UART_VIRT AT91_IO_P2V(CONFIG_DEBUG_UART_PHYS)  #define AT91_DBGU_SR		(0x14)	/* Status Register */  #define AT91_DBGU_THR		(0x1c)	/* Transmitter Holding Register */ @@ -24,7 +24,7 @@  	.macro	addruart, rp, rv, tmp  	ldr	\rp, =CONFIG_DEBUG_UART_PHYS		@ System peripherals (phys address) -	ldr	\rv, =CONFIG_DEBUG_UART_VIRT		@ System peripherals (virt address) +	ldr	\rv, =AT91_DEBUG_UART_VIRT		@ System peripherals (virt address)  	.endm  	.macro	senduart,rd,rx diff --git a/arch/arm/include/debug/imx.S b/arch/arm/include/debug/imx.S index 619d8cc1ac12..92c44760d656 100644 --- a/arch/arm/include/debug/imx.S +++ b/arch/arm/include/debug/imx.S @@ -11,6 +11,7 @@   *   */ +#include <asm/assembler.h>  #include "imx-uart.h"  /* @@ -34,6 +35,7 @@  		.endm  		.macro	senduart,rd,rx +		ARM_BE8(rev \rd, \rd)  		str	\rd, [\rx, #0x40]	@ TXDATA  		.endm @@ -42,6 +44,7 @@  		.macro	busyuart,rd,rx  1002:		ldr	\rd, [\rx, #0x98]	@ SR2 +		ARM_BE8(rev \rd, \rd)  		tst	\rd, #1 << 3		@ TXDC  		beq	1002b			@ wait until transmit done  		.endm diff --git a/arch/arm/include/debug/palmchip.S b/arch/arm/include/debug/palmchip.S new file mode 100644 index 000000000000..6824b2d1c38e --- /dev/null +++ b/arch/arm/include/debug/palmchip.S @@ -0,0 +1,11 @@ +#include <linux/serial_reg.h> + +#undef UART_TX +#undef UART_LSR +#undef UART_MSR + +#define UART_TX 1 +#define UART_LSR 7 +#define UART_MSR 8 + +#include <debug/8250.S> diff --git a/arch/arm/include/debug/zynq.S b/arch/arm/include/debug/zynq.S index de86b9247564..060cb5b49bfd 100644 --- a/arch/arm/include/debug/zynq.S +++ b/arch/arm/include/debug/zynq.S @@ -20,9 +20,9 @@  #define UART_SR_TXEMPTY		0x00000008	/* TX FIFO empty */  #define UART0_PHYS		0xE0000000 -#define UART0_VIRT		0xF0000000 +#define UART0_VIRT		0xF0800000  #define UART1_PHYS		0xE0001000 -#define UART1_VIRT		0xF0001000 +#define UART1_VIRT		0xF0801000  #if IS_ENABLED(CONFIG_DEBUG_ZYNQ_UART1)  # define LL_UART_PADDR		UART1_PHYS | 
