 cbc9586c13
			
		
	
	
		cbc9586c13
		
	
	
	
	
		
			
			- FPU context is stored only if conflict between 2 FPU users or while exporting context of a process to userspace while it is the active user of FPU - FPU has its owner (fpu_owner) which points to the process whose state is currently loaded in FPU - the FPU exception is only turned on when scheduling a process which is not the owner of FPU - FPU state is restored for the process that generated the FPU exception. This process runs immediately without letting scheduler to pick a new process to resolve the FPU conflict asap, to minimize the FPU thrashing and FPU exception hadler execution - faster all non-FPU-exception kernel entries as FPU state is not checked nor saved - removed MF_USED_FPU flag, only MF_FPU_INITIALIZED remains to signal that a process has used FPU in the past
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef GLO_H
 | |
| #define GLO_H
 | |
| 
 | |
| /* Global variables used in the kernel. This file contains the declarations;
 | |
|  * storage space for the variables is allocated in table.c, because EXTERN is
 | |
|  * defined as extern unless the _TABLE definition is seen. We rely on the 
 | |
|  * compiler's default initialization (0) for several global variables. 
 | |
|  */
 | |
| #ifdef _TABLE
 | |
| #undef EXTERN
 | |
| #define EXTERN
 | |
| #endif
 | |
| 
 | |
| #include <minix/config.h>
 | |
| #include <machine/archtypes.h>
 | |
| #include "archconst.h"
 | |
| #include "config.h"
 | |
| #include "debug.h"
 | |
| 
 | |
| /* Kernel information structures. This groups vital kernel information. */
 | |
| EXTERN struct kinfo kinfo;		/* kernel information for users */
 | |
| EXTERN struct machine machine;		/* machine information for users */
 | |
| EXTERN struct kmessages kmess;  	/* diagnostic messages in kernel */
 | |
| EXTERN struct k_randomness krandom;	/* gather kernel random information */
 | |
| EXTERN struct loadinfo kloadinfo;	/* status of load average */
 | |
| 
 | |
| /* Process scheduling information and the kernel reentry count. */
 | |
| EXTERN struct proc *proc_ptr;	/* pointer to currently running process */
 | |
| EXTERN struct proc *bill_ptr;	/* process to bill for clock ticks */
 | |
| EXTERN struct proc *vmrequest;  /* first process on vmrequest queue */
 | |
| EXTERN unsigned lost_ticks;	/* clock ticks counted outside clock task */
 | |
| 
 | |
| 
 | |
| /* Interrupt related variables. */
 | |
| EXTERN irq_hook_t irq_hooks[NR_IRQ_HOOKS];	/* hooks for general use */
 | |
| EXTERN int irq_actids[NR_IRQ_VECTORS];		/* IRQ ID bits active */
 | |
| EXTERN int irq_use;				/* map of all in-use irq's */
 | |
| EXTERN u32_t system_hz;				/* HZ value */
 | |
| 
 | |
| /* Miscellaneous. */
 | |
| EXTERN reg_t mon_sp;			/* boot monitor stack */
 | |
| EXTERN int mon_return;			/* true if we can return to monitor */
 | |
| EXTERN int do_serial_debug;
 | |
| EXTERN time_t boottime;
 | |
| EXTERN char params_buffer[512];		/* boot monitor parameters */
 | |
| EXTERN int minix_panicing;
 | |
| EXTERN char fpu_presence;
 | |
| EXTERN struct proc * fpu_owner;
 | |
| EXTERN int verboseboot;			/* verbose boot, init'ed in cstart */
 | |
| #define MAGICTEST 0xC0FFEE23
 | |
| EXTERN u32_t magictest;			/* global magic number */
 | |
| 
 | |
| #if DEBUG_TRACE
 | |
| EXTERN int verboseflags;
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_APIC
 | |
| EXTERN int config_no_apic; /* optionaly turn off apic */
 | |
| #endif
 | |
| 
 | |
| EXTERN u64_t cpu_hz[CONFIG_MAX_CPUS];
 | |
| 
 | |
| #define cpu_set_freq(cpu, freq)	do {cpu_hz[cpu] = freq;} while (0)
 | |
| #define cpu_get_freq(cpu)	cpu_hz[cpu]
 | |
| 
 | |
| /* VM */
 | |
| EXTERN int vm_running;
 | |
| EXTERN int catch_pagefaults;
 | |
| EXTERN struct proc *ptproc;
 | |
| 
 | |
| /* Timing */
 | |
| EXTERN util_timingdata_t timingdata[TIMING_CATEGORIES];
 | |
| 
 | |
| /* Variables that are initialized elsewhere are just extern here. */
 | |
| extern struct boot_image image[]; 	/* system image processes */
 | |
| extern char *t_stack[];			/* task stack space */
 | |
| extern struct segdesc_s gdt[];		/* global descriptor table */
 | |
| 
 | |
| EXTERN volatile int serial_debug_active;
 | |
| 
 | |
| #endif /* GLO_H */
 |