From patchwork Wed May 27 13:35:07 2026 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Hemanth Kumar M D X-Patchwork-Id: 88847 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id 06343CD6E46 for ; Wed, 27 May 2026 13:35:48 +0000 (UTC) Received: from mx0b-0064b401.pphosted.com (mx0b-0064b401.pphosted.com [205.220.178.238]) by mx.groups.io with SMTP id smtpd.msgproc01-g2.20549.1779888937277117232 for ; Wed, 27 May 2026 06:35:37 -0700 Authentication-Results: mx.groups.io; dkim=fail reason="dkim: body hash did not verify" header.i=@windriver.com header.s=PPS06212021 header.b=l5ivZ9JR; spf=permerror, err=parse error for token &{10 18 %{ir}.%{v}.%{d}.spf.has.pphosted.com}: invalid domain name (domain: windriver.com, ip: 205.220.178.238, mailfrom: prvs=96079a5f83=hemanth.kumarmd@windriver.com) Received: from pps.filterd (m0250812.ppops.net [127.0.0.1]) by mx0a-0064b401.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 64RCxt8d3067731 for ; Wed, 27 May 2026 13:35:36 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=windriver.com; h=cc:content-transfer-encoding:content-type:date:from :in-reply-to:message-id:mime-version:references:subject:to; s= PPS06212021; bh=qnxRhCyr0SIo7obPESBlNMwA26LWhd052/k8mlsATHg=; b= l5ivZ9JR88Qbk9jqZrUX0tqW6qdATfMIGE0FKGp102WUgjB3wX++VISn5iio+Od4 IR7XoJCvnlse4n5kE2N1CZaNdIpGZlwDgqnjJtMG62CpUCQpDGmt1aeRla6W6O/z xfr0IkLnyotNCjQ4gWjNVUWo3QZBUyWqLEH8hyxeyOynrKVAxK7T3fwxmTjrtEmS W9Xe71WyNtCs1U9GiPRrXCLFwwae/fkeXy0Zu1YZA/cA1sf+PB9ssQLxqx8UcaP9 wjioC/tNyNTXjjXiLHGGkcPeDWDV88OVucOd1TZW+G5mXu9XN2xy9B9yVw1JMtE2 PUZoclgd8BHhaXOJcQSBZg== Received: from ph8pr06cu001.outbound.protection.outlook.com (mail-westus3azon11012015.outbound.protection.outlook.com [40.107.209.15]) by mx0a-0064b401.pphosted.com (PPS) with ESMTPS id 4eb376dytx-2 (version=TLSv1.3 cipher=TLS_AES_256_GCM_SHA384 bits=256 verify=NOT) for ; Wed, 27 May 2026 13:35:35 +0000 (GMT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=MjEUskwbYXFbBckt+3Sizjzb5CaDja3jcfTDWDi946iEhFfzozxFX5IquGQdb+7yn1sdklhxS6nfTxO7eL69jkRAhOkYiRBrXYQRLwlZdcD74csOPZPsGMJi4qkkKTijD3+vaAuBRNwX07OIWOBXgnVnN3jgQDgMB3v+pYRmFgrb+nz726hBPwclTVxlPLeSi8R3hYD7G0q1QoLGQkWuev+0oYmmGhMF/++T/pZJqzAe66aA0th9uW0hxH9xwg9bLom3lno0bgA8RxLdrCftit2GrPfuIzeMVkOYwQSSiIyYtkyaLJrnimOfigBCqayUWbKliXq9dJ71WIc62v2e/g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=qnxRhCyr0SIo7obPESBlNMwA26LWhd052/k8mlsATHg=; b=B0v4ooCIUTaDdCmFQSQD+BHWqbxWNrmNWJed0OjT7AuOdhvC8WT1RBSEe+xWgfd+qsGsyidvFz6c8MZuDXNmYVLRMI3rD2oVm9OOkUKyByX/PMBZA2oiP0N89jDfTxMrOpHtb6SJ2MHFEaaMRC58oaEwDYTsJ7XQu4gjBTTscNStjPRlda4nVLcYbv+eh2NkWy5Df+Q/APbRu6+lw/wPzMSleTXVEfRnZLozUcd5kyQSgAR2Fhj8q/JydFlMEV76nuGdvWiERmpfIS4Gwea+n21rpgN4nBzYB6coqyvfmNCE+0s2g7qx5c8k0v2W1Y3bEtuNyrRClxDHqd+iL0ZUnQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=windriver.com; dmarc=pass action=none header.from=windriver.com; dkim=pass header.d=windriver.com; arc=none Received: from DM6PR11MB4564.namprd11.prod.outlook.com (2603:10b6:5:2a0::7) by MW4PR11MB5774.namprd11.prod.outlook.com (2603:10b6:303:182::16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.12; Wed, 27 May 2026 13:35:32 +0000 Received: from DM6PR11MB4564.namprd11.prod.outlook.com ([fe80::21dd:5cab:fc47:1dfe]) by DM6PR11MB4564.namprd11.prod.outlook.com ([fe80::21dd:5cab:fc47:1dfe%3]) with mapi id 15.21.0071.011; Wed, 27 May 2026 13:35:32 +0000 From: Hemanth.KumarMD@windriver.com To: openembedded-core@lists.openembedded.org Cc: Sundeep.Kokkonda@windriver.com, Hemanth.KumarMD@windriver.com Subject: [PATCH v5 1/7] gcc: Upgrade GCC to 16.1 release Date: Wed, 27 May 2026 06:35:07 -0700 Message-ID: <20260527133516.2337150-2-Hemanth.KumarMD@windriver.com> X-Mailer: git-send-email 2.49.0 In-Reply-To: <20260527133516.2337150-1-Hemanth.KumarMD@windriver.com> References: <20260527133516.2337150-1-Hemanth.KumarMD@windriver.com> X-ClientProxiedBy: SJ0PR13CA0126.namprd13.prod.outlook.com (2603:10b6:a03:2c6::11) To DM6PR11MB4564.namprd11.prod.outlook.com (2603:10b6:5:2a0::7) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6PR11MB4564:EE_|MW4PR11MB5774:EE_ X-MS-Office365-Filtering-Correlation-Id: 646e4b92-40da-4354-e1f5-08debbf4d31f X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|52116014|376014|1800799024|13003099007|18002099003|22082099003|12006099003|38350700014|6133799003|11063799006|56012099006|3023799007; X-Microsoft-Antispam-Message-Info: f1P8NFLNwucP7+gX6FdviWMFBOsM976h4jK8XUCySvhVREJp4CgnIm8qCI+Z2uPTwL9bxx7KVhA3ZxpWWMq22oZYqlk4IanjVNlgBHdQtyLKcbfffXOpA6SBZJfX6FGLZiMNTtlWES+CxEtFIs/K1xNOMUuEWeeygV6uL04S0mpq0HFNlr4g+ZW8YuqNf21j/Mjr47yx9DZARJomn8LtdGhqvDkVQU8YTwz9gBIz+ZuuUpIcnuVFVD9lzVYNo0bFSXkRUtGxzUL/4vZJPkANdP9DPz0MNwRAWuprnhSBSxJvkixjEHLz3KIDPVsg8p4gqGt/MamvnRhqbO+dHFiQZl2IWmS8egm9xvGUsrZofuI6QTYdBqjmLWCUPsSWLh6/YohrGY2DKH78HCqtGhhJ+D/6LHqzOWCwZJ/s9W9kEQqkeGxtnlwXtnRGcXL6diygS1V8f/lQB3z3yT59c16tWHbYj8OuL43nEfDMrs8v6iXca5bd/Y5xqtYVY2sl/ByME6CiT+FIlVoRf6/KEtM3DPEOLfULoZmBdu5vM3lOAlefof4parC1otSgzW+YAUrf/T6mvV7AEt3XvYZSFkMvP2buM/cDJTOpVeKBm/QRmzuk3eYoXKAbuzHKS8BYH80Y4ooRq9ymTcIZNkyUw2r2epdQhJP+nblkOw7MIRc1mgNsGlixTsGr3ottrQBeMO3wcVdvMGpeNeVao/jQSAn3Rw== X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:DM6PR11MB4564.namprd11.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(366016)(52116014)(376014)(1800799024)(13003099007)(18002099003)(22082099003)(12006099003)(38350700014)(6133799003)(11063799006)(56012099006)(3023799007);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?q?96z+IohfF2FBVOO6ZsYXzrywc1Hz?= =?utf-8?q?JTKRsVFtjqqXDYBAIQd+3gM8P5mOSSjhML8TU0L+hOdfQQ/3MmeThm3ywCOiMN737?= =?utf-8?q?pWwJM/GnL8yAsqci6tFoKLKRkMqqYgR/z0+W3LUm6hGMmq82s+45Lyzhnv5sj65VY?= =?utf-8?q?LpawHWlgvCiYoToBLp6HekI32QOpnP87g8XvctS6z7m/bzh3KPO2CvAxS+sNuYAN0?= =?utf-8?q?K0R8jEJqvOgD5NDDW0GHLLsaW3noMXdYaEn3rbWzHJEFe7FCwxDJ+UV0yxAIJLjkU?= =?utf-8?q?Ac5yXGHVUvI5nWvYsyxkdZc4z6wAwHQQKb0NWb0AlAYJ78hwhNYVTnDAQAjzgJsjE?= =?utf-8?q?/hXBts4dcOr2anUSur6DAc9+vMNBO3Xm/Pqn8sXRd3P1jFCRkNuR5pjxa/lG/NwPU?= =?utf-8?q?/qqEdJ5d0Ch82AMkDHRq7lPJ35VrBYNlDN+pWj3dm98/iM9+G8C1pgcIfQYad+i06?= =?utf-8?q?gluSm32fiHXa0UT/rk5otWxHae0gcjoCXjoowJxuIKQazjucRboOFGOtrJY6XJsii?= =?utf-8?q?wK77Ig4F0NtHkqli60OrEUJjN2Gsaztg2HJXpPskbXSPpASPgSgoRWXHZLLOLIWtE?= =?utf-8?q?RVyy+A6zuDvNCN6MUbLZKAANEaQblv4Sd+I7hSXdtL8GpvWNh30LuCJmZrwa36hxf?= =?utf-8?q?V1hdYYsn6Cp2giRbyMxb/8jUeAK4+uBjR1kxeTv+xhWWj1LB+3STPOtoL3DdIrmhE?= =?utf-8?q?hQmCpnvz31EHyLJ2rk6ktoysWsWYxZsTO2kK4or2EETJ57nkXUMDxM95P6g+Eglqe?= =?utf-8?q?dA51349xRJ/oc8Utait3IeuQO9dmvLl0uuAyHfRT+oU0P60G9jb6+fEkGZpvNgIxh?= =?utf-8?q?4yWgrQfllOZbyhyfsRhTmVkjjf8B1IOXeCHwTgZl1ouWQ3PwhKI0JK0nc8eccrLVH?= =?utf-8?q?ztiN40QhjSyd1CihblHGtVTyu0ohmJKm3CKd859SeqBoyNf/kNxi9/OrLzrdUPLee?= =?utf-8?q?EgGpVQJ55zz7/HkStyzgWoe00Po6RvoefG1wQUsnftr1PXZ1jaeBsRMTG0KmYFVYO?= =?utf-8?q?CYN0m2Gia57UlvAX/zNOOnvl4QZ60RH81QUxV4v0cKM2kLx2TTtDz4H5ydZQX7zjF?= =?utf-8?q?nOWxteds588FZNgLDTI+hiv+HQkoKKxds1HpP/bvuBkhX7Od3bXPecbGPBObgYewm?= =?utf-8?q?TAtWRa+t/y3NKzm2fVn5NqY5DvVOvr0P/681QGoJSfULULji8zZ6PO4mzQgktnEdR?= =?utf-8?q?8q5vldHlj7i1DuAP/0iQHsyGUDoRN8OCl7FFdw4iUmWHBTGZVEjYkoeVGyA/YLunk?= =?utf-8?q?+Sr4NC/MtuKoCszqJhRRCqvkBl3cD6XxjqXpe+efpVU3VkheN+DAe3MG7UosbGVW1?= =?utf-8?q?IKjrJIA6sWlmnaHbUEFNt1wlx1By0Gm+SJDtRQ6l07hdRJMJd4weJ4S7AqWm6Ut6E?= =?utf-8?q?qjmuzzSjdqoCp7anriY45SXJefI4Hp+ni5daRRLZMmAVFo2OYhf/eA5MIzIytk+zl?= =?utf-8?q?tKasevmLVVxa1t3jaTl+iC/rlyIit6tH4cETe+rmbdb8pmqPzCj93o63JvmcU7xpV?= =?utf-8?q?F9TcUf2yohO49LsMYsq2hMdZEOrRCyl2pBpSmHs0aKj14rBGNsSgxe4hBBV1AMP1A?= =?utf-8?q?o8Kzv9nqilkQHNL0EbLBNjiEsN9WulZJ8j9gTLSG00XtHWs0TIOwLd9a4++jBD+bv?= =?utf-8?q?Th7F+DDVrdORCX9foyIfKHIAP8axobfUsG0nW8Q9SvJSpwyPid6dY=3D?= X-Exchange-RoutingPolicyChecked: rEzsSsjVNbiR9OYq6MFkMEgOYbtb2RAknQYwrCGq/uVFbVIKbwItPnyRc4g0qTatBtzV+BYnfYcNVM3D63/yOlaMD7z3BRSZAJFCHTpujUpgEAAQ/6uyyoL6ElcqR1Xm6+LfMml4NP268/B6n7IyU+FRN55NTOvJgQ2DKC2RcnFoThvRExsxCd1E9W9YXIAAnAxp3/PIiy90/aSFJsGhpQvH9s+eWogpQTkOK2m/8O8EKbv4Tscamh41puNYZ/lye0Hmlj+/6p48xOGzbJlkbeiirgogNLkefHLpt8O5FGyywwitcuJgrPqqA6at5A/1S4Rmbe3bZ7YUn0guSkjuMg== X-OriginatorOrg: windriver.com X-MS-Exchange-CrossTenant-Network-Message-Id: 646e4b92-40da-4354-e1f5-08debbf4d31f X-MS-Exchange-CrossTenant-AuthSource: DM6PR11MB4564.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 May 2026 13:35:32.3576 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 8ddb2873-a1ad-4a18-ae4e-4644631433be X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 61q+Ik2zIrZWQLOZ31jXrSgIiFi3X4tc9paGrKpov0w3YhjUwTKWImPHM6PZyiXoFhYbgCDRuJUERW2WangZMTIHTg/wYf8WmsQj28/jpIw= X-MS-Exchange-Transport-CrossTenantHeadersStamped: MW4PR11MB5774 X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwNTI3MDEzMyBTYWx0ZWRfXwhhymR+/PFUO aW1uDOphwKnEFel3xfb2RVRQY0Acc65P6VIEu08EMhZ4WLu5/A0EduFHK5XDvk3JnAa30wdswV8 43/T9atawkC/SmJp+YUsRrP4jMEQJ7UHwLmgqdLyyyuBHSihZnQwd4GsbOHkrw655NACaeAxBgV /5pmmAkseGprLRscTVKLBOvmafI+khqyc6X/Nl3XbezFZWb8INBDHIGrXVO5KoukuEAjwqOjWWp kB2VtDNRGk0JNFz/F70qis0X447g7gkD+KQfYFV3aFOGO6McLxFxsbmCnzG8EuWRSfR3vAIPTMS aSIg3j+qM1/+jVGzzbKy3Ldd3OKSbP8STtJyp0CZli4ZRq/tYcE3eX0+tfgNSGNDmHGVQ3SrMCU 1mFDo0GaVU2IDV9aA60lAukjimh4OjLD+RDwONc3fVt7dcKpNUDAqv59juKbJoGxj8JOvOegk6b 7SaZ6GcGkY6RjVnezYg== X-Authority-Analysis: v=2.4 cv=M5B97Sws c=1 sm=1 tr=0 ts=6a16f328 cx=c_pps a=YvmT30J82QCmV9938MlLOg==:117 a=6eWqkTHjU83fiwn7nKZWdM+Sl24=:19 a=z/mQ4Ysz8XfWz/Q5cLBRGdckG28=:19 a=lCpzRmAYbLLaTzLvsPZ7Mbvzbb8=:19 a=xqWC_Br6kY4A:10 a=IkcTkHD0fZMA:10 a=NGcC8JguVDcA:10 a=VkNPw1HP01LnGYTKEx00:22 a=bi6dqmuHe4P4UrxVR6um:22 a=fTW__CHxibyLmBMfj2wP:22 a=mDV3o1hIAAAA:8 a=t7CeM3EgAAAA:8 a=pGLkceISAAAA:8 a=7CQSdrXTAAAA:8 a=iGHA9ds3AAAA:8 a=20KFwNOVAAAA:8 a=9VPlPrzCAAAA:8 a=hwpk83-eGoRv12KktN0A:9 a=bxMAh2iGgf655hUu:21 a=3ZKOabzyN94A:10 a=QEXdDO2ut3YA:10 a=FdTzh2GWekK77mhwV6Dw:22 a=a-qgeE7W1pNrGK8U0ZQC:22 a=nM-MV4yxpKKO9kiQg6Ot:22 a=aK1hd8Lu7Q_i5nYwpAI3:22 X-Proofpoint-GUID: d0wmTxgDNsooR6atwUib0I8gZJK6BBbE X-Proofpoint-ORIG-GUID: d0wmTxgDNsooR6atwUib0I8gZJK6BBbE X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1143,Hydra:6.1.125,FMLib:17.12.100.49 definitions=2026-05-27_02,2026-05-26_03,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 suspectscore=0 impostorscore=0 phishscore=0 clxscore=1015 spamscore=0 adultscore=0 bulkscore=0 malwarescore=0 lowpriorityscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2605130000 definitions=main-2605270133 X-MIME-Autoconverted: from 8bit to quoted-printable by mx0a-0064b401.pphosted.com id 64RCxt8d3067731 List-Id: X-Webhook-Received: from 45-33-107-173.ip.linodeusercontent.com [45.33.107.173] by aws-us-west-2-korg-lkml-1.web.codeaurora.org with HTTPS for ; Wed, 27 May 2026 13:35:48 -0000 X-Groupsio-URL: https://lists.openembedded.org/g/openembedded-core/message/237662 From: Hemanth Kumar M D Notable changes in GCC 16 include: - Improved C23/C++23 support and initial C++26 features - Enhanced diagnostics and static analyzer improvements - Optimizer and code generation enhancements - Target-specific updates for AArch64, RISC-V, x86, and others - Runtime library updates (libstdc++, libatomic, libgomp, libsanitizer) - Multiple bug fixes and performance improvements * Rebased existing OE-Core patches for GCC 16.1 and dropped patches merged upstream. For detailed info: https://gcc.gnu.org/gcc-16/changes.html Signed-off-by: Hemanth Kumar M D --- meta/conf/distro/include/maintainers.inc | 2 +- meta/conf/distro/include/tcmode-default.inc | 2 +- .../gcc/{gcc-15.2.inc => gcc-16.1.inc} | 17 +- ...ian_15.2.bb => gcc-cross-canadian_16.1.bb} | 0 .../{gcc-cross_15.2.bb => gcc-cross_16.1.bb} | 0 ...-crosssdk_15.2.bb => gcc-crosssdk_16.1.bb} | 0 ...cc-runtime_15.2.bb => gcc-runtime_16.1.bb} | 0 ...itizers_15.2.bb => gcc-sanitizers_16.1.bb} | 0 ...{gcc-source_15.2.bb => gcc-source_16.1.bb} | 0 ...AMIC_LINKER-and-UCLIBC_DYNAMIC_LINKE.patch | 2 +- ...sroot-gcc-version-specific-dirs-with.patch | 4 +- ...omic-Do-not-enforce-march-on-aarch64.patch | 18 +- ...025-gcc-testsuite-tweaks-for-mips-OE.patch | 78 +++--- .../gcc/gcc/0026-fix-pr90579-testcases.patch | 40 --- .../gcc/gcc/0027-gcc15-pr122394.patch | 88 ------ ...028-fix-gcc-libitm-false-postives-01.patch | 187 ------------- ...028-fix-gcc-libitm-false-postives-02.patch | 220 --------------- ...dy-Make-it-buildable-by-C-11-to-C-26.patch | 257 ------------------ .../gcc/{gcc_15.2.bb => gcc_16.1.bb} | 0 ...initial_15.2.bb => libgcc-initial_16.1.bb} | 0 .../gcc/{libgcc_15.2.bb => libgcc_16.1.bb} | 0 ...ibgfortran_15.2.bb => libgfortran_16.1.bb} | 0 22 files changed, 66 insertions(+), 849 deletions(-) rename meta/recipes-devtools/gcc/{gcc-15.2.inc => gcc-16.1.inc} (88%) rename meta/recipes-devtools/gcc/{gcc-cross-canadian_15.2.bb => gcc-cross-canadian_16.1.bb} (100%) rename meta/recipes-devtools/gcc/{gcc-cross_15.2.bb => gcc-cross_16.1.bb} (100%) rename meta/recipes-devtools/gcc/{gcc-crosssdk_15.2.bb => gcc-crosssdk_16.1.bb} (100%) rename meta/recipes-devtools/gcc/{gcc-runtime_15.2.bb => gcc-runtime_16.1.bb} (100%) rename meta/recipes-devtools/gcc/{gcc-sanitizers_15.2.bb => gcc-sanitizers_16.1.bb} (100%) rename meta/recipes-devtools/gcc/{gcc-source_15.2.bb => gcc-source_16.1.bb} (100%) delete mode 100644 meta/recipes-devtools/gcc/gcc/0026-fix-pr90579-testcases.patch delete mode 100644 meta/recipes-devtools/gcc/gcc/0027-gcc15-pr122394.patch delete mode 100644 meta/recipes-devtools/gcc/gcc/0028-fix-gcc-libitm-false-postives-01.patch delete mode 100644 meta/recipes-devtools/gcc/gcc/0028-fix-gcc-libitm-false-postives-02.patch delete mode 100644 meta/recipes-devtools/gcc/gcc/0028-libcody-Make-it-buildable-by-C-11-to-C-26.patch rename meta/recipes-devtools/gcc/{gcc_15.2.bb => gcc_16.1.bb} (100%) rename meta/recipes-devtools/gcc/{libgcc-initial_15.2.bb => libgcc-initial_16.1.bb} (100%) rename meta/recipes-devtools/gcc/{libgcc_15.2.bb => libgcc_16.1.bb} (100%) rename meta/recipes-devtools/gcc/{libgfortran_15.2.bb => libgfortran_16.1.bb} (100%) diff --git a/meta/conf/distro/include/maintainers.inc b/meta/conf/distro/include/maintainers.inc index 24c5a9d712..fdfdec28b5 100644 --- a/meta/conf/distro/include/maintainers.inc +++ b/meta/conf/distro/include/maintainers.inc @@ -200,7 +200,7 @@ RECIPE_MAINTAINER:pn-gcc-cross-canadian-${TRANSLATED_TARGET_ARCH} = "Khem Raj -Date: Sun, 10 Aug 2025 20:28:00 +0800 -Subject: [PATCH] testsuite: i386: Fix gcc.target/i386/pr90579.c when PIE is - enabled [PR118885] - -When gcc build with --enable-deafult-pie the following tests -were getting failed: - FAIL: gcc.target/i386/pr90579.c scan-assembler vaddsd\tr\\+40 - FAIL: gcc.target/i386/pr90579.c scan-assembler vaddsd\tr\\+32 - FAIL: gcc.target/i386/pr90579.c scan-assembler vaddsd\tr\\+24 - FAIL: gcc.target/i386/pr90579.c scan-assembler vaddsd\tr\\+16 - - PR target/118885 - -gcc/testsuite/ChangeLog: - - * gcc.target/i386/pr90579.c: add -fno-pie to dg-options - to fix tests when PIE is enabled. - -Upstream-Status: Backport [https://gcc.gnu.org/cgit/gcc/commit/?id=679e24f5a751663998ff7202149a749e0f7251f9] - -Signed-off-by: Harish Sadineni ---- - gcc/testsuite/gcc.target/i386/pr90579.c | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -diff --git a/gcc/testsuite/gcc.target/i386/pr90579.c b/gcc/testsuite/gcc.target/i386/pr90579.c -index ab48a44063c..19081ec9fdf 100644 ---- a/gcc/testsuite/gcc.target/i386/pr90579.c -+++ b/gcc/testsuite/gcc.target/i386/pr90579.c -@@ -1,5 +1,5 @@ - /* { dg-do compile } */ --/* { dg-options "-O3 -mavx2 -mfpmath=sse" } */ -+/* { dg-options "-O3 -mavx2 -mfpmath=sse -fno-pie" } */ - - extern double r[6]; - extern double a[]; --- -2.49.0 diff --git a/meta/recipes-devtools/gcc/gcc/0027-gcc15-pr122394.patch b/meta/recipes-devtools/gcc/gcc/0027-gcc15-pr122394.patch deleted file mode 100644 index 9ee371cef7..0000000000 --- a/meta/recipes-devtools/gcc/gcc/0027-gcc15-pr122394.patch +++ /dev/null @@ -1,88 +0,0 @@ -From e55dcff97708a4937dc4d8736b8b3074ebbff6f3 Mon Sep 17 00:00:00 2001 -From: Jakub Jelinek -Date: Mon, 27 Oct 2025 17:43:17 +0100 -Subject: phiopt: Fix up DEBUG_EXPR_DECL creation in spaceship_replacement - [PR122394] - -The following testcase ICEs in gcc 15 (and is at least latent in 12-14 too), -because the DEBUG_EXPR_DECL has incorrect mode. It has -TREE_TYPE (orig_use_lhs) type, but TYPE_MODE (type) rather than -TYPE_MODE (TREE_TYPE (orig_use_lhs)) where the two types are sometimes -the same, but sometimes different (same if !has_cast_debug_uses, different -otherwise). - -Though, there wouldn't be the this issue if it used the proper API to create -the DEBUG_EXPR_DECL which takes care of everything. This is the sole -spot that doesn't use that API. - -Doesn't affect the trunk because the code has been removed and replaced with -different stuff after the libstdc++ ABI change in r16-3474. -Before r15-5557 the mode has been always wrong because this was done only -for has_cast_debug_uses. And the bug has been introduced with r12-5490. - -Enough archeology, while it could be fixed by changing the second -SET_DECL_MODE argument, I think it is better to use build_debug_expr_decl. - -2025-10-27 Jakub Jelinek - - PR tree-optimization/122394 - * tree-ssa-phiopt.cc (spaceship_replacement): Use - build_debug_expr_decl instead of manually building DEBUG_EXPR_DECL - and getting SET_DECL_MODE wrong. - - * g++.dg/opt/pr122394.C: New test. - -Upstream-Status: Backport [https://gcc.gnu.org/cgit/gcc/commit/?id=e55dcff97708a4937dc4d8736b8b3074ebbff6f3] -Signed-off-by: Hongxu Jia ---- - gcc/testsuite/g++.dg/opt/pr122394.C | 20 ++++++++++++++++++++ - gcc/tree-ssa-phiopt.cc | 6 ++---- - 2 files changed, 22 insertions(+), 4 deletions(-) - create mode 100644 gcc/testsuite/g++.dg/opt/pr122394.C - -diff --git a/gcc/testsuite/g++.dg/opt/pr122394.C b/gcc/testsuite/g++.dg/opt/pr122394.C -new file mode 100644 -index 000000000000..1f84bebd74c2 ---- /dev/null -+++ b/gcc/testsuite/g++.dg/opt/pr122394.C -@@ -0,0 +1,20 @@ -+// PR tree-optimization/122394 -+// { dg-do compile { target c++23 } } -+// { dg-options "-O1 -g" } -+ -+#include -+ -+struct A { -+ friend auto operator<=> (A, A) = default; -+ double a; -+}; -+void foo (); -+A b, c; -+ -+void -+bar () -+{ -+ bool d = c >= b; -+ if (d) -+ foo (); -+} -diff --git a/gcc/tree-ssa-phiopt.cc b/gcc/tree-ssa-phiopt.cc -index aaebae6b38c0..3e0ad9d3bb09 100644 ---- a/gcc/tree-ssa-phiopt.cc -+++ b/gcc/tree-ssa-phiopt.cc -@@ -2995,10 +2995,8 @@ spaceship_replacement (basic_block cond_bb, basic_block middle_bb, - if (has_cast_debug_uses - || (HONOR_NANS (TREE_TYPE (lhs1)) && !is_cast)) - { -- tree temp3 = make_node (DEBUG_EXPR_DECL); -- DECL_ARTIFICIAL (temp3) = 1; -- TREE_TYPE (temp3) = TREE_TYPE (orig_use_lhs); -- SET_DECL_MODE (temp3, TYPE_MODE (type)); -+ tree temp3 -+ = build_debug_expr_decl (TREE_TYPE (orig_use_lhs)); - if (has_cast_debug_uses) - t = fold_convert (TREE_TYPE (temp3), temp2); - else --- -cgit - diff --git a/meta/recipes-devtools/gcc/gcc/0028-fix-gcc-libitm-false-postives-01.patch b/meta/recipes-devtools/gcc/gcc/0028-fix-gcc-libitm-false-postives-01.patch deleted file mode 100644 index d8ed99adb5..0000000000 --- a/meta/recipes-devtools/gcc/gcc/0028-fix-gcc-libitm-false-postives-01.patch +++ /dev/null @@ -1,187 +0,0 @@ -From b129ff0880c6d10e0379b46889d01255ee8d1f82 Mon Sep 17 00:00:00 2001 -From: Pietro Monteiro -Date: Fri, 30 Jan 2026 20:22:49 -0500 -Subject: libitm: testsuite: don't include libstdc++ paths in test names - [PR69018] - -Libitm C++ tests pass -B/full/path/to/build/libstc++/src/.libs on the -options argument to dg-runtest and the libstdc++ include paths as -the default-extra-options. This causes 2 problems: - -1) If a test uses `dg-options' then the libstdc++ include paths are -not passed to the compiler. - -2) The `-B/full/path/to/build/libstc++/src/.libs' gets added to the -test name. This makes comparing build done in different directories -harder because the hardcoded full path. - -Stop passing options and default-extra-options to dg-runtest and move -dealing with the path-releated flags to libitm_target_compile in -libitm.exp, where they are added to additional_flags. - -Also change the FSF address to the website in the license text. - -libitm/ChangeLog: - PR libitm/69018 - * testsuite/lib/libitm.exp (libitm_target_compile): Add - lang_include_flags and `-B${blddir}/${lang_library_paths}' to - additional_flags. - * testsuite/libitm.c++/c++.exp: Set lang_library_paths and lang_include_flags. - -Upstream-Status: Backport [https://gcc.gnu.org/cgit/gcc/patch/?id=b129ff0880c6d10e0379b46889d01255ee8d1f82] - -Signed-off-by: Pietro Monteiro -Signed-off-by: Harish Sadineni ---- - libitm/testsuite/lib/libitm.exp | 25 ++++++++++---- - libitm/testsuite/libitm.c++/c++.exp | 67 +++++++++++++++++-------------------- - 2 files changed, 48 insertions(+), 44 deletions(-) - -diff --git a/libitm/testsuite/lib/libitm.exp b/libitm/testsuite/lib/libitm.exp -index 0b3301537cee..69a49906d338 100644 ---- a/libitm/testsuite/lib/libitm.exp -+++ b/libitm/testsuite/lib/libitm.exp -@@ -9,8 +9,7 @@ - # GNU General Public License for more details. - # - # You should have received a copy of the GNU General Public License --# along with this program; if not, write to the Free Software --# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -+# along with this program; if not, see . - - # Damn dejagnu for not having proper library search paths for load_lib. - # We have to explicitly load everything that gcc-dg.exp wants to load. -@@ -193,14 +192,24 @@ proc libitm_target_compile { source dest type options } { - global gluefile wrap_flags - global ALWAYS_CFLAGS - global GCC_UNDER_TEST -- global lang_test_file -- global lang_library_path -+ global lang_library_paths - global lang_link_flags -+ global lang_include_flags - -- if { [info exists lang_test_file] } { -- if { $blddir != "" } { -+ if { [info exists lang_include_flags] } { -+ lappend options "additional_flags=${lang_include_flags}" -+ } -+ -+ if { [info exists lang_library_paths] } { -+ foreach lang_library_path $lang_library_paths { -+ # targets that use lib[...].a%s in their specs need a -B option -+ # for uninstalled testing. -+ lappend options "additional_flags=-B${blddir}/${lang_library_path}" - lappend options "ldflags=-L${blddir}/${lang_library_path}" - } -+ } -+ -+ if { [info exists lang_link_flags] } { - lappend options "ldflags=${lang_link_flags}" - } - -@@ -219,7 +228,9 @@ proc libitm_target_compile { source dest type options } { - set options [concat "$ALWAYS_CFLAGS" $options] - } - -- set options [dg-additional-files-options $options $source $dest $type] -+ if { $source != "" } { -+ set options [dg-additional-files-options $options $source $dest $type] -+ } - - set result [target_compile $source $dest $type $options] - -diff --git a/libitm/testsuite/libitm.c++/c++.exp b/libitm/testsuite/libitm.c++/c++.exp -index a1ce7ce4062e..90f3058e7249 100644 ---- a/libitm/testsuite/libitm.c++/c++.exp -+++ b/libitm/testsuite/libitm.c++/c++.exp -@@ -11,8 +11,7 @@ - # GNU General Public License for more details. - # - # You should have received a copy of the GNU General Public License --# along with this program; if not, write to the Free Software --# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -+# along with this program; if not, see . - - load_lib libitm-dg.exp - load_gcc_lib gcc-dg.exp -@@ -33,48 +32,42 @@ set blddir [lookfor_file [get_multilibs] libitm] - - - if { $blddir != "" } { -- # Look for a static libstdc++ first. -- if [file exists "${blddir}/${lang_library_path}/libstdc++.a"] { -- set lang_test_file "${lang_library_path}/libstdc++.a" -- set lang_test_file_found 1 -- # We may have a shared only build, so look for a shared libstdc++. -- } elseif [file exists "${blddir}/${lang_library_path}/libstdc++.${shlib_ext}"] { -- set lang_test_file "${lang_library_path}/libstdc++.${shlib_ext}" -- set lang_test_file_found 1 -- } else { -- puts "No libstdc++ library found, will not execute c++ tests" -+ if { ![file exists "${blddir}/${lang_library_path}/libstdc++.a"] -+ && ![file exists "${blddir}/${lang_library_path}/libstdc++.${shlib_ext}"] } { -+ verbose -log "No libstdc++ library found, will not execute c++ tests" -+ unset lang_library_path -+ return - } --} elseif { [info exists GXX_UNDER_TEST] } { -- set lang_test_file_found 1 -- # Needs to exist for libitm.exp. -- set lang_test_file "" -+ lappend lang_library_paths ${lang_library_path} -+} elseif { ![info exists GXX_UNDER_TEST] } { -+ verbose -log "GXX_UNDER_TEST not defined, will not execute c++ tests" -+ return -+} -+ -+# Gather a list of all tests. -+set tests [lsort [glob -nocomplain $srcdir/$subdir/*.C]] -+ -+if { $blddir != "" } { -+ set ld_library_path "$always_ld_library_path:${blddir}/${lang_library_path}" - } else { -- puts "GXX_UNDER_TEST not defined, will not execute c++ tests" -+ set ld_library_path "$always_ld_library_path" - } - --if { $lang_test_file_found } { -- # Gather a list of all tests. -- set tests [lsort [glob -nocomplain $srcdir/$subdir/*.C]] -+append ld_library_path [gcc-set-multilib-library-path $GCC_UNDER_TEST] -+set_ld_library_path_env_vars - -- set stdcxxadder "" -- if { $blddir != "" } { -- set ld_library_path "$always_ld_library_path:${blddir}/${lang_library_path}" -- set stdcxxadder "-B ${blddir}/${lang_library_path}" -- } else { -- set ld_library_path "$always_ld_library_path" -- } -- append ld_library_path [gcc-set-multilib-library-path $GCC_UNDER_TEST] -- set_ld_library_path_env_vars -+set flags_file "${blddir}/../libstdc++-v3/scripts/testsuite_flags" -+if { [file exists $flags_file] } { -+ set lang_include_flags [exec sh $flags_file --build-includes] -+} - -- set flags_file "${blddir}/../libstdc++-v3/scripts/testsuite_flags" -- if { [file exists $flags_file] } { -- set libstdcxx_includes [exec sh $flags_file --build-includes] -- } else { -- set libstdcxx_includes "" -- } -+# Main loop. -+dg-runtest $tests "" "" - -- # Main loop. -- dg-runtest $tests $stdcxxadder $libstdcxx_includes -+if { $blddir != "" } { -+ unset lang_include_flags -+ unset lang_library_path -+ unset lang_library_paths - } - - # All done. --- -cgit diff --git a/meta/recipes-devtools/gcc/gcc/0028-fix-gcc-libitm-false-postives-02.patch b/meta/recipes-devtools/gcc/gcc/0028-fix-gcc-libitm-false-postives-02.patch deleted file mode 100644 index 67ed47ff51..0000000000 --- a/meta/recipes-devtools/gcc/gcc/0028-fix-gcc-libitm-false-postives-02.patch +++ /dev/null @@ -1,220 +0,0 @@ -From 66ce317036f2eb5aeb96d5e4b9e468799d7566b6 Mon Sep 17 00:00:00 2001 -From: Pietro Monteiro -Date: Wed, 11 Feb 2026 11:55:13 -0500 -Subject: libitm: Fix recent libitm testsuite regression [PR69018] -MIME-Version: 1.0 -Content-Type: text/plain; charset=UTF-8 -Content-Transfer-Encoding: 8bit - -The commit r16-7202-gb129ff0880c6d1 broke running libitm’s testsuite -using combinations of options because it didn’t clean up all the -global variables set in c++.exp. Fix the regression by using g++ for -the C++ tests and cleaning up the variables shared between C and C++ -tests. - -libitm/ChangeLog: - PR libitm/69018 - * testsuite/lib/libitm.exp (libitm_init): Check - GXX_UNDER_TEST. Add "${blddir}/.libs" to - always_ld_library_path if blddir is not empty. Use - "-fdiagnostics-plain-output". Don't set compiler to GCC_UNDER_TEST. - * testsuite/libitm.c++/c++.exp: If $blddir is not empty set - libstdc++_library_path, shlib_ext, lang_include_flags, add - "${blddir}/${lang_library_paths}" to ld_library_path. - Unset libstdc++_library_path and shlib_ext if we skip C++ - tests and at the end of the test run. - * testsuite/libitm.c/c.exp: Update the FSF address to the - website in the license text. Unset lang_library_paths and - lang_include_flags. Set the compiler to $GCC_UNDER_TEST. - -Upstream-Status: Backport [https://gcc.gnu.org/cgit/gcc/patch/?id=66ce317036f2eb5aeb96d5e4b9e468799d7566b6] - -Co-authored-by: Jakub Jelinek -Signed-off-by: Pietro Monteiro -Signed-off-by: Harish Sadineni ---- - libitm/testsuite/lib/libitm.exp | 21 +++++++++++++++---- - libitm/testsuite/libitm.c++/c++.exp | 42 ++++++++++++++----------------------- - libitm/testsuite/libitm.c/c.exp | 14 ++++++------- - 3 files changed, 40 insertions(+), 37 deletions(-) - -diff --git a/libitm/testsuite/lib/libitm.exp b/libitm/testsuite/lib/libitm.exp -index 69a49906d338..2de0f6cbf158 100644 ---- a/libitm/testsuite/lib/libitm.exp -+++ b/libitm/testsuite/lib/libitm.exp -@@ -79,7 +79,7 @@ proc libitm_init { args } { - global ALWAYS_CFLAGS - global CFLAGS - global TOOL_EXECUTABLE TOOL_OPTIONS -- global GCC_UNDER_TEST -+ global GCC_UNDER_TEST GXX_UNDER_TEST - global TESTING_IN_BUILD_TREE - global target_triplet - global always_ld_library_path -@@ -97,6 +97,17 @@ proc libitm_init { args } { - } else { - set GCC_UNDER_TEST "[find_gcc]" - } -+ # Only if we're guessing 'GCC_UNDER_TEST', we're also going to guess -+ # 'GXX_UNDER_TEST' -+ if ![info exists GXX_UNDER_TEST] then { -+ if [info exists TOOL_EXECUTABLE] { -+ set GXX_UNDER_TEST $TOOL_EXECUTABLE -+ } else { -+ set GXX_UNDER_TEST "[find_g++]" -+ } -+ } else { -+ error "GXX_UNDER_TEST set but not GCC_UNDER_TEST" -+ } - } - - if ![info exists tmpdir] { -@@ -119,7 +130,7 @@ proc libitm_init { args } { - } - - # Compute what needs to be put into LD_LIBRARY_PATH -- set always_ld_library_path ".:${blddir}/.libs" -+ set always_ld_library_path "." - - # Compute what needs to be added to the existing LD_LIBRARY_PATH. - if {$gccdir != ""} { -@@ -150,6 +161,8 @@ proc libitm_init { args } { - lappend ALWAYS_CFLAGS "additional_flags=-B${blddir}/" - lappend ALWAYS_CFLAGS "additional_flags=-I${blddir}" - lappend ALWAYS_CFLAGS "ldflags=-L${blddir}/.libs" -+ -+ append always_ld_library_path ":${blddir}/.libs" - } - lappend ALWAYS_CFLAGS "additional_flags=-I${srcdir}/.." - -@@ -179,7 +192,8 @@ proc libitm_init { args } { - # Turn on transactional memory support. - lappend ALWAYS_CFLAGS "additional_flags=-fgnu-tm" - -- lappend ALWAYS_CFLAGS "additional_flags=-fdiagnostics-color=never" -+ # Disable caret, color, URL diagnostics -+ lappend ALWAYS_CFLAGS "additional_flags=-fdiagnostics-plain-output" - } - - # -@@ -220,7 +234,6 @@ proc libitm_target_compile { source dest type options } { - - lappend options "additional_flags=[libio_include_flags]" - lappend options "timeout=[timeout_value]" -- lappend options "compiler=$GCC_UNDER_TEST" - - set options [concat $libitm_compile_options $options] - -diff --git a/libitm/testsuite/libitm.c++/c++.exp b/libitm/testsuite/libitm.c++/c++.exp -index 90f3058e7249..c24dc830bcc5 100644 ---- a/libitm/testsuite/libitm.c++/c++.exp -+++ b/libitm/testsuite/libitm.c++/c++.exp -@@ -16,39 +16,33 @@ - load_lib libitm-dg.exp - load_gcc_lib gcc-dg.exp - --global shlib_ext -- --set shlib_ext [get_shlib_extension] --# The C++ tests should be linked with g++, which defaults to -shared-libgcc. --# Doing that is currently too intrusive, so hardcode here. --set lang_link_flags "-shared-libgcc -lstdc++" --set lang_test_file_found 0 --set lang_library_path "../libstdc++-v3/src/.libs" -- --# Initialize dg. --dg-init -- --set blddir [lookfor_file [get_multilibs] libitm] -- -- - if { $blddir != "" } { -- if { ![file exists "${blddir}/${lang_library_path}/libstdc++.a"] -- && ![file exists "${blddir}/${lang_library_path}/libstdc++.${shlib_ext}"] } { -+ set libstdc++_library_path "../libstdc++-v3/src/.libs" -+ set shlib_ext [get_shlib_extension] -+ if { ![file exists "${blddir}/${libstdc++_library_path}/libstdc++.a"] -+ && ![file exists "${blddir}/${libstdc++_library_path}/libstdc++.${shlib_ext}"] } { - verbose -log "No libstdc++ library found, will not execute c++ tests" -- unset lang_library_path -+ unset libstdc++_library_path -+ unset shlib_ext - return - } -- lappend lang_library_paths ${lang_library_path} -+ lappend lang_library_paths ${libstdc++_library_path} - } elseif { ![info exists GXX_UNDER_TEST] } { - verbose -log "GXX_UNDER_TEST not defined, will not execute c++ tests" - return - } - -+lappend ALWAYS_CFLAGS "compiler=$GXX_UNDER_TEST" -+ -+# Initialize dg. -+dg-init -+ - # Gather a list of all tests. - set tests [lsort [glob -nocomplain $srcdir/$subdir/*.C]] - - if { $blddir != "" } { -- set ld_library_path "$always_ld_library_path:${blddir}/${lang_library_path}" -+ set lang_include_flags [exec sh ${blddir}/../libstdc++-v3/scripts/testsuite_flags --build-includes] -+ set ld_library_path "$always_ld_library_path:${blddir}/${lang_library_paths}" - } else { - set ld_library_path "$always_ld_library_path" - } -@@ -56,18 +50,14 @@ if { $blddir != "" } { - append ld_library_path [gcc-set-multilib-library-path $GCC_UNDER_TEST] - set_ld_library_path_env_vars - --set flags_file "${blddir}/../libstdc++-v3/scripts/testsuite_flags" --if { [file exists $flags_file] } { -- set lang_include_flags [exec sh $flags_file --build-includes] --} -- - # Main loop. - dg-runtest $tests "" "" - - if { $blddir != "" } { - unset lang_include_flags -- unset lang_library_path -+ unset libstdc++_library_path - unset lang_library_paths -+ unset shlib_ext - } - - # All done. -diff --git a/libitm/testsuite/libitm.c/c.exp b/libitm/testsuite/libitm.c/c.exp -index daa71427d64c..7a697b870932 100644 ---- a/libitm/testsuite/libitm.c/c.exp -+++ b/libitm/testsuite/libitm.c/c.exp -@@ -9,20 +9,20 @@ - # GNU General Public License for more details. - # - # You should have received a copy of the GNU General Public License --# along with this program; if not, write to the Free Software --# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -+# along with this program; if not, see . - --if [info exists lang_library_path] then { -- unset lang_library_path -- unset lang_link_flags -+if [info exists lang_library_paths] then { -+ unset lang_library_paths - } --if [info exists lang_test_file] then { -- unset lang_test_file -+if [info exists lang_include_flags] then { -+ unset lang_include_flags - } - - load_lib libitm-dg.exp - load_gcc_lib gcc-dg.exp - -+lappend ALWAYS_CFLAGS "compiler=$GCC_UNDER_TEST" -+ - # If a testcase doesn't have special options, use these. - if ![info exists DEFAULT_CFLAGS] then { - set DEFAULT_CFLAGS "-O2" --- -cgit diff --git a/meta/recipes-devtools/gcc/gcc/0028-libcody-Make-it-buildable-by-C-11-to-C-26.patch b/meta/recipes-devtools/gcc/gcc/0028-libcody-Make-it-buildable-by-C-11-to-C-26.patch deleted file mode 100644 index 431facb011..0000000000 --- a/meta/recipes-devtools/gcc/gcc/0028-libcody-Make-it-buildable-by-C-11-to-C-26.patch +++ /dev/null @@ -1,257 +0,0 @@ -From 0ffe3c9af4e5d5468df742512b6e930fe7039230 Mon Sep 17 00:00:00 2001 -From: Jakub Jelinek -Date: Fri, 21 Nov 2025 16:25:58 +0100 -Subject: [PATCH] libcody: Make it buildable by C++11 to C++26 - -The following builds with -std=c++11 and c++14 and c++17 and c++20 and c++23 -and c++26. - -I see the u8 string literals are mixed e.g. with strerror, so in --fexec-charset=IBM1047 there will still be garbage, so am not 100% sure if -the u8 literals everywhere are worth it either. - -2025-11-21 Jakub Jelinek - - * cody.hh (S2C): For __cpp_char8_t >= 201811 use char8_t instead of - char in argument type. - (MessageBuffer::Space): Revert 2025-11-15 change. - (MessageBuffer::Append): For __cpp_char8_t >= 201811 add overload - with char8_t const * type of first argument. - (Packet::Packet): Similarly for first argument. - * client.cc (CommunicationError, Client::ProcessResponse, - Client::Connect, ConnectResponse, PathnameResponse, OKResponse, - IncludeTranslateResponse): Cast u8 string literals to (const char *) - where needed. - * server.cc (Server::ProcessRequests, ConnectRequest): Likewise. - -Signed-off-by: Martin Jansa -Upstream-Status: Backport [07a767c7a50d1daae8ef7d4aba73fe53ad40c0b7] ---- - libcody/client.cc | 36 +++++++++++++++++++----------------- - libcody/cody.hh | 22 ++++++++++++++++++++++ - libcody/server.cc | 28 ++++++++++++++-------------- - 3 files changed, 55 insertions(+), 31 deletions(-) - -diff --git a/libcody/client.cc b/libcody/client.cc -index ae69d190cb77..147fecdbe500 100644 ---- a/libcody/client.cc -+++ b/libcody/client.cc -@@ -97,7 +97,7 @@ int Client::CommunicateWithServer () - - static Packet CommunicationError (int err) - { -- std::string e {u8"communication error:"}; -+ std::string e {(const char *) u8"communication error:"}; - e.append (strerror (err)); - - return Packet (Client::PC_ERROR, std::move (e)); -@@ -110,33 +110,34 @@ Packet Client::ProcessResponse (std::vector &words, - { - if (e == EINVAL) - { -- std::string msg (u8"malformed string '"); -+ std::string msg ((const char *) u8"malformed string '"); - msg.append (words[0]); -- msg.append (u8"'"); -+ msg.append ((const char *) u8"'"); - return Packet (Client::PC_ERROR, std::move (msg)); - } - else -- return Packet (Client::PC_ERROR, u8"missing response"); -+ return Packet (Client::PC_ERROR, (const char *) u8"missing response"); - } - - Assert (!words.empty ()); -- if (words[0] == u8"ERROR") -+ if (words[0] == (const char *) u8"ERROR") - return Packet (Client::PC_ERROR, -- words.size () == 2 ? words[1]: u8"malformed error response"); -+ words.size () == 2 ? words[1] -+ : (const char *) u8"malformed error response"); - - if (isLast && !read.IsAtEnd ()) - return Packet (Client::PC_ERROR, -- std::string (u8"unexpected extra response")); -+ std::string ((const char *) u8"unexpected extra response")); - - Assert (code < Detail::RC_HWM); - Packet result (responseTable[code] (words)); - result.SetRequest (code); - if (result.GetCode () == Client::PC_ERROR && result.GetString ().empty ()) - { -- std::string msg {u8"malformed response '"}; -+ std::string msg {(const char *) u8"malformed response '"}; - - read.LexedLine (msg); -- msg.append (u8"'"); -+ msg.append ((const char *) u8"'"); - result.GetString () = std::move (msg); - } - else if (result.GetCode () == Client::PC_CONNECT) -@@ -199,7 +200,7 @@ Packet Client::Connect (char const *agent, char const *ident, - size_t alen, size_t ilen) - { - write.BeginLine (); -- write.AppendWord (u8"HELLO"); -+ write.AppendWord ((const char *) u8"HELLO"); - write.AppendInteger (Version); - write.AppendWord (agent, true, alen); - write.AppendWord (ident, true, ilen); -@@ -211,7 +212,8 @@ Packet Client::Connect (char const *agent, char const *ident, - // HELLO $version $agent [$flags] - Packet ConnectResponse (std::vector &words) - { -- if (words[0] == u8"HELLO" && (words.size () == 3 || words.size () == 4)) -+ if (words[0] == (const char *) u8"HELLO" -+ && (words.size () == 3 || words.size () == 4)) - { - char *eptr; - unsigned long val = strtoul (words[1].c_str (), &eptr, 10); -@@ -247,7 +249,7 @@ Packet Client::ModuleRepo () - // PATHNAME $dir | ERROR - Packet PathnameResponse (std::vector &words) - { -- if (words[0] == u8"PATHNAME" && words.size () == 2) -+ if (words[0] == (const char *) u8"PATHNAME" && words.size () == 2) - return Packet (Client::PC_PATHNAME, std::move (words[1])); - - return Packet (Client::PC_ERROR, u8""); -@@ -256,7 +258,7 @@ Packet PathnameResponse (std::vector &words) - // OK or ERROR - Packet OKResponse (std::vector &words) - { -- if (words[0] == u8"OK") -+ if (words[0] == (const char *) u8"OK") - return Packet (Client::PC_OK); - else - return Packet (Client::PC_ERROR, -@@ -319,11 +321,11 @@ Packet Client::IncludeTranslate (char const *include, Flags flags, size_t ilen) - // PATHNAME $cmifile - Packet IncludeTranslateResponse (std::vector &words) - { -- if (words[0] == u8"BOOL" && words.size () == 2) -+ if (words[0] == (const char *) u8"BOOL" && words.size () == 2) - { -- if (words[1] == u8"FALSE") -- return Packet (Client::PC_BOOL, 0); -- else if (words[1] == u8"TRUE") -+ if (words[1] == (const char *) u8"FALSE") -+ return Packet (Client::PC_BOOL); -+ else if (words[1] == (const char *) u8"TRUE") - return Packet (Client::PC_BOOL, 1); - else - return Packet (Client::PC_ERROR, u8""); -diff --git a/libcody/cody.hh b/libcody/cody.hh -index 789ce9e70b75..93bce93aa94d 100644 ---- a/libcody/cody.hh -+++ b/libcody/cody.hh -@@ -47,12 +47,21 @@ namespace Detail { - - // C++11 doesn't have utf8 character literals :( - -+#if __cpp_char8_t >= 201811 -+template -+constexpr char S2C (char8_t const (&s)[I]) -+{ -+ static_assert (I == 2, "only single octet strings may be converted"); -+ return s[0]; -+} -+#else - template - constexpr char S2C (char const (&s)[I]) - { - static_assert (I == 2, "only single octet strings may be converted"); - return s[0]; - } -+#endif - - /// Internal buffering class. Used to concatenate outgoing messages - /// and Lex incoming ones. -@@ -123,6 +132,13 @@ public: - Space (); - Append (str, maybe_quote, len); - } -+#if __cpp_char8_t >= 201811 -+ void AppendWord (char8_t const *str, bool maybe_quote = false, -+ size_t len = ~size_t (0)) -+ { -+ AppendWord ((const char *) str, maybe_quote, len); -+ } -+#endif - /// Add a word as with AppendWord - /// @param str the string to append - /// @param maybe_quote string might need quoting, as for Append -@@ -264,6 +280,12 @@ public: - : string (s), cat (STRING), code (c) - { - } -+#if __cpp_char8_t >= 201811 -+ Packet (unsigned c, const char8_t *s) -+ : string ((const char *) s), cat (STRING), code (c) -+ { -+ } -+#endif - Packet (unsigned c, std::vector &&v) - : vector (std::move (v)), cat (VECTOR), code (c) - { -diff --git a/libcody/server.cc b/libcody/server.cc -index e2fa069bb933..c18469fae843 100644 ---- a/libcody/server.cc -+++ b/libcody/server.cc -@@ -36,12 +36,12 @@ static RequestPair - const requestTable[Detail::RC_HWM] = - { - // Same order as enum RequestCode -- RequestPair {u8"HELLO", nullptr}, -- RequestPair {u8"MODULE-REPO", ModuleRepoRequest}, -- RequestPair {u8"MODULE-EXPORT", ModuleExportRequest}, -- RequestPair {u8"MODULE-IMPORT", ModuleImportRequest}, -- RequestPair {u8"MODULE-COMPILED", ModuleCompiledRequest}, -- RequestPair {u8"INCLUDE-TRANSLATE", IncludeTranslateRequest}, -+ RequestPair {(const char *) u8"HELLO", nullptr}, -+ RequestPair {(const char *) u8"MODULE-REPO", ModuleRepoRequest}, -+ RequestPair {(const char *) u8"MODULE-EXPORT", ModuleExportRequest}, -+ RequestPair {(const char *) u8"MODULE-IMPORT", ModuleImportRequest}, -+ RequestPair {(const char *) u8"MODULE-COMPILED", ModuleCompiledRequest}, -+ RequestPair {(const char *) u8"INCLUDE-TRANSLATE", IncludeTranslateRequest}, - }; - } - -@@ -135,21 +135,21 @@ void Server::ProcessRequests (void) - std::string msg; - - if (err > 0) -- msg = u8"error processing '"; -+ msg = (const char *) u8"error processing '"; - else if (ix >= Detail::RC_HWM) -- msg = u8"unrecognized '"; -+ msg = (const char *) u8"unrecognized '"; - else if (IsConnected () && ix == Detail::RC_CONNECT) -- msg = u8"already connected '"; -+ msg = (const char *) u8"already connected '"; - else if (!IsConnected () && ix != Detail::RC_CONNECT) -- msg = u8"not connected '"; -+ msg = (const char *) u8"not connected '"; - else -- msg = u8"malformed '"; -+ msg = (const char *) u8"malformed '"; - - read.LexedLine (msg); -- msg.append (u8"'"); -+ msg.append ((const char *) u8"'"); - if (err > 0) - { -- msg.append (u8" "); -+ msg.append ((const char *) u8" "); - msg.append (strerror (err)); - } - resolver->ErrorResponse (this, std::move (msg)); -@@ -176,7 +176,7 @@ Resolver *ConnectRequest (Server *s, Resolver *r, - return nullptr; - - if (words.size () == 3) -- words.emplace_back (u8""); -+ words.emplace_back ((const char *) u8""); - unsigned version = ParseUnsigned (words[1]); - if (version == ~0u) - return nullptr; diff --git a/meta/recipes-devtools/gcc/gcc_15.2.bb b/meta/recipes-devtools/gcc/gcc_16.1.bb similarity index 100% rename from meta/recipes-devtools/gcc/gcc_15.2.bb rename to meta/recipes-devtools/gcc/gcc_16.1.bb diff --git a/meta/recipes-devtools/gcc/libgcc-initial_15.2.bb b/meta/recipes-devtools/gcc/libgcc-initial_16.1.bb similarity index 100% rename from meta/recipes-devtools/gcc/libgcc-initial_15.2.bb rename to meta/recipes-devtools/gcc/libgcc-initial_16.1.bb diff --git a/meta/recipes-devtools/gcc/libgcc_15.2.bb b/meta/recipes-devtools/gcc/libgcc_16.1.bb similarity index 100% rename from meta/recipes-devtools/gcc/libgcc_15.2.bb rename to meta/recipes-devtools/gcc/libgcc_16.1.bb diff --git a/meta/recipes-devtools/gcc/libgfortran_15.2.bb b/meta/recipes-devtools/gcc/libgfortran_16.1.bb similarity index 100% rename from meta/recipes-devtools/gcc/libgfortran_15.2.bb rename to meta/recipes-devtools/gcc/libgfortran_16.1.bb