aboutsummaryrefslogtreecommitdiff
path: root/libc/cpu.c
diff options
context:
space:
mode:
authorMarvin Borner2021-03-08 19:30:48 +0100
committerMarvin Borner2021-03-08 19:30:48 +0100
commit38cfba2f71bfa9bdea562cb6465b9dc0155fc467 (patch)
treefd2e4fccc637135fe2934c35ce697af16b2a5831 /libc/cpu.c
parent776f1da4686d57dfa1c398d3b875d174fe6082c6 (diff)
Better randomization (soon: random memory locs)
Diffstat (limited to 'libc/cpu.c')
-rw-r--r--libc/cpu.c19
1 files changed, 13 insertions, 6 deletions
diff --git a/libc/cpu.c b/libc/cpu.c
index b74ed57..cb9aa49 100644
--- a/libc/cpu.c
+++ b/libc/cpu.c
@@ -99,10 +99,16 @@ void cr4_set(u32 cr4)
__asm__ volatile("movl %%eax, %%cr4" ::"a"(cr4));
}
-static u32 cpu_features = 0;
-static u8 cpu_has_feature(u32 feature)
+static u32 cpu_cfeatures = 0;
+u8 cpu_has_cfeature(enum cpuid_features feature)
{
- return (cpu_features & feature) != 0;
+ return (cpu_cfeatures & feature) != 0;
+}
+
+static u32 cpu_dfeatures = 0;
+u8 cpu_has_dfeature(enum cpuid_features feature)
+{
+ return (cpu_dfeatures & feature) != 0;
}
static void fpu_handler(struct regs *r)
@@ -121,8 +127,9 @@ void cpu_enable_features(void)
{
u32 a, b, c, d;
cpuid(CPUID_FEATURES, &a, &b, &c, &d);
- cpu_features = d;
- if (cpu_has_feature(CPUID_FEAT_EDX_SSE)) {
+ cpu_cfeatures = c;
+ cpu_dfeatures = d;
+ if (cpu_has_dfeature(CPUID_FEAT_EDX_SSE)) {
cr0_set(cr0_get() & ~(1 << 2));
cr0_set(cr0_get() | (1 << 1));
cr4_set(cr4_get() | (3 << 9));
@@ -130,7 +137,7 @@ void cpu_enable_features(void)
panic("No SSE support!\n");
}
- if (cpu_has_feature(CPUID_FEAT_EDX_FPU)) {
+ if (cpu_has_dfeature(CPUID_FEAT_EDX_FPU)) {
__asm__ volatile("fninit");
__asm__ volatile("fxsave %0" : "=m"(fpu_state));
irq_install_handler(7, fpu_handler);