patches/gcc/4.3.4/230-pr34571.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Sun Jul 17 22:43:07 2011 +0200 (2011-07-17)
changeset 2893 a8a65758664f
permissions -rw-r--r--
cc/gcc: do not use the core pass-2 to build the baremetal compiler

In case we build a baremetal compiler, use the standard passes:
- core_cc is used to build the C library;
- as such, it is meant to run on build, not host;
- the final compiler is meant to run on host;

As the current final compiler step can not build a baremetal compiler,
call the core backend from the final step.

NB: Currently, newlib is built during the start_files pass, so we have
to have a core compiler by then... Once we can build the baremetal
compiler from the final cc step, then we can move the newlib build to
the proper step, and then get rid of the core pass-1 static compiler...

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
thomas@1461
     1
Original patch from: ../4.3.2/230-pr34571.patch
thomas@1461
     2
thomas@1461
     3
-= BEGIN original header =-
thomas@1461
     4
Original patch from gentoo: gentoo/src/patchsets/gcc/4.3.1/gentoo/64_all_gcc43-pr34571.patch
thomas@1461
     5
http://gcc.gnu.org/PR34571
thomas@1461
     6
thomas@1461
     7
2007-12-26  Rask Ingemann Lambertsen  <rask@sygehus.dk>
thomas@1461
     8
thomas@1461
     9
	PR target/34571
thomas@1461
    10
	* config/alpha/alpha.c (alpha_cannot_force_const_mem): Use
thomas@1461
    11
	symbolic_operand.
thomas@1461
    12
	* varasm.c (output_constant_pool_1): Fix typo.
thomas@1461
    13
thomas@1461
    14
-= END original header =-
thomas@1461
    15
thomas@1461
    16
diff -durN gcc-4.3.3.orig/gcc/config/alpha/alpha.c gcc-4.3.3/gcc/config/alpha/alpha.c
thomas@1461
    17
--- gcc-4.3.3.orig/gcc/config/alpha/alpha.c	2008-09-09 01:16:55.000000000 +0200
thomas@1461
    18
+++ gcc-4.3.3/gcc/config/alpha/alpha.c	2009-01-27 22:25:29.000000000 +0100
thomas@1461
    19
@@ -1113,8 +1113,7 @@
thomas@1461
    20
 static bool
thomas@1461
    21
 alpha_cannot_force_const_mem (rtx x)
thomas@1461
    22
 {
thomas@1461
    23
-  enum rtx_code code = GET_CODE (x);
thomas@1461
    24
-  return code == SYMBOL_REF || code == LABEL_REF || code == CONST;
thomas@1461
    25
+  return symbolic_operand (x, GET_MODE (x));
thomas@1461
    26
 }
thomas@1461
    27
 
thomas@1461
    28
 /* We do not allow indirect calls to be optimized into sibling calls, nor