 8866b4d0ef
			
		
	
	
		8866b4d0ef
		
	
	
	
	
		
			
			- reinstalled priority changing, now in sched() and unready() - reinstalled check on message buffer in sys_call() - reinstalled check in send masks in sys_call() - changed do_fork() to get new privilege structure for SYS_PROCs - removed some processes from boot image---will be dynamically started later
		
			
				
	
	
		
			79 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
| /* General macros and constants used by the kernel. */
 | |
| #ifndef CONST_H
 | |
| #define CONST_H
 | |
| 
 | |
| #include <ibm/interrupt.h>	/* interrupt numbers and hardware vectors */
 | |
| #include <ibm/ports.h>		/* port addresses and magic numbers */
 | |
| #include <ibm/bios.h>		/* BIOS addresses, sizes and magic numbers */
 | |
| #include <ibm/cpu.h>		/* BIOS addresses, sizes and magic numbers */
 | |
| #include <minix/config.h>
 | |
| #include "config.h"
 | |
| 
 | |
| /* To translate an address in kernel space to a physical address.  This is
 | |
|  * the same as umap_local(proc_ptr, D, vir, sizeof(*vir)), but less costly.
 | |
|  */
 | |
| #define vir2phys(vir)	(kinfo.data_base + (vir_bytes) (vir))
 | |
| 
 | |
| /* Translate a pointer to a field in a structure to a pointer to the structure
 | |
|  * itself. So it translates '&struct_ptr->field' back to 'struct_ptr'.
 | |
|  */
 | |
| #define structof(type, field, ptr) \
 | |
| 	((type *) (((char *) (ptr)) - offsetof(type, field)))
 | |
| 
 | |
| /* Constants used in virtual_copy(). Values must be 0 and 1, respectively. */
 | |
| #define _SRC_	0
 | |
| #define _DST_	1
 | |
| 
 | |
| /* Number of random sources */
 | |
| #define RANDOM_SOURCES	16
 | |
| 
 | |
| /* Constants and macros for bit map manipulation. */
 | |
| #define BITCHUNK_BITS   (sizeof(bitchunk_t) * CHAR_BIT)
 | |
| #define BITMAP_CHUNKS(nr_bits) (((nr_bits)+BITCHUNK_BITS-1)/BITCHUNK_BITS)  
 | |
| #define MAP_CHUNK(map,bit) (map)[((bit)/BITCHUNK_BITS)]
 | |
| #define CHUNK_OFFSET(bit) ((bit)%BITCHUNK_BITS))
 | |
| #define GET_BIT(map,bit) ( MAP_CHUNK(map,bit) & (1 << CHUNK_OFFSET(bit) )
 | |
| #define SET_BIT(map,bit) ( MAP_CHUNK(map,bit) |= (1 << CHUNK_OFFSET(bit) )
 | |
| #define UNSET_BIT(map,bit) ( MAP_CHUNK(map,bit) &= ~(1 << CHUNK_OFFSET(bit) )
 | |
| 
 | |
| #define get_sys_bit(map,bit) \
 | |
| 	( MAP_CHUNK(map.chunk,bit) & (1 << CHUNK_OFFSET(bit) )
 | |
| #define set_sys_bit(map,bit) \
 | |
| 	( MAP_CHUNK(map.chunk,bit) |= (1 << CHUNK_OFFSET(bit) )
 | |
| #define unset_sys_bit(map,bit) \
 | |
| 	( MAP_CHUNK(map.chunk,bit) &= ~(1 << CHUNK_OFFSET(bit) )
 | |
| #define NR_SYS_CHUNKS	BITMAP_CHUNKS(NR_SYS_PROCS)
 | |
| 
 | |
| 
 | |
| #if (CHIP == INTEL)
 | |
| 
 | |
| /* Program stack words and masks. */
 | |
| #define INIT_PSW      0x0200	/* initial psw */
 | |
| #define INIT_TASK_PSW 0x1200	/* initial psw for tasks (with IOPL 1) */
 | |
| #define TRACEBIT      0x0100	/* OR this with psw in proc[] for tracing */
 | |
| #define SETPSW(rp, new)		/* permits only certain bits to be set */ \
 | |
| 	((rp)->p_reg.psw = (rp)->p_reg.psw & ~0xCD5 | (new) & 0xCD5)
 | |
| #define IF_MASK 0x00000200
 | |
| #define IOPL_MASK 0x003000
 | |
| 
 | |
| /* Disable/ enable hardware interrupts. The parameters of lock() and unlock()
 | |
|  * are used when debugging is enabled. See debug.h for more information.
 | |
|  */
 | |
| #define lock(c, v)	intr_disable(); 
 | |
| #define unlock(c)	intr_enable(); 
 | |
| 
 | |
| /* Sizes of memory tables. The boot monitor distinguishes three memory areas, 
 | |
|  * namely low mem below 1M, 1M-16M, and mem after 16M. More chunks are needed
 | |
|  * for DOS MINIX.
 | |
|  */
 | |
| #define NR_MEMS            8	
 | |
| 
 | |
| 
 | |
| #endif /* (CHIP == INTEL) */
 | |
| 
 | |
| #if (CHIP == M68000)
 | |
| /* M68000 specific constants go here. */
 | |
| #endif /* (CHIP == M68000) */
 | |
| 
 | |
| #endif /* CONST_H */
 |