Only use O_CLOEXEC on platforms that support it
Change a9fca58
made use of the O_CLOEXEC flag, which is not supported on
older Linux kernels. This change makes the use contingent on kernel
support.
Testing: I manually compiled breakpad on CentOS 5.8 running kernel
2.6.18-308.8.2.el5.centos.plusxen.
Bug: 730
Change-Id: I21dff928cfba3c156a56708913f65a0c7b5396a6
Reviewed-on: https://chromium-review.googlesource.com/498528
Reviewed-by: Mike Frysinger <vapier@chromium.org>
This commit is contained in:
parent
54a54702a1
commit
ffe3e47865
6 changed files with 141 additions and 0 deletions
1
aclocal.m4
vendored
1
aclocal.m4
vendored
|
@ -1298,6 +1298,7 @@ AC_SUBST([am__untar])
|
||||||
m4_include([m4/ax_append_compile_flags.m4])
|
m4_include([m4/ax_append_compile_flags.m4])
|
||||||
m4_include([m4/ax_append_flag.m4])
|
m4_include([m4/ax_append_flag.m4])
|
||||||
m4_include([m4/ax_check_compile_flag.m4])
|
m4_include([m4/ax_check_compile_flag.m4])
|
||||||
|
m4_include([m4/ax_check_define.m4])
|
||||||
m4_include([m4/ax_cxx_compile_stdcxx.m4])
|
m4_include([m4/ax_cxx_compile_stdcxx.m4])
|
||||||
m4_include([m4/ax_pthread.m4])
|
m4_include([m4/ax_pthread.m4])
|
||||||
m4_include([m4/ax_require_defined.m4])
|
m4_include([m4/ax_require_defined.m4])
|
||||||
|
|
40
configure
vendored
40
configure
vendored
|
@ -7455,6 +7455,46 @@ ac_compiler_gnu=$ac_cv_c_compiler_gnu
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for O_CLOEXEC defined in fcntl.h" >&5
|
||||||
|
$as_echo_n "checking for O_CLOEXEC defined in fcntl.h... " >&6; }
|
||||||
|
if ${ac_cv_defined_O_CLOEXEC_fcntl_h+:} false; then :
|
||||||
|
$as_echo_n "(cached) " >&6
|
||||||
|
else
|
||||||
|
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
||||||
|
/* end confdefs.h. */
|
||||||
|
#include <fcntl.h>
|
||||||
|
int
|
||||||
|
main ()
|
||||||
|
{
|
||||||
|
|
||||||
|
#ifdef O_CLOEXEC
|
||||||
|
int ok;
|
||||||
|
#else
|
||||||
|
choke me
|
||||||
|
#endif
|
||||||
|
|
||||||
|
;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
_ACEOF
|
||||||
|
if ac_fn_c_try_compile "$LINENO"; then :
|
||||||
|
ac_cv_defined_O_CLOEXEC_fcntl_h=yes
|
||||||
|
else
|
||||||
|
ac_cv_defined_O_CLOEXEC_fcntl_h=no
|
||||||
|
fi
|
||||||
|
rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
|
||||||
|
fi
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_defined_O_CLOEXEC_fcntl_h" >&5
|
||||||
|
$as_echo "$ac_cv_defined_O_CLOEXEC_fcntl_h" >&6; }
|
||||||
|
if test $ac_cv_defined_O_CLOEXEC_fcntl_h != "no"; then :
|
||||||
|
|
||||||
|
else
|
||||||
|
|
||||||
|
$as_echo "#define O_CLOEXEC 0" >>confdefs.h
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
# Only build Linux client libs when compiling for Linux
|
# Only build Linux client libs when compiling for Linux
|
||||||
case $host in
|
case $host in
|
||||||
*-*-linux* | *-android* )
|
*-*-linux* | *-android* )
|
||||||
|
|
|
@ -101,6 +101,10 @@ AS_VAR_APPEND([WARN_CXXFLAGS], " -Werror")
|
||||||
AC_LANG_POP([C++])
|
AC_LANG_POP([C++])
|
||||||
AC_SUBST([WARN_CXXFLAGS])
|
AC_SUBST([WARN_CXXFLAGS])
|
||||||
|
|
||||||
|
dnl Test support for O_CLOEXEC
|
||||||
|
AX_CHECK_DEFINE([fcntl.h], [O_CLOEXEC], [],
|
||||||
|
[AC_DEFINE([O_CLOEXEC], [0], [Fallback definition for old systems])])
|
||||||
|
|
||||||
# Only build Linux client libs when compiling for Linux
|
# Only build Linux client libs when compiling for Linux
|
||||||
case $host in
|
case $host in
|
||||||
*-*-linux* | *-android* )
|
*-*-linux* | *-android* )
|
||||||
|
|
92
m4/ax_check_define.m4
Normal file
92
m4/ax_check_define.m4
Normal file
|
@ -0,0 +1,92 @@
|
||||||
|
# ===========================================================================
|
||||||
|
# https://www.gnu.org/software/autoconf-archive/ax_check_define.html
|
||||||
|
# ===========================================================================
|
||||||
|
#
|
||||||
|
# SYNOPSIS
|
||||||
|
#
|
||||||
|
# AC_CHECK_DEFINE([symbol], [ACTION-IF-FOUND], [ACTION-IF-NOT])
|
||||||
|
# AX_CHECK_DEFINE([includes],[symbol], [ACTION-IF-FOUND], [ACTION-IF-NOT])
|
||||||
|
#
|
||||||
|
# DESCRIPTION
|
||||||
|
#
|
||||||
|
# Complements AC_CHECK_FUNC but it does not check for a function but for a
|
||||||
|
# define to exist. Consider a usage like:
|
||||||
|
#
|
||||||
|
# AC_CHECK_DEFINE(__STRICT_ANSI__, CFLAGS="$CFLAGS -D_XOPEN_SOURCE=500")
|
||||||
|
#
|
||||||
|
# LICENSE
|
||||||
|
#
|
||||||
|
# Copyright (c) 2008 Guido U. Draheim <guidod@gmx.de>
|
||||||
|
#
|
||||||
|
# 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, see <https://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
# As a special exception, the respective Autoconf Macro's copyright owner
|
||||||
|
# gives unlimited permission to copy, distribute and modify the configure
|
||||||
|
# scripts that are the output of Autoconf when processing the Macro. You
|
||||||
|
# need not follow the terms of the GNU General Public License when using
|
||||||
|
# or distributing such scripts, even though portions of the text of the
|
||||||
|
# Macro appear in them. The GNU General Public License (GPL) does govern
|
||||||
|
# all other use of the material that constitutes the Autoconf Macro.
|
||||||
|
#
|
||||||
|
# This special exception to the GPL applies to versions of the Autoconf
|
||||||
|
# Macro released by the Autoconf Archive. When you make and distribute a
|
||||||
|
# modified version of the Autoconf Macro, you may extend this special
|
||||||
|
# exception to the GPL to apply to your modified version as well.
|
||||||
|
|
||||||
|
#serial 9
|
||||||
|
|
||||||
|
AU_ALIAS([AC_CHECK_DEFINED], [AC_CHECK_DEFINE])
|
||||||
|
AC_DEFUN([AC_CHECK_DEFINE],[
|
||||||
|
AS_VAR_PUSHDEF([ac_var],[ac_cv_defined_$1])dnl
|
||||||
|
AC_CACHE_CHECK([for $1 defined], ac_var,
|
||||||
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[
|
||||||
|
#ifdef $1
|
||||||
|
int ok;
|
||||||
|
#else
|
||||||
|
choke me
|
||||||
|
#endif
|
||||||
|
]])],[AS_VAR_SET(ac_var, yes)],[AS_VAR_SET(ac_var, no)]))
|
||||||
|
AS_IF([test AS_VAR_GET(ac_var) != "no"], [$2], [$3])dnl
|
||||||
|
AS_VAR_POPDEF([ac_var])dnl
|
||||||
|
])
|
||||||
|
|
||||||
|
AU_ALIAS([AX_CHECK_DEFINED], [AX_CHECK_DEFINE])
|
||||||
|
AC_DEFUN([AX_CHECK_DEFINE],[
|
||||||
|
AS_VAR_PUSHDEF([ac_var],[ac_cv_defined_$2_$1])dnl
|
||||||
|
AC_CACHE_CHECK([for $2 defined in $1], ac_var,
|
||||||
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <$1>]], [[
|
||||||
|
#ifdef $2
|
||||||
|
int ok;
|
||||||
|
#else
|
||||||
|
choke me
|
||||||
|
#endif
|
||||||
|
]])],[AS_VAR_SET(ac_var, yes)],[AS_VAR_SET(ac_var, no)]))
|
||||||
|
AS_IF([test AS_VAR_GET(ac_var) != "no"], [$3], [$4])dnl
|
||||||
|
AS_VAR_POPDEF([ac_var])dnl
|
||||||
|
])
|
||||||
|
|
||||||
|
AC_DEFUN([AX_CHECK_FUNC],
|
||||||
|
[AS_VAR_PUSHDEF([ac_var], [ac_cv_func_$2])dnl
|
||||||
|
AC_CACHE_CHECK([for $2], ac_var,
|
||||||
|
dnl AC_LANG_FUNC_LINK_TRY
|
||||||
|
[AC_LINK_IFELSE([AC_LANG_PROGRAM([$1
|
||||||
|
#undef $2
|
||||||
|
char $2 ();],[
|
||||||
|
char (*f) () = $2;
|
||||||
|
return f != $2; ])],
|
||||||
|
[AS_VAR_SET(ac_var, yes)],
|
||||||
|
[AS_VAR_SET(ac_var, no)])])
|
||||||
|
AS_IF([test AS_VAR_GET(ac_var) = yes], [$3], [$4])dnl
|
||||||
|
AS_VAR_POPDEF([ac_var])dnl
|
||||||
|
])# AC_CHECK_FUNC
|
|
@ -27,6 +27,7 @@
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
#include "common/linux/eintr_wrapper.h"
|
#include "common/linux/eintr_wrapper.h"
|
||||||
#include "common/linux/guid_creator.h"
|
#include "common/linux/guid_creator.h"
|
||||||
|
|
||||||
|
|
|
@ -45,6 +45,9 @@
|
||||||
/* Define to 1 if you have the <unistd.h> header file. */
|
/* Define to 1 if you have the <unistd.h> header file. */
|
||||||
#undef HAVE_UNISTD_H
|
#undef HAVE_UNISTD_H
|
||||||
|
|
||||||
|
/* Fallback definition for old systems */
|
||||||
|
#undef O_CLOEXEC
|
||||||
|
|
||||||
/* Name of package */
|
/* Name of package */
|
||||||
#undef PACKAGE
|
#undef PACKAGE
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue