summaryrefslogtreecommitdiff
path: root/gold
diff options
context:
space:
mode:
authorIan Lance Taylor <ian@airs.com>2009-03-27 23:21:09 +0000
committerIan Lance Taylor <ian@airs.com>2009-03-27 23:21:09 +0000
commit2f35ab9b82f18c1ba7b27fb804859d6ed8482796 (patch)
tree1456d74d906200b979fa5b7c79861b1ae3cb6591 /gold
parent10e1b6bb907a5ec314012ebb75c94a8e5b29b145 (diff)
downloadbinutils-gdb-2f35ab9b82f18c1ba7b27fb804859d6ed8482796.tar.gz
* mremap.c: New file.
* configure.ac: Call AC_REPLACE_FUNCS on mremap. * gold.h (MREMAP_MAYMOVE): Define if HAVE_MREMAP is not defined. (mremap): Declare if HAVE_MREMAP is not defined. * configure, Makefile.in, config.in: Rebuild.
Diffstat (limited to 'gold')
-rw-r--r--gold/ChangeLog8
-rw-r--r--gold/Makefile.in3
-rw-r--r--gold/config.in3
-rwxr-xr-xgold/configure3
-rw-r--r--gold/configure.ac2
-rw-r--r--gold/gold.h5
-rw-r--r--gold/mremap.c57
7 files changed, 78 insertions, 3 deletions
diff --git a/gold/ChangeLog b/gold/ChangeLog
index 0f4063cb221..f6f638fb94e 100644
--- a/gold/ChangeLog
+++ b/gold/ChangeLog
@@ -1,3 +1,11 @@
+2009-03-27 Ian Lance Taylor <iant@google.com>
+
+ * mremap.c: New file.
+ * configure.ac: Call AC_REPLACE_FUNCS on mremap.
+ * gold.h (MREMAP_MAYMOVE): Define if HAVE_MREMAP is not defined.
+ (mremap): Declare if HAVE_MREMAP is not defined.
+ * configure, Makefile.in, config.in: Rebuild.
+
2009-03-27 Cary Coutant <ccoutant@google.com>
* powerpc.cc (Target_powerpc::check_non_pic): Assert that output is
diff --git a/gold/Makefile.in b/gold/Makefile.in
index 4976af916d3..8c1d00d7a52 100644
--- a/gold/Makefile.in
+++ b/gold/Makefile.in
@@ -50,7 +50,7 @@ DIST_COMMON = README $(am__configure_deps) $(srcdir)/../config.guess \
$(srcdir)/../mkinstalldirs $(srcdir)/Makefile.am \
$(srcdir)/Makefile.in $(srcdir)/config.in \
$(top_srcdir)/configure $(top_srcdir)/po/Make-in ChangeLog \
- NEWS TODO ftruncate.c pread.c yyscript.c yyscript.h
+ NEWS TODO ftruncate.c mremap.c pread.c yyscript.c yyscript.h
subdir = .
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
am__aclocal_m4_deps = $(top_srcdir)/../config/depstand.m4 \
@@ -536,6 +536,7 @@ distclean-compile:
-rm -f *.tab.c
@AMDEP_TRUE@@am__include@ @am__quote@$(DEPDIR)/ftruncate.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@$(DEPDIR)/mremap.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@$(DEPDIR)/pread.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/archive.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/binary.Po@am__quote@
diff --git a/gold/config.in b/gold/config.in
index 9e41cfb1cef..93264cfc665 100644
--- a/gold/config.in
+++ b/gold/config.in
@@ -46,6 +46,9 @@
/* Define to 1 if you have the <memory.h> header file. */
#undef HAVE_MEMORY_H
+/* Define to 1 if you have the `mremap' function. */
+#undef HAVE_MREMAP
+
/* Define if compiler supports #pragma omp threadprivate */
#undef HAVE_OMP_SUPPORT
diff --git a/gold/configure b/gold/configure
index 2b49c2ec5cb..62359040305 100755
--- a/gold/configure
+++ b/gold/configure
@@ -5167,7 +5167,8 @@ done
-for ac_func in pread ftruncate
+
+for ac_func in pread ftruncate mremap
do
as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh`
echo "$as_me:$LINENO: checking for $ac_func" >&5
diff --git a/gold/configure.ac b/gold/configure.ac
index a770f877e9a..335ecb3d75a 100644
--- a/gold/configure.ac
+++ b/gold/configure.ac
@@ -312,7 +312,7 @@ LFS_CFLAGS="-D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64"
AC_SUBST(LFS_CFLAGS)
AC_CHECK_FUNCS(chsize)
-AC_REPLACE_FUNCS(pread ftruncate)
+AC_REPLACE_FUNCS(pread ftruncate mremap)
# Link in zlib if we can. This allows us to write compressed sections.
AC_SEARCH_LIBS(zlibVersion, z, [AC_CHECK_HEADERS(zlib.h)])
diff --git a/gold/gold.h b/gold/gold.h
index 780561d4219..dc8da551ada 100644
--- a/gold/gold.h
+++ b/gold/gold.h
@@ -125,6 +125,11 @@ extern "C" ssize_t pread(int, void*, size_t, off_t);
extern "C" int ftruncate(int, off_t);
#endif
+#ifndef HAVE_MREMAP
+#define MREMAP_MAYMOVE 1
+extern "C" void *mremap (void *, size_t, size_t, int, ...);
+#endif
+
namespace gold
{
diff --git a/gold/mremap.c b/gold/mremap.c
new file mode 100644
index 00000000000..caa7bc76b56
--- /dev/null
+++ b/gold/mremap.c
@@ -0,0 +1,57 @@
+/* mremap.c -- version of mremap for gold. */
+
+/* Copyright 2009 Free Software Foundation, Inc.
+ Written by Ian Lance Taylor <iant@google.com>.
+
+ This file is part of gold.
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 3 of the License, or
+ (at your option) any later version.
+
+ This program 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 General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
+ MA 02110-1301, USA. */
+
+#include "config.h"
+#include "ansidecl.h"
+
+#include <string.h>
+#include <sys/types.h>
+#include <sys/mman.h>
+
+/* This file implements mremap for systems which don't have it. The
+ gold code requires support for mmap. However, there are systems
+ which have mmap but not mremap. This is not a general replacement
+ for mremap; it only supports the features which are required for
+ gold. In particular, we assume that the MREMAP_MAYMOVE flag is
+ set. */
+
+/* Some BSD systems still use MAP_ANON instead of MAP_ANONYMOUS. */
+
+#ifndef MAP_ANONYMOUS
+# define MAP_ANONYMOUS MAP_ANON
+#endif
+
+void *
+mremap (void *old_address, size_t old_size, size_t new_size,
+ int flags ATTRIBUTE_UNUSED, ...)
+{
+ void *ret;
+
+ ret = mmap (0, new_size, PROT_READ | PROT_WRITE,
+ MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
+ if (ret == MAP_FAILED)
+ return ret;
+ memcpy (ret, old_address,
+ old_size < new_size ? old_size : new_size);
+ (void) munmap (old_address, old_size);
+ return ret;
+}