mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			
		
			
				
	
	
		
			185 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			185 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
/* memory allocation routines with error checking.
 | 
						|
   Copyright 1989, 90, 91, 92, 93, 94 Free Software Foundation, Inc.
 | 
						|
   
 | 
						|
This file is part of the libiberty library.
 | 
						|
Libiberty is free software; you can redistribute it and/or
 | 
						|
modify it under the terms of the GNU Library General Public
 | 
						|
License as published by the Free Software Foundation; either
 | 
						|
version 2 of the License, or (at your option) any later version.
 | 
						|
 | 
						|
Libiberty 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
 | 
						|
Library General Public License for more details.
 | 
						|
 | 
						|
You should have received a copy of the GNU Library General Public
 | 
						|
License along with libiberty; see the file COPYING.LIB.  If
 | 
						|
not, write to the Free Software Foundation, Inc., 51 Franklin Street - Fifth Floor,
 | 
						|
Boston, MA 02110-1301, USA.  */
 | 
						|
 | 
						|
/*
 | 
						|
 | 
						|
@deftypefn Replacement void* xmalloc (size_t)
 | 
						|
 | 
						|
Allocate memory without fail.  If @code{malloc} fails, this will print
 | 
						|
a message to @code{stderr} (using the name set by
 | 
						|
@code{xmalloc_set_program_name},
 | 
						|
if any) and then call @code{xexit}.  Note that it is therefore safe for
 | 
						|
a program to contain @code{#define malloc xmalloc} in its source.
 | 
						|
 | 
						|
@end deftypefn
 | 
						|
 | 
						|
@deftypefn Replacement void* xrealloc (void *@var{ptr}, size_t @var{size})
 | 
						|
Reallocate memory without fail.  This routine functions like @code{realloc},
 | 
						|
but will behave the same as @code{xmalloc} if memory cannot be found.
 | 
						|
 | 
						|
@end deftypefn
 | 
						|
 | 
						|
@deftypefn Replacement void* xcalloc (size_t @var{nelem}, size_t @var{elsize})
 | 
						|
 | 
						|
Allocate memory without fail, and set it to zero.  This routine functions
 | 
						|
like @code{calloc}, but will behave the same as @code{xmalloc} if memory
 | 
						|
cannot be found.
 | 
						|
 | 
						|
@end deftypefn
 | 
						|
 | 
						|
@deftypefn Replacement void xmalloc_set_program_name (const char *@var{name})
 | 
						|
 | 
						|
You can use this to set the name of the program used by
 | 
						|
@code{xmalloc_failed} when printing a failure message.
 | 
						|
 | 
						|
@end deftypefn
 | 
						|
 | 
						|
@deftypefn Replacement void xmalloc_failed (size_t)
 | 
						|
 | 
						|
This function is not meant to be called by client code, and is listed
 | 
						|
here for completeness only.  If any of the allocation routines fail, this
 | 
						|
function will be called to print an error message and terminate execution.
 | 
						|
 | 
						|
@end deftypefn
 | 
						|
 | 
						|
*/
 | 
						|
 | 
						|
#ifdef HAVE_CONFIG_H
 | 
						|
#include "config.h"
 | 
						|
#endif
 | 
						|
#include "ansidecl.h"
 | 
						|
#include "libiberty.h"
 | 
						|
 | 
						|
#include <stdio.h>
 | 
						|
 | 
						|
#include <stddef.h>
 | 
						|
 | 
						|
#if VMS
 | 
						|
#include <stdlib.h>
 | 
						|
#include <unixlib.h>
 | 
						|
#else
 | 
						|
/* For systems with larger pointers than ints, these must be declared.  */
 | 
						|
#  if HAVE_STDLIB_H && HAVE_UNISTD_H && HAVE_DECL_MALLOC \
 | 
						|
      && HAVE_DECL_REALLOC && HAVE_DECL_CALLOC && HAVE_DECL_SBRK
 | 
						|
#    include <stdlib.h>
 | 
						|
#    include <unistd.h>
 | 
						|
#  else
 | 
						|
#    ifdef __cplusplus
 | 
						|
extern "C" {
 | 
						|
#    endif /* __cplusplus */
 | 
						|
void *malloc (size_t);
 | 
						|
void *realloc (void *, size_t);
 | 
						|
void *calloc (size_t, size_t);
 | 
						|
void *sbrk (ptrdiff_t);
 | 
						|
#    ifdef __cplusplus
 | 
						|
}
 | 
						|
#    endif /* __cplusplus */
 | 
						|
#  endif /* HAVE_STDLIB_H ...  */
 | 
						|
#endif /* VMS */
 | 
						|
 | 
						|
/* The program name if set.  */
 | 
						|
static const char *name = "";
 | 
						|
 | 
						|
#ifdef HAVE_SBRK
 | 
						|
/* The initial sbrk, set when the program name is set. Not used for win32
 | 
						|
   ports other than cygwin32.  */
 | 
						|
static char *first_break = NULL;
 | 
						|
#endif /* HAVE_SBRK */
 | 
						|
 | 
						|
void
 | 
						|
xmalloc_set_program_name (const char *s)
 | 
						|
{
 | 
						|
  name = s;
 | 
						|
#ifdef HAVE_SBRK
 | 
						|
  /* Win32 ports other than cygwin32 don't have brk() */
 | 
						|
  if (first_break == NULL)
 | 
						|
    first_break = (char *) sbrk (0);
 | 
						|
#endif /* HAVE_SBRK */
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
xmalloc_failed (size_t size)
 | 
						|
{
 | 
						|
#ifdef HAVE_SBRK
 | 
						|
  extern char **environ;
 | 
						|
  size_t allocated;
 | 
						|
 | 
						|
  if (first_break != NULL)
 | 
						|
    allocated = (char *) sbrk (0) - first_break;
 | 
						|
  else
 | 
						|
    allocated = (char *) sbrk (0) - (char *) &environ;
 | 
						|
  fprintf (stderr,
 | 
						|
	   "\n%s%sout of memory allocating %lu bytes after a total of %lu bytes\n",
 | 
						|
	   name, *name ? ": " : "",
 | 
						|
	   (unsigned long) size, (unsigned long) allocated);
 | 
						|
#else /* HAVE_SBRK */
 | 
						|
  fprintf (stderr,
 | 
						|
	   "\n%s%sout of memory allocating %lu bytes\n",
 | 
						|
	   name, *name ? ": " : "",
 | 
						|
	   (unsigned long) size);
 | 
						|
#endif /* HAVE_SBRK */
 | 
						|
  xexit (1);
 | 
						|
}  
 | 
						|
 | 
						|
PTR
 | 
						|
xmalloc (size_t size)
 | 
						|
{
 | 
						|
  PTR newmem;
 | 
						|
 | 
						|
  if (size == 0)
 | 
						|
    size = 1;
 | 
						|
  newmem = malloc (size);
 | 
						|
  if (!newmem)
 | 
						|
    xmalloc_failed (size);
 | 
						|
 | 
						|
  return (newmem);
 | 
						|
}
 | 
						|
 | 
						|
PTR
 | 
						|
xcalloc (size_t nelem, size_t elsize)
 | 
						|
{
 | 
						|
  PTR newmem;
 | 
						|
 | 
						|
  if (nelem == 0 || elsize == 0)
 | 
						|
    nelem = elsize = 1;
 | 
						|
 | 
						|
  newmem = calloc (nelem, elsize);
 | 
						|
  if (!newmem)
 | 
						|
    xmalloc_failed (nelem * elsize);
 | 
						|
 | 
						|
  return (newmem);
 | 
						|
}
 | 
						|
 | 
						|
PTR
 | 
						|
xrealloc (PTR oldmem, size_t size)
 | 
						|
{
 | 
						|
  PTR newmem;
 | 
						|
 | 
						|
  if (size == 0)
 | 
						|
    size = 1;
 | 
						|
  if (!oldmem)
 | 
						|
    newmem = malloc (size);
 | 
						|
  else
 | 
						|
    newmem = realloc (oldmem, size);
 | 
						|
  if (!newmem)
 | 
						|
    xmalloc_failed (size);
 | 
						|
 | 
						|
  return (newmem);
 | 
						|
}
 |