summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Frysinger <vapier@gentoo.org>2005-05-30 04:05:05 +0000
committerMike Frysinger <vapier@gentoo.org>2005-05-30 04:05:05 +0000
commitd30f3f97597b89af74e15fa7289444a1ed618f0a (patch)
tree2f051585150edaf80bde48f09c1be3f9c516c3e0 /sys-devel
parent- update baselayout-lite to use libc expanded variable elibc_uclibc vs uclibc... (diff)
downloadgentoo-2-d30f3f97597b89af74e15fa7289444a1ed618f0a.tar.gz
gentoo-2-d30f3f97597b89af74e15fa7289444a1ed618f0a.tar.bz2
gentoo-2-d30f3f97597b89af74e15fa7289444a1ed618f0a.zip
move sse2 patch to patch tarball and add a new alpha mieee patch
(Portage version: 2.0.51.22-r1)
Diffstat (limited to 'sys-devel')
-rw-r--r--sys-devel/gcc/files/3.4.4/gcc-3.4.4-fix-sse2-pinsrw.patch140
-rw-r--r--sys-devel/gcc/files/digest-gcc-3.4.42
-rw-r--r--sys-devel/gcc/gcc-3.4.4.ebuild7
3 files changed, 3 insertions, 146 deletions
diff --git a/sys-devel/gcc/files/3.4.4/gcc-3.4.4-fix-sse2-pinsrw.patch b/sys-devel/gcc/files/3.4.4/gcc-3.4.4-fix-sse2-pinsrw.patch
deleted file mode 100644
index 721ff7df9a93..000000000000
--- a/sys-devel/gcc/files/3.4.4/gcc-3.4.4-fix-sse2-pinsrw.patch
+++ /dev/null
@@ -1,140 +0,0 @@
-Back ported from mainline to gcc-3.4
-
-http://gcc.gnu.org/bugzilla/show_bug.cgi?id=14631
-http://gcc.gnu.org/ml/gcc-patches/2004-09/msg01949.html
-
-2005-01-03 Richard Henderson <rth@redhat.com>
- Uros Bizjak <uros@kss-loka.si>
-
- PR target/14631
- * config/i386/i386.c (ix86_expand_builtin): [IX86_BUILTIN_PINSRW,
- IX86_BUILTIN_PINSRW128]: Fix wrong selector range in error message.
- * config/i386/i386.md (mmx_pinsrw, sse2_pinsrw): Fix selector
- handling.
- (*mmx_pinsrw, *sse2_pinsrw): New patterns.
- * config/i386/i386/predicates.md (const_pow2_1_to_8_operand,
- const_pow2_1_to_128_operand): New predicates.
-
---- gcc/gcc/config/i386/i386.c
-+++ gcc/gcc/config/i386/i386.c
-@@ -3820,6 +3820,21 @@
- return (GET_CODE (op) == CONST_INT && INTVAL (op) >= 0 && INTVAL (op) < 256);
- }
-
-+/* Match exactly one bit in 4-bit mask. */
-+int
-+const_pow2_1_to_8_operand (rtx op, enum machine_mode mode ATTRIBUTE_UNUSED)
-+{
-+ unsigned int log = exact_log2 (INTVAL (op));
-+ return log <= 3;
-+}
-+
-+/* Match exactly one bit in 8-bit mask. */
-+int
-+const_pow2_1_to_128_operand (rtx op, enum machine_mode mode ATTRIBUTE_UNUSED)
-+{
-+ unsigned int log = exact_log2 (INTVAL (op));
-+ return log <= 7;
-+}
-
- /* True if this is a constant appropriate for an increment or decrement. */
-
-@@ -13437,7 +13437,7 @@
- if (! (*insn_data[icode].operand[3].predicate) (op2, mode2))
- {
- error ("selector must be an integer constant in the range 0..%i",
-- fcode == IX86_BUILTIN_PINSRW ? 15:255);
-+ fcode == IX86_BUILTIN_PINSRW ? 3:7);
- return const0_rtx;
- }
- if (target == 0
---- gcc/gcc/config/i386/i386.md
-+++ gcc/gcc/config/i386/i386.md
-@@ -21446,14 +21446,31 @@
-
- ;; MMX insert/extract/shuffle
-
--(define_insn "mmx_pinsrw"
-+(define_expand "mmx_pinsrw"
-+ [(set (match_operand:V4HI 0 "register_operand" "")
-+ (vec_merge:V4HI
-+ (match_operand:V4HI 1 "register_operand" "")
-+ (vec_duplicate:V4HI
-+ (match_operand:SI 2 "nonimmediate_operand" ""))
-+ (match_operand:SI 3 "const_0_to_3_operand" "")))]
-+ "TARGET_SSE || TARGET_3DNOW_A"
-+{
-+ operands[2] = gen_lowpart (HImode, operands[2]);
-+ operands[3] = GEN_INT (1 << INTVAL (operands[3]));
-+})
-+
-+(define_insn "*mmx_pinsrw"
- [(set (match_operand:V4HI 0 "register_operand" "=y")
-- (vec_merge:V4HI (match_operand:V4HI 1 "register_operand" "0")
-- (vec_duplicate:V4HI
-- (truncate:HI (match_operand:SI 2 "nonimmediate_operand" "rm")))
-- (match_operand:SI 3 "const_0_to_15_operand" "N")))]
-+ (vec_merge:V4HI
-+ (match_operand:V4HI 1 "register_operand" "0")
-+ (vec_duplicate:V4HI
-+ (match_operand:HI 2 "nonimmediate_operand" "rm"))
-+ (match_operand:SI 3 "const_pow2_1_to_8_operand" "N")))]
- "TARGET_SSE || TARGET_3DNOW_A"
-- "pinsrw\t{%3, %2, %0|%0, %2, %3}"
-+{
-+ operands[3] = GEN_INT (exact_log2 (INTVAL (operands[3])));
-+ return "pinsrw\t{%3, %k2, %0|%0, %k2, %3}";
-+}
- [(set_attr "type" "mmxcvt")
- (set_attr "mode" "DI")])
-
-@@ -23141,15 +23158,31 @@
-
- ;; MMX insert/extract/shuffle
-
--(define_insn "sse2_pinsrw"
-+(define_expand "sse2_pinsrw"
-+ [(set (match_operand:V8HI 0 "register_operand" "")
-+ (vec_merge:V8HI
-+ (match_operand:V8HI 1 "register_operand" "")
-+ (vec_duplicate:V8HI
-+ (match_operand:SI 2 "nonimmediate_operand" ""))
-+ (match_operand:SI 3 "const_0_to_7_operand" "")))]
-+ "TARGET_SSE2"
-+{
-+ operands[2] = gen_lowpart (HImode, operands[2]);
-+ operands[3] = GEN_INT (1 << INTVAL (operands[3]));
-+})
-+
-+(define_insn "*sse2_pinsrw"
- [(set (match_operand:V8HI 0 "register_operand" "=x")
-- (vec_merge:V8HI (match_operand:V8HI 1 "register_operand" "0")
-- (vec_duplicate:V8HI
-- (truncate:HI
-- (match_operand:SI 2 "nonimmediate_operand" "rm")))
-- (match_operand:SI 3 "const_0_to_255_operand" "N")))]
-+ (vec_merge:V8HI
-+ (match_operand:V8HI 1 "register_operand" "0")
-+ (vec_duplicate:V8HI
-+ (match_operand:HI 2 "nonimmediate_operand" "rm"))
-+ (match_operand:SI 3 "const_pow2_1_to_128_operand" "N")))]
- "TARGET_SSE2"
-- "pinsrw\t{%3, %2, %0|%0, %2, %3}"
-+{
-+ operands[3] = GEN_INT (exact_log2 (INTVAL (operands[3])));
-+ return "pinsrw\t{%3, %k2, %0|%0, %k2, %3}";
-+}
- [(set_attr "type" "ssecvt")
- (set_attr "mode" "TI")])
-
---- gcc/gcc/config/i386/i386.h
-+++ gcc/gcc/config/i386/i386.h
-@@ -2944,6 +2944,8 @@
- {"const_0_to_7_operand", {CONST_INT}}, \
- {"const_0_to_15_operand", {CONST_INT}}, \
- {"const_0_to_255_operand", {CONST_INT}}, \
-+ {"const_pow2_1_to_8_operand", {CONST_INT}}, \
-+ {"const_pow2_1_to_128_operand", {CONST_INT}}, \
- {"incdec_operand", {CONST_INT}}, \
- {"mmx_reg_operand", {REG}}, \
- {"reg_no_sp_operand", {SUBREG, REG}}, \
diff --git a/sys-devel/gcc/files/digest-gcc-3.4.4 b/sys-devel/gcc/files/digest-gcc-3.4.4
index f83366a5e158..b1f4ba5a723a 100644
--- a/sys-devel/gcc/files/digest-gcc-3.4.4
+++ b/sys-devel/gcc/files/digest-gcc-3.4.4
@@ -1,6 +1,6 @@
MD5 b594ff4ea4fbef4ba9220887de713dfe gcc-3.4.4.tar.bz2 27565872
MD5 ca3387f40e4cfef56afe6f1f78f077e2 gcc-3.4.4-ssp-1.0.tar.bz2 31612
MD5 2e82451a5de7e7be5ee0e15ed2648aff gcc-3.4.4-uclibc-patches-1.0.tar.bz2 21617
-MD5 e37ead9b62ab7fd2fafb6559e943221a gcc-3.4.4-patches-1.0.tar.bz2 83993
+MD5 9396d40681e7caf3b5d6ac50cd61b015 gcc-3.4.4-patches-1.1.tar.bz2 71078
MD5 474718bd45586247a7937bed549d8562 gcc-3.4.4-piepatches-v8.7.8.tar.bz2 15514
MD5 d5da59b788f30b6e31488cdae51ca822 bounds-checking-gcc-3.4.4-1.00.patch.bz2 815608
diff --git a/sys-devel/gcc/gcc-3.4.4.ebuild b/sys-devel/gcc/gcc-3.4.4.ebuild
index 1fbed04cb7d1..701ba2e9e920 100644
--- a/sys-devel/gcc/gcc-3.4.4.ebuild
+++ b/sys-devel/gcc/gcc-3.4.4.ebuild
@@ -1,9 +1,9 @@
# Copyright 1999-2005 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/sys-devel/gcc/gcc-3.4.4.ebuild,v 1.4 2005/05/28 07:33:22 vapier Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/gcc/gcc-3.4.4.ebuild,v 1.5 2005/05/30 04:05:05 vapier Exp $
MAN_VER=""
-PATCH_VER="1.0"
+PATCH_VER="1.1"
UCLIBC_VER="1.0"
PIE_VER="8.7.8"
PP_VER="1.0"
@@ -89,9 +89,6 @@ src_unpack() {
#epatch ${FILESDIR}/3.4.3/libffi-nogcj-lib-path-fix.patch
fi
- # Grab fixes for remaining SSE wrong-code bugs
- epatch "${FILESDIR}"/3.4.4/gcc-3.4.4-fix-sse2-pinsrw.patch
-
# Fix cross-compiling
epatch "${FILESDIR}"/3.4.4/gcc-3.4.4-cross-compile.patch