 a972f4bacc
			
		
	
	
		a972f4bacc
		
	
	
	
	
		
			
			- macros used with RTS_SET group of macros to define struct proc p_rts_flags are now prefixed with RTS_ to make things clear
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* The kernel call implemented in this file:
 | |
|  *   m_type:	SYS_NICE
 | |
|  *
 | |
|  * The parameters for this kernel call are:
 | |
|  *    m1_i1:	PR_ENDPT   	process number to change priority
 | |
|  *    m1_i2:	PR_PRIORITY	the new priority
 | |
|  */
 | |
| 
 | |
| #include "../system.h"
 | |
| #include <minix/type.h>
 | |
| #include <sys/resource.h>
 | |
| 
 | |
| #if USE_NICE
 | |
| 
 | |
| /*===========================================================================*
 | |
|  *				  do_nice				     *
 | |
|  *===========================================================================*/
 | |
| PUBLIC int do_nice(message *m_ptr)
 | |
| {
 | |
| /* Change process priority or stop the process. */
 | |
|   int proc_nr, pri, new_q ;
 | |
|   register struct proc *rp;
 | |
| 
 | |
|   /* Extract the message parameters and do sanity checking. */
 | |
|   if(!isokendpt(m_ptr->PR_ENDPT, &proc_nr)) return EINVAL;
 | |
|   if (iskerneln(proc_nr)) return(EPERM);
 | |
|   pri = m_ptr->PR_PRIORITY;
 | |
|   rp = proc_addr(proc_nr);
 | |
| 
 | |
|   /* The value passed in is currently between PRIO_MIN and PRIO_MAX. 
 | |
|    * We have to scale this between MIN_USER_Q and MAX_USER_Q to match 
 | |
|    * the kernel's scheduling queues.
 | |
|    */
 | |
|   if (pri < PRIO_MIN || pri > PRIO_MAX) return(EINVAL);
 | |
| 
 | |
|   new_q = MAX_USER_Q + (pri-PRIO_MIN) * (MIN_USER_Q-MAX_USER_Q+1) / 
 | |
|       (PRIO_MAX-PRIO_MIN+1);
 | |
|   if (new_q < MAX_USER_Q) new_q = MAX_USER_Q;	/* shouldn't happen */
 | |
|   if (new_q > MIN_USER_Q) new_q = MIN_USER_Q;	/* shouldn't happen */
 | |
| 
 | |
|   /* Make sure the process is not running while changing its priority. 
 | |
|    * Put the process back in its new queue if it is runnable.
 | |
|    */
 | |
|   RTS_LOCK_SET(rp, RTS_SYS_LOCK);
 | |
|   rp->p_max_priority = rp->p_priority = new_q;
 | |
|   RTS_LOCK_UNSET(rp, RTS_SYS_LOCK);
 | |
| 
 | |
|   return(OK);
 | |
| }
 | |
| 
 | |
| #endif /* USE_NICE */
 | |
| 
 |