Added new signal types for kernel events:
- SIGKMESS: new kernel message (sent to TTY, IS, or LOG) - SIGKSTOP: MINIX is shut down (sent to TTY-> switch to primary console) - SIGKSIG: kernel signals pending (sent to PM) Renamed SYS_SETPRIORITY to SYS_NICE.
This commit is contained in:
		
							parent
							
								
									198c976f7e
								
							
						
					
					
						commit
						0129d98ae1
					
				| @ -65,9 +65,8 @@ | |||||||
|  */ |  */ | ||||||
| #define NOTIFY_FROM(p_nr)	 (0x1000 | ((p_nr) + NR_TASKS))  | #define NOTIFY_FROM(p_nr)	 (0x1000 | ((p_nr) + NR_TASKS))  | ||||||
| #  define SYN_ALARM	NOTIFY_FROM(CLOCK) 	/* synchronous alarm */ | #  define SYN_ALARM	NOTIFY_FROM(CLOCK) 	/* synchronous alarm */ | ||||||
| #  define KSIG_PENDING NOTIFY_FROM(SYSTEM) 	/* pending signal(s) */ | #  define SYS_EVENT	NOTIFY_FROM(SYSTEM) 	/* signal system event */ | ||||||
| #  define HARD_INT	NOTIFY_FROM(HARDWARE) 	/* hardware interrupt */ | #  define HARD_INT	NOTIFY_FROM(HARDWARE) 	/* hardware interrupt */ | ||||||
| #  define NEW_KMESS    NOTIFY_FROM(SYSTEM)  	/* new kernel message */ |  | ||||||
| #  define NEW_KSIG	NOTIFY_FROM(HARDWARE)  	/* new kernel signal */ | #  define NEW_KSIG	NOTIFY_FROM(HARDWARE)  	/* new kernel signal */ | ||||||
| #  define FKEY_PRESSED	NOTIFY_FROM(TTY)  	/* function key press */ | #  define FKEY_PRESSED	NOTIFY_FROM(TTY)  	/* function key press */ | ||||||
| 
 | 
 | ||||||
| @ -239,7 +238,7 @@ | |||||||
| #  define SYS_PHYSCOPY  31 	/* sys_physcopy(src_addr,dst_addr,count) */ | #  define SYS_PHYSCOPY  31 	/* sys_physcopy(src_addr,dst_addr,count) */ | ||||||
| #  define SYS_VIRVCOPY  32	/* sys_virvcopy(vec_ptr, vec_size) */ | #  define SYS_VIRVCOPY  32	/* sys_virvcopy(vec_ptr, vec_size) */ | ||||||
| #  define SYS_MEMSET    33	/* sys_memset(char, addr, count) */ | #  define SYS_MEMSET    33	/* sys_memset(char, addr, count) */ | ||||||
| #  define SYS_SETPRIORITY  34	/* sys_setpriority(who,prio) */ | #  define SYS_NICE      34	/* sys_nice(who,prio) */ | ||||||
| #define NR_SYS_CALLS	35	/* number of system calls */  | #define NR_SYS_CALLS	35	/* number of system calls */  | ||||||
| 
 | 
 | ||||||
| /* Field names for SYS_MEMSET, SYS_SEGCTL. */ | /* Field names for SYS_MEMSET, SYS_SEGCTL. */ | ||||||
| @ -344,8 +343,8 @@ | |||||||
| #define I_PROC_NR      m7_i4	/* calling process */ | #define I_PROC_NR      m7_i4	/* calling process */ | ||||||
| #define I_VAL_PTR      m7_p1	/* virtual address at caller */  | #define I_VAL_PTR      m7_p1	/* virtual address at caller */  | ||||||
| #define I_VAL_LEN      m7_i1	/* max length of value */ | #define I_VAL_LEN      m7_i1	/* max length of value */ | ||||||
| #define I_KEY_PTR      m7_p2	/* virtual address of key to lookup */  | #define I_VAL_PTR2      m7_p2	/* second virtual address */  | ||||||
| #define I_KEY_LEN      m7_i2	/* length of key to lookup */ | #define I_VAL_LEN2      m7_i2	/* second length, or proc nr */ | ||||||
| 
 | 
 | ||||||
| /* Field names for SYS_TIMES. */ | /* Field names for SYS_TIMES. */ | ||||||
| #define T_PROC_NR   	m4_l1	/* process to request time info for */ | #define T_PROC_NR   	m4_l1	/* process to request time info for */ | ||||||
|  | |||||||
| @ -56,8 +56,6 @@ | |||||||
| /* Defines for driver and kernel configuration. */ | /* Defines for driver and kernel configuration. */ | ||||||
| #define AUTO_BIOS          0	/* xt_wini.c - use Western's autoconfig BIOS */ | #define AUTO_BIOS          0	/* xt_wini.c - use Western's autoconfig BIOS */ | ||||||
| #define LINEWRAP           1	/* console.c - wrap lines at column 80 */ | #define LINEWRAP           1	/* console.c - wrap lines at column 80 */ | ||||||
| #define ALLOW_GAP_MESSAGES 1	/* proc.c - allow messages in the gap between |  | ||||||
| 				 * the end of bss and lowest stack address */ |  | ||||||
| 
 | 
 | ||||||
| /* Number of controller tasks (/dev/cN device classes). */ | /* Number of controller tasks (/dev/cN device classes). */ | ||||||
| #define NR_CTRLRS          2 | #define NR_CTRLRS          2 | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ _PROTOTYPE( int sys_exit, (int proc)					); | |||||||
| _PROTOTYPE( int sys_trace, (int req, int proc, long addr, long *data_p)	); | _PROTOTYPE( int sys_trace, (int req, int proc, long addr, long *data_p)	); | ||||||
| 
 | 
 | ||||||
| _PROTOTYPE( int sys_svrctl, (int proc, int req, int priv,vir_bytes argp)); | _PROTOTYPE( int sys_svrctl, (int proc, int req, int priv,vir_bytes argp)); | ||||||
| _PROTOTYPE( int sys_setpriority, (int proc, int prio)			); | _PROTOTYPE( int sys_nice, (int proc, int prio)				); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| /* Shorthands for sys_sdevio() system call. */ | /* Shorthands for sys_sdevio() system call. */ | ||||||
| @ -102,7 +102,7 @@ _PROTOTYPE(int sys_segctl, (int *index, u16_t *seg, vir_bytes *off, | |||||||
| #define sys_getschedinfo(v1,v2)	sys_getinfo(GET_SCHEDINFO, v1,0, v2,0) | #define sys_getschedinfo(v1,v2)	sys_getinfo(GET_SCHEDINFO, v1,0, v2,0) | ||||||
| #define sys_getlocktimings(dst)	sys_getinfo(GET_LOCKTIMING, dst, 0,0,0) | #define sys_getlocktimings(dst)	sys_getinfo(GET_LOCKTIMING, dst, 0,0,0) | ||||||
| _PROTOTYPE(int sys_getinfo, (int request, void *val_ptr, int val_len, | _PROTOTYPE(int sys_getinfo, (int request, void *val_ptr, int val_len, | ||||||
| 				 void *key_ptr, int key_len)		); | 				 void *val_ptr2, int val_len2)		); | ||||||
| 
 | 
 | ||||||
| /* Signal control. */ | /* Signal control. */ | ||||||
| _PROTOTYPE(int sys_kill, (int proc, int sig) ); | _PROTOTYPE(int sys_kill, (int proc, int sig) ); | ||||||
|  | |||||||
| @ -25,7 +25,7 @@ typedef unsigned long sigset_t; | |||||||
| #endif | #endif | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #define _NSIG             17	/* number of signals used */ | #define _NSIG             20	/* number of signals used */ | ||||||
| 
 | 
 | ||||||
| #define SIGHUP             1	/* hangup */ | #define SIGHUP             1	/* hangup */ | ||||||
| #define SIGINT             2	/* interrupt (DEL) */ | #define SIGINT             2	/* interrupt (DEL) */ | ||||||
| @ -48,6 +48,13 @@ typedef unsigned long sigset_t; | |||||||
| #define SIGEMT             7	/* obsolete */ | #define SIGEMT             7	/* obsolete */ | ||||||
| #define SIGBUS            10	/* obsolete */ | #define SIGBUS            10	/* obsolete */ | ||||||
| 
 | 
 | ||||||
|  | /* MINIX specific signals. These signals are not used by user proceses, 
 | ||||||
|  |  * but meant to inform system processes, like the PM, about system events. | ||||||
|  |  */ | ||||||
|  | #define SIGKMESS   	  18	/* new kernel message */ | ||||||
|  | #define SIGKSIG    	  19	/* kernel signal pending */ | ||||||
|  | #define SIGKSTOP    	  20	/* kernel shutting down */ | ||||||
|  | 
 | ||||||
| /* POSIX requires the following signals to be defined, even if they are
 | /* POSIX requires the following signals to be defined, even if they are
 | ||||||
|  * not supported.  Here are the definitions, but they are not supported. |  * not supported.  Here are the definitions, but they are not supported. | ||||||
|  */ |  */ | ||||||
| @ -57,6 +64,7 @@ typedef unsigned long sigset_t; | |||||||
| #define SIGTTIN           21	/* background process wants to read */ | #define SIGTTIN           21	/* background process wants to read */ | ||||||
| #define SIGTTOU           22	/* background process wants to write */ | #define SIGTTOU           22	/* background process wants to write */ | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| /* The sighandler_t type is not allowed unless _POSIX_SOURCE is defined. */ | /* The sighandler_t type is not allowed unless _POSIX_SOURCE is defined. */ | ||||||
| typedef void _PROTOTYPE( (*__sighandler_t), (int) ); | typedef void _PROTOTYPE( (*__sighandler_t), (int) ); | ||||||
| 
 | 
 | ||||||
| @ -66,6 +74,7 @@ typedef void _PROTOTYPE( (*__sighandler_t), (int) ); | |||||||
| #define SIG_IGN	   ((__sighandler_t)  1)	/* ignore signal */ | #define SIG_IGN	   ((__sighandler_t)  1)	/* ignore signal */ | ||||||
| #define SIG_HOLD   ((__sighandler_t)  2)	/* block signal */ | #define SIG_HOLD   ((__sighandler_t)  2)	/* block signal */ | ||||||
| #define SIG_CATCH  ((__sighandler_t)  3)	/* catch signal */ | #define SIG_CATCH  ((__sighandler_t)  3)	/* catch signal */ | ||||||
|  | #define SIG_MESS   ((__sighandler_t)  4)	/* pass as message (MINIX) */ | ||||||
| 
 | 
 | ||||||
| #ifdef _POSIX_SOURCE | #ifdef _POSIX_SOURCE | ||||||
| struct sigaction { | struct sigaction { | ||||||
|  | |||||||
| @ -27,7 +27,7 @@ OBJECTS	= \ | |||||||
| 	$(LIBSYS)(sys_getinfo.o) \
 | 	$(LIBSYS)(sys_getinfo.o) \
 | ||||||
| 	$(LIBSYS)(sys_irqctl.o) \
 | 	$(LIBSYS)(sys_irqctl.o) \
 | ||||||
| 	$(LIBSYS)(sys_segctl.o) \
 | 	$(LIBSYS)(sys_segctl.o) \
 | ||||||
| 	$(LIBSYS)(sys_setpriority.o) \
 | 	$(LIBSYS)(sys_nice.o) \
 | ||||||
| 	$(LIBSYS)(sys_umap.o) \
 | 	$(LIBSYS)(sys_umap.o) \
 | ||||||
| 	$(LIBSYS)(sys_physcopy.o) \
 | 	$(LIBSYS)(sys_physcopy.o) \
 | ||||||
| 	$(LIBSYS)(sys_vircopy.o) \
 | 	$(LIBSYS)(sys_vircopy.o) \
 | ||||||
| @ -89,8 +89,8 @@ $(LIBSYS)(sys_irqctl.o):	sys_irqctl.c | |||||||
| $(LIBSYS)(sys_eniop.o):	sys_eniop.c | $(LIBSYS)(sys_eniop.o):	sys_eniop.c | ||||||
| 	$(CC1) sys_eniop.c | 	$(CC1) sys_eniop.c | ||||||
| 
 | 
 | ||||||
| $(LIBSYS)(sys_setpriority.o):	sys_setpriority.c | $(LIBSYS)(sys_nice.o):	sys_nice.c | ||||||
| 	$(CC1) sys_setpriority.c | 	$(CC1) sys_nice.c | ||||||
| 
 | 
 | ||||||
| $(LIBSYS)(sys_segctl.o):	sys_segctl.c | $(LIBSYS)(sys_segctl.o):	sys_segctl.c | ||||||
| 	$(CC1) sys_segctl.c | 	$(CC1) sys_segctl.c | ||||||
|  | |||||||
| @ -3,21 +3,21 @@ | |||||||
| /*===========================================================================*
 | /*===========================================================================*
 | ||||||
|  *                                sys_getinfo				     * |  *                                sys_getinfo				     * | ||||||
|  *===========================================================================*/ |  *===========================================================================*/ | ||||||
| PUBLIC int sys_getinfo(request, val_ptr, val_len, key_ptr, key_len) | PUBLIC int sys_getinfo(request, ptr, len, ptr2, len2) | ||||||
| int request; 				/* system info requested */ | int request; 				/* system info requested */ | ||||||
| void *val_ptr;				/* pointer where to store it */ | void *ptr;				/* pointer where to store it */ | ||||||
| int val_len;				/* max length of value to get */ | int len;				/* max length of value to get */ | ||||||
| void *key_ptr;				/* pointer to key requested */ | void *ptr2;				/* second pointer */ | ||||||
| int key_len;				/* length of key */  | int len2;				/* length or process nr */  | ||||||
| { | { | ||||||
|     message m; |     message m; | ||||||
| 
 | 
 | ||||||
|     m.I_REQUEST = request; |     m.I_REQUEST = request; | ||||||
|     m.I_PROC_NR = SELF;			/* always store values at caller */ |     m.I_PROC_NR = SELF;			/* always store values at caller */ | ||||||
|     m.I_VAL_PTR = val_ptr; |     m.I_VAL_PTR = ptr; | ||||||
|     m.I_VAL_LEN = val_len; |     m.I_VAL_LEN = len; | ||||||
|     m.I_KEY_PTR = key_ptr; |     m.I_VAL_PTR2 = ptr2; | ||||||
|     m.I_KEY_LEN = key_len; |     m.I_VAL_LEN2 = len2; | ||||||
| 
 | 
 | ||||||
|     return(_taskcall(SYSTASK, SYS_GETINFO, &m)); |     return(_taskcall(SYSTASK, SYS_GETINFO, &m)); | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,13 +1,13 @@ | |||||||
| #include "syslib.h" | #include "syslib.h" | ||||||
| 
 | 
 | ||||||
| /*===========================================================================*
 | /*===========================================================================*
 | ||||||
|  *                                sys_xit			     	     * |  *                                sys_nice			     	     * | ||||||
|  *===========================================================================*/ |  *===========================================================================*/ | ||||||
| PUBLIC int sys_setpriority(int proc, int prio) | PUBLIC int sys_nice(int proc, int prio) | ||||||
| { | { | ||||||
|   message m; |   message m; | ||||||
| 
 | 
 | ||||||
|   m.m1_i1 = proc; |   m.m1_i1 = proc; | ||||||
|   m.m1_i2 = prio; |   m.m1_i2 = prio; | ||||||
|   return(_taskcall(SYSTASK, SYS_SETPRIORITY, &m)); |   return(_taskcall(SYSTASK, SYS_NICE, &m)); | ||||||
| } | } | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Jorrit Herder
						Jorrit Herder