diff options
| author | Kirill Smelkov <kirr@mns.spb.ru> | 2014-03-27 18:22:50 +0400 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2014-03-27 11:54:01 -0700 | 
| commit | 61f76a3612db199a9eb9090c2605d8fc35ffc41c (patch) | |
| tree | fc5e216179e5fd11343f0b59b77b3da354ece5c9 /git-compat-util.h | |
| parent | 12cd81743dc4645ef909b0c38582f5714c9a8ff7 (diff) | |
| download | git-61f76a3612db199a9eb9090c2605d8fc35ffc41c.tar.gz | |
Portable alloca for Git
In the next patch we'll have to use alloca() for performance reasons,
but since alloca is non-standardized and is not portable, let's have a
trick with compatibility wrappers:
1. at configure time, determine, do we have working alloca() through
   alloca.h, and define
    #define HAVE_ALLOCA_H
   if yes.
2. in code
    #ifdef HAVE_ALLOCA_H
    # include <alloca.h>
    # define xalloca(size)      (alloca(size))
    # define xalloca_free(p)    do {} while(0)
    #else
    # define xalloca(size)      (xmalloc(size))
    # define xalloca_free(p)    (free(p))
    #endif
   and use it like
   func() {
       p = xalloca(size);
       ...
       xalloca_free(p);
   }
This way, for systems, where alloca is available, we'll have optimal
on-stack allocations with fast executions. On the other hand, on
systems, where alloca is not available, this gracefully fallbacks to
xmalloc/free.
Both autoconf and config.mak.uname configurations were updated. For
autoconf, we are not bothering considering cases, when no alloca.h is
available, but alloca() works some other way - its simply alloca.h is
available and works or not, everything else is deep legacy.
For config.mak.uname, I've tried to make my almost-sure guess for where
alloca() is available, but since I only have access to Linux it is the
only change I can be sure about myself, with relevant to other changed
systems people Cc'ed.
NOTE
SunOS and Windows had explicit -DHAVE_ALLOCA_H in their configurations.
I've changed that to now-common HAVE_ALLOCA_H=YesPlease which should be
correct.
Cc: Brandon Casey <drafnel@gmail.com>
Cc: Marius Storm-Olsen <mstormo@gmail.com>
Cc: Johannes Sixt <j6t@kdbg.org>
Cc: Johannes Schindelin <Johannes.Schindelin@gmx.de>
Cc: Ramsay Jones <ramsay@ramsay1.demon.co.uk>
Cc: Gerrit Pape <pape@smarden.org>
Cc: Petr Salinger <Petr.Salinger@seznam.cz>
Cc: Jonathan Nieder <jrnieder@gmail.com>
Acked-by: Thomas Schwinge <thomas@codesourcery.com> (GNU Hurd changes)
Signed-off-by: Kirill Smelkov <kirr@mns.spb.ru>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'git-compat-util.h')
| -rw-r--r-- | git-compat-util.h | 8 | 
1 files changed, 8 insertions, 0 deletions
| diff --git a/git-compat-util.h b/git-compat-util.h index cbd86c37f5..63b2b3bb47 100644 --- a/git-compat-util.h +++ b/git-compat-util.h @@ -526,6 +526,14 @@ extern void release_pack_memory(size_t);  typedef void (*try_to_free_t)(size_t);  extern try_to_free_t set_try_to_free_routine(try_to_free_t); +#ifdef HAVE_ALLOCA_H +# include <alloca.h> +# define xalloca(size)      (alloca(size)) +# define xalloca_free(p)    do {} while (0) +#else +# define xalloca(size)      (xmalloc(size)) +# define xalloca_free(p)    (free(p)) +#endif  extern char *xstrdup(const char *str);  extern void *xmalloc(size_t size);  extern void *xmallocz(size_t size); | 
