Changeset 79f1f38f in mainline
- Timestamp:
- 2005-05-09T00:35:09Z (20 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 9db5b66
- Parents:
- 9c926f3
- Location:
- arch/ia32
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
arch/ia32/include/cpu.h
r9c926f3 r79f1f38f 31 31 32 32 #include <config.h> 33 #include <proc/thread.h> 33 34 #include <typedefs.h> 34 35 #include <arch/pm.h> … … 47 48 int stepping; 48 49 struct tss *tss; 50 thread_t *fpu_owner; 49 51 }; 50 52 51 53 54 void set_TS_flag(void); 55 void reset_TS_flag(void); 56 52 57 #endif -
arch/ia32/src/cpu/cpu.c
r9c926f3 r79f1f38f 62 62 }; 63 63 64 void set_TS_flag(void) 65 { 66 asm 67 ( 68 "mov %%cr0,%%eax;" 69 "or $8,%%eax;" 70 "mov %%eax,%%cr0;" 71 : 72 : 73 :"%eax" 74 ); 75 } 76 77 void reset_TS_flag(void) 78 { 79 asm 80 ( 81 "mov %%cr0,%%eax;" 82 "and $0xffFFffF7,%%eax;" 83 "mov %%eax,%%cr0;" 84 : 85 : 86 :"%eax" 87 ); 88 } 89 90 91 64 92 void cpu_arch_init(void) 65 93 { 66 94 CPU->arch.tss = tss_p; 95 CPU->arch.fpu_owner=NULL; 67 96 } 68 97 -
arch/ia32/src/fpu_context.c
r9c926f3 r79f1f38f 30 30 31 31 #include <fpu_context.h> 32 #include <arch.h> 33 #include <cpu.h> 34 32 35 33 36 void fpu_context_save(fpu_context_t *fctx) … … 38 41 void fpu_context_restore(fpu_context_t *fctx) 39 42 { 43 if(THREAD==CPU->arch.fpu_owner) reset_TS_flag(); 44 else set_TS_flag(); 40 45 } 41 46
Note:
See TracChangeset
for help on using the changeset viewer.