mirror of
https://github.com/Fennix-Project/Kernel.git
synced 2025-05-28 07:24:37 +00:00
implemented fxsr
This commit is contained in:
parent
3d947c2a03
commit
776f6d71b0
11
Architecture/amd64/cpu/fxsr.asm
Normal file
11
Architecture/amd64/cpu/fxsr.asm
Normal file
@ -0,0 +1,11 @@
|
||||
[bits 64]
|
||||
|
||||
[global _amd64_fxsave]
|
||||
_amd64_fxsave:
|
||||
fxsave [rdi]
|
||||
ret
|
||||
|
||||
[global _amd64_fxrstor]
|
||||
_amd64_fxrstor:
|
||||
fxrstor [rdi]
|
||||
ret
|
11
Architecture/i686/cpu/fxsr.asm
Normal file
11
Architecture/i686/cpu/fxsr.asm
Normal file
@ -0,0 +1,11 @@
|
||||
[bits 64]
|
||||
|
||||
[global _i386_fxsave]
|
||||
_i386_fxsave:
|
||||
fxsave [edi]
|
||||
ret
|
||||
|
||||
[global _i386_fxrstor]
|
||||
_i386_fxrstor:
|
||||
fxrstor [edi]
|
||||
ret
|
@ -5,6 +5,11 @@
|
||||
|
||||
#include <cstring>
|
||||
|
||||
extern "C" void _amd64_fxsave(char *Buffer);
|
||||
extern "C" void _amd64_fxrstor(char *Buffer);
|
||||
extern "C" void _i386_fxsave(char *Buffer);
|
||||
extern "C" void _i386_fxrstor(char *Buffer);
|
||||
|
||||
#define x86_CPUID_VENDOR_OLDAMD "AMDisbetter!" /* Early engineering samples of AMD K5 processor */
|
||||
#define x86_CPUID_VENDOR_AMD "AuthenticAMD"
|
||||
#define x86_CPUID_VENDOR_INTEL "GenuineIntel"
|
||||
@ -1580,6 +1585,7 @@ namespace CPU
|
||||
__attribute__((no_stack_protector)) static inline void fxsave(char *FXSaveArea)
|
||||
{
|
||||
#if defined(__amd64__)
|
||||
_amd64_fxsave(FXSaveArea);
|
||||
// asmv("fxsaveq (%0)"
|
||||
// :
|
||||
// : "r"(FXSaveArea)
|
||||
@ -1590,6 +1596,7 @@ namespace CPU
|
||||
__attribute__((no_stack_protector)) static inline void fxrstor(char *FXRstorArea)
|
||||
{
|
||||
#if defined(__amd64__)
|
||||
_amd64_fxrstor(FXRstorArea);
|
||||
// asmv("fxrstorq (%0)"
|
||||
// :
|
||||
// : "r"(FXRstorArea)
|
||||
|
Loading…
x
Reference in New Issue
Block a user