gcc-3.3-libstdc++-v3-dg.exp.patch
来自「linux下编译交叉工具链的工具源码」· PATCH 代码 · 共 55 行
PATCH
55 行
Without this patch, the commandRUNTESTFLAGS=--target=powerpc-750-linux-gnu -v -v -v -v make check-target-libstdc++-v3fails in two ways:1. the -L option meant to locate the testsuite directory is incorrect, and2. the wrong compiler is invoked, causing all sorts of havoc, not least of whichis the native compiler is invoked when we really wanted to invoke the cross-compilerwe just built.Here's an example log of the problem in action. Every testcase fails, this shows just one:-------------Invoking the compiler as g++ -ggdb3 -DDEBUG_ASSERT -I/home3/dank/wk/ixos/dap_interim/linux/3rdParty/crosstool/crosstool-0.12/build/powerpc-750-linux-gnu/gcc-3.3-glibc-2.2.5/gcc-3.3/libstdc++-v3/testsuite /home3/dank/wk/ixos/dap_interim/linux/3rdParty/crosstool/crosstool-0.12/build/powerpc-750-linux-gnu/gcc-3.3-glibc-2.2.5/gcc-3.3/libstdc++-v3/testsuite/20_util/binders.cc -g -O2 -DDEBUG_ASSERT -L/testsuite -lv3test -lm -o ./binders.execompiler exited with status 1output is:/usr/lib/gcc-lib/i386-linux/2.95.4/../../../../include/g++-3/stl_function.h: In method `void binder2nd<mem_fun1_ref_t<void,Elem,int> >::operator ()(const Elem &) const':^M/usr/lib/gcc-lib/i386-linux/2.95.4/../../../../include/g++-3/stl_algo.h:83: instantiated from `for_each<Elem *, binder2nd<mem_fun1_ref_t<void,Elem,int> > >(Elem *, Elem *, binder2nd<mem_fun1_ref_t<void,Elem,int> >)'^M/home3/dank/wk/ixos/dap_interim/linux/3rdParty/crosstool/crosstool-0.12/build/powerpc-750-linux-gnu/gcc-3.3-glibc-2.2.5/gcc-3.3/libstdc++-v3/testsuite/20_util/binders.cc:43: instantiated from here^M/usr/lib/gcc-lib/i386-linux/2.95.4/../../../../include/g++-3/stl_function.h:224: conversion from `const Elem' to `Elem &' discards qualifiers^M/usr/lib/gcc-lib/i386-linux/2.95.4/../../../../include/g++-3/stl_function.h:622: in passing argument 1 of `mem_fun1_ref_t<void,Elem,int>::operator ()(Elem &, int) const'^M...FAIL: 20_util/binders.cc (test for excess errors)WARNING: 20_util/binders.cc compilation failed to produce executable-------------And here's the patch. I'm not happy with it, and it probably gets some cases wrong,but it seems to work for the common native case and for my cross-compiler case.--- gcc-3.3/libstdc++-v3/testsuite/lib/libstdc++-v3-dg.exp.old Sun Jul 13 10:42:01 2003+++ gcc-3.3/libstdc++-v3/testsuite/lib/libstdc++-v3-dg.exp Sun Jul 13 11:39:54 2003@@ -46,8 +46,23 @@ global gluefile wrap_flags global ld_library_path global tool_root_dir+ global target_triplet set blddir [lookfor_file [get_multilibs] libstdc++-v3]+ if { $blddir == "" } {+ set multilibs [get_multilibs]+ # FIXME: assume multilib only one level deep+ set multisub [file tail $multilibs]+ verbose "libstdc++-v3-init: couldn't find libstdc++-v3 in $multilibs, trying $objdir"+ set blddir [lookfor_file ${objdir} "$target_triplet/$multisub/libstdc++-v3"]+ }+ if { $blddir == "" } {+ verbose "libstdc++-v3-init: couldn't find libstdc++-v3, trying $objdir without multilibs"+ set blddir [lookfor_file ${objdir} "$target_triplet/libstdc++-v3"]+ }+ if { $blddir == "" } {+ error "Can't find libstdc++-v3"+ } # By default, we assume we want to run program images. global dg-do-what-default
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?