Skip to content

Commit

Permalink
Enable SSE in i386
Browse files Browse the repository at this point in the history
For libcompiler_rt makes use of SSE instructions in its floating point
routines, CR4's OSFXSR flag must be enabled or an #UD exception will
ensue.
This patch also enables the OSXMMEXCPT flag, just to be in sync with
the amd64 version of the boot code.
  • Loading branch information
fltt committed Mar 17, 2017
1 parent e5207b2 commit 3c157b5
Show file tree
Hide file tree
Showing 4 changed files with 37 additions and 6 deletions.
1 change: 1 addition & 0 deletions AUTHORS
Original file line number Diff line number Diff line change
Expand Up @@ -11,3 +11,4 @@ Sebastian Wicki <[email protected]>
Dan Skorupski <[email protected]>
Matt Gray <[email protected]>
Ian Eyberg <[email protected]>
Francesco Lattanzio <[email protected]>
10 changes: 5 additions & 5 deletions platform/hw/arch/amd64/locore.S
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ ENTRY(_start)

/* clear console */
pushl %eax
movw $0x20, %ax
movw $' ', %ax
movl $(CONS_ADDRESS), %edi
movl $(CONS_WIDTH*CONS_HEIGHT), %ecx
rep stosw
Expand Down Expand Up @@ -102,13 +102,13 @@ ENTRY(_start)

/* 1: enable pae and sse */
movl %cr4, %eax
orl $0x620, %eax
orl $(CR4_OSXMMEXCPT|CR4_OSFXSR|CR4_PAE), %eax
movl %eax, %cr4

/* 2: enable long mode */
movl $0xc0000080, %ecx
movl $MSR_EFER, %ecx
rdmsr
movl $0x100, %eax
movl $MSR_EFER_LME, %eax
wrmsr

/* 3: load pml4 pointer */
Expand All @@ -117,7 +117,7 @@ ENTRY(_start)

/* 4: enable paging */
movl %cr0, %eax
orl $0x80010001, %eax
orl $(CR0_PG|CR0_WP|CR0_PE), %eax
movl %eax, %cr0

/* 5: poetically longjump to longmode */
Expand Down
15 changes: 14 additions & 1 deletion platform/hw/arch/i386/locore.S
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ ENTRY(_start)

/* clear console */
pushl %eax
movw $0x20, %ax
movw $' ', %ax
movl $(CONS_ADDRESS), %edi
movl $(CONS_WIDTH*CONS_HEIGHT), %ecx
rep stosw
Expand All @@ -62,6 +62,18 @@ ENTRY(_start)
cmpl $MULTIBOOT_BOOTLOADER_MAGIC, %eax
jne nomultiboot

/* test the sse feature flag */
movl $CPUID_01H_LEAF, %eax
cpuid
test $CPUID_01H_EDX_SSE, %edx
jz no_sse

/* enable sse */
movl %cr4, %eax
orl $(CR4_OSXMMEXCPT|CR4_OSFXSR), %eax
movl %eax, %cr4

no_sse:
call x86_boot

jmp haltme
Expand All @@ -74,6 +86,7 @@ nomultiboot:
movsbl (%ebx), %eax
test %al, %al
je haltme

orl $0x500, %eax
movl %eax, (%ecx)
inc %ebx
Expand Down
17 changes: 17 additions & 0 deletions platform/hw/include/arch/x86/reg.h
Original file line number Diff line number Diff line change
@@ -1,3 +1,20 @@
#define CPUID_01H_LEAF 0x01

#define CPUID_01H_EDX_SSE 0x02000000 /* SSE Extensions */

#define CR0_PG 0x80000000 /* Paging */
#define CR0_WP 0x00010000 /* Write Protect */
#define CR0_PE 0x00000001 /* Protection Enable */

#define CR4_OSXMMEXCPT 0x00000400 /* OS support for unmasked SIMD FP exceptions */
#define CR4_OSFXSR 0x00000200 /* OS support for FXSAVE & FXRSTOR */
#define CR4_PAE 0x00000020 /* Physical Address Extension */

/* Extended Feature Enable Register */
#define MSR_EFER 0xc0000080

#define MSR_EFER_LME 0x00000100 /* Long Mode Enable */

#define PIC1_CMD 0x20
#define PIC1_DATA 0x21
#define PIC2_CMD 0xa0
Expand Down

0 comments on commit 3c157b5

Please sign in to comment.