Skip to content

Commit

Permalink
Merge pull request #1038 from stilor/make-fix-glob
Browse files Browse the repository at this point in the history
Fix make's glob() with new glibc
  • Loading branch information
stilor committed Sep 28, 2018
2 parents 5f18c3e + 9d7c783 commit d0dd654
Show file tree
Hide file tree
Showing 14 changed files with 188 additions and 40 deletions.
39 changes: 39 additions & 0 deletions packages/make/4.2.1/0000-glob-v2.patch
@@ -0,0 +1,39 @@
commit 48c8a116a914a325a0497721f5d8b58d5bba34d4
Author: Paul Smith <psmith@gnu.org>
Date: Sun Nov 19 15:09:16 2017 -0500

* configure.ac: Support GLIBC glob interface version 2

---
configure | 3 +--
configure.ac | 3 +--
2 files changed, 2 insertions(+), 4 deletions(-)

--- a/configure.ac
+++ b/configure.ac
@@ -399,10 +399,9 @@
#include <glob.h>
#include <fnmatch.h>

-#define GLOB_INTERFACE_VERSION 1
#if !defined _LIBC && defined __GNU_LIBRARY__ && __GNU_LIBRARY__ > 1
# include <gnu-versions.h>
-# if _GNU_GLOB_INTERFACE_VERSION == GLOB_INTERFACE_VERSION
+# if _GNU_GLOB_INTERFACE_VERSION == 1 || _GNU_GLOB_INTERFACE_VERSION == 2
gnu glob
# endif
#endif],
--- a/configure
+++ b/configure
@@ -11481,10 +11481,9 @@
#include <glob.h>
#include <fnmatch.h>

-#define GLOB_INTERFACE_VERSION 1
#if !defined _LIBC && defined __GNU_LIBRARY__ && __GNU_LIBRARY__ > 1
# include <gnu-versions.h>
-# if _GNU_GLOB_INTERFACE_VERSION == GLOB_INTERFACE_VERSION
+# if _GNU_GLOB_INTERFACE_VERSION == 1 || _GNU_GLOB_INTERFACE_VERSION == 2
gnu glob
# endif
#endif
64 changes: 64 additions & 0 deletions packages/make/4.2.1/0001-glob-v2-gl_lstat.patch
@@ -0,0 +1,64 @@
commit 193f1e81edd6b1b56b0eb0ff8aa4b41c7b4257b4
Author: Paul Eggert <eggert@cs.ucla.edu>
Date: Sun Sep 24 09:12:58 2017 -0400

glob: Do not assume glibc glob internals.

It has been proposed that glibc glob start using gl_lstat,
which the API allows it to do. GNU 'make' should not get in
the way of this. See:
https://sourceware.org/ml/libc-alpha/2017-09/msg00409.html

* dir.c (local_lstat): New function, like local_stat.
(dir_setup_glob): Use it to initialize gl_lstat too, as the API
requires.

---
dir.c | 29 +++++++++++++++++++++++++++--
1 file changed, 27 insertions(+), 2 deletions(-)

--- a/dir.c
+++ b/dir.c
@@ -1299,15 +1299,40 @@
}
#endif

+/* Similarly for lstat. */
+#if !defined(lstat) && !defined(WINDOWS32) || defined(VMS)
+# ifndef VMS
+# ifndef HAVE_SYS_STAT_H
+int lstat (const char *path, struct stat *sbuf);
+# endif
+# else
+ /* We are done with the fake lstat. Go back to the real lstat */
+# ifdef lstat
+# undef lstat
+# endif
+# endif
+# define local_lstat lstat
+#elif defined(WINDOWS32)
+/* Windows doesn't support lstat(). */
+# define local_lstat local_stat
+#else
+static int
+local_lstat (const char *path, struct stat *buf)
+{
+ int e;
+ EINTRLOOP (e, lstat (path, buf));
+ return e;
+}
+#endif
+
void
dir_setup_glob (glob_t *gl)
{
gl->gl_opendir = open_dirstream;
gl->gl_readdir = read_dirstream;
gl->gl_closedir = free;
+ gl->gl_lstat = local_lstat;
gl->gl_stat = local_stat;
- /* We don't bother setting gl_lstat, since glob never calls it.
- The slot is only there for compatibility with 4.4 BSD. */
}

void
1 change: 0 additions & 1 deletion scripts/build/libc/glibc.sh
Expand Up @@ -26,7 +26,6 @@ do_libc_extract() {
CT_DoExecLog ALL ln -sf "${CT_GLIBC_PORTS_SRC_DIR}/${CT_GLIBC_PORTS_BASENAME}" \
"${CT_GLIBC_SRC_DIR}/${CT_GLIBC_BASENAME}/ports"
fi
# TBD make the configure timestamp fix in all patched packages (e.g. part of CT_ExtractPatch)
}

# Build and install headers and start files
Expand Down
14 changes: 14 additions & 0 deletions scripts/functions
Expand Up @@ -2165,6 +2165,20 @@ CT_DoExtractPatch()
CT_DoExecLog ALL "${CT_CONFIG_SHELL}" -c "${devel_bootstrap}"
fi

# Fix up the timestamps on the file we may be patching: otherwise, we may
# have a circular dependency. For example, we need make to build autoconf
# and automake companion tools, but we need autoconf and automake to regenerate
# aclocal.m4 or config.h.in after the patch touches configure.ac. Instead,
# assume the patch fixes all the files it needs.
find . -type f -name "aclocal.m4" \
-exec touch {} \; -exec echo touch {} \; | CT_DoLog ALL
find . -type f -name "config.h.in" \
-exec touch {} \; -exec echo touch {} \; | CT_DoLog ALL
find . -type f -name "Makefile.in" \
-exec touch {} \; -exec echo touch {} \; | CT_DoLog ALL
find . -type f -name "configure" \
-exec touch {} \; -exec echo touch {} \; | CT_DoLog ALL

if [ -n "${patchfunc}" ]; then
${patchfunc}
fi
Expand Down
7 changes: 7 additions & 0 deletions testing/docker/archlinux/Dockerfile
@@ -1,3 +1,10 @@
FROM base/archlinux:latest
ARG CTNG_UID
ARG CTNG_GID
RUN groupadd -g $CTNG_GID ctng
RUN useradd -d /home/ctng -m -g $CTNG_GID -u $CTNG_UID -s /bin/bash ctng
RUN pacman -Syu --noconfirm
RUN pacman -S --noconfirm base-devel git help2man python unzip
RUN wget -O /sbin/dumb-init https://github.com/Yelp/dumb-init/releases/download/v1.2.1/dumb-init_1.2.1_amd64
RUN chmod a+x /sbin/dumb-init
ENTRYPOINT [ "/sbin/dumb-init", "--" ]
10 changes: 10 additions & 0 deletions testing/docker/centos6/Dockerfile
@@ -0,0 +1,10 @@
FROM centos:6
ARG CTNG_UID
ARG CTNG_GID
RUN groupadd -g $CTNG_GID ctng
RUN useradd -d /home/ctng -m -g $CTNG_GID -u $CTNG_UID -s /bin/bash ctng
RUN yum install -y autoconf gperf bison flex texinfo help2man gcc-c++ patch \
ncurses-devel python-devel perl-Thread-Queue bzip2 git wget xz unzip
RUN wget -O /sbin/dumb-init https://github.com/Yelp/dumb-init/releases/download/v1.2.1/dumb-init_1.2.1_amd64
RUN chmod a+x /sbin/dumb-init
ENTRYPOINT [ "/sbin/dumb-init", "--" ]
10 changes: 5 additions & 5 deletions testing/docker/common-scripts/ctng-build-sample
Expand Up @@ -2,8 +2,8 @@

set -e
cd
rm -rf bld-samples
mkdir bld-samples
cd bld-samples
export PATH=$HOME/inst-ctng/bin:$PATH
ct-ng build-all ${1+CT_SAMPLES="$*"}
rm -rf work/bld-samples
mkdir -p work/bld-samples work/inst-xtools
cd work/bld-samples
export PATH=$HOME/work/inst-ctng/bin:$PATH
ct-ng build-all CT_PREFIX=$HOME/work/inst-xtools ${1+CT_SAMPLES="$*"}
8 changes: 4 additions & 4 deletions testing/docker/common-scripts/ctng-install
Expand Up @@ -2,9 +2,9 @@

set -e
cd
rm -rf bld-ctng
mkdir bld-ctng
cd bld-ctng
/crosstool-ng/configure --prefix=$HOME/inst-ctng
rm -rf work/bld-ctng work/inst-ctng
mkdir work/bld-ctng
cd work/bld-ctng
/crosstool-ng/configure --prefix=$HOME/work/inst-ctng
make
make install
2 changes: 1 addition & 1 deletion testing/docker/common-scripts/ctng-test-basic
Expand Up @@ -2,7 +2,7 @@

set -e
cd
export PATH=$HOME/inst-ctng/bin:$PATH
export PATH=$HOME/work/inst-ctng/bin:$PATH
ct-ng help
ct-ng list-samples
ct-ng list-steps
17 changes: 0 additions & 17 deletions testing/docker/common-scripts/su-as-user

This file was deleted.

33 changes: 21 additions & 12 deletions testing/docker/dmgr.sh
Expand Up @@ -42,24 +42,32 @@ action_build()
local cntr=$1

msg "Building Docker container for ${cntr}"
docker build --no-cache -t "ctng-${cntr}" "${cntr}"
set -x
docker build --no-cache -t "ctng-${cntr}" --build-arg CTNG_GID=`id -g` --build-arg CTNG_UID=`id -u` "${cntr}"
}

# Common backend for enter/test
_dckr()
{
local topdir=`cd ../.. && pwd`
local cntr=$1
local scmd prefix
shift

mkdir -p build-${cntr}
docker run --rm -i -t \
-v `pwd`/common-scripts:/setup-scripts:ro \
prefix="docker run --rm -i -t \
-v `pwd`/common-scripts:/common-scripts:ro \
-v ${topdir}:/crosstool-ng:ro \
-v `pwd`/build-${cntr}:/home \
-v $HOME/src:/src:ro \
ctng-${cntr} \
${SETUPCMD:-/setup-scripts/su-as-user `id -un` `id -u` `id -gn` `id -g`} "$@"
-v `pwd`/build-${cntr}:/home/ctng/work \
-v $HOME/src:/home/ctng/src:ro \
ctng-${cntr}"
if [ -n "${AS_ROOT}" ]; then
$prefix "$@"
elif [ -n "$*" ]; then
$prefix su -l ctng -c "$*"
else
$prefix su -l ctng
fi
}

# Run the test
Expand All @@ -69,8 +77,8 @@ action_install()

# The test assumes the top directory is bootstrapped, but clean.
msg "Setting up crosstool-NG in ${cntr}"
_dckr "${cntr}" /setup-scripts/ctng-install
_dckr "${cntr}" /setup-scripts/ctng-test-basic
_dckr "${cntr}" /common-scripts/ctng-install && \
_dckr "${cntr}" /common-scripts/ctng-test-basic
}

# Run the test
Expand All @@ -81,16 +89,17 @@ action_sample()

# The test assumes the top directory is bootstrapped, but clean.
msg "Building samples in ${cntr} [$@]"
_dckr "${cntr}" /setup-scripts/ctng-build-sample "$@"
_dckr "${cntr}" /common-scripts/ctng-build-sample "$@"
}

# Enter the container using the same user account/environment as for testing.
action_enter()
{
local cntr=$1
shift

msg "Entering ${cntr}"
_dckr "${cntr}"
_dckr "${cntr}" "$@"
}

# Enter the container using the same user account/environment as for testing.
Expand All @@ -99,7 +108,7 @@ action_root()
local cntr=$1

msg "Entering ${cntr} as root"
SETUPCMD=/bin/bash _dckr "${cntr}"
AS_ROOT=y _dckr "${cntr}" /bin/bash
}

# Clean up after test suite run
Expand Down
8 changes: 8 additions & 0 deletions testing/docker/docker-remove-all.sh
@@ -0,0 +1,8 @@
#!/bin/bash

for c in `docker ps -a -q`; do
docker rm $c
done
for i in `docker images -q`; do
docker rmi --force $i
done
4 changes: 4 additions & 0 deletions testing/docker/gentoo-amd64/Dockerfile
@@ -1,4 +1,8 @@
FROM gentoo/stage3-amd64-hardened
ARG CTNG_UID
ARG CTNG_GID
RUN groupadd -g $CTNG_GID ctng
RUN useradd -d /home/ctng -m -g $CTNG_GID -u $CTNG_UID -s /bin/bash ctng
RUN wget -O /sbin/dumb-init https://github.com/Yelp/dumb-init/releases/download/v1.2.1/dumb-init_1.2.1_amd64
RUN chmod a+x /sbin/dumb-init
ENTRYPOINT [ "/sbin/dumb-init", "--" ]
11 changes: 11 additions & 0 deletions testing/docker/mint19-amd64/Dockerfile
@@ -0,0 +1,11 @@
FROM linuxmintd/mint19-amd64
ARG CTNG_UID
ARG CTNG_GID
RUN groupadd -g $CTNG_GID ctng
RUN useradd -d /home/ctng -m -g $CTNG_GID -u $CTNG_UID -s /bin/bash ctng
RUN apt-get update
RUN apt-get install -y gcc gperf bison flex texinfo help2man make libncurses5-dev \
python-dev autoconf automake libtool libtool-bin gawk
RUN wget -O /sbin/dumb-init https://github.com/Yelp/dumb-init/releases/download/v1.2.1/dumb-init_1.2.1_amd64
RUN chmod a+x /sbin/dumb-init
ENTRYPOINT [ "/sbin/dumb-init", "--" ]

0 comments on commit d0dd654

Please sign in to comment.