X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=xmalloc.c;h=2344d2d54ec62edfe13b4549aa09d48cc8bfb748;hb=0001803f0b9523c94fa2ede48eaecb047fef4524;hp=58c337e99e2ef4a895fc7b800eb8228b52cde75c;hpb=89a92869e56aba4e4cab2d639c00a86f0545c862;p=platform%2Fupstream%2Fbash.git diff --git a/xmalloc.c b/xmalloc.c index 58c337e..2344d2d 100644 --- a/xmalloc.c +++ b/xmalloc.c @@ -62,18 +62,38 @@ static size_t allocated; /* **************************************************************** */ #if defined (HAVE_SBRK) +#define FINDBRK() \ +do { \ + if (brkfound == 0) \ + { \ + lbreak = (PTR_T)sbrk (0); \ + brkfound++; \ + } \ +} while (0) + static size_t findbrk () { - if (brkfound == 0) - { - lbreak = (PTR_T)sbrk (0); - brkfound++; - } + FINDBRK(); return (char *)sbrk (0) - (char *)lbreak; } +#else +#define FINDBRK() #endif +static void +allocerr (func, bytes) + const char *func; + size_t bytes; +{ +#if defined (HAVE_SBRK) + allocated = findbrk (); + fatal_error (_("%s: cannot allocate %lu bytes (%lu bytes allocated)"), func, (unsigned long)bytes, (unsigned long)allocated); +#else + fatal_error (_("%s: cannot allocate %lu bytes"), func, (unsigned long)bytes); +#endif /* !HAVE_SBRK */ +} + /* Return a pointer to free()able block of memory large enough to hold BYTES number of bytes. If the memory cannot be allocated, print an error message and abort. */ @@ -83,17 +103,16 @@ xmalloc (bytes) { PTR_T temp; +#if defined (DEBUG) + if (bytes == 0) + internal_warning("xmalloc: size argument is 0"); +#endif + + FINDBRK(); temp = malloc (bytes); if (temp == 0) - { -#if defined (HAVE_SBRK) - allocated = findbrk (); - fatal_error (_("xmalloc: cannot allocate %lu bytes (%lu bytes allocated)"), (unsigned long)bytes, (unsigned long)allocated); -#else - fatal_error (_("xmalloc: cannot allocate %lu bytes"), (unsigned long)bytes); -#endif /* !HAVE_SBRK */ - } + allocerr ("xmalloc", bytes); return (temp); } @@ -105,17 +124,16 @@ xrealloc (pointer, bytes) { PTR_T temp; +#if defined (DEBUG) + if (bytes == 0) + internal_warning("xrealloc: size argument is 0"); +#endif + + FINDBRK(); temp = pointer ? realloc (pointer, bytes) : malloc (bytes); if (temp == 0) - { -#if defined (HAVE_SBRK) - allocated = findbrk (); - fatal_error (_("xrealloc: cannot reallocate %lu bytes (%lu bytes allocated)"), (unsigned long)bytes, (unsigned long)allocated); -#else - fatal_error (_("xrealloc: cannot allocate %lu bytes"), (unsigned long)bytes); -#endif /* !HAVE_SBRK */ - } + allocerr ("xrealloc", bytes); return (temp); } @@ -133,6 +151,21 @@ xfree (string) #ifdef USING_BASH_MALLOC #include +static void +sh_allocerr (func, bytes, file, line) + const char *func; + size_t bytes; + char *file; + int line; +{ +#if defined (HAVE_SBRK) + allocated = findbrk (); + fatal_error (_("%s: %s:%d: cannot allocate %lu bytes (%lu bytes allocated)"), func, file, line, (unsigned long)bytes, (unsigned long)allocated); +#else + fatal_error (_("%s: %s:%d: cannot allocate %lu bytes"), func, file, line, (unsigned long)bytes); +#endif /* !HAVE_SBRK */ +} + PTR_T sh_xmalloc (bytes, file, line) size_t bytes; @@ -141,17 +174,16 @@ sh_xmalloc (bytes, file, line) { PTR_T temp; +#if defined (DEBUG) + if (bytes == 0) + internal_warning("xmalloc: %s:%d: size argument is 0", file, line); +#endif + + FINDBRK(); temp = sh_malloc (bytes, file, line); if (temp == 0) - { -#if defined (HAVE_SBRK) - allocated = findbrk (); - fatal_error (_("xmalloc: %s:%d: cannot allocate %lu bytes (%lu bytes allocated)"), file, line, (unsigned long)bytes, (unsigned long)allocated); -#else - fatal_error (_("xmalloc: %s:%d: cannot allocate %lu bytes"), file, line, (unsigned long)bytes); -#endif /* !HAVE_SBRK */ - } + sh_allocerr ("xmalloc", bytes, file, line); return (temp); } @@ -165,17 +197,16 @@ sh_xrealloc (pointer, bytes, file, line) { PTR_T temp; +#if defined (DEBUG) + if (bytes == 0) + internal_warning("xrealloc: %s:%d: size argument is 0", file, line); +#endif + + FINDBRK(); temp = pointer ? sh_realloc (pointer, bytes, file, line) : sh_malloc (bytes, file, line); if (temp == 0) - { -#if defined (HAVE_SBRK) - allocated = findbrk (); - fatal_error (_("xrealloc: %s:%d: cannot reallocate %lu bytes (%lu bytes allocated)"), file, line, (unsigned long)bytes, (unsigned long)allocated); -#else - fatal_error (_("xrealloc: %s:%d: cannot allocate %lu bytes"), file, line, (unsigned long)bytes); -#endif /* !HAVE_SBRK */ - } + sh_allocerr ("xrealloc", bytes, file, line); return (temp); }