Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp800161yba; Wed, 24 Apr 2019 09:47:16 -0700 (PDT) X-Google-Smtp-Source: APXvYqxZlQbAsaVeUf1VsCueA0G3R2IFPfv0TuIAQxtTej31gnwvjq1JDtz8QSYexod5A1yac1GA X-Received: by 2002:aa7:9e5b:: with SMTP id z27mr12513681pfq.186.1556124436156; Wed, 24 Apr 2019 09:47:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556124436; cv=none; d=google.com; s=arc-20160816; b=LMjZ0kE0eacybqMplmqKcnggg2cX66tXP0dpBhm0YJjHKn/njttvI5Grx2dhenDh+B p3jyZb0Emr0ycW+vVf4t+Uc3yjBfZUMhPg6C+HI9rFh4x8oHYU30fvgu5KhrA345NcJb z3dZ2qvRxZ82cGH5RjaBJXyGarZcV+uKjEZuAdt47fcyLX+XBMa7mmZ7PQamHOiVa0b6 /YcrBJOYD9BNoHyOX8z+jcJqiwsg1TrZZcP4ApI3vnP+4uwabDa0HUwHHarBCHKlCpbW Shp4g3nxRiAxuk9UEt81CsW5xsRLlJv2jV0TNF44r5aOPxpGH1gdQ1MRmTPo0RCwI9q5 WMBg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=q83bHKAPFgR6EBpCx0kVx0s2kkYe42auq1lfTGltqhs=; b=ccJZlgzcc5OvSpqEZ16AmVBlPEkWy+MzAcs5N28p7CeSS1e+1Gex2HaZa1mF0UE3iJ Bsq2cTsMM6lWBSVuNXEsvLOgAsrIq9xlQSEcSqxrv7CpBZUNqswsUMbW8rHx5jmT0iGd 3lGR2252M3Txut/IpML1HkogYEi53kIO8qi9ymjTBT3V+iL8Ke5C35RV/MKjTlOVW5Tn xD+HI2DRLnY2vahviQpxXT0A1smafnPIbCrpEfILQjYGq5SgtLQKWcvtBXwoma+5Lfu1 m774N2/T93Nn44l0trkZdNMDPt6IGbrlLV3imSSzhqsh/1iRnKoT9E2zW9TDVvYOGJfc HptQ== 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 n72si21596653pfi.0.2019.04.24.09.47.00; Wed, 24 Apr 2019 09:47:16 -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 S1732775AbfDXQps (ORCPT + 99 others); Wed, 24 Apr 2019 12:45:48 -0400 Received: from foss.arm.com ([217.140.101.70]:48864 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726935AbfDXQpq (ORCPT ); Wed, 24 Apr 2019 12:45:46 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 6EE3DEBD; Wed, 24 Apr 2019 09:45:45 -0700 (PDT) Received: from fuggles.cambridge.arm.com (usa-sjc-imap-foss1.foss.arm.com [10.72.51.249]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 4CC813F706; Wed, 24 Apr 2019 09:45:41 -0700 (PDT) Date: Wed, 24 Apr 2019 17:45:38 +0100 From: Will Deacon To: Mathieu Desnoyers Cc: Peter Zijlstra , "Paul E . McKenney" , Boqun Feng , linux-kernel@vger.kernel.org, linux-api@vger.kernel.org, Thomas Gleixner , Andy Lutomirski , Dave Watson , Paul Turner , Andrew Morton , Russell King , Ingo Molnar , "H . Peter Anvin" , Andi Kleen , Chris Lameter , Ben Maurer , Steven Rostedt , Josh Triplett , Linus Torvalds , Catalin Marinas , Michael Kerrisk , Joel Fernandes , Shuah Khan , linux-kselftest@vger.kernel.org Subject: Re: [RFC PATCH for 5.2 08/10] rseq/selftests: aarch64 code signature: handle big-endian environment Message-ID: <20190424164538.GC18611@fuggles.cambridge.arm.com> References: <20190424152502.14246-1-mathieu.desnoyers@efficios.com> <20190424152502.14246-9-mathieu.desnoyers@efficios.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190424152502.14246-9-mathieu.desnoyers@efficios.com> User-Agent: Mutt/1.11.1+86 (6f28e57d73f2) () Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Apr 24, 2019 at 11:25:00AM -0400, Mathieu Desnoyers wrote: > Handle compiling with -mbig-endian on aarch64, which generates binaries > with mixed code vs data endianness (little endian code, big endian > data). > > Else mismatch between code endianness for the generated signatures and > data endianness for the RSEQ_SIG parameter passed to the rseq > registration will trigger application segmentation faults when the > kernel try to abort rseq critical sections. > > Signed-off-by: Mathieu Desnoyers > CC: Peter Zijlstra > CC: Thomas Gleixner > CC: Joel Fernandes > CC: Catalin Marinas > CC: Dave Watson > CC: Will Deacon > CC: Shuah Khan > CC: Andi Kleen > CC: linux-kselftest@vger.kernel.org > CC: "H . Peter Anvin" > CC: Chris Lameter > CC: Russell King > CC: Michael Kerrisk > CC: "Paul E . McKenney" > CC: Paul Turner > CC: Boqun Feng > CC: Josh Triplett > CC: Steven Rostedt > CC: Ben Maurer > CC: linux-api@vger.kernel.org > CC: Andy Lutomirski > CC: Andrew Morton > CC: Linus Torvalds > --- > tools/testing/selftests/rseq/rseq-arm64.h | 17 +++++++++++++++-- > 1 file changed, 15 insertions(+), 2 deletions(-) > > diff --git a/tools/testing/selftests/rseq/rseq-arm64.h b/tools/testing/selftests/rseq/rseq-arm64.h > index b41a2a48e965..200dae9e4208 100644 > --- a/tools/testing/selftests/rseq/rseq-arm64.h > +++ b/tools/testing/selftests/rseq/rseq-arm64.h > @@ -6,7 +6,20 @@ > * (C) Copyright 2018 - Will Deacon > */ > > -#define RSEQ_SIG 0xd428bc00 /* BRK #0x45E0 */ > +/* > + * 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 __AARCH64EB__ > +#define RSEQ_SIG_DATA 0x00bc28d4 /* BRK #0x45E0. */ It would be neater to implement swab32 and use that with RSEQ_SIG_CODE, but either way: Acked-by: Will Deacon Will