patches/gcc/4.3.0/210-pr35440.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Wed May 20 20:13:13 2009 +0000 (2009-05-20)
changeset 1345 27fec561af53
parent 746 b150d6f590fc
permissions -rw-r--r--
Merge the uClinux/noMMU stuff back to /trunk:
- merge Linux and uClinux back to a single kernel
- add ARCH_USE_MMU and acquainted config options that
architectures can auto-select
- make binutils and elf2flt two "Binary utilities" that
go in a single common sub-{menu,directory} structure

-------- diffstat follows --------
/trunk/scripts/build/kernel/uclinux.sh | 2 0 2 0 -
/trunk/scripts/build/kernel/linux.sh | 206 204 2 0 +++++++++++++++++++++++++++++
/trunk/scripts/build/kernel/linux-common.sh | 198 0 198 0 ----------------------------
/trunk/scripts/build/binutils.sh | 232 0 232 0 --------------------------------
/trunk/scripts/build/elf2flt.sh | 150 0 150 0 ---------------------
/trunk/scripts/crosstool-NG.sh.in | 6 4 2 0 +
/trunk/config/kernel/linux.in | 249 249 0 0 +++++++++++++++++++++++++++++++++++
/trunk/config/kernel/linux.in-common | 252 0 252 0 -----------------------------------
/trunk/config/kernel/uclinux.in | 21 0 21 0 ---
/trunk/config/target.in | 23 22 1 0 +++
/trunk/config/elf2flt.in | 49 0 49 0 -------
/trunk/config/libc/glibc.in | 2 1 1 0
/trunk/config/libc/eglibc.in | 2 1 1 0
/trunk/config/config.in | 1 0 1 0 -
/trunk/config/arch/sh.in | 1 1 0 0 +
/trunk/config/arch/arm.in | 2 1 1 0
/trunk/config/arch/powerpc.in | 1 1 0 0 +
/trunk/config/arch/ia64.in | 1 1 0 0 +
/trunk/config/arch/alpha.in | 1 1 0 0 +
/trunk/config/arch/x86.in | 1 1 0 0 +
/trunk/config/arch/mips.in | 1 1 0 0 +
/trunk/config/arch/powerpc64.in | 1 1 0 0 +
22 files changed, 489 insertions(+), 913 deletions(-)
     1 Original patch from gentoo: gentoo/src/patchsets/gcc/4.3.0/gentoo/60_all_gcc43-pr35440.patch
     2 2008-03-19  Jakub Jelinek  <jakub@redhat.com>
     3 
     4 	PR c/35440
     5 	* c-pretty-print.c (pp_c_initializer_list): Handle CONSTRUCTOR
     6 	for all types.
     7 
     8 	* gcc.dg/pr35440.c: New test.
     9 
    10 diff -durN gcc-4.3.0.orig/gcc/c-pretty-print.c gcc-4.3.0/gcc/c-pretty-print.c
    11 --- gcc-4.3.0.orig/gcc/c-pretty-print.c	2008-01-29 14:59:59.000000000 +0100
    12 +++ gcc-4.3.0/gcc/c-pretty-print.c	2008-06-10 14:44:54.000000000 +0200
    13 @@ -1173,6 +1173,12 @@
    14    tree type = TREE_TYPE (e);
    15    const enum tree_code code = TREE_CODE (type);
    16  
    17 +  if (TREE_CODE (e) == CONSTRUCTOR)
    18 +    {
    19 +      pp_c_constructor_elts (pp, CONSTRUCTOR_ELTS (e));
    20 +      return;
    21 +    }
    22 +
    23    switch (code)
    24      {
    25      case RECORD_TYPE:
    26 @@ -1207,16 +1213,12 @@
    27      case VECTOR_TYPE:
    28        if (TREE_CODE (e) == VECTOR_CST)
    29  	pp_c_expression_list (pp, TREE_VECTOR_CST_ELTS (e));
    30 -      else if (TREE_CODE (e) == CONSTRUCTOR)
    31 -	pp_c_constructor_elts (pp, CONSTRUCTOR_ELTS (e));
    32        else
    33  	break;
    34        return;
    35  
    36      case COMPLEX_TYPE:
    37 -      if (TREE_CODE (e) == CONSTRUCTOR)
    38 -	pp_c_constructor_elts (pp, CONSTRUCTOR_ELTS (e));
    39 -      else if (TREE_CODE (e) == COMPLEX_CST || TREE_CODE (e) == COMPLEX_EXPR)
    40 +      if (TREE_CODE (e) == COMPLEX_CST || TREE_CODE (e) == COMPLEX_EXPR)
    41  	{
    42  	  const bool cst = TREE_CODE (e) == COMPLEX_CST;
    43  	  pp_expression (pp, cst ? TREE_REALPART (e) : TREE_OPERAND (e, 0));
    44 diff -durN gcc-4.3.0.orig/gcc/testsuite/gcc.dg/pr35440.c gcc-4.3.0/gcc/testsuite/gcc.dg/pr35440.c
    45 --- gcc-4.3.0.orig/gcc/testsuite/gcc.dg/pr35440.c	1970-01-01 01:00:00.000000000 +0100
    46 +++ gcc-4.3.0/gcc/testsuite/gcc.dg/pr35440.c	2008-06-10 14:44:54.000000000 +0200
    47 @@ -0,0 +1,12 @@
    48 +/* PR c/35440 */
    49 +/* { dg-do compile } */
    50 +/* { dg-options "-std=gnu99" } */
    51 +
    52 +struct A {};
    53 +struct B { int i; char j[2]; };
    54 +
    55 +void foo (void)
    56 +{
    57 +  (struct A){}();			/* { dg-error "called object" } */
    58 +  (struct B){ .i = 2, .j[1] = 1 }();	/* { dg-error "called object" } */
    59 +}