| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 | /* vi: set sw=4 ts=4: *//* * nice() for uClibc * * Copyright (C) 2005 by Manuel Novoa III <mjn3@codepoet.org> * Copyright (C) 2000-2006 Erik Andersen <andersen@uclibc.org> * * Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball. */#include <sys/syscall.h>#include <unistd.h>#include <sys/resource.h>libc_hidden_proto(getpriority)#ifdef __NR_nice# define __NR___syscall_nice __NR_nicestatic inline _syscall1(int, __syscall_nice, int, incr);#else# include <limits.h>libc_hidden_proto(setpriority)static inline int int_add_no_wrap(int a, int b){	int s = a + b;	if (b < 0) {		if (s > a) s = INT_MIN;	} else {		if (s < a) s = INT_MAX;	}	return s;}static inline int __syscall_nice(int incr){	int old_priority;# if 1	/* This should never fail. */	old_priority = getpriority(PRIO_PROCESS, 0);# else	/* But if you want to be paranoid... */	int old_errno;	old_errno = errno;	__set_errno(0);	old_priority = getpriority(PRIO_PROCESS, 0);	if ((old_priority == -1) && errno) {		return -1;	}	__set_errno(old_errno);# endif	if (setpriority(PRIO_PROCESS, 0, int_add_no_wrap(old_priority, incr))) {		__set_errno(EPERM);	/* SUSv3 mandates EPERM for nice failure. */		return -1;	}	return 0;}#endifint nice(int incr){	if (__syscall_nice(incr)) {		return -1;	}	return getpriority(PRIO_PROCESS, 0);}
 |