Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp5212518ybl; Tue, 14 Jan 2020 05:28:15 -0800 (PST) X-Google-Smtp-Source: APXvYqxEfk1Vqttgb8bovioG4z1O+5rBvvY+VFniUWE0aFmddigpqrJCk7eqaFaIPi+C7l644ScW X-Received: by 2002:aca:1a17:: with SMTP id a23mr15759635oia.84.1579008495234; Tue, 14 Jan 2020 05:28:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579008495; cv=none; d=google.com; s=arc-20160816; b=QlSUIjJZCkE1L4FnMkjUfdvcT/w1rjYKHV68cnzmw8M8h9X8H3VuFo+FlzB43GerFE CV9+vhaY+uA2IhNWFcU97hKaBWMNyUjb2ymLLEH88zI/jz3e3ElcoDToJDxiIRbBqfhz zeRw3pJYqUuZYQtITY2kXEtUZSVS5QslMDaDxT4unTK5i8sEQZ2HBvkEGy6BeFPk3cmz L3ldhnYk5w3BDeqyrz5jbI6+SYxclb9+iNjeQ4dox4iWYOGPhtCRshtToEaVNPCVdNZj kmuQ3oz7vNA9JL7Fi6EntH7IneSZzjocBhwy+1/0nlCNbo1uLGN0S/aAhxti7TxxIBe8 LrZw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=hHyuJmXVduqIfPICE4zv6dRyviyKWjQwlVRhFHJPUsg=; b=QT+x9Y5qVu55A5wOTg/C8KO1Vjx5hCqRBhKxZs2QPK6lEh8vTnqfkWHckyafvsWoQv BuezkkhTaSNl/HY+jDnnLQ/yoDWcORyeYsLXeMN3M2yK4UTRE/jRgUgyDyxbf2A/JnKo mGlHHglrRJklM1ezJPWRCXg7dhJvEJVmxZv8V87kFHcN6tCOt61Cj4NgVYET7kRY2Ucv DMDPmmP++kgwwrBO5vAWD5qwaZkJmTWhAZsW38RrgqDSHu9tGclRZBdVmOI7ptjgt7Nj wH4zPpEiIzTEXZmqSOWKJEZ4dHNYI1SWN2jfOEZbfybehl2UXEuRVdXowL6dX9B0cdUX pVhw== 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 q28si7226422oij.149.2020.01.14.05.28.03; Tue, 14 Jan 2020 05:28:15 -0800 (PST) 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 S1728734AbgANN1O (ORCPT + 99 others); Tue, 14 Jan 2020 08:27:14 -0500 Received: from mout.kundenserver.de ([217.72.192.74]:53329 "EHLO mout.kundenserver.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726450AbgANN1O (ORCPT ); Tue, 14 Jan 2020 08:27:14 -0500 Received: from threadripper.lan ([149.172.19.189]) by mrelayeu.kundenserver.de (mreue106 [212.227.15.145]) with ESMTPA (Nemesis) id 1N2mS2-1jnUi72fDo-0139pi; Tue, 14 Jan 2020 14:26:59 +0100 From: Arnd Bergmann To: "David S. Miller" , Sam Ravnborg Cc: Arnd Bergmann , stable@vger.kernel.org, "Dmitry V . Levin" , Rich Felker , libc-alpha@sourceware.org, sparclinux@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH] sparc32: fix struct ipc64_perm type definition Date: Tue, 14 Jan 2020 14:26:14 +0100 Message-Id: <20200114132633.3694261-1-arnd@arndb.de> X-Mailer: git-send-email 2.20.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Provags-ID: V03:K1:DM0uz4nPPp4jUgO+yEl0v/MrWqjzx2Rp+eofrZT3+3zAthy+ydz QSO2+u4V7klg2IcLv4t4yjuSyVrBjGQBVGoD1cXq8nWNIx6n2u5WnYxRUDZLY6GsKk5Ab6A 7UyFygze4/I1fVwPPO6PFNC+qKCz9nh6MuG9DRmSf5kSoSz3EK1+hfiTB1t7c3PvXI9UaIY CEW6heDh8oejelRASyLfA== X-Spam-Flag: NO X-UI-Out-Filterresults: notjunk:1;V03:K0:DkWAj92lmQg=:OftWo0gr1NF8IyXuls1x2e qmZPERCuY3Ytd6XWAXtx26zynKyU9RaTIfTJS4m6ZliS1RIXpNMANGyR65iJGYPF5QqQojX/U vW4SEI9g0Kk07aay1VlIRG4wv3vbqkOAYaK+M+oA6L7jbS4gmfd+k9n3PG9E7t3+Gf/8sapza Qm+XJa3mTWMKFG2xCQNdreBHokDkmCaeYoO4DOfuSctJ+ataSH8creZBmRObCr6w/MyVE32me bloS1HSooVfYur5UwwpX4/u2D9d6pxCPKwcEN+iELycpP3HpLpbdohx+biaTubrWi2m3HAicA UaiDyXMM+dhWx80FUhuSXqeTNxjOzNNRm1mKBYyAMxmC7HIAcpG5qGaXNpWf2dq5Sk+3MKYKg L/EX373pa2mYOUquAQ4WiQjvBy3MOghuClB3gjzni+zl4eoxogiLrGp7+QYza7SAHHwe0HcvW 6GdP2mgKJhj1FRwuA2pj01L7HCBpjhwVxVgRXqBg5rXWhzR6FwS2MZANzMcQCRd2LbUzZvPdR xe7RQkuOOumhVuRiPHQgMsuLA7y/9L1kr+TPtGF1JKl88s4LIP2sqzqnpEV8n0FrFRYnVbqA8 CJ21aW8CD094vF47iRI+WPb2QxVPoCJgs/rNs9wKijvoxPKYRuGqz3sMaUHyD4tJ+O6dGU4Dk Mv4IsqiI5rLPxCKLAQPKKS6peJsx1NAkM8fiWGdgFBf8OqcXY3EP5RoZhOLCyC6zHbZGSK8Hp gNS4QbQ1dsRpAiDXhbp5rthkXc+5GYVZki7CexeR0apdrwMWlKO3oWAjAMcVdnRhe/5LQF/Bf O31CtvwqLuwVmSgC27q617uJ35kPx4nB1JsOCUniOK5K0ieIv3VC5oJ/VfWbTl7BLBg5TFmGC y17/ah14Qj3FGJy0AGyA== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org As discussed in the strace issue tracker, it appears that the sparc32 sysvipc support has been broken for the past 11 years. It was however working in compat mode, which is how it must have escaped most of the regular testing. The problem is that a cleanup patch inadvertently changed the uid/gid fields in struct ipc64_perm from 32-bit types to 16-bit types in uapi headers. Both glibc and uclibc-ng still use the original types, so they should work fine with compat mode, but not natively. Change the definitions to use __kernel_uid32_t and __kernel_gid32_t again. Fixes: 83c86984bff2 ("sparc: unify ipcbuf.h") Link: https://github.com/strace/strace/issues/116 Cc: # v2.6.29 Cc: Sam Ravnborg Cc: "Dmitry V . Levin" Cc: Rich Felker Cc: libc-alpha@sourceware.org Signed-off-by: Arnd Bergmann --- arch/sparc/include/uapi/asm/ipcbuf.h | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/arch/sparc/include/uapi/asm/ipcbuf.h b/arch/sparc/include/uapi/asm/ipcbuf.h index 5b933a598a33..0ea1240d2ea1 100644 --- a/arch/sparc/include/uapi/asm/ipcbuf.h +++ b/arch/sparc/include/uapi/asm/ipcbuf.h @@ -17,19 +17,19 @@ struct ipc64_perm { - __kernel_key_t key; - __kernel_uid_t uid; - __kernel_gid_t gid; - __kernel_uid_t cuid; - __kernel_gid_t cgid; + __kernel_key_t key; + __kernel_uid32_t uid; + __kernel_gid32_t gid; + __kernel_uid32_t cuid; + __kernel_gid32_t cgid; #ifndef __arch64__ - unsigned short __pad0; + unsigned short __pad0; #endif - __kernel_mode_t mode; - unsigned short __pad1; - unsigned short seq; - unsigned long long __unused1; - unsigned long long __unused2; + __kernel_mode_t mode; + unsigned short __pad1; + unsigned short seq; + unsigned long long __unused1; + unsigned long long __unused2; }; #endif /* __SPARC_IPCBUF_H */ -- 2.20.0