Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp735973yba; Thu, 18 Apr 2019 08:43:35 -0700 (PDT) X-Google-Smtp-Source: APXvYqzGmNFNRxWYEFWRw/hgulyBhQoaZ+LloraUUKVYGXP4a1u+GB8fqdAdrdB0hb5PEIRRqOU6 X-Received: by 2002:a65:424b:: with SMTP id d11mr89331513pgq.205.1555602215068; Thu, 18 Apr 2019 08:43:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555602215; cv=none; d=google.com; s=arc-20160816; b=haLFWljWQauGC+xznMSAEd0oFjxs2Ryooj+B9nI+My5udCkNiqKKAY0QHgSF+4bWH7 UPN2YsJYMzavNIMkBb+DCewLmstCrwv0np3yEswsuyNXmUG3QFk/gZslxkLPe2OLjdeS 3qkm7Or2vZlPKqPmhd1R+/V8dqLk17FkQkDwv4/QBlwY8fCjy6oqrJY9uXWhtoAQuMYE XTzHq+094ay8ZyJn6dzGy8BEgtzzHitYgkfOjie3sx0Dz1z4tDKt9WUyrLMGnfIgd+Mk QuCVnBNrPRCrO2Fo87ZKr6CqhcmQz+hInHGXxyLgQxTcM1cBgh/oYOVaI02B5uvEEtmt L7hA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:thread-index:thread-topic :content-transfer-encoding:mime-version:subject:references :in-reply-to:message-id:cc:to:from:date:dkim-signature:dkim-filter; bh=8DlPRt44lm3eiwiK9yLHyGozIyGwAdDpWlkTLTD9+3s=; b=mqbueH7rdvhQI/OHcoqX13X3Ss5HrQtVbk0d1bOheuhjZPhkT9uA8xRzmyRFpZWq0i 7lR7PDaPClFa+dK5mNdJOOHlZXn90LTY4xDXwQPXLGbafzl5Y8Z/lyAAkSJpPVWAj5DX FNEX2SAKbMRj4yR/KJvaa3ooc/LUkSEgOxztLq4vfq5bVYlvXzYTLU31IGROXmRl1nty 4mqJL1TwHwvjVB/xLxjlOEG7e5pDC3Dgb3Bl+5X7lYvgALcxB8pou7XJLt7KSMhRSBqL FljxjW5FuhFY4IaND870f2vE6wv0b6OgwCYc/P31lGLQ3aGE1E6EPdyGks27N7EpBDNv joDQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@efficios.com header.s=default header.b=mNmyclgG; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=efficios.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r17si2018818pgv.128.2019.04.18.08.43.19; Thu, 18 Apr 2019 08:43:35 -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; dkim=pass header.i=@efficios.com header.s=default header.b=mNmyclgG; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=efficios.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388535AbfDRPlJ (ORCPT + 99 others); Thu, 18 Apr 2019 11:41:09 -0400 Received: from mail.efficios.com ([167.114.142.138]:34544 "EHLO mail.efficios.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387519AbfDRPlJ (ORCPT ); Thu, 18 Apr 2019 11:41:09 -0400 Received: from localhost (ip6-localhost [IPv6:::1]) by mail.efficios.com (Postfix) with ESMTP id EE8E418CA18; Thu, 18 Apr 2019 11:41:07 -0400 (EDT) Received: from mail.efficios.com ([IPv6:::1]) by localhost (mail02.efficios.com [IPv6:::1]) (amavisd-new, port 10032) with ESMTP id HlrPFju684Kz; Thu, 18 Apr 2019 11:41:07 -0400 (EDT) Received: from localhost (ip6-localhost [IPv6:::1]) by mail.efficios.com (Postfix) with ESMTP id 6293318CA10; Thu, 18 Apr 2019 11:41:07 -0400 (EDT) DKIM-Filter: OpenDKIM Filter v2.10.3 mail.efficios.com 6293318CA10 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=efficios.com; s=default; t=1555602067; bh=8DlPRt44lm3eiwiK9yLHyGozIyGwAdDpWlkTLTD9+3s=; h=Date:From:To:Message-ID:MIME-Version; b=mNmyclgGgEzkIM7+UQr6ygDrX7rb6a672T0Z0ghBopOM3O9XD8OOzvgKoy82R1J6M do2CzpH2H7XdzqwfbYe7rgFVdYQbxlEr6OJ6zxJtUrwN1HdFz9nWBPMxnsGH2p/0dh TTz2tcEvHF47My7ummqlShPrm60EvxF2rug+l+dlUa5v53hPiANZNau1QZCEYCVCFW gAup7EbUlha8AF2dv3HRZdavpel3qmxYDjvFjmaWJwnEN35bUXzg9Kdrc/ZNBdSbwD MbfmrmzGWJchDisilKYyuaOybBJPDYB80RgfUTz8remZ+yBeBs68ZtxmrIoHpMWYop G6E/P6SAskZog== X-Virus-Scanned: amavisd-new at efficios.com Received: from mail.efficios.com ([IPv6:::1]) by localhost (mail02.efficios.com [IPv6:::1]) (amavisd-new, port 10026) with ESMTP id XTq_iuxT4JEJ; Thu, 18 Apr 2019 11:41:07 -0400 (EDT) Received: from mail02.efficios.com (mail02.efficios.com [167.114.142.138]) by mail.efficios.com (Postfix) with ESMTP id 42EA918CA04; Thu, 18 Apr 2019 11:41:07 -0400 (EDT) Date: Thu, 18 Apr 2019 11:41:07 -0400 (EDT) From: Mathieu Desnoyers To: Szabolcs Nagy Cc: Joseph Myers , Will Deacon , nd , carlos , Florian Weimer , libc-alpha , Thomas Gleixner , Ben Maurer , Peter Zijlstra , "Paul E. McKenney" , Boqun Feng , Dave Watson , Paul Turner , Rich Felker , linux-kernel , linux-api Message-ID: <1055153722.1072.1555602067220.JavaMail.zimbra@efficios.com> In-Reply-To: <6cbfea7b-9d83-74a5-9cd2-af56a5d68818@arm.com> References: <20190416173216.9028-1-mathieu.desnoyers@efficios.com> <20190416173216.9028-2-mathieu.desnoyers@efficios.com> <364803063.586.1555516769056.JavaMail.zimbra@efficios.com> <1770787324.668.1555530989646.JavaMail.zimbra@efficios.com> <1066731871.915.1555593471194.JavaMail.zimbra@efficios.com> <6cbfea7b-9d83-74a5-9cd2-af56a5d68818@arm.com> Subject: Re: [PATCH 1/5] glibc: Perform rseq(2) registration at C startup and thread creation (v8) MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit X-Originating-IP: [167.114.142.138] X-Mailer: Zimbra 8.8.12_GA_3794 (ZimbraWebClient - FF66 (Linux)/8.8.12_GA_3794) Thread-Topic: glibc: Perform rseq(2) registration at C startup and thread creation (v8) Thread-Index: AQHU9HpbUigwBDiNHkaVVFlkWH4PtKZAhB6AgAAE+oCAAD0+gIABIvSAgAAl0IBuJwpORg== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org ----- On Apr 18, 2019, at 11:33 AM, Szabolcs Nagy Szabolcs.Nagy@arm.com wrote: > On 18/04/2019 14:17, Mathieu Desnoyers wrote: >> ----- On Apr 17, 2019, at 3:56 PM, Mathieu Desnoyers >> mathieu.desnoyers@efficios.com wrote: >>> ----- On Apr 17, 2019, at 12:17 PM, Joseph Myers joseph@codesourcery.com wrote: >>>> 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. >>> >>> Right. The signature passed as argument to the rseq registration >>> system call needs to be in data endianness (currently exposed kernel >>> ABI). >>> >>> Ideally for userspace, we want to define a signature in code endianness >>> that happens to nicely match specific code patterns. > ... >> For aarch64, I think we can simply do: >> >> /* >> * aarch64 -mbig-endian generates mixed endianness code vs data: >> * little-endian code and big-endian data. Ensure the RSEQ_SIG signature >> * matches code endianness. >> */ >> #define RSEQ_SIG_CODE 0xd428bc00 /* BRK #0x45E0. */ >> >> #ifdef __ARM_BIG_ENDIAN >> #define RSEQ_SIG_DATA 0x00bc28d4 /* BRK #0x45E0. */ >> #else >> #define RSEQ_SIG_DATA RSEQ_SIG_CODE >> #endif >> >> #define RSEQ_SIG RSEQ_SIG_DATA >> >> Feedback is most welcome, > > so the RSEQ_SIG value is supposed to be used with .word > in asm instead of .inst? We want a .inst so it translates into a valid trap instruction. It's better to trap in case program execution reaches this by mistake (makes debugging easier). > > i don't think we use __ARM_* in public headers currently, > but hopefully aarch64_be compilers implement it. Can I use #if __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__ then ? > > otherwise this looks ok to me. > > (i think a rare palindrome instruction would work too, e.g. > 0a5f5f0a and w10, w24, wzr, lsr #23 // shifted 0 > 2a5f5f2a orr w10, w25, wzr, lsr #23 > eb9f9feb negs x11, xzr, asr #39 > c83f3fc8 stxp wzr, x8, x15, [x30] // store to LR ignoring success > d9ffffd9 stz2g x25, [x30, #-16]! // v8.5 tag+zero 2 granules around LR > etc. it does not need to be a guaranteed trap) Unfortunately it's not a trap :/ Thanks, Mathieu -- Mathieu Desnoyers EfficiOS Inc. http://www.efficios.com