vfpmacros.h 1.51 KB
Newer Older
Linus Torvalds's avatar
Linus Torvalds committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
/*
 * linux/include/asm-arm/vfpmacros.h
 *
 * Assembler-only file containing VFP macros and register definitions.
 */
#include "vfp.h"

@ Macros to allow building with old toolkits (with no VFP support)
	.macro	VFPFMRX, rd, sysreg, cond
	MRC\cond	p10, 7, \rd, \sysreg, cr0, 0	@ FMRX	\rd, \sysreg
	.endm

	.macro	VFPFMXR, sysreg, rd, cond
	MCR\cond	p10, 7, \rd, \sysreg, cr0, 0	@ FMXR	\sysreg, \rd
	.endm

	@ read all the working registers back into the VFP
Catalin Marinas's avatar
Catalin Marinas committed
18
	.macro	VFPFLDMIA, base, tmp
19
#if __LINUX_ARM_ARCH__ < 6
Linus Torvalds's avatar
Linus Torvalds committed
20
	LDC	p11, cr0, [\base],#33*4		    @ FLDMIAX \base!, {d0-d15}
21 22
#else
	LDC	p11, cr0, [\base],#32*4		    @ FLDMIAD \base!, {d0-d15}
Catalin Marinas's avatar
Catalin Marinas committed
23 24 25 26 27 28 29
#endif
#ifdef CONFIG_VFPv3
	VFPFMRX	\tmp, MVFR0			    @ Media and VFP Feature Register 0
	and	\tmp, \tmp, #MVFR0_A_SIMD_MASK	    @ A_SIMD field
	cmp	\tmp, #2			    @ 32 x 64bit registers?
	ldceql	p11, cr0, [\base],#32*4		    @ FLDMIAD \base!, {d16-d31}
	addne	\base, \base, #32*4		    @ step over unused register space
30
#endif
Linus Torvalds's avatar
Linus Torvalds committed
31 32 33
	.endm

	@ write all the working registers out of the VFP
Catalin Marinas's avatar
Catalin Marinas committed
34
	.macro	VFPFSTMIA, base, tmp
35
#if __LINUX_ARM_ARCH__ < 6
Linus Torvalds's avatar
Linus Torvalds committed
36
	STC	p11, cr0, [\base],#33*4		    @ FSTMIAX \base!, {d0-d15}
37 38
#else
	STC	p11, cr0, [\base],#32*4		    @ FSTMIAD \base!, {d0-d15}
Catalin Marinas's avatar
Catalin Marinas committed
39 40 41 42 43 44 45
#endif
#ifdef CONFIG_VFPv3
	VFPFMRX	\tmp, MVFR0			    @ Media and VFP Feature Register 0
	and	\tmp, \tmp, #MVFR0_A_SIMD_MASK	    @ A_SIMD field
	cmp	\tmp, #2			    @ 32 x 64bit registers?
	stceql	p11, cr0, [\base],#32*4		    @ FSTMIAD \base!, {d16-d31}
	addne	\base, \base, #32*4		    @ step over unused register space
46
#endif
Linus Torvalds's avatar
Linus Torvalds committed
47
	.endm