Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 6 Sep 2013 13:34:59 -0700
From:      Xin LI <delphij@gmail.com>
To:        David Chisnall <theraven@freebsd.org>
Cc:        "svn-src-head@freebsd.org" <svn-src-head@freebsd.org>, "svn-src-all@freebsd.org" <svn-src-all@freebsd.org>, "src-committers@freebsd.org" <src-committers@freebsd.org>
Subject:   Re: svn commit: r255321 - in head: contrib/llvm/tools/clang/lib/Driver gnu/lib gnu/usr.bin/cc share/mk sys/sys tools/build/options
Message-ID:  <CAGMYy3sypEMfqbASezvSwHPGJnzQBLsHHEpEQ9nou2ahB=c1uw@mail.gmail.com>
In-Reply-To: <201309062008.r86K836C048843@svn.freebsd.org>
References:  <201309062008.r86K836C048843@svn.freebsd.org>

next in thread | previous in thread | raw e-mail | index | archive | help
Will this break cross building on 9.x host?  I hit this:

c++  -O2 -pipe -I/tank/home/delphij/head/lib/clang/libllvmsupport/../../../contrib/llvm/include
-I/tank/home/delphij/head/lib/clang/libllvmsupport/../../../contrib/llvm/tools/clang/include
-I/tank/home/delphij/head/lib/clang/libllvmsupport/../../../contrib/llvm/lib/Support
-I. -I/tank/home/delphij/head/lib/clang/libllvmsupport/../../../contrib/llvm/../../lib/clang/include
-DLLVM_ON_UNIX -DLLVM_ON_FREEBSD -D__STDC_LIMIT_MACROS
-D__STDC_CONSTANT_MACROS -fno-strict-aliasing
-DLLVM_DEFAULT_TARGET_TRIPLE=\"x86_64-unknown-freebsd10.0\"
-DLLVM_HOST_TRIPLE=\"x86_64-unknown-freebsd10.0\"
-DDEFAULT_SYSROOT=\"\"
-I/tank/home/delphij/obj/tank/home/delphij/head/tmp/legacy/usr/include
-Wno-c++11-extensions -fno-exceptions -fno-rtti  -c
/tank/home/delphij/head/lib/clang/libllvmsupport/../../../contrib/llvm/lib/Support/APFloat.cpp
-o APFloat.o
cc1plus: error: unrecognized command line option "-Wno-c++11-extensions"

On Fri, Sep 6, 2013 at 1:08 PM, David Chisnall <theraven@freebsd.org> wrote:
> Author: theraven
> Date: Fri Sep  6 20:08:03 2013
> New Revision: 255321
> URL: http://svnweb.freebsd.org/changeset/base/255321
>
> Log:
>   On platforms where clang is the default compiler, don't build gcc or libstdc++.
>   To enable them, set WITH_GCC and WITH_GNUCXX in src.conf.
>   Make clang default to using libc++ on FreeBSD 10.
>   Bumped __FreeBSD_version for the change.
>
>   GCC is still enabled on PC98, because the PC98 bootloader requires GCC to build
>   (or, at least, hard-codes the use of gcc into its build).
>
>   Thanks to everyone who helped make the ports tree ready for this (and bapt
>   for coordinating them all).  Also to imp for reviewing this and working on the
>   forward-porting of the changes in our gcc so that we're getting to a much
>   better place with regard to external toolchains.
>
>   Sorry to all of the people who helped who I forgot to mention by name.
>
>   Reviewed by:  bapt, imp, dim, ...
>
> Added:
>   head/tools/build/options/WITHOUT_GNUCXX   (contents, props changed)
>   head/tools/build/options/WITH_GNUCXX   (contents, props changed)
> Modified:
>   head/contrib/llvm/tools/clang/lib/Driver/ToolChains.cpp
>   head/contrib/llvm/tools/clang/lib/Driver/ToolChains.h
>   head/gnu/lib/Makefile
>   head/gnu/usr.bin/cc/Makefile
>   head/share/mk/bsd.own.mk
>   head/sys/sys/param.h
>
> Modified: head/contrib/llvm/tools/clang/lib/Driver/ToolChains.cpp
> ==============================================================================
> --- head/contrib/llvm/tools/clang/lib/Driver/ToolChains.cpp     Fri Sep  6 18:41:57 2013        (r255320)
> +++ head/contrib/llvm/tools/clang/lib/Driver/ToolChains.cpp     Fri Sep  6 20:08:03 2013        (r255321)
> @@ -1851,6 +1851,38 @@ bool FreeBSD::UseSjLjExceptions() const
>    }
>  }
>
> +ToolChain::CXXStdlibType
> +FreeBSD::GetCXXStdlibType(const ArgList &Args) const {
> +  if (Arg *A = Args.getLastArg(options::OPT_stdlib_EQ)) {
> +    StringRef Value = A->getValue();
> +    if (Value == "libc++")
> +      return ToolChain::CST_Libcxx;
> +    if (Value == "libstdc++")
> +      return ToolChain::CST_Libstdcxx;
> +    getDriver().Diag(diag::err_drv_invalid_stdlib_name)
> +      << A->getAsString(Args);
> +  }
> +
> +  return getTriple().getOSMajorVersion() >= 10 ? ToolChain::CST_Libcxx :
> +         ToolChain::CST_Libstdcxx;
> +}
> +
> +void FreeBSD::AddClangCXXStdlibIncludeArgs(const ArgList &DriverArgs,
> +                                          ArgStringList &CC1Args) const {
> +  if (DriverArgs.hasArg(options::OPT_nostdlibinc) ||
> +      DriverArgs.hasArg(options::OPT_nostdincxx))
> +    return;
> +
> +  if (GetCXXStdlibType(DriverArgs) == ToolChain::CST_Libcxx)
> +    addSystemInclude(DriverArgs, CC1Args,
> +                     getDriver().SysRoot + "/usr/include/c++/v1");
> +  else
> +    addSystemInclude(DriverArgs, CC1Args,
> +                     getDriver().SysRoot + "/usr/include/c++/4.2");
> +  return;
> +
> +}
> +
>  /// NetBSD - NetBSD tool chain which can call as(1) and ld(1) directly.
>
>  NetBSD::NetBSD(const Driver &D, const llvm::Triple& Triple, const ArgList &Args)
>
> Modified: head/contrib/llvm/tools/clang/lib/Driver/ToolChains.h
> ==============================================================================
> --- head/contrib/llvm/tools/clang/lib/Driver/ToolChains.h       Fri Sep  6 18:41:57 2013        (r255320)
> +++ head/contrib/llvm/tools/clang/lib/Driver/ToolChains.h       Fri Sep  6 20:08:03 2013        (r255321)
> @@ -458,9 +458,14 @@ class LLVM_LIBRARY_VISIBILITY FreeBSD :
>  public:
>    FreeBSD(const Driver &D, const llvm::Triple& Triple, const ArgList &Args);
>
> +  virtual CXXStdlibType GetCXXStdlibType(const ArgList &Args) const;
> +
>    virtual bool IsMathErrnoDefault() const { return false; }
>    virtual bool IsObjCNonFragileABIDefault() const { return true; }
>
> +  virtual void AddClangCXXStdlibIncludeArgs(const ArgList &DriverArgs,
> +                                            ArgStringList &CC1Args) const;
> +
>    virtual bool UseSjLjExceptions() const;
>  protected:
>    virtual Tool *buildAssembler() const;
>
> Modified: head/gnu/lib/Makefile
> ==============================================================================
> --- head/gnu/lib/Makefile       Fri Sep  6 18:41:57 2013        (r255320)
> +++ head/gnu/lib/Makefile       Fri Sep  6 20:08:03 2013        (r255321)
> @@ -10,7 +10,7 @@ SUBDIR+= libssp
>
>  # libsupc++ uses libstdc++ headers, although 'make includes' should
>  # have taken care of that already.
> -.if ${MK_CXX} != "no"
> +.if ${MK_GNUCXX} != "no"
>  SUBDIR+= libstdc++ libsupc++
>  .endif
>
>
> Modified: head/gnu/usr.bin/cc/Makefile
> ==============================================================================
> --- head/gnu/usr.bin/cc/Makefile        Fri Sep  6 18:41:57 2013        (r255320)
> +++ head/gnu/usr.bin/cc/Makefile        Fri Sep  6 20:08:03 2013        (r255321)
> @@ -12,7 +12,12 @@ SUBDIR+= cpp
>  .endif
>
>  .if ${MK_CXX} != "no"
> -SUBDIR+= cc1plus c++ c++filt
> +.if ${MK_GNUCXX} != "no"
> +SUBDIR+= cc1plus c++
> +.endif
> +# This should be moved into the above block once c++filt from elftoolchain or
> +# similar is provided.
> +SUBDIR+= c++filt
>  .endif
>
>  .if ${MK_GCOV} != "no"
>
> Modified: head/share/mk/bsd.own.mk
> ==============================================================================
> --- head/share/mk/bsd.own.mk    Fri Sep  6 18:41:57 2013        (r255320)
> +++ head/share/mk/bsd.own.mk    Fri Sep  6 20:08:03 2013        (r255321)
> @@ -284,7 +284,6 @@ __DEFAULT_YES_OPTIONS = \
>      FP_LIBC \
>      FREEBSD_UPDATE \
>      GAMES \
> -    GCC \
>      GCOV \
>      GDB \
>      GNU \
> @@ -400,6 +399,11 @@ __T=${TARGET_ARCH}
>  .else
>  __T=${MACHINE_ARCH}
>  .endif
> +.if defined(TARGET)
> +__TT=${TARGET}
> +.else
> +__TT=${MACHINE_ARCH}
> +.endif
>  # Clang is only for x86, powerpc and little-endian arm right now, by default.
>  .if ${__T} == "amd64" || ${__T} == "i386" || ${__T:Mpowerpc*}
>  __DEFAULT_YES_OPTIONS+=CLANG CLANG_FULL
> @@ -414,8 +418,30 @@ __DEFAULT_NO_OPTIONS+=CLANG CLANG_FULL
>  .if ${__T} == "amd64" || ${__T} == "arm" || ${__T} == "armv6" || \
>      ${__T} == "i386"
>  __DEFAULT_YES_OPTIONS+=CLANG_IS_CC
> +# The pc98 bootloader requires gcc to build and so we must leave gcc enabled
> +# for pc98 for now.
> +.if ${__TT} == "pc98"
> +__DEFAULT_NO_OPTIONS+=GNUCXX
> +__DEFAULT_YES_OPTIONS+=GCC
> +.else
> +__DEFAULT_NO_OPTIONS+=GCC GNUCXX
> +.endif
> +# The libc++ headers use c++11 extensions.  These are normally silenced because
> +# they are treated as system headers, but we explicitly disable that warning
> +# suppression when building the base system to catch bugs in our headers.
> +# Eventually we'll want to start building the base system C++ code as C++11,
> +# but not yet.
> +CXXFLAGS+=     -Wno-c++11-extensions
>  .else
> +# If clang is not cc, then build gcc by default
>  __DEFAULT_NO_OPTIONS+=CLANG_IS_CC
> +__DEFAULT_YES_OPTIONS+=GCC
> +# And if g++ is c++, build the rest of the GNU C++ stack
> +.if defined(WITHOUT_CXX)
> +__DEFAULT_NO_OPTIONS+=GNUCXX
> +.else
> +__DEFAULT_YES_OPTIONS+=GNUCXX
> +.endif
>  .endif
>  # FDT is needed only for arm, mips and powerpc
>  .if ${__T:Marm*} || ${__T:Mpowerpc*} || ${__T:Mmips*}
>
> Modified: head/sys/sys/param.h
> ==============================================================================
> --- head/sys/sys/param.h        Fri Sep  6 18:41:57 2013        (r255320)
> +++ head/sys/sys/param.h        Fri Sep  6 20:08:03 2013        (r255321)
> @@ -58,7 +58,7 @@
>   *             in the range 5 to 9.
>   */
>  #undef __FreeBSD_version
> -#define __FreeBSD_version 1000053      /* Master, propagated to newvers */
> +#define __FreeBSD_version 1000054      /* Master, propagated to newvers */
>
>  /*
>   * __FreeBSD_kernel__ indicates that this system uses the kernel of FreeBSD,
>
> Added: head/tools/build/options/WITHOUT_GNUCXX
> ==============================================================================
> --- /dev/null   00:00:00 1970   (empty, because file is newly added)
> +++ head/tools/build/options/WITHOUT_GNUCXX     Fri Sep  6 20:08:03 2013        (r255321)
> @@ -0,0 +1,3 @@
> +.\" $FreeBSD$
> +Do not build the GNU C++ stack (g++, libstdc++).
> +This is the default on platforms where clang is the system compiler.
>
> Added: head/tools/build/options/WITH_GNUCXX
> ==============================================================================
> --- /dev/null   00:00:00 1970   (empty, because file is newly added)
> +++ head/tools/build/options/WITH_GNUCXX        Fri Sep  6 20:08:03 2013        (r255321)
> @@ -0,0 +1,3 @@
> +.\" $FreeBSD$
> +Build the GNU C++ stack (g++, libstdc++).
> +This is the default on platforms where gcc is the system compiler.



-- 
Xin LI <delphij@delphij.net> https://www.delphij.net/
FreeBSD - The Power to Serve! Live free or die



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?CAGMYy3sypEMfqbASezvSwHPGJnzQBLsHHEpEQ9nou2ahB=c1uw>