2005-04-16 15:20:36 -07:00
/* ----------------------------------------------------------------------- *
*
* Copyright 2002 - 2004 H . Peter Anvin - All Rights Reserved
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation , Inc . , 53 Temple Place Ste 330 ,
2009-03-31 14:57:37 +11:00
* Boston MA 02111 - 1307 , USA ; either version 2 of the License , or
2005-04-16 15:20:36 -07:00
* ( at your option ) any later version ; incorporated herein by reference .
*
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
/*
2010-08-12 06:44:54 +10:00
* raid6 / x86 . h
2005-04-16 15:20:36 -07:00
*
* Definitions common to x86 and x86 - 64 RAID - 6 code only
*/
# ifndef LINUX_RAID_RAID6X86_H
# define LINUX_RAID_RAID6X86_H
2007-10-29 04:31:16 +00:00
# if (defined(__i386__) || defined(__x86_64__)) && !defined(__arch_um__)
2005-04-16 15:20:36 -07:00
# ifdef __KERNEL__ /* Real code */
2007-02-28 20:11:25 -08:00
# include <asm/i387.h>
2005-04-16 15:20:36 -07:00
# else /* Dummy code for user space testing */
2007-02-28 20:11:25 -08:00
static inline void kernel_fpu_begin ( void )
2005-04-16 15:20:36 -07:00
{
}
2007-02-28 20:11:25 -08:00
static inline void kernel_fpu_end ( void )
2005-04-16 15:20:36 -07:00
{
}
2012-05-22 13:54:23 +10:00
# define __aligned(x) __attribute__((aligned(x)))
2007-02-28 20:11:25 -08:00
# define X86_FEATURE_MMX (0*32+23) /* Multimedia Extensions */
# define X86_FEATURE_FXSR (0*32+24) / * FXSAVE and FXRSTOR instructions
* ( fast save and restore ) */
# define X86_FEATURE_XMM (0*32+25) /* Streaming SIMD Extensions */
# define X86_FEATURE_XMM2 (0*32+26) /* Streaming SIMD Extensions-2 */
2012-05-22 13:54:23 +10:00
# define X86_FEATURE_XMM3 (4*32+ 0) /* "pni" SSE-3 */
# define X86_FEATURE_SSSE3 (4*32+ 9) /* Supplemental SSE-3 */
# define X86_FEATURE_AVX (4*32+28) /* Advanced Vector Extensions */
2012-11-08 13:47:44 -08:00
# define X86_FEATURE_AVX2 (9*32+ 5) /* AVX2 instructions */
2007-02-28 20:11:25 -08:00
# define X86_FEATURE_MMXEXT (1*32+22) /* AMD MMX extensions */
2005-04-16 15:20:36 -07:00
2007-02-28 20:11:25 -08:00
/* Should work well enough on modern CPUs for testing */
static inline int boot_cpu_has ( int flag )
2005-04-16 15:20:36 -07:00
{
2012-11-08 13:47:44 -08:00
u32 eax , ebx , ecx , edx ;
eax = ( flag & 0x100 ) ? 7 :
( flag & 0x20 ) ? 0x80000001 : 1 ;
ecx = 0 ;
2005-04-16 15:20:36 -07:00
2007-02-28 20:11:25 -08:00
asm volatile ( " cpuid "
2012-11-08 13:47:44 -08:00
: " +a " ( eax ) , " =b " ( ebx ) , " =d " ( edx ) , " +c " ( ecx ) ) ;
2005-04-16 15:20:36 -07:00
2012-11-08 13:47:44 -08:00
return ( ( flag & 0x100 ? ebx :
( flag & 0x80 ) ? ecx : edx ) > > ( flag & 31 ) ) & 1 ;
2005-04-16 15:20:36 -07:00
}
# endif /* ndef __KERNEL__ */
# endif
# endif