diff options
Diffstat (limited to 'sys-devel/gcc')
-rw-r--r-- | sys-devel/gcc/Manifest | 3 | ||||
-rw-r--r-- | sys-devel/gcc/files/gcc-14.0.1_pre20240303-uninit.patch | 48 | ||||
-rw-r--r-- | sys-devel/gcc/gcc-14.0.1_pre20240303-r1.ebuild (renamed from sys-devel/gcc/gcc-14.0.1_pre20240303.ebuild) | 1 |
3 files changed, 51 insertions, 1 deletions
diff --git a/sys-devel/gcc/Manifest b/sys-devel/gcc/Manifest index b7bba03bdc2d..b222043747c6 100644 --- a/sys-devel/gcc/Manifest +++ b/sys-devel/gcc/Manifest @@ -1,3 +1,4 @@ +AUX gcc-14.0.1_pre20240303-uninit.patch 2047 BLAKE2B edad64293826366fc668da1926dd7a860ee4acb77771cacba043a1ccea3fe1886b4cbc586012026f57e610a0bbebc08120d693786e0cd49c50c80693ced75447 SHA512 9de6b5182086a0abebd8e171ab3b3a9775dac2408684acf27e2d92dce0c44e1622197a00ca72319a0ad4f173279313d6a560f0dbcce8368bc57bb8735bff792f AUX gcc-configure-LANG.patch 2052 BLAKE2B 28c36f4992e41305ee421dade5eaaac34e3bdc523665b03f360f2bc01e8f69e9dc48052edb80dece63ab561e80325b4f125502482eb16f7324f1c03670021550 SHA512 a694c7ac2f45cc657097ff5b0cf1356ac88a9c06035c9ba15167e9d444844d0d8a478eb1b9b62195dd063774f79697b9148b9cdb6c261640b472c291061b2129 AUX gcc-configure-texinfo.patch 341 BLAKE2B d2ea3b2ea08f5d3a498ba27d0fb95e325097e2104e55caa28b66515cb48662649140d90b639369aedc54b2b1178fa4b49cda442f5f504e09d88a2efa45a5057c SHA512 e8d34c5077409df5495cf0c5fbf5e77f841c5698108fa6a5fde33eb28202c685603bdefd8368918e55f30c4b995e895d71d64c715c1ec2b017e09eb2c54c09ff DIST gcc-10.5.0-musl-patches-2.tar.xz 3452 BLAKE2B 5387e516d07d81477b3f39b8b3bd986bf861d32cd25dc5481c97bd3620d00c918c5661e86857f66dbf28a655401a53e43417f638c443e44cbfdbf5e950caac4d SHA512 86f2ce31cc4fc4fb5a6043fb527bf822d895e1a6220652024f78a1cbd5a962edb6be8dc5f43c32053e075f39bb2350ea8f14e7d57e0473dd2933a7b44676bde5 @@ -51,7 +52,7 @@ EBUILD gcc-13.2.1_p20240302.ebuild 1622 BLAKE2B e56c313f3b93e10bfc82f90eaef9a199 EBUILD gcc-13.3.9999.ebuild 1589 BLAKE2B bf6463d9ba5db2a0d494941a33cc7a2be6fd01fc75222c1de50997555b70ebaf2a374dd9f61ffc3eafc1befe23ebedb36123e4f2366cb623b69f1ed566a1a3b1 SHA512 2138f692eca45b998e5675fde63a5b36dbc1dbdec36d2aecf5695c12c51caeaa578a443bc9e795de9e711a55bef79dbf5ce9751a151002bf1625df90b1bb9ca4 EBUILD gcc-14.0.1_pre20240218.ebuild 1596 BLAKE2B 28bc3d16f92ad77a9695ba347e78956dbccddea79ab219f7f6bcfa398134d48481a5e78b7746a796bf233ebbd5310446b4a298a50ec259999fbd73a3f28f2e57 SHA512 846edacff83f3c4be93327af1d308cd22da16482c32b24f34a861117ea25b230f8557ba76c860b209293b6bd5b6f43c7d8917a16ff9b37fd5eb8df297e21cccb EBUILD gcc-14.0.1_pre20240225.ebuild 1596 BLAKE2B 28bc3d16f92ad77a9695ba347e78956dbccddea79ab219f7f6bcfa398134d48481a5e78b7746a796bf233ebbd5310446b4a298a50ec259999fbd73a3f28f2e57 SHA512 846edacff83f3c4be93327af1d308cd22da16482c32b24f34a861117ea25b230f8557ba76c860b209293b6bd5b6f43c7d8917a16ff9b37fd5eb8df297e21cccb -EBUILD gcc-14.0.1_pre20240303.ebuild 1596 BLAKE2B 9915b028ed2d25f453e5bdded194524dff5349d6ee6835716fa5dbebaf500d88ad304408267c397e4199750c30aeaddfeba798c9fa679f61c8063367948c9e6e SHA512 a1b84a0a2d251751d7f7fb36c264287a0fc8a41d7c90cce1aeed34634a7e19445eac86d6c57820302596275bf7dffe4a9ed286bd11450900eab16a5af87f1739 +EBUILD gcc-14.0.1_pre20240303-r1.ebuild 1636 BLAKE2B 4f8278ae5a0215153b5b76103e79a92d0acd4cf84a94e5a59e9b9b3460981ed12e1639f9da4ba3c52e07bfa1b73285843d6ca28b55de012cb815a66cb973a03c SHA512 70455be50f55c33346e3a4a3b57c7ad41b3f6b950aee8eb818b49acad6c1357320da4450377c7a78420f145a511f45e223c6e03e59ea3275ae84756dd0f67c24 EBUILD gcc-14.0.9999.ebuild 1322 BLAKE2B b046a70094fe4e7a946d61414b5f2884c804501a681868066027d1f29950afe41744234550019868c19218fa5562339ce2872e8ecee09839a8ff06e6c9bbb6e0 SHA512 2e02f746aa1d4269f7490db34fecafbdafa239dd7497f6e00b29667dd3ec6276e6a258345b8f1a0a2296a21bf4f5c46cfcd3d1a3e6f3f26804c305c19c0169ed EBUILD gcc-8.5.0-r1.ebuild 498 BLAKE2B e24f62fdb50bf2e9957cbb85c72adc96d369938a7f552735772de964f7023b8b34bd11e7e544d268cc308e25272084a728bd061f37c568d42ea65d55bb2a2e93 SHA512 f35b353e9f54eb3e1c6f8e0ea262458b41da9bddb993793aff79f765c4d93811744979d34e50c6470a9b2cfb63b7006bd284d819b7a98e56a8b3a34ae570ae76 EBUILD gcc-9.5.0.ebuild 1206 BLAKE2B 262931215488db54cab2141549f997a48e22d0a917917eb670d41d5b155c7685e92eb1bc3843d2eca47dd15a450199aea5d99777d2870ff09b1a79ac8a63bcb0 SHA512 3737a70e70e53a581280ff1449d7d92bb9ffba0919b618ea43d4747e09b2803795a05c07c0e3a2ec8982f8d5594be58f9ac549d329b18dc236ad5159e4a47132 diff --git a/sys-devel/gcc/files/gcc-14.0.1_pre20240303-uninit.patch b/sys-devel/gcc/files/gcc-14.0.1_pre20240303-uninit.patch new file mode 100644 index 000000000000..5ad41c4581a9 --- /dev/null +++ b/sys-devel/gcc/files/gcc-14.0.1_pre20240303-uninit.patch @@ -0,0 +1,48 @@ +https://gcc.gnu.org/git/?p=gcc.git;a=commit;h=901e7bdab70e2275723ac31dacbbce0b6f68f4f4 + +From 901e7bdab70e2275723ac31dacbbce0b6f68f4f4 Mon Sep 17 00:00:00 2001 +From: Jakub Jelinek <jakub@redhat.com> +Date: Mon, 4 Mar 2024 19:23:02 +0100 +Subject: [PATCH] combine: Fix recent WORD_REGISTER_OPERATIONS check [PR113010] + +On Mon, Mar 04, 2024 at 05:18:39PM +0100, Rainer Orth wrote: +> unfortunately, the patch broke Solaris/SPARC bootstrap +> (sparc-sun-solaris2.11): +> +> .../gcc/combine.cc: In function 'rtx_code simplify_comparison(rtx_code, rtx_def**, rtx_def**)': +> .../gcc/combine.cc:12101:25: error: '*(unsigned int*)((char*)&inner_mode + offsetof(scalar_int_mode, scalar_int_mode::m_mode))' may be used uninitialized [-Werror=maybe-uninitialized] +> 12101 | scalar_int_mode mode, inner_mode, tmode; +> | ^~~~~~~~~~ + +I don't see how it could ever work properly, inner_mode in that spot is +just uninitialized. + +I think we shouldn't worry about paradoxical subregs of non-scalar_int_mode +REGs/MEMs and for the scalar_int_mode ones should initialize inner_mode +before we use it. +Another option would be to use +maybe_lt (GET_MODE_PRECISION (GET_MODE (SUBREG_REG (op0))), BITS_PER_WORD) +and +load_extend_op (GET_MODE (SUBREG_REG (op0))) == ZERO_EXTEND, +or set machine_mode smode = GET_MODE (SUBREG_REG (op0)); and use it in +those two spots. + +2024-03-04 Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/113010 + * combine.cc (simplify_comparison): Guard the + WORD_REGISTER_OPERATIONS check on scalar_int_mode of SUBREG_REG + and initialize inner_mode. +--- a/gcc/combine.cc ++++ b/gcc/combine.cc +@@ -12554,6 +12554,8 @@ simplify_comparison (enum rtx_code code, rtx *pop0, rtx *pop1) + if (paradoxical_subreg_p (op0)) + { + if (WORD_REGISTER_OPERATIONS ++ && is_a <scalar_int_mode> (GET_MODE (SUBREG_REG (op0)), ++ &inner_mode) + && GET_MODE_PRECISION (inner_mode) < BITS_PER_WORD + /* On WORD_REGISTER_OPERATIONS targets the bits + beyond sub_mode aren't considered undefined, +-- +2.39.3 diff --git a/sys-devel/gcc/gcc-14.0.1_pre20240303.ebuild b/sys-devel/gcc/gcc-14.0.1_pre20240303-r1.ebuild index 97b3b7629c95..ddfe33a42323 100644 --- a/sys-devel/gcc/gcc-14.0.1_pre20240303.ebuild +++ b/sys-devel/gcc/gcc-14.0.1_pre20240303-r1.ebuild @@ -60,5 +60,6 @@ src_prepare() { toolchain_src_prepare + eapply "${FILESDIR}"/${P}-uninit.patch eapply_user } |