patches/binutils/2.15/190-vmx.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Sun May 03 09:50:16 2009 +0000 (2009-05-03)
branchnewlib
changeset 1366 5e5d1e6f55d3
parent 745 e445c00d134d
permissions -rw-r--r--
Update the newlib devel branch with stuff from /trunk@1498.

-------- diffstat follows --------
/devel/newlib/configure | 336 176 160 0 +++++++------
/devel/newlib/Makefile.in | 12 3 9 0 -
/devel/newlib/scripts/build/kernel/linux.sh | 2 1 1 0
/devel/newlib/scripts/build/internals.sh | 1 0 1 0 -
/devel/newlib/scripts/build/libc/eglibc.sh | 1 0 1 0 -
/devel/newlib/scripts/build/mpfr.sh | 2 1 1 0
/devel/newlib/scripts/functions | 111 5 106 0 ----
/devel/newlib/scripts/config.guess | 7 5 2 0 +
/devel/newlib/scripts/config.sub | 3 2 1 0 +
/devel/newlib/scripts/saveSample.sh.in | 4 2 2 0
/devel/newlib/docs/overview.txt | 8 6 2 0 +
/devel/newlib/samples/armeb-unknown-linux-uclibc/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/sh4-unknown-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/x86_64-unknown-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/arm-unknown-elf/crosstool.config | 12 3 9 0 -
/devel/newlib/samples/armeb-unknown-eabi/crosstool.config | 2 0 2 0 -
/devel/newlib/samples/arm-unknown-linux-gnueabi/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/ia64-unknown-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/x86_64-unknown-linux-uclibc/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/armeb-unknown-linux-gnueabi/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/powerpc-e500v2-linux-gnuspe/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/i686-nptl-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/arm-unknown-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/powerpc-unknown-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/mips-unknown-linux-uclibc/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/arm-unknown-linux-uclibcgnueabi/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/arm-iphone-linux-gnueabi/crosstool.config | 8 4 4 0
/devel/newlib/samples/armeb-unknown-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/powerpc-unknown_nofpu-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/i586-geode-linux-uclibc/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/arm-unknown-linux-uclibc/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/powerpc-unknown-linux-uclibc/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/mips-unknown-elf/crosstool.config | 2 0 2 0 -
/devel/newlib/samples/powerpc-405-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/armeb-unknown-linux-uclibcgnueabi/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/arm-unknown-eabi/crosstool.config | 12 3 9 0 -
/devel/newlib/samples/mipsel-unknown-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/powerpc64-unknown-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/alphaev56-unknown-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/samples/powerpc-860-linux-gnu/crosstool.config | 14 5 9 0 -
/devel/newlib/config/kernel/linux.in | 108 2 106 0 ----
/devel/newlib/config/global/ct-behave.in | 22 13 9 0 +
/devel/newlib/config/global/download.in | 210 15 195 0 +-------
/devel/newlib/config/libc/glibc.in | 7 7 0 0 +
/devel/newlib/config/libc/glibc-eglibc.in-common | 15 14 1 0 +
45 files changed, 382 insertions(+), 839 deletions(-)
yann@402
     1
Grabbed with
yann@402
     2
wget 'http://sources.redhat.com/cgi-bin/cvsweb.cgi/src/opcodes/ppc-opc.c.diff?r1=1.70&r2=1.71&cvsroot=src'
yann@402
     3
See 
yann@402
     4
http://mail.gnu.org/archive/html/bug-binutils/2004-05/msg00071.html
yann@402
     5
and
yann@402
     6
http://sources.redhat.com/ml/binutils-cvs/2004-05/msg00111.html
yann@402
     7
yann@402
     8
This fixes problems like
yann@402
     9
{standard input}: Assembler messages:
yann@402
    10
{standard input}:1: Error: Unrecognized opcode: `dssall' 
yann@402
    11
which show up in binutils-2.15 when building the Linux kernel,
yann@402
    12
or possibly failed compilations when building setjmp/longjmp in glibc.
yann@402
    13
yann@402
    14
An alternative fix would be to pass -many to the assembler.
yann@402
    15
A patch to do that for glibc is at
yann@402
    16
wget 'http://sources.redhat.com/cgi-bin/get-raw-msg?listname=libc-alpha&date=2004-05&msgid=40B36E8C.9030609%40us.ibm.com'
yann@402
    17
Yet another, better, fix would be for gcc to generate assembly
yann@402
    18
that told the assembler which processor type to use.
yann@402
    19
Presumably the Linux kernel sources would need a fix, too.
yann@402
    20
Probably better to just fix binutils to accept sources that it used to.
yann@402
    21
yann@402
    22
yann@402
    23
===================================================================
yann@402
    24
RCS file: /cvs/src/src/opcodes/ppc-opc.c,v
yann@402
    25
retrieving revision 1.70
yann@402
    26
retrieving revision 1.71
yann@402
    27
diff -u -r1.70 -r1.71
yann@402
    28
--- src/opcodes/ppc-opc.c	2004/05/05 13:43:36	1.70
yann@402
    29
+++ src/opcodes/ppc-opc.c	2004/05/19 05:11:48	1.71
yann@402
    30
@@ -1004,8 +1004,13 @@
yann@402
    31
 
yann@402
    32
   /* If only one bit of the FXM field is set, we can use the new form
yann@402
    33
      of the instruction, which is faster.  Unlike the Power4 branch hint
yann@402
    34
-     encoding, this is not backward compatible.  */
yann@402
    35
-  else if ((dialect & PPC_OPCODE_POWER4) != 0 && (value & -value) == value)
yann@402
    36
+     encoding, this is not backward compatible.  Do not generate the
yann@402
    37
+     new form unless -mpower4 has been given, or -many and the two
yann@402
    38
+     operand form of mfcr was used.  */
yann@402
    39
+  else if ((value & -value) == value
yann@402
    40
+	   && ((dialect & PPC_OPCODE_POWER4) != 0
yann@402
    41
+	       || ((dialect & PPC_OPCODE_ANY) != 0
yann@402
    42
+		   && (insn & (0x3ff << 1)) == 19 << 1)))
yann@402
    43
     insn |= 1 << 20;
yann@402
    44
 
yann@402
    45
   /* Any other value on mfcr is an error.  */