 6f77685609
			
		
	
	
		6f77685609
		
	
	
	
	
		
			
			mainly in the kernel and headers. This split based on work by Ingmar Alting <iaalting@cs.vu.nl> done for his Minix PowerPC architecture port. . kernel does not program the interrupt controller directly, do any other architecture-dependent operations, or contain assembly any more, but uses architecture-dependent functions in arch/$(ARCH)/. . architecture-dependent constants and types defined in arch/$(ARCH)/include. . <ibm/portio.h> moved to <minix/portio.h>, as they have become, for now, architecture-independent functions. . int86, sdevio, readbios, and iopenable are now i386-specific kernel calls and live in arch/i386/do_* now. . i386 arch now supports even less 86 code; e.g. mpx86.s and klib86.s have gone, and 'machine.protected' is gone (and always taken to be 1 in i386). If 86 support is to return, it should be a new architecture. . prototypes for the architecture-dependent functions defined in kernel/arch/$(ARCH)/*.c but used in kernel/ are in kernel/proto.h . /etc/make.conf included in makefiles and shell scripts that need to know the building architecture; it defines ARCH=<arch>, currently only i386. . some basic per-architecture build support outside of the kernel (lib) . in clock.c, only dequeue a process if it was ready . fixes for new include files files deleted: . mpx/klib.s - only for choosing between mpx/klib86 and -386 . klib86.s - only for 86 i386-specific files files moved (or arch-dependent stuff moved) to arch/i386/: . mpx386.s (entry point) . klib386.s . sconst.h . exception.c . protect.c . protect.h . i8269.c
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* The kernel call implemented in this file:
 | |
|  *   m_type:	SYS_UMAP
 | |
|  *
 | |
|  * The parameters for this kernel call are:
 | |
|  *    m5_i1:	CP_SRC_PROC_NR	(process number)	
 | |
|  *    m5_c1:	CP_SRC_SPACE	(segment where address is: T, D, or S)
 | |
|  *    m5_l1:	CP_SRC_ADDR	(virtual address)	
 | |
|  *    m5_l2:	CP_DST_ADDR	(returns physical address)	
 | |
|  *    m5_l3:	CP_NR_BYTES	(size of datastructure) 	
 | |
|  */
 | |
| 
 | |
| #include "../system.h"
 | |
| 
 | |
| #if USE_UMAP
 | |
| 
 | |
| /*==========================================================================*
 | |
|  *				do_umap					    *
 | |
|  *==========================================================================*/
 | |
| PUBLIC int do_umap(m_ptr)
 | |
| register message *m_ptr;	/* pointer to request message */
 | |
| {
 | |
| /* Map virtual address to physical, for non-kernel processes. */
 | |
|   int seg_type = m_ptr->CP_SRC_SPACE & SEGMENT_TYPE;
 | |
|   int seg_index = m_ptr->CP_SRC_SPACE & SEGMENT_INDEX;
 | |
|   vir_bytes offset = m_ptr->CP_SRC_ADDR;
 | |
|   int count = m_ptr->CP_NR_BYTES;
 | |
|   int endpt = (int) m_ptr->CP_SRC_ENDPT;
 | |
|   int proc_nr;
 | |
|   phys_bytes phys_addr;
 | |
| 
 | |
|   /* Verify process number. */
 | |
|   if (endpt == SELF)
 | |
| 	proc_nr = who_p;
 | |
|   else
 | |
| 	if (! isokendpt(endpt, &proc_nr))
 | |
| 		return(EINVAL);
 | |
| 
 | |
|   /* See which mapping should be made. */
 | |
|   switch(seg_type) {
 | |
|   case LOCAL_SEG:
 | |
|       phys_addr = umap_local(proc_addr(proc_nr), seg_index, offset, count); 
 | |
|       break;
 | |
|   case REMOTE_SEG:
 | |
|       phys_addr = umap_remote(proc_addr(proc_nr), seg_index, offset, count); 
 | |
|       break;
 | |
| #if _MINIX_CHIP == _CHIP_INTEL
 | |
|   case BIOS_SEG:
 | |
|       phys_addr = umap_bios(proc_addr(proc_nr), offset, count); 
 | |
|       break;
 | |
| #endif
 | |
|   case GRANT_SEG:
 | |
|       phys_addr = umap_grant(proc_addr(proc_nr), offset, count); 
 | |
|       break;
 | |
|   default:
 | |
|       return(EINVAL);
 | |
|   }
 | |
|   m_ptr->CP_DST_ADDR = phys_addr;
 | |
|   return (phys_addr == 0) ? EFAULT: OK;
 | |
| }
 | |
| 
 | |
| #endif /* USE_UMAP */
 |