mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-11-03 20:53:13 +03:00 
			
		
		
		
	This patch makes sysdeps/unix/sysv/linux code assume the prlimit64 syscall is always available, given the minimum of a 3.2 kernel. __ASSUME_PRLIMIT64, which in fact was no longer used, is removed. Code conditional on __NR_prlimit64 being defined is made unconditional. Fallback code for the case where prlimit64 produces an ENOSYS error is removed, substantially simplifying some functions. Tested for x86_64 and x86. * sysdeps/unix/sysv/linux/kernel-features.h (__ASSUME_PRLIMIT64): Remove macro. * sysdeps/unix/sysv/linux/getrlimit64.c (__getrlimit64): Assume prlimit64 is always available and does not give an ENOSYS error. * sysdeps/unix/sysv/linux/prlimit.c [__NR_prlimit64]: Make code unconditional. [!__NR_prlimit64]: Remove conditional code. * sysdeps/unix/sysv/linux/setrlimit.c (__setrlimit): Assume prlimit64 is always available and does not give an ENOSYS error. * sysdeps/unix/sysv/linux/setrlimit64.c (__setrlimit64): Likewise.
		
			
				
	
	
		
			88 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* Linux getrlimit64 implementation (64 bits rlim_t).
 | 
						|
   Copyright (C) 2010-2017 Free Software Foundation, Inc.
 | 
						|
   This file is part of the GNU C Library.
 | 
						|
 | 
						|
   The GNU C Library is free software; you can redistribute it and/or
 | 
						|
   modify it under the terms of the GNU Lesser General Public
 | 
						|
   License as published by the Free Software Foundation; either
 | 
						|
   version 2.1 of the License, or (at your option) any later version.
 | 
						|
 | 
						|
   The GNU C Library is distributed in the hope that it will be useful,
 | 
						|
   but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | 
						|
   Lesser General Public License for more details.
 | 
						|
 | 
						|
   You should have received a copy of the GNU Lesser General Public
 | 
						|
   License along with the GNU C Library; if not, see
 | 
						|
   <http://www.gnu.org/licenses/>.  */
 | 
						|
 | 
						|
#include <errno.h>
 | 
						|
#include <sys/types.h>
 | 
						|
#include <shlib-compat.h>
 | 
						|
 | 
						|
/* Add this redirection so the strong_alias for __RLIM_T_MATCHES_RLIM64_T
 | 
						|
   linking getlimit64 to {__}getrlimit does not throw a type error.  */
 | 
						|
#undef getrlimit
 | 
						|
#undef __getrlimit
 | 
						|
#define getrlimit getrlimit_redirect
 | 
						|
#define __getrlimit __getrlimit_redirect
 | 
						|
#include <sys/resource.h>
 | 
						|
#undef getrlimit
 | 
						|
#undef __getrlimit
 | 
						|
 | 
						|
/* Put the soft and hard limits for RESOURCE in *RLIMITS.
 | 
						|
   Returns 0 if successful, -1 if not (and sets errno).  */
 | 
						|
int
 | 
						|
__getrlimit64 (enum __rlimit_resource resource, struct rlimit64 *rlimits)
 | 
						|
{
 | 
						|
  return INLINE_SYSCALL_CALL (prlimit64, 0, resource, NULL, rlimits);
 | 
						|
}
 | 
						|
libc_hidden_def (__getrlimit64)
 | 
						|
 | 
						|
#if __RLIM_T_MATCHES_RLIM64_T
 | 
						|
/* If both rlim_t and rlimt64_t are essentially the same type we can use
 | 
						|
   alias both interfaces.  */
 | 
						|
strong_alias (__getrlimit64, __GI_getrlimit)
 | 
						|
strong_alias (__getrlimit64, __GI___getrlimit)
 | 
						|
strong_alias (__getrlimit64, __getrlimit)
 | 
						|
weak_alias (__getrlimit64, getrlimit)
 | 
						|
/* And there is no need for compat symbols.  */
 | 
						|
# undef SHLIB_COMPAT
 | 
						|
# define SHLIB_COMPAT(a, b, c) 0
 | 
						|
#endif
 | 
						|
 | 
						|
#if SHLIB_COMPAT (libc, GLIBC_2_1, GLIBC_2_2)
 | 
						|
/* Back compatible 2GiB limited rlimit.  */
 | 
						|
extern int __new_getrlimit (enum __rlimit_resource, struct rlimit *);
 | 
						|
 | 
						|
int
 | 
						|
attribute_compat_text_section
 | 
						|
__old_getrlimit64 (enum __rlimit_resource resource, struct rlimit64 *rlimits)
 | 
						|
{
 | 
						|
# if __RLIM_T_MATCHES_RLIM64_T
 | 
						|
#  define rlimits32 (*rlimits)
 | 
						|
# else
 | 
						|
  struct rlimit rlimits32;
 | 
						|
# endif
 | 
						|
 | 
						|
  if (__new_getrlimit (resource, &rlimits32) < 0)
 | 
						|
    return -1;
 | 
						|
 | 
						|
  if (rlimits32.rlim_cur == RLIM_INFINITY)
 | 
						|
    rlimits->rlim_cur = RLIM64_INFINITY >> 1;
 | 
						|
  else
 | 
						|
    rlimits->rlim_cur = rlimits32.rlim_cur;
 | 
						|
  if (rlimits32.rlim_max == RLIM_INFINITY)
 | 
						|
    rlimits->rlim_max = RLIM64_INFINITY >> 1;
 | 
						|
  else
 | 
						|
    rlimits->rlim_max = rlimits32.rlim_max;
 | 
						|
 | 
						|
  return 0;
 | 
						|
}
 | 
						|
versioned_symbol (libc, __getrlimit64, getrlimit64, GLIBC_2_2);
 | 
						|
compat_symbol (libc, __old_getrlimit64, getrlimit64, GLIBC_2_1);
 | 
						|
#else
 | 
						|
weak_alias (__getrlimit64, getrlimit64)
 | 
						|
libc_hidden_weak (getrlimit64)
 | 
						|
#endif
 |