Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp4366806pxb; Tue, 25 Jan 2022 08:54:48 -0800 (PST) X-Google-Smtp-Source: ABdhPJzJqwX7mrk/k+02dmSAHYmfX82nvEHmga3FCR3H05m11px6nHXikyJL3H+f1MKG/thFnkhZ X-Received: by 2002:a17:906:a148:: with SMTP id bu8mr16626638ejb.421.1643129688225; Tue, 25 Jan 2022 08:54:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643129688; cv=none; d=google.com; s=arc-20160816; b=qnBmV4qKKNfs7aJCO/8FLEe26dDmcz+hYijI1QCrSShK/ca2BNBAnbQHo5dff5pGV2 uEf0FLhG3tS9Iwiafo8PbuJ6Y5OgS44qlKB0DNyoVyW97zK5uHOJVXNkx7hAxW/T5baR sOZG5ytqdsUPKdOAZ6TCfDj+tQvh7VOyViqAGNxyCIbVDn0X+FsD+GBnt8tosvOF4HRl 5CsduluLHmLWoVL4StNKr8wBZCdnE9sRIDuSkvprdVZiPq7k36BdJnLbNymz1j+0KmWb Yn142htt6wLP0ZJ+klWSRNwSNJFS0Gy3f+SJ+elFMYpZWhOG6P4dub0+EermovGv4d6f 9vAw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=4CpKuJXpI1Yzjuxun9Ubbp+TowVRVgGj8ejFzpHPpgE=; b=Usv6L72E2Z8nwPCxu5BqZ7HEhTyPvjs/kk6dQLMAqKRhUHpnvbyCOOqhLU2cuNSrEd OQyRUqEt8AgLPysi5LBOw/CqFnvH4umPl1P9Jf+KFy1YZoxyeFt9Ii5idX15Ur0BJOzS T0VptoxidznNoadr2ZK15q1PGZQfxSemn9spd4tTv257CbuPXA/1awN2FZWzrMXWhkzv KdzVoJca9G8dHKi1eYeAVv71ME73qVJZVXC007+w9n/8dEWohyjShAwXIrNxktn2pGqV rj9XXA6lSMtPBQz3x/Pvsc/UNIFjUTYzRatnQ28QCcRU/fq7iluUTUY9gSGJFl7ONae1 jZ3w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=LlF0UtQm; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j15si1516249edw.582.2022.01.25.08.54.23; Tue, 25 Jan 2022 08:54:48 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=LlF0UtQm; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1445888AbiAYM0K (ORCPT + 99 others); Tue, 25 Jan 2022 07:26:10 -0500 Received: from ams.source.kernel.org ([145.40.68.75]:58562 "EHLO ams.source.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1444963AbiAYMWN (ORCPT ); Tue, 25 Jan 2022 07:22:13 -0500 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id D668CB817E6; Tue, 25 Jan 2022 12:22:05 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id E1FAEC340E0; Tue, 25 Jan 2022 12:21:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1643113324; bh=smHriwhZRzmYd06A5ADB/HEiixrqxr9u1mD1v+Ab6Rs=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=LlF0UtQmRh0zWYeJwpjdNbcl+auvhufZbOuRQRLHGYYtnDjxug/riXLFSSl2/cva9 UPOtl3tKKDG+IwxiqznI6SEzWmoqfrbPngwY1qQ7DGH7sOPphdsjmz1jQo+wpj/esN 7XyHDDOyMXsYMAsvY6AL193unLLV1ALpaqEUnjMeR7mj6z/M7OpaE+XWIDJMOxtJTa Mv1qF4fI2pGgMcx2aEIDdzFksSv0g2OUCHdrqcTYxQNkN2gTpYM/xJHfwLHyBVlvPp rqv4dxpLUpJHJds/ckQUtLTL/VcVkh1PCwIdZs5FS0EFdtESiG6Z6/bXvIU3Q7zX0C /JbVI4irv9Hxg== Date: Tue, 25 Jan 2022 13:21:56 +0100 From: Christian Brauner To: Mathieu Desnoyers Cc: Thomas Gleixner , linux-kernel@vger.kernel.org, Peter Zijlstra , "Paul E . McKenney" , Boqun Feng , "H . Peter Anvin" , Paul Turner , linux-api@vger.kernel.org, Shuah Khan , linux-kselftest@vger.kernel.org, Florian Weimer , Andy Lutomirski , Dave Watson , Andrew Morton , Russell King , Andi Kleen , Christian Brauner , Ben Maurer , Steven Rostedt , Josh Triplett , Linus Torvalds , Catalin Marinas , Will Deacon , Michael Kerrisk , Joel Fernandes Subject: Re: [RFC PATCH 02/15] rseq: Remove broken uapi field layout on 32-bit little endian Message-ID: <20220125122156.v2f5anzcs35i3rii@wittgenstein> References: <20220124171253.22072-1-mathieu.desnoyers@efficios.com> <20220124171253.22072-3-mathieu.desnoyers@efficios.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20220124171253.22072-3-mathieu.desnoyers@efficios.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Jan 24, 2022 at 12:12:40PM -0500, Mathieu Desnoyers wrote: > The rseq rseq_cs.ptr.{ptr32,padding} uapi endianness handling is > entirely wrong on 32-bit little endian: a preprocessor logic mistake > wrongly uses the big endian field layout on 32-bit little endian > architectures. > > Fortunately, those ptr32 accessors were never used within the kernel, > and only meant as a convenience for user-space. > > Remove those and only leave the "ptr64" union field, as this is the only > thing really needed to express the ABI. Document how 32-bit > architectures are meant to interact with this "ptr64" union field. > > Fixes: ec9c82e03a74 ("rseq: uapi: Declare rseq_cs field as union, update includes") > Signed-off-by: Mathieu Desnoyers > Cc: Florian Weimer > Cc: Thomas Gleixner > Cc: linux-api@vger.kernel.org > Cc: Peter Zijlstra > Cc: Boqun Feng > Cc: Andy Lutomirski > Cc: Dave Watson > Cc: Paul Turner > Cc: Andrew Morton > Cc: Russell King > Cc: "H . Peter Anvin" > Cc: Andi Kleen > Cc: Christian Brauner > Cc: Ben Maurer > Cc: Steven Rostedt > Cc: Josh Triplett > Cc: Linus Torvalds > Cc: Catalin Marinas > Cc: Will Deacon > Cc: Michael Kerrisk > Cc: Joel Fernandes > Cc: Paul E. McKenney > --- > include/uapi/linux/rseq.h | 17 ++++------------- > 1 file changed, 4 insertions(+), 13 deletions(-) > > diff --git a/include/uapi/linux/rseq.h b/include/uapi/linux/rseq.h > index 9a402fdb60e9..31290f2424a7 100644 > --- a/include/uapi/linux/rseq.h > +++ b/include/uapi/linux/rseq.h > @@ -105,22 +105,13 @@ struct rseq { > * Read and set by the kernel. Set by user-space with single-copy > * atomicity semantics. This field should only be updated by the > * thread which registered this data structure. Aligned on 64-bit. > + * > + * 32-bit architectures should update the low order bits of the > + * rseq_cs.ptr64 field, leaving the high order bits initialized > + * to 0. > */ > union { A bit unfortunate we seem to have to keep the union around even though it's just one field now.