Mercurial > vim
changeset 32371:a182764faa18 v9.0.1517
patch 9.0.1517: MacOS: configure removes -O2 from $CFLAGS
Commit: https://github.com/vim/vim/commit/00d07e7682d289c3afee9df557ae909b9b403f9c
Author: Rose <83477269+AtariDreams@users.noreply.github.com>
Date: Sat May 6 18:07:14 2023 +0100
patch 9.0.1517: MacOS: configure removes -O2 from $CFLAGS
Problem: MacOS: configure removes -O2 from $CFLAGS.
Solution: Only adjust $CFLAGS for gcc. (closes https://github.com/vim/vim/issues/12351)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Sat, 06 May 2023 19:15:03 +0200 |
parents | f3abbfef6f19 |
children | 6cfb4f5fd395 |
files | src/auto/configure src/configure.ac src/version.c |
diffstat | 3 files changed, 12 insertions(+), 16 deletions(-) [+] |
line wrap: on
line diff
--- a/src/auto/configure +++ b/src/auto/configure @@ -4477,12 +4477,14 @@ if test -z "$CFLAGS"; then CFLAGS="-O" test "$GCC" = yes && CFLAGS="-O2 -fno-strength-reduce -Wall -Wno-deprecated-declarations" fi + if test "$GCC" = yes; then gccversion=`$CC -dumpversion` if test "x$gccversion" = "x"; then gccversion=`$CC --version | sed -e '2,$d' -e 's/darwin.//' -e 's/^[^0-9]*\([0-9]\.[0-9.]*\).*$/\1/g'` fi - if test "$gccversion" = "3.0.1" -o "$gccversion" = "3.0.2" -o "$gccversion" = "4.0.1"; then + + if test "$gccversion" = "3.0.1" -o "$gccversion" = "3.0.2" -o "$gccversion" = "4.0.1"; then echo 'GCC [34].0.[12] has a bug in the optimizer, disabling "-O#"' CFLAGS=`echo "$CFLAGS" | sed 's/-O[23456789]/-O/'` else @@ -4777,11 +4779,6 @@ rm -f core conftest.err conftest.$ac_obj with_x=no fi fi - - if test "$MACARCH" = "intel" -o "$MACARCH" = "both"; then - CFLAGS=`echo "$CFLAGS" | sed 's/-O[23456789]/-Oz/'` - fi - else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; }
--- a/src/configure.ac +++ b/src/configure.ac @@ -93,14 +93,19 @@ if test -z "$CFLAGS"; then CFLAGS="-O" test "$GCC" = yes && CFLAGS="-O2 -fno-strength-reduce -Wall -Wno-deprecated-declarations" fi + if test "$GCC" = yes; then - dnl method that should work for nearly all versions + dnl Method that should work for nearly all gcc versions. gccversion=`$CC -dumpversion` if test "x$gccversion" = "x"; then dnl old method; fall-back for when -dumpversion doesn't work gccversion=`$CC --version | sed -e '2,$d' -e 's/darwin.//' -e 's/^[[^0-9]]*\([[0-9]]\.[[0-9.]]*\).*$/\1/g'` fi - dnl version 4.0.1 was reported to cause trouble on Macintosh by Marcin Dalecki + + dnl Gcc version 4.0.1 was reported to cause trouble on Macintosh by Marcin + dnl Dalecki. For Mac with Intel the symptom reported is: malloc() reports + dnl double free. This happens in expand_filename(), because the optimizer + dnl swaps two blocks of code, both using "repl", that can't be swapped. if test "$gccversion" = "3.0.1" -o "$gccversion" = "3.0.2" -o "$gccversion" = "4.0.1"; then echo 'GCC [[34]].0.[[12]] has a bug in the optimizer, disabling "-O#"' CFLAGS=`echo "$CFLAGS" | sed 's/-O[[23456789]]/-O/'` @@ -299,14 +304,6 @@ if test "$vim_cv_uname_output" = Darwin; with_x=no fi fi - - dnl Avoid a bug with -O2 with gcc 4.0.1. Symptom: malloc() reports double - dnl free. This happens in expand_filename(), because the optimizer swaps - dnl two blocks of code, both using "repl", that can't be swapped. - if test "$MACARCH" = "intel" -o "$MACARCH" = "both"; then - CFLAGS=`echo "$CFLAGS" | sed 's/-O[[23456789]]/-Oz/'` - fi - else AC_MSG_RESULT(no) fi