aboutsummaryrefslogtreecommitdiff
path: root/kernel/drivers/fpu.c
blob: d8a2b7936fd2f26b2b1512a1e415790099cd49bd (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// MIT License, Copyright (c) 2020 Marvin Borner

#include <def.h>

void set_fpu_cw(const u16 cw)
{
	__asm__ volatile("fldcw %0" ::"m"(cw));
}

void fpu_install()
{
	__asm__ volatile("clts");
	u32 t;
	__asm__ volatile("mov %%cr0, %0" : "=r"(t));
	t &= ~(1 << 2);
	t |= (1 << 1);
	__asm__ volatile("mov %0, %%cr0" ::"r"(t));

	__asm__ volatile("mov %%cr4, %0" : "=r"(t));
	t |= 3 << 9;
	__asm__ volatile("mov %0, %%cr4" ::"r"(t));

	__asm__ volatile("fninit");
}