 2d72cbec41
			
		
	
	
		2d72cbec41
		
	
	
	
	
		
			
			. add cpufeature detection of both . use it for both ipc and kernelcall traps, using a register for call number . SYSENTER/SYSCALL does not save any context, therefore userland has to save it . to accomodate multiple kernel entry/exit types, the entry type is recorded in the process struct. hitherto all types were interrupt (soft int, exception, hard int); now SYSENTER/SYSCALL is new, with the difference that context is not fully restored from proc struct when running the process again. this can't be done as some information is missing. . complication: cases in which the kernel has to fully change process context (i.e. sigreturn). in that case the exit type is changed from SYSENTER/SYSEXIT to soft-int (i.e. iret) and context is fully restored from the proc struct. this does mean the PC and SP must change, as the sysenter/sysexit userland code will otherwise try to restore its own context. this is true in the sigreturn case. . override all usage by setting libc_ipc=1
		
			
				
	
	
		
			26 lines
		
	
	
		
			496 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			26 lines
		
	
	
		
			496 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #include <sys/cdefs.h>
 | |
| #include <lib.h>
 | |
| #include "namespace.h"
 | |
| 
 | |
| #ifdef __weak_alias
 | |
| __weak_alias(syscall, _syscall)
 | |
| #endif
 | |
| 
 | |
| int _syscall(endpoint_t who, int syscallnr, message *msgptr)
 | |
| {
 | |
|   int status;
 | |
| 
 | |
|   msgptr->m_type = syscallnr;
 | |
|   status = sendrec(who, msgptr);
 | |
|   if (status != 0) {
 | |
| 	/* 'sendrec' itself failed. */
 | |
| 	/* XXX - strerror doesn't know all the codes */
 | |
| 	msgptr->m_type = status;
 | |
|   }
 | |
|   if (msgptr->m_type < 0) {
 | |
| 	errno = -msgptr->m_type;
 | |
| 	return(-1);
 | |
|   }
 | |
|   return(msgptr->m_type);
 | |
| }
 |