Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp344594pxb; Thu, 27 Jan 2022 23:52:10 -0800 (PST) X-Google-Smtp-Source: ABdhPJz74Lo786O01f0vIPdaTI53ZxDFRw2AAMLoAGNVFd8qJjewHgNE//7bW7M0/jsh9qELkH52 X-Received: by 2002:a17:902:b692:: with SMTP id c18mr511256pls.85.1643356330015; Thu, 27 Jan 2022 23:52:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643356330; cv=none; d=google.com; s=arc-20160816; b=BLWQBZINrtf0W5jfZej9T8jk88ET1Zf7fpzYdVsZZHf1BRodEHXv6Ezz/Ro03XSD/G +nTfMPhgwstn4BAvd21KGv6AArrl05txIilHG2gBeH8HPFISiDXwsy1ztj4N3nMPxLjq LVSZk85i8FYAPU47/2HWD5O9fNGLEmhBuePgiY5bcw2nWuyugy64f6+wR82Q281kvQpL 0QUENRz65f/e/8qBbZipzScVar1t5qK5GjtmB0n7Zh/LNnKuAzie360oqE3w2DM0xCkj k4O0PFe1vC9FZe+pQvQrU86DigUIWWdISDbLIXzz258P7zMl5xGI3RygFNEnH2Y13CiD lmEA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dkim-signature:dkim-filter; bh=cRqh6zSj9GZH8t608eqoD75yviKq/ALEi5aVTfTfbkI=; b=LR90tnj04fPeuiDGnPEOgNDvLPsF2Zcenh9HlePfwDnZUKtfsOJxBvSN3Yxqlwis46 MOBzdroL0/RcoxmArlHn9mz6MEWqXG6D3+HvyNPbk/ebQDwgCcMBCytA9us4k+frlOqE pYgIGbXjJPQ22JonnPRyCj3s8km/218dnbDkMum0nh+bjBIiHnSyFQBoZnVFgg6GeDrj nPsfD3pVuqNQRMZqw5/Jp9/ptD5RB902Nj2WQdRsU3Rt68RfeJAFtRMY2EChhF8UHloT ocVQs08qhiF7gTiymmlW+0kM1lnALpdl5IabeKPc/gwMYmKS0Khy4DScozcsuUYivmwH Y5XQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@efficios.com header.s=default header.b=kUCrNk9h; 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=efficios.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j2si3273052pfc.28.2022.01.27.23.51.58; Thu, 27 Jan 2022 23:52:09 -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=@efficios.com header.s=default header.b=kUCrNk9h; 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=efficios.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237649AbiA0P1c (ORCPT + 99 others); Thu, 27 Jan 2022 10:27:32 -0500 Received: from mail.efficios.com ([167.114.26.124]:56128 "EHLO mail.efficios.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237542AbiA0P1b (ORCPT ); Thu, 27 Jan 2022 10:27:31 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.efficios.com (Postfix) with ESMTP id F1AEA3698BE; Thu, 27 Jan 2022 10:27:30 -0500 (EST) Received: from mail.efficios.com ([127.0.0.1]) by localhost (mail03.efficios.com [127.0.0.1]) (amavisd-new, port 10032) with ESMTP id iNVvjsDn1UKo; Thu, 27 Jan 2022 10:27:30 -0500 (EST) Received: from localhost (localhost [127.0.0.1]) by mail.efficios.com (Postfix) with ESMTP id 40DF5369B88; Thu, 27 Jan 2022 10:27:30 -0500 (EST) DKIM-Filter: OpenDKIM Filter v2.10.3 mail.efficios.com 40DF5369B88 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=efficios.com; s=default; t=1643297250; bh=cRqh6zSj9GZH8t608eqoD75yviKq/ALEi5aVTfTfbkI=; h=From:To:Date:Message-Id; b=kUCrNk9hvekCSfXQh7ZOludwqXf07XZyEnGKe3+trdCkJi7pO+6neIMhOJ6Kq8N7T NhRe44ydQOjQA1zTXhQH2dArS3nHYNp+cip5c/MrFwTx/lWdKP3cQU4wZrgnVrSkbS emYljpzganzbCl6w3YZ5S88nh3izZRP5gd61DGJsPzBQChHaG8ptHuWP8iI7HhwC2x Q2NOBzQi9JF7qzhIC0Cm8yw/yHaDPN6aEzUVms6iNUVHd86FgdrAvLdwnWimZRDi2f R+zVxXse2O2KMMZuz1voxmJI8NKOT7vBwkytzJEmQHdm22Q2i8673kgrGH5Unbm4wE gBa/7RwcX1bvg== X-Virus-Scanned: amavisd-new at efficios.com Received: from mail.efficios.com ([127.0.0.1]) by localhost (mail03.efficios.com [127.0.0.1]) (amavisd-new, port 10026) with ESMTP id 9PLYYLCLjF8C; Thu, 27 Jan 2022 10:27:30 -0500 (EST) Received: from localhost.localdomain (192-222-180-24.qc.cable.ebox.net [192.222.180.24]) by mail.efficios.com (Postfix) with ESMTPSA id 8AEF3369A41; Thu, 27 Jan 2022 10:27:29 -0500 (EST) From: Mathieu Desnoyers To: Peter Zijlstra Cc: linux-kernel@vger.kernel.org, Thomas Gleixner , "Paul E . McKenney" , Boqun Feng , "H . Peter Anvin" , Paul Turner , linux-api@vger.kernel.org, Shuah Khan , linux-kselftest@vger.kernel.org, Mathieu Desnoyers , 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: [RFC PATCH v2] rseq: Remove broken uapi field layout on 32-bit little endian Date: Thu, 27 Jan 2022 10:27:20 -0500 Message-Id: <20220127152720.25898-1-mathieu.desnoyers@efficios.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <1116876795.2062.1643223596536.JavaMail.zimbra@efficios.com> References: <1116876795.2062.1643223596536.JavaMail.zimbra@efficios.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 replace the whole rseq_cs union by a __u64 type, as this is the only thing really needed to express the ABI. Document how 32-bit architectures are meant to interact with this 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 | 20 ++++---------------- kernel/rseq.c | 8 ++++---- 2 files changed, 8 insertions(+), 20 deletions(-) diff --git a/include/uapi/linux/rseq.h b/include/uapi/linux/rseq.h index 9a402fdb60e9..77ee207623a9 100644 --- a/include/uapi/linux/rseq.h +++ b/include/uapi/linux/rseq.h @@ -105,23 +105,11 @@ 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 field, leaving the high order bits initialized to 0. */ - union { - __u64 ptr64; -#ifdef __LP64__ - __u64 ptr; -#else - struct { -#if (defined(__BYTE_ORDER) && (__BYTE_ORDER == __BIG_ENDIAN)) || defined(__BIG_ENDIAN) - __u32 padding; /* Initialized to zero. */ - __u32 ptr32; -#else /* LITTLE */ - __u32 ptr32; - __u32 padding; /* Initialized to zero. */ -#endif /* ENDIAN */ - } ptr; -#endif - } rseq_cs; + __u64 rseq_cs; /* * Restartable sequences flags field. diff --git a/kernel/rseq.c b/kernel/rseq.c index 6d45ac3dae7f..97ac20b4f738 100644 --- a/kernel/rseq.c +++ b/kernel/rseq.c @@ -128,10 +128,10 @@ static int rseq_get_rseq_cs(struct task_struct *t, struct rseq_cs *rseq_cs) int ret; #ifdef CONFIG_64BIT - if (get_user(ptr, &t->rseq->rseq_cs.ptr64)) + if (get_user(ptr, &t->rseq->rseq_cs)) return -EFAULT; #else - if (copy_from_user(&ptr, &t->rseq->rseq_cs.ptr64, sizeof(ptr))) + if (copy_from_user(&ptr, &t->rseq->rseq_cs, sizeof(ptr))) return -EFAULT; #endif if (!ptr) { @@ -217,9 +217,9 @@ static int clear_rseq_cs(struct task_struct *t) * Set rseq_cs to NULL. */ #ifdef CONFIG_64BIT - return put_user(0UL, &t->rseq->rseq_cs.ptr64); + return put_user(0UL, &t->rseq->rseq_cs); #else - if (clear_user(&t->rseq->rseq_cs.ptr64, sizeof(t->rseq->rseq_cs.ptr64))) + if (clear_user(&t->rseq->rseq_cs, sizeof(t->rseq->rseq_cs))) return -EFAULT; return 0; #endif -- 2.17.1