mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 1b4fb8545f
			
		
	
	
		1b4fb8545f
		
	
	
	
	
		
			
			The xgetbv() function is needed in the pre-decompression boot code, but asm/fpu/internal.h can't be included there directly. Doing so opens the door to include-hell due to various include-magic in boot/compressed/misc.h. Avoid that by moving xgetbv()/xsetbv() to a separate header file and include it instead. Signed-off-by: Joerg Roedel <jroedel@suse.de> Signed-off-by: Borislav Petkov <bp@suse.de> Link: https://lkml.kernel.org/r/20200907131613.12703-27-joro@8bytes.org
		
			
				
	
	
		
			35 lines
		
	
	
		
			649 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			649 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef _ASM_X86_FPU_XCR_H
 | |
| #define _ASM_X86_FPU_XCR_H
 | |
| 
 | |
| /*
 | |
|  * MXCSR and XCR definitions:
 | |
|  */
 | |
| 
 | |
| static inline void ldmxcsr(u32 mxcsr)
 | |
| {
 | |
| 	asm volatile("ldmxcsr %0" :: "m" (mxcsr));
 | |
| }
 | |
| 
 | |
| extern unsigned int mxcsr_feature_mask;
 | |
| 
 | |
| #define XCR_XFEATURE_ENABLED_MASK	0x00000000
 | |
| 
 | |
| static inline u64 xgetbv(u32 index)
 | |
| {
 | |
| 	u32 eax, edx;
 | |
| 
 | |
| 	asm volatile("xgetbv" : "=a" (eax), "=d" (edx) : "c" (index));
 | |
| 	return eax + ((u64)edx << 32);
 | |
| }
 | |
| 
 | |
| static inline void xsetbv(u32 index, u64 value)
 | |
| {
 | |
| 	u32 eax = value;
 | |
| 	u32 edx = value >> 32;
 | |
| 
 | |
| 	asm volatile("xsetbv" :: "a" (eax), "d" (edx), "c" (index));
 | |
| }
 | |
| 
 | |
| #endif /* _ASM_X86_FPU_XCR_H */
 |