From patchwork Fri May 15 14:40:48 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Szabolcs Nagy X-Patchwork-Id: 1291233 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Authentication-Results: ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=sourceware.org (client-ip=8.43.85.97; helo=sourceware.org; envelope-from=libc-alpha-bounces@sourceware.org; receiver=) Authentication-Results: ozlabs.org; dmarc=none (p=none dis=none) header.from=arm.com Authentication-Results: ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=armh.onmicrosoft.com header.i=@armh.onmicrosoft.com header.a=rsa-sha256 header.s=selector2-armh-onmicrosoft-com header.b=nT4mUA8T; dkim=pass (1024-bit key) header.d=armh.onmicrosoft.com header.i=@armh.onmicrosoft.com header.a=rsa-sha256 header.s=selector2-armh-onmicrosoft-com header.b=nT4mUA8T; dkim-atps=neutral Received: from sourceware.org (server2.sourceware.org [8.43.85.97]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by ozlabs.org (Postfix) with ESMTPS id 49Nrhl05xyz9sWC for ; Sat, 16 May 2020 00:41:59 +1000 (AEST) Received: from server2.sourceware.org (localhost [IPv6:::1]) by sourceware.org (Postfix) with ESMTP id 6CF2639858B3; Fri, 15 May 2020 14:41:27 +0000 (GMT) X-Original-To: libc-alpha@sourceware.org Delivered-To: libc-alpha@sourceware.org Received: from EUR02-VE1-obe.outbound.protection.outlook.com (mail-eopbgr20070.outbound.protection.outlook.com [40.107.2.70]) by sourceware.org (Postfix) with ESMTPS id 0D0D3398404F for ; Fri, 15 May 2020 14:41:13 +0000 (GMT) DMARC-Filter: OpenDMARC Filter v1.3.2 sourceware.org 0D0D3398404F Authentication-Results: sourceware.org; dmarc=none (p=none dis=none) header.from=arm.com Authentication-Results: sourceware.org; spf=pass smtp.mailfrom=Szabolcs.Nagy@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=iZh5KL8Go1oj+k9t8KzDO6b+0S5YUJTizL+ZLniEr7k=; b=nT4mUA8T7dc/2fuqUiVikOGTrn3Eh14DP2HKvrYwou4awjGpaS3PP0bFQSEdoXxALci0KS1YSGvAJWw8H/leCIh9SNLZfQOMJaF5NoTIhqlAtZrwIK5xmL+lh9Mcx7x4rKbs7NUYgHb9DA8CVAsnIYempScsWknhWfMUtrEhfZ0= Received: from DB6PR0601CA0001.eurprd06.prod.outlook.com (2603:10a6:4:7b::11) by VI1PR0801MB2125.eurprd08.prod.outlook.com (2603:10a6:800:5b::23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3000.25; Fri, 15 May 2020 14:41:11 +0000 Received: from DB5EUR03FT043.eop-EUR03.prod.protection.outlook.com (2603:10a6:4:7b:cafe::2c) by DB6PR0601CA0001.outlook.office365.com (2603:10a6:4:7b::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3000.20 via Frontend Transport; Fri, 15 May 2020 14:41:11 +0000 Authentication-Results: spf=pass (sender IP is 63.35.35.123) smtp.mailfrom=arm.com; sourceware.org; dkim=pass (signature was verified) header.d=armh.onmicrosoft.com; sourceware.org; dmarc=bestguesspass 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; Received: from 64aa7808-outbound-1.mta.getcheckrecipient.com (63.35.35.123) by DB5EUR03FT043.mail.protection.outlook.com (10.152.20.236) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3000.19 via Frontend Transport; Fri, 15 May 2020 14:41:11 +0000 Received: ("Tessian outbound 567b75aed2b9:v54"); Fri, 15 May 2020 14:41:11 +0000 X-CheckRecipientChecked: true X-CR-MTA-CID: 5b272e464954e71a X-CR-MTA-TID: 64aa7808 Received: from 273b603f9dba.1 by 64aa7808-outbound-1.mta.getcheckrecipient.com id F24D3700-04C4-4BD5-AD4F-6200A079A45C.1; Fri, 15 May 2020 14:41:05 +0000 Received: from EUR03-DB5-obe.outbound.protection.outlook.com by 64aa7808-outbound-1.mta.getcheckrecipient.com with ESMTPS id 273b603f9dba.1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384); Fri, 15 May 2020 14:41:05 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=Ydzzf9J7EZWYMpDXA/Svbhnlu7LCf4eSWiYbpyQCYyXIx+qjxxCDRUHo7XlqJ3MzwuxNADYd+UF405bstnrJS6WdPMUfZsca0R8KNNrvn5m34hnHYmmtQHYGGIAUwSdVUHpNZenVB0mU1pFIguOChtWTMm8UcChq1As86hrAy3TWvw0wjeGPkjJ4+UyoqxEy/99UmGXJt18u2wxxVpiBs90/zH1QCI5cw4PEIXSsLGInUP9QIXScaKmNh6yLoTG2CzeIRsQzsGMYQ0K5JmtiwY4dTmDbKtsHA2MHpT/7ORyf2LeURaWQoo5ydecp7Js/xvfc6te0cwgtWW9XXIBJ5g== 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-SenderADCheck; bh=iZh5KL8Go1oj+k9t8KzDO6b+0S5YUJTizL+ZLniEr7k=; b=Ppyn9cAbTcoKBa3Ag2FLrBmcHto8WEN3oxjFpzTjtStXUwshcQ/F1X53eYMIoFou7iTLAxu0MURKLlCD39CeB58sZaKbbvamKnAwB9vsfMY2Y696UJIRPDB488zMCZS/nVhO3Q573mAyw88rmiXZZvTclPH/DGmBjg4/AX5VZpvpCdZlWvXSS+tB2JHs+Zt1xYeHDxMdgM/NOYuVjHxaKXWdykLE1X4CwwMqw7uoJptau/+U2tlzx0gW7icHt9k4q2KaI69QcORv9nmhT69wBkcjesU0XW2dVimLM7LMMsP4LHLC6mcLM4esw904jfMfokstKr8ScBYGViHGrIbC8A== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; 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=iZh5KL8Go1oj+k9t8KzDO6b+0S5YUJTizL+ZLniEr7k=; b=nT4mUA8T7dc/2fuqUiVikOGTrn3Eh14DP2HKvrYwou4awjGpaS3PP0bFQSEdoXxALci0KS1YSGvAJWw8H/leCIh9SNLZfQOMJaF5NoTIhqlAtZrwIK5xmL+lh9Mcx7x4rKbs7NUYgHb9DA8CVAsnIYempScsWknhWfMUtrEhfZ0= Authentication-Results-Original: sourceware.org; dkim=none (message not signed) header.d=none;sourceware.org; dmarc=none action=none header.from=arm.com; Received: from AM6PR08MB3047.eurprd08.prod.outlook.com (2603:10a6:209:4c::23) by AM6PR08MB3528.eurprd08.prod.outlook.com (2603:10a6:20b:4b::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2979.34; Fri, 15 May 2020 14:41:04 +0000 Received: from AM6PR08MB3047.eurprd08.prod.outlook.com ([fe80::49fd:6ded:4da7:8862]) by AM6PR08MB3047.eurprd08.prod.outlook.com ([fe80::49fd:6ded:4da7:8862%7]) with mapi id 15.20.2979.033; Fri, 15 May 2020 14:41:04 +0000 From: Szabolcs Nagy To: libc-alpha@sourceware.org Subject: [PATCH v3 04/13] aarch64: configure test for BTI support Date: Fri, 15 May 2020 15:40:48 +0100 Message-Id: X-Mailer: git-send-email 2.17.1 In-Reply-To: References: X-ClientProxiedBy: LO2P265CA0309.GBRP265.PROD.OUTLOOK.COM (2603:10a6:600:a5::33) To AM6PR08MB3047.eurprd08.prod.outlook.com (2603:10a6:209:4c::23) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (217.140.106.55) by LO2P265CA0309.GBRP265.PROD.OUTLOOK.COM (2603:10a6:600:a5::33) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3000.24 via Frontend Transport; Fri, 15 May 2020 14:41:04 +0000 X-Mailer: git-send-email 2.17.1 X-Originating-IP: [217.140.106.55] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-HT: Tenant X-MS-Office365-Filtering-Correlation-Id: c25e1f24-9727-4ecd-9f15-08d7f8de0301 X-MS-TrafficTypeDiagnostic: AM6PR08MB3528:|VI1PR0801MB2125: X-Microsoft-Antispam-PRVS: x-checkrecipientrouted: true NoDisclaimer: true X-MS-Oob-TLC-OOBClassifiers: OLM:7219;OLM:7219; X-Forefront-PRVS: 04041A2886 X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam-Untrusted: BCL:0; X-Microsoft-Antispam-Message-Info-Original: vruBVW2P6kDoS1rYLNBUxHZ03q2yQ0FPPVYS6GplZDu0jD3taor331jY8XR1bAzGjO9FoJ12qAIOGFJ2pmhB7dDgyO/sHMnHh6sspaQeftMJH8qVgqT7gBnd1745YiwIumJnrbvrgavz203hm9ZXliBYL9tiWXoInQvbx2ziTc7yz2i7i+qgO7ozAwWDzZELMQldz7saeEs4p3/rJvsvxR1k3WCTmuKynrBlKNzEOcIPCZO/ZaP+uf9g9XueBUehSncAEOrSFrYQh+QAmIYPO/A6AXzvoVftncVzU8Ty8TLvzgH9fmCzxHzZ69m9v49sqkNvvHmzth4WZ6kaGjFdHEf9+0ulUzs//3Wco+1PjbJxlCk87a6gh8EWpIZoNWjfylTLjTnWESgdLyU2Vcd/qoht7T6gVvOEpsL3zNZ2nBdkHg9yoHXSplrwhWdDRhNuXlF0sVdW696lkC90B3wy1E55w8Eb1D3p88dcBbYb2JQiYJa5vYaq+WI2i/+KZHUgtPKdPaMlRgGHYQDPe7YcPadSbDgMKNCd8To8mbcadCQ= X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:AM6PR08MB3047.eurprd08.prod.outlook.com; PTR:; CAT:NONE; SFTY:; SFS:(4636009)(136003)(376002)(39860400002)(346002)(366004)(396003)(86362001)(6506007)(69590400007)(52116002)(478600001)(316002)(6666004)(6916009)(6486002)(66556008)(44832011)(6512007)(5660300002)(2906002)(956004)(66476007)(8936002)(66946007)(36756003)(186003)(26005)(2616005)(8676002)(16526019)(136400200001); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData: beuHMQOKGxY2qgVz+RziSSsxYbpma/lyUMA6ENML2V/BMp56ln57RiTWgoV90ZhDRSYkJRYyhePFACExFuinGX4XQ0jYEFt8zmLqIaVMDpbiNVQVCpmDTISiV4dz4wCM1uGCXORAuAwDyUXfXwNjsvs0/ni7qol6bJ19EFPGP6LBiDu0akigu+aY1CwI7fO5TuAfHjv4cwqCOFKauZ/uWDtxJqVPV4rrWGNAgsvXzfd0n+/CBorbsfgRSEVJY9vuaNG7uEyTYOK8r41V29stREIs5QVhPQf/THs5nxchV2f3n5VPC0qv0HxB7t+/aIkkN2D9/lbpJJRekZlZp8Vld8EZV7c8DR/JojSQbsNsq1NOQtjV9K323Q+DUYdO28c8bws2nlJrc1JeUyeb2Y95FjjlKsdCzezTsVUK9DvoliPRUmOr4/6W89yiLWGzLz2SUuchYCFPuJr95S0EZXYFUAX8q9pyvmUdsYbURW3Q30uUjvsQ/6e9Q6dFwh4WWEHR X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM6PR08MB3528 Original-Authentication-Results: sourceware.org; dkim=none (message not signed) header.d=none; sourceware.org; dmarc=none action=none header.from=arm.com; X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DB5EUR03FT043.eop-EUR03.prod.protection.outlook.com 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; SFTY:; SFS:(4636009)(346002)(39860400002)(136003)(396003)(376002)(46966005)(956004)(2616005)(8936002)(336012)(47076004)(82740400003)(81166007)(6486002)(6512007)(316002)(44832011)(6916009)(478600001)(69590400007)(86362001)(8676002)(70586007)(36756003)(70206006)(82310400002)(6666004)(2906002)(26005)(356005)(186003)(16526019)(6506007)(5660300002)(136400200001); DIR:OUT; SFP:1101; X-MS-Office365-Filtering-Correlation-Id-Prvs: 429088f3-f7e8-40c1-5b6d-08d7f8ddfefc X-Forefront-PRVS: 04041A2886 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: rMyMtyX1dyWnNN9VGAN/Bkr70PYKKvu9QFkcojXqpEB3jELoAUsQF5Wwy5dA9ukqVn9S5m5+1fYhaQ1FA22Y+91Nnf1FIIdkODp5vD4Qo0md/Q+TI5N1tK4KCkKu2XDoERaUrmsC3JNgQ6arkYvgrBiOxN1+Fd6LbtQJr1qCge6OkWryLHAKbTieRHQMWeocgaKKmvVE89mmSOWgOQF4f58wirTh/UMKXHiJIpyPXKO2vqBJCLT0S0uNoHMDhAVbqHhZOw5XL1IbPxVdlcEoNAbq2iKHEmxKyETLq1TZUSb8wLBGTT6rY3qkMyihO/k/hvi+f4wfOcJtt5X/GB4FHcsxTAsMev7MffaXoPJJQSqWakBTXRNOM+bIFw/yU9Llz4wbwEj/bFupOEhzW75QqcaMRF+KTD/NnxbhnW4K4qrTJuDPlneCqXe9HQTsERXiicu43CdhrqmXcOeRXvqNgbB9Au72aN3p74/KXad5OBvkwUTUQ9PYAW8ZUvrmDu3+HmkPCm+LIeAkSdECDPQvzThQn5LFY5I11paZiD9g8eS3CJB0rEIe7nrBTnZyKAzQ0OH8KmqMNB8CVr67ZSw2cQ== X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 May 2020 14:41:11.3010 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: c25e1f24-9727-4ecd-9f15-08d7f8de0301 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-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR0801MB2125 X-Spam-Status: No, score=-19.6 required=5.0 tests=BAYES_00, DKIM_SIGNED, DKIM_VALID, GIT_PATCH_0, MSGID_FROM_MTA_HEADER, RCVD_IN_DNSWL_LOW, RCVD_IN_MSPIKE_H2, SPF_HELO_PASS, SPF_PASS, TXREP, UNPARSEABLE_RELAY autolearn=ham autolearn_force=no version=3.4.2 X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on server2.sourceware.org X-BeenThere: libc-alpha@sourceware.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Libc-alpha mailing list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: libc-alpha-bounces@sourceware.org Sender: "Libc-alpha" Check BTI support in the compiler and linker. The check also requires READELF that understands the BTI GNU property note. It is expected to succeed with gcc >=gcc-9 configured with --enable-standard-branch-protection and binutils >=binutils-2.33. Reviewed-by: Adhemerval Zanella --- config.h.in | 3 +++ sysdeps/aarch64/configure | 42 ++++++++++++++++++++++++++++++++++++ sysdeps/aarch64/configure.ac | 19 ++++++++++++++++ 3 files changed, 64 insertions(+) diff --git a/config.h.in b/config.h.in index dea43df438..506b0c416c 100644 --- a/config.h.in +++ b/config.h.in @@ -109,6 +109,9 @@ /* AArch64 big endian ABI */ #undef HAVE_AARCH64_BE +/* AArch64 BTI support enabled. */ +#undef HAVE_AARCH64_BTI + /* C-SKY ABI version. */ #undef CSKYABI diff --git a/sysdeps/aarch64/configure b/sysdeps/aarch64/configure index 5bd355a691..70477a7fa5 100644 --- a/sysdeps/aarch64/configure +++ b/sysdeps/aarch64/configure @@ -172,3 +172,45 @@ else config_vars="$config_vars default-abi = lp64" fi + +# Only consider BTI supported if -mbranch-protection=bti is +# on by default in the compiler and the linker produces +# binaries with GNU property notes in PT_GNU_PROPERTY segment. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for BTI support" >&5 +$as_echo_n "checking for BTI support... " >&6; } +if ${libc_cv_aarch64_bti+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat > conftest.c <&5 + (eval $ac_try) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; } \ + && { ac_try='$READELF -lW conftest.so | grep -q GNU_PROPERTY' + { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_try\""; } >&5 + (eval $ac_try) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; } \ + && { ac_try='$READELF -nW conftest.so | grep -q "NT_GNU_PROPERTY_TYPE_0.*AArch64 feature:.* BTI"' + { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_try\""; } >&5 + (eval $ac_try) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; } + then + libc_cv_aarch64_bti=yes + fi + rm -rf conftest.* +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $libc_cv_aarch64_bti" >&5 +$as_echo "$libc_cv_aarch64_bti" >&6; } +if test $libc_cv_aarch64_bti = yes; then + $as_echo "#define HAVE_AARCH64_BTI 1" >>confdefs.h + +fi diff --git a/sysdeps/aarch64/configure.ac b/sysdeps/aarch64/configure.ac index 7851dd4dac..798f494740 100644 --- a/sysdeps/aarch64/configure.ac +++ b/sysdeps/aarch64/configure.ac @@ -20,3 +20,22 @@ if test $libc_cv_aarch64_be = yes; then else LIBC_CONFIG_VAR([default-abi], [lp64]) fi + +# Only consider BTI supported if -mbranch-protection=bti is +# on by default in the compiler and the linker produces +# binaries with GNU property notes in PT_GNU_PROPERTY segment. +AC_CACHE_CHECK([for BTI support], [libc_cv_aarch64_bti], [dnl + cat > conftest.c <