From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from EUR05-DB8-obe.outbound.protection.outlook.com (mail-db8eur05on2068.outbound.protection.outlook.com [40.107.20.68]) by sourceware.org (Postfix) with ESMTPS id 86A693851406 for ; Wed, 3 Aug 2022 15:35:50 +0000 (GMT) DMARC-Filter: OpenDMARC Filter v1.4.1 sourceware.org 86A693851406 Authentication-Results: sourceware.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: sourceware.org; spf=pass smtp.mailfrom=arm.com ARC-Seal: i=2; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=pass; b=QXzxRFd95p1/jhLB7A3icLrWeKhqgVi2jAlAUTE0/aAGiPAP2HJvjjsJTOHwivM97X1i4n0jaBiGQrzHDYKG3hY/Na0GY6xdWuLhA+hsklDJbgC7/FqLcq/+U+Gmc2XqA1u3DQ7CWYpRF8R2vwETZpYOtoAYci6T9GWv7RiDnJIVxqUIhxukKT4c81vrbP+37U6yVACDCfhvQ4cla+IUbF/dbq8a0qjZBtndeP0Z/zvP5aE87R7KWhDUYYaYBhytR1GWPYluc8Yfy0PHnMRMdU1OQLQ0O3ctZxTIgV6d0Nq8RMgIYLQpX4az1nWX7QGA5p2kVVOhMt8wqipRJ4iPfA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; 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=TzJ0HA4xT2xJQIIf8cD9cNLocAO6IiA3Gdv9dEeKBMs=; b=I6v8j4tuWuo+3RbuPfC57e6gfZAzlXDSnKRYcigCVZfRZE7Ek5ylVjFi8PMax5HA7zCfDNsLXvYqDWMGgrn7haxRU71xYOZ1mTjMcy2zajQHjRb9IL6KEOiUz+tR88DmWxGuHN4uGtjhkgoo+UndCwP6RNWsfU2R3OKrcCLq33uecODDSPqQeX+QUbXsZYCPgfo1LWX3LCaT9GQH61A/vnE31B1q7z4uWymeXuIMcXIqydxBMnbhzfiHq5xgWKKUrz32RPUqQtwjFpj8C+KW9LwImgcREanm+Hp1aWqiVCUgEviIw/zlZ+qSHU5M7N5x316hkLGDQ5mvJesZwveK5Q== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 63.35.35.123) smtp.rcpttodomain=sourceware.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=armh.onmicrosoft.com; arc=pass (0 oda=1 ltdi=1 spf=[1, 1, smtp.mailfrom=arm.com] dmarc=[1, 1, header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=armh.onmicrosoft.com; s=selector2-armh-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=TzJ0HA4xT2xJQIIf8cD9cNLocAO6IiA3Gdv9dEeKBMs=; b=Vyy/wrMxevps9TE6MXKZRa86D+7AoLCZOK3TMzmS49sDolqoIdwQQkFl20ZHFKyhJbqgu6iopI6JnRlfZz3VC8FJ5LrNdVob/jsHYovuyAJE6jIBkWMMj1kAJC0pe6ZFmwCxiVR08Y4gvR+0f5WtK3WTO2YZP23gqt0rN1Ya4Tk= Received: from DB8P191CA0005.EURP191.PROD.OUTLOOK.COM (2603:10a6:10:130::15) by AM0PR08MB3779.eurprd08.prod.outlook.com (2603:10a6:208:101::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5482.11; Wed, 3 Aug 2022 15:35:48 +0000 Received: from DBAEUR03FT060.eop-EUR03.prod.protection.outlook.com (2603:10a6:10:130:cafe::d9) by DB8P191CA0005.outlook.office365.com (2603:10a6:10:130::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5482.12 via Frontend Transport; Wed, 3 Aug 2022 15:35:48 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 63.35.35.123) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=armh.onmicrosoft.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 63.35.35.123 as permitted sender) receiver=protection.outlook.com; client-ip=63.35.35.123; helo=64aa7808-outbound-1.mta.getcheckrecipient.com; pr=C Received: from 64aa7808-outbound-1.mta.getcheckrecipient.com (63.35.35.123) by DBAEUR03FT060.mail.protection.outlook.com (100.127.142.238) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5482.12 via Frontend Transport; Wed, 3 Aug 2022 15:35:48 +0000 Received: ("Tessian outbound fccf984e7173:v123"); Wed, 03 Aug 2022 15:35:48 +0000 X-CheckRecipientChecked: true X-CR-MTA-CID: 3c3a2963f46242fe X-CR-MTA-TID: 64aa7808 Received: from a53c83ebc50c.1 by 64aa7808-outbound-1.mta.getcheckrecipient.com id 9D390840-9A8D-4EC8-8054-FBCBDC5E40A1.1; Wed, 03 Aug 2022 15:35:40 +0000 Received: from EUR05-DB8-obe.outbound.protection.outlook.com by 64aa7808-outbound-1.mta.getcheckrecipient.com with ESMTPS id a53c83ebc50c.1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384); Wed, 03 Aug 2022 15:35:40 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=cppL2TML3eMyxYucQ/6OkFEU1t834uogwxoTIESO7hRSypNa6EjVGJxnA5+o9vdZSgtMuHOSakF1XQA77RZkNKqtYiwMCLCqC2wKXOWC8aqEUI3bsZlrLaGtdqHx/Iw99PsjQ6zF22kY92EIwwKAs1rjVEfZtEXLxvbYiJOGJUT1xd+87mC/8Of7ylt6g42D981jO91FhuJ8WP6ItK/yVLcsOJmFwP7FMODCqHDTaddXeEnk2w8BJ2sphNMO2XK7PBw9eE0csXNREQK/JkEWl5dxLb+OrJfuFQsb40H9XFXHZf4M6V4QV/hVoqSIT+VNQqGr4v42mlPLd+NWz+gC7Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; 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=TzJ0HA4xT2xJQIIf8cD9cNLocAO6IiA3Gdv9dEeKBMs=; b=d4kR7Xa3dy/Z1W28GQld53x8BWNwOJCQ8+4lME5X8ZFd+40/OMiQ+3AjFDNXGYRZ7Lki4fmkk2My4Q3pMJhXGHheSr+Ud0/dXv6j9TGGj54lp3H1DOY6rUJtQ8JEtK8m3VzGToMoV1sADi0PoHONvyUVHhTHZokLjwn2bOXQe3saslsyURSmJj1WgvBpjs7IBAU97RYxy35OuDvqKUmSmlS2sA9oMLiGCcfREbikiKenLY6WbjqIDa0vQcqvAu/gMxYSm8nschxhDTunwHYLzWqA+Dc9xS4MpumI0EX0BWP0/i/06HBXQTQvRvLOUYlHYyBOmzja1ifQLIJOnhBi4w== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 40.67.248.234) smtp.rcpttodomain=sourceware.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=armh.onmicrosoft.com; s=selector2-armh-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=TzJ0HA4xT2xJQIIf8cD9cNLocAO6IiA3Gdv9dEeKBMs=; b=Vyy/wrMxevps9TE6MXKZRa86D+7AoLCZOK3TMzmS49sDolqoIdwQQkFl20ZHFKyhJbqgu6iopI6JnRlfZz3VC8FJ5LrNdVob/jsHYovuyAJE6jIBkWMMj1kAJC0pe6ZFmwCxiVR08Y4gvR+0f5WtK3WTO2YZP23gqt0rN1Ya4Tk= Received: from AS9PR0301CA0058.eurprd03.prod.outlook.com (2603:10a6:20b:469::17) by VI1PR08MB5486.eurprd08.prod.outlook.com (2603:10a6:803:13b::8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5504.14; Wed, 3 Aug 2022 15:35:39 +0000 Received: from AM5EUR03FT020.eop-EUR03.prod.protection.outlook.com (2603:10a6:20b:469:cafe::c5) by AS9PR0301CA0058.outlook.office365.com (2603:10a6:20b:469::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5504.14 via Frontend Transport; Wed, 3 Aug 2022 15:35:39 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 40.67.248.234) smtp.mailfrom=arm.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 40.67.248.234 as permitted sender) receiver=protection.outlook.com; client-ip=40.67.248.234; helo=nebula.arm.com; pr=C Received: from nebula.arm.com (40.67.248.234) by AM5EUR03FT020.mail.protection.outlook.com (10.152.16.116) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5482.12 via Frontend Transport; Wed, 3 Aug 2022 15:35:39 +0000 Received: from AZ-NEU-EX04.Arm.com (10.251.24.32) by AZ-NEU-EX04.Arm.com (10.251.24.32) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.9; Wed, 3 Aug 2022 15:35:33 +0000 Received: from e125768.cambridge.arm.com (10.2.78.50) by mail.arm.com (10.251.24.32) with Microsoft SMTP Server id 15.1.2507.9 via Frontend Transport; Wed, 3 Aug 2022 15:35:33 +0000 From: Victor Do Nascimento To: CC: , Victor Do Nascimento Subject: [PATCH v2 8/8] newlib: libc: aeabi_memset M-profile PACBTI-enablement Date: Wed, 3 Aug 2022 16:35:24 +0100 Message-ID: <20220803153524.20631-9-victor.donascimento@arm.com> X-Mailer: git-send-email 2.36.1 In-Reply-To: <20220803153524.20631-1-victor.donascimento@arm.com> References: <20220803153524.20631-1-victor.donascimento@arm.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-EOPAttributedMessage: 1 X-MS-Office365-Filtering-Correlation-Id: 7cf8f692-960b-46a6-01fe-08da7565d6b2 X-MS-TrafficTypeDiagnostic: VI1PR08MB5486:EE_|DBAEUR03FT060:EE_|AM0PR08MB3779:EE_ x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0; X-Microsoft-Antispam-Message-Info-Original: zsrLETHo9yD5Jue0mpZVMgqSH0PJmBa+4SJystf4a3bdNs8PCFS1k4xJRHJOViKF9VbLkKrCiT91sWx6ozV0fu2kQClX+ZrF/G3Ms9o6Ew8Et3MJJX7+D1GQNwhe1R7BDd/Pe8TcApCeG04N+NkVmcRgWTX9j4zT/gzNMaAvhF+H06vGOW9GoYzLRVUHQXWXUof1p3PwyuA25jAyg3Qfz0VXWjlCbFDiFmTHYkA2DZNx1ZsLi6KMapH1Ocl3peO9qvqyUh2eBbx+kY0v/vaBNTAIbvQElJvnvdrZzTIDIr3gJZufx3EKK5DUsGCVGNRHEDrjeFqw/+E8eVrCrsaCbNnbv67KWio2t5UIa84xSnmp7Ts/Mwd5YA/d8wlf2inMHLHy4YRNENMFCiF/SIxOl7UseF3gUyDcB9/9phOs5XLPspdvXcQlOmY5P5oftjwdTEvz2PGhxvMbMDYvzzFU94XrFPJWg1rqw+vCBtsRMaW6d8CmWrl0gkh5fPxmHqSk5y75K66Bgm5b542NkCKPkyVUGIaMQC1QN5ZAlg36kpf9HtJsPqOh9dYa4yrbHUSDOYatCU7I3f79u/mD9YMBYHBSh+seWmkkrDW/AFUKjv6vxIq9XM6U8bdTULneax9pMtPphqQbny9xrhvz3eha/xusuSJh3l5/Eu7wzy1w651H+k+JzQisKk6y688HpH+75XLigKbTySMJ2HGjeZ1aSauRZDS1nxKiZhN7QM2CP8HdkFUtkka7iCDy0ohb38bcRlIszgcvzOell8lTKY7DST+UXUynMCybq2WZbZHK0p/1sfFI8bD1C5NdU/65QFA4iVWHJTlGfPyJcMl3iZ13SQ== X-Forefront-Antispam-Report-Untrusted: CIP:40.67.248.234; CTRY:IE; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:nebula.arm.com; PTR:InfoDomainNonexistent; CAT:NONE; SFS:(13230016)(4636009)(136003)(396003)(346002)(39860400002)(376002)(46966006)(40470700004)(36840700001)(36756003)(5660300002)(54906003)(6916009)(8676002)(4326008)(40480700001)(70206006)(478600001)(316002)(70586007)(8936002)(40460700003)(7696005)(2616005)(26005)(6666004)(2906002)(186003)(86362001)(1076003)(426003)(336012)(47076005)(356005)(81166007)(82740400003)(82310400005)(83380400001)(36860700001)(41300700001)(36900700001); DIR:OUT; SFP:1101; X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR08MB5486 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DBAEUR03FT060.eop-EUR03.prod.protection.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: ac8c3e00-4a7d-4a2a-44b5-08da7565d177 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: OEsR04ySEEhVru7T1DHV2rZio7WUqX6OG3LKu5aefUZHoPXBuTRhfQt4Z6KcK4KeUUFWVqcG0PlbTC9y5ADmsHJ83Ys1AKY5ayHwsL80LWtvuRintqd0kX+keQV6Agrak/wTF8lnCyxBYsGEG8lhn7CvfEthvTpAjFqpzZix07xvoMPib67xlcjJKp/9u2GHSVes6ynVWefRix0xy80Ys4N3RxF5+1E/O6d+t1zvTaiqg6Tx3sFVCSlQwdTJMlaxYRoLARl+ofDdLtsAh37nO60Fei99yqykh/XmbsAOrGaX1pCjS9LTui9XLln2WMgdiQhHThRrIjA5jifW9DJF7wIP+XAI1pF5vzbj+J31rvTGwvS/ttBQy+PcwolCNiUtqk0LWqOo6l3no+5CAkCK49Ex0xkkP6jb0wDwWs4VHL6dFG795kzifYxtvxzgm+zGnkl+VkL5lQrlJaaQ6XelsEGS30AJmM6hGQ11U4GxLWZtW5VVWAXmi2OFkwfJleey/fU7xJxGWCtV9szhG5OOxd2yUt1qiXjkl8TZ5h1KU4RgRj9fuzJPnoodPRGFpbZlb7iAL7S89V3Oed5qXzs0FvPve4F0VFZGm2NsX7KHksQlurfBnx/3Dm92n17nqtGfvRAL5RVzv4Yh/r4PLpCpR7swLm+a4y+8kHC8rraIMWwU2DZE0DKd70a8FN9ke5mqLgXgHHf9AoLOkvUiKR/eecZOAJgn0pMKK6pAgQ7ZIHNyOit+4HRXWKs6flGWo88U1tU42cY2KmPvLEDyhDtMd7pZV641S9PZYVpwIp5MQX9LoEh/vI8jlrBiTuWAfsDQ X-Forefront-Antispam-Report: CIP:63.35.35.123; CTRY:IE; LANG:en; SCL:1; SRV:; IPV:CAL; SFV:NSPM; H:64aa7808-outbound-1.mta.getcheckrecipient.com; PTR:ec2-63-35-35-123.eu-west-1.compute.amazonaws.com; CAT:NONE; SFS:(13230016)(4636009)(396003)(136003)(376002)(346002)(39860400002)(40470700004)(46966006)(36840700001)(47076005)(426003)(336012)(8676002)(1076003)(36756003)(2616005)(36860700001)(26005)(186003)(41300700001)(7696005)(82310400005)(83380400001)(2906002)(478600001)(86362001)(40460700003)(5660300002)(82740400003)(6666004)(81166007)(40480700001)(54906003)(8936002)(6916009)(70206006)(4326008)(316002)(70586007); DIR:OUT; SFP:1101; X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Aug 2022 15:35:48.0483 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 7cf8f692-960b-46a6-01fe-08da7565d6b2 X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d; Ip=[63.35.35.123]; Helo=[64aa7808-outbound-1.mta.getcheckrecipient.com] X-MS-Exchange-CrossTenant-AuthSource: DBAEUR03FT060.eop-EUR03.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM0PR08MB3779 X-Spam-Status: No, score=-13.1 required=5.0 tests=BAYES_00, DKIM_SIGNED, DKIM_VALID, FORGED_SPF_HELO, GIT_PATCH_0, KAM_DMARC_NONE, RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2, SPF_HELO_PASS, SPF_NONE, TXREP, UNPARSEABLE_RELAY autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on server2.sourceware.org X-BeenThere: newlib@sourceware.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Newlib mailing list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 03 Aug 2022 15:35:51 -0000 Add function prologue/epilogue to conditionally add BTI landing pads and/or PAC code generation & authentication instructions depending on compilation flags. --- newlib/libc/machine/arm/aeabi_memset-thumb2.S | 47 ++++++++++++++++++- 1 file changed, 46 insertions(+), 1 deletion(-) diff --git a/newlib/libc/machine/arm/aeabi_memset-thumb2.S b/newlib/libc/machine/arm/aeabi_memset-thumb2.S index eaca1d8d7..8bd4b5eaa 100644 --- a/newlib/libc/machine/arm/aeabi_memset-thumb2.S +++ b/newlib/libc/machine/arm/aeabi_memset-thumb2.S @@ -26,14 +26,43 @@ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ +#include "pacbti.h" + .thumb .syntax unified .global __aeabi_memset .type __aeabi_memset, %function + .fnstart + .cfi_startproc ASM_ALIAS __aeabi_memset4 __aeabi_memset ASM_ALIAS __aeabi_memset8 __aeabi_memset __aeabi_memset: +#if __HAVE_PAC_LEAF +#if __ARM_FEATURE_BTI_DEFAULT + pacbti ip, lr, sp +#else + pac ip, lr, sp +#endif /* __ARM_FEATURE_BTI_DEFAULT */ + .cfi_register 143, 12 + push {r4, r5, r6, ip} + .save {r4, r5, r6, ra_auth_code} + .cfi_def_cfa_offset 16 + .cfi_offset 4, -16 + .cfi_offset 5, -12 + .cfi_offset 6, -8 + .cfi_offset 143, -4 +#else +#if __ARM_FEATURE_BTI_DEFAULT + bti +#endif /* __ARM_FEATURE_BTI_DEFAULT */ push {r4, r5, r6} + .save {r4, r5, r6} + .cfi_def_cfa_offset 12 + .cfi_offset 4, -12 + .cfi_offset 5, -8 + .cfi_offset 6, -4 +#endif /* __HAVE_PAC_LEAF */ + lsls r4, r0, #30 beq 10f subs r4, r1, #1 @@ -98,10 +127,26 @@ __aeabi_memset: cmp r3, r4 bne 8b 9: +#if __HAVE_PAC_LEAF + pop {r4, r5, r6, ip} + .cfi_restore 143 + .cfi_restore 6 + .cfi_restore 5 + .cfi_restore 4 + .cfi_def_cfa_offset 0 + aut ip, lr, sp +#else pop {r4, r5, r6} - bx lr + .cfi_restore 6 + .cfi_restore 5 + .cfi_restore 4 + .cfi_def_cfa_offset 0 +#endif /* __HAVE_PAC_LEAF */ + bx lr 10: mov r4, r1 mov r3, r0 b 3b + .cfi_endproc + .fnend .size __aeabi_memset, . - __aeabi_memset -- 2.36.1