Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp4334178yba; Wed, 17 Apr 2019 09:18:44 -0700 (PDT) X-Google-Smtp-Source: APXvYqw9RuV4adxw9/BzzLWq1KBd7f26TnHiGA9XPIzzPp0UhYXJ6AaOocc2tLONQJS0puimOl/P X-Received: by 2002:a65:5189:: with SMTP id h9mr82869953pgq.304.1555517924014; Wed, 17 Apr 2019 09:18:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555517924; cv=none; d=google.com; s=arc-20160816; b=rZ9cYP8VN0NZ4Mq5y0clRAus3i9OUnU2m79cz/KwzMpaWk/CQbJMWhxjkOoIetWG6Q WTKqwBN91dDKqUON6ypDay1o6WDO7GaErJg4uvPz6ghhY0WV/ywLyyPh65HUrCEbm+FK 1/p0cOWQH5q3LkinbzfWPSqxszdj6qyny7vJTgMF506tEse9Udg4u5+7GTJgRoxnbhhI agWIf4MZF/GPF/+zVnPZhZCDpwoNzyutoOKJK47PHdAkjF+l5zFBFZFVSbVteFUsi7MJ DpAgfzCs4uxps0ACyrUpJcg/9J0VU6mn4uUn86YG0PW/awSu2pvyLIFIdlNkBwhGHFeT yg+w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :message-id:in-reply-to:subject:cc:to:from:date; bh=C9Mr2/YQENlabpRSqdhtevmoHivoPA+5qXU6TiiO3uk=; b=tbV9zUpcjEDWzHcusG8av33LI5wDWfTol/coqtB5q9gF1FkFiq7d6BB6OnxTpldoHE Zgx8h7fFVIw3TbnnVahfpH6cLAE/YQOLL/uSbu91OdvXBgwxNApPYuEvO6KVtbfE2boG bS9l6e2aaECDngzlnuP0G5rw08LdA1J+O+cwlAaEQsZt08rOQ3WF4B/9O0tBbvdtSkzG 26ZNODuzKIqmVHDzrM6yUU/FbPA9jqZZ3KbOQdknDv1CwXYVKXh4o6zKC9aFNnJ+hXo6 qp1F+LOMAUprYbHwmp8EFhFJnZd3W6O2pcAJ+p4fpvXhxf/Dz4O8FBAVRZItuupm4n7y laQA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q9si50236553pll.41.2019.04.17.09.18.28; Wed, 17 Apr 2019 09:18:43 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732760AbfDQQRd (ORCPT + 99 others); Wed, 17 Apr 2019 12:17:33 -0400 Received: from relay1.mentorg.com ([192.94.38.131]:47521 "EHLO relay1.mentorg.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729512AbfDQQRd (ORCPT ); Wed, 17 Apr 2019 12:17:33 -0400 Received: from nat-ies.mentorg.com ([192.94.31.2] helo=svr-ies-mbx-01.mgc.mentorg.com) by relay1.mentorg.com with esmtps (TLSv1.2:ECDHE-RSA-AES256-SHA384:256) id 1hGnFR-0004jS-U7 from joseph_myers@mentor.com ; Wed, 17 Apr 2019 09:17:21 -0700 Received: from digraph.polyomino.org.uk (137.202.0.90) by svr-ies-mbx-01.mgc.mentorg.com (139.181.222.1) with Microsoft SMTP Server (TLS) id 15.0.1320.4; Wed, 17 Apr 2019 17:17:18 +0100 Received: from jsm28 (helo=localhost) by digraph.polyomino.org.uk with local-esmtp (Exim 4.90_1) (envelope-from ) id 1hGnFN-0001mB-U1; Wed, 17 Apr 2019 16:17:17 +0000 Date: Wed, 17 Apr 2019 16:17:17 +0000 From: Joseph Myers X-X-Sender: jsm28@digraph.polyomino.org.uk To: Mathieu Desnoyers CC: carlos , Will Deacon , Florian Weimer , Szabolcs Nagy , libc-alpha , Thomas Gleixner , Ben Maurer , Peter Zijlstra , "Paul E. McKenney" , Boqun Feng , Dave Watson , Paul Turner , Rich Felker , linux-kernel , linux-api Subject: Re: [PATCH 1/5] glibc: Perform rseq(2) registration at C startup and thread creation (v8) In-Reply-To: <364803063.586.1555516769056.JavaMail.zimbra@efficios.com> Message-ID: References: <20190416173216.9028-1-mathieu.desnoyers@efficios.com> <20190416173216.9028-2-mathieu.desnoyers@efficios.com> <364803063.586.1555516769056.JavaMail.zimbra@efficios.com> User-Agent: Alpine 2.21 (DEB 202 2017-01-01) MIME-Version: 1.0 Content-Type: text/plain; charset="US-ASCII" X-Originating-IP: [137.202.0.90] X-ClientProxiedBy: svr-ies-mbx-01.mgc.mentorg.com (139.181.222.1) To svr-ies-mbx-01.mgc.mentorg.com (139.181.222.1) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 17 Apr 2019, Mathieu Desnoyers wrote: > > +/* RSEQ_SIG is a signature required before each abort handler code. > > + > > + It is a 32-bit value that maps to actual architecture code compiled > > + into applications and libraries. It needs to be defined for each > > + architecture. When choosing this value, it needs to be taken into > > + account that generating invalid instructions may have ill effects on > > + tools like objdump, and may also have impact on the CPU speculative > > + execution efficiency in some cases. */ > > + > > +#define RSEQ_SIG 0xd428bc00 /* BRK #0x45E0. */ > > After further investigation, we should probably do the following > to handle compiling with -mbig-endian on aarch64, which generates > binaries with mixed code vs data endianness (little endian code, > big endian data): First, the comment on RSEQ_SIG should specify whether it is to be interpreted in the code or the data endianness. > For ARM32, the situation is a bit more complex. Only armv6+ > generates mixed-endianness code vs data with -mbig-endian. > Prior to armv6, the code and data endianness matches. Therefore, > I plan to #ifdef the reversed endianness handling with: > > #if __ARM_ARCH >= 6 && __ARM_BIG_ENDIAN > > on arm32. That doesn't work well because BE code (.o files) can be built for v5te (for example) and used on a range of different architecture variants with both BE32 and BE8 - the choice between BE32 and BE8 is a link-time choice, not a compile-time choice. So if the value for Arm is a compile-time constant, it should also work for both BE32 and BE8. In turn, that suggests to me that RSEQ_SIG should be defined to be a value that is always in the code endianness (and whatever corresponding kernel code handles RSEQ_SIG values should act accordingly on architectures where the two endiannesses can differ). If the kernel ABI is already fixed in a way that prevents such a definition of RSEQ_SIG semantics as using code endianness, a value should be chosen for Arm that works for both endiannesses. (Also, installed glibc headers are supposed to work with older compilers, and support for __ARM_ARCH was only added in GCC 4.8. Before that you need to test lots of separate macros for different architecture variants to determine a version number.) -- Joseph S. Myers joseph@codesourcery.com