| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 | /* vi: set sw=4 ts=4: *//* * setrlimit() for uClibc * * 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 <sys/resource.h>#include <bits/wordsize.h>/* Only wrap setrlimit if the new usetrlimit is not present and setrlimit sucks */#if defined(__NR_usetrlimit)/* just call usetrlimit() */# define __NR___syscall_usetrlimit __NR_usetrlimitstatic __always_inline_syscall2(int, __syscall_usetrlimit, enum __rlimit_resource, resource,          const struct rlimit *, rlim)int setrlimit(__rlimit_resource_t resource, struct rlimit *rlimits){	return __syscall_usetrlimit(resource, rlimits);}#elif !defined(__UCLIBC_HANDLE_OLDER_RLIMIT__)/* We don't need to wrap setrlimit() */_syscall2(int, setrlimit, __rlimit_resource_t, resource,		const struct rlimit *, rlim)#else# define __need_NULL# include <stddef.h># include <errno.h># include <sys/param.h>/* we have to handle old style setrlimit() */# define __NR___syscall_setrlimit __NR_setrlimitstatic __always_inline_syscall2(int, __syscall_setrlimit, int, resource, const struct rlimit *, rlim)int setrlimit(__rlimit_resource_t resource, const struct rlimit *rlimits){	struct rlimit rlimits_small;	if (rlimits == NULL) {		__set_errno(EINVAL);		return -1;	}	/* We might have to correct the limits values.  Since the old values	 * were signed the new values might be too large.  */	rlimits_small.rlim_cur = MIN((unsigned long int) rlimits->rlim_cur,								  RLIM_INFINITY >> 1);	rlimits_small.rlim_max = MIN((unsigned long int) rlimits->rlim_max,								  RLIM_INFINITY >> 1);	return __syscall_setrlimit(resource, &rlimits_small);}#endiflibc_hidden_def(setrlimit)#if __WORDSIZE == 64strong_alias_untyped(setrlimit, setrlimit64)#endif
 |