From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id AE37EC77B72 for ; Fri, 14 Apr 2023 15:25:25 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id DD920900002; Fri, 14 Apr 2023 11:25:24 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id D898C6B0075; Fri, 14 Apr 2023 11:25:24 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id C77DB900002; Fri, 14 Apr 2023 11:25:24 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0016.hostedemail.com [216.40.44.16]) by kanga.kvack.org (Postfix) with ESMTP id BA3AB6B0072 for ; Fri, 14 Apr 2023 11:25:24 -0400 (EDT) Received: from smtpin03.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay06.hostedemail.com (Postfix) with ESMTP id 88967AB7B9 for ; Fri, 14 Apr 2023 15:25:24 +0000 (UTC) X-FDA: 80680370568.03.0340486 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by imf08.hostedemail.com (Postfix) with ESMTP id D8306160002 for ; Fri, 14 Apr 2023 15:25:21 +0000 (UTC) Authentication-Results: imf08.hostedemail.com; dkim=none; dmarc=pass (policy=none) header.from=arm.com; spf=pass (imf08.hostedemail.com: domain of Luca.Vizzarro@arm.com designates 217.140.110.172 as permitted sender) smtp.mailfrom=Luca.Vizzarro@arm.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1681485922; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=i+GOAo28JNAOCrRbLOeXmFJaGrbed0qacVaGMx/eMlQ=; b=glRo+1yIMNMnZEH5tQP0VKDBYzNTAP7tNza6+SlA/GPEXPAl8wL6qyeq7UiwhHfNJIhR4/ 1UI9zLuGoS/eixwkIdBMcvglodcGfAH2s9fuddDBbENlJch4m0A/Y4rWf625YPd81iNeDg 11wf728bjp244aAyMp/XQjILXXtZ4RA= ARC-Authentication-Results: i=1; imf08.hostedemail.com; dkim=none; dmarc=pass (policy=none) header.from=arm.com; spf=pass (imf08.hostedemail.com: domain of Luca.Vizzarro@arm.com designates 217.140.110.172 as permitted sender) smtp.mailfrom=Luca.Vizzarro@arm.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1681485922; a=rsa-sha256; cv=none; b=yo2XNKQyAIN4B8m99pWMKbHAsNBfXC/Q5gbhzYD267t95BkAmY8nb+xG0ckLOzw/uJkaJW guHk1s9MYOsY0YxVLw+dWBM1oKPPuLWUHl5hfs1dfbLgMACD3rVnxNtY9CIInWXwtXiUT3 pOS13gJZ+a7vMI+SbKqeKKT4ERxyR4w= Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 6F7DD1756; Fri, 14 Apr 2023 08:26:05 -0700 (PDT) Received: from localhost.localdomain (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id E1DE73F6C4; Fri, 14 Apr 2023 08:25:18 -0700 (PDT) From: Luca Vizzarro To: linux-kernel@vger.kernel.org Cc: Luca Vizzarro , Andrew Morton , Alexander Viro , Christian Brauner , Jeff Layton , Chuck Lever , Kevin Brodsky , Vincenzo Frascino , Szabolcs Nagy , "Theodore Ts'o" , David Laight , Mark Rutland , linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, linux-morello@op-lists.linaro.org Subject: [PATCH v2 4/5] memfd: Pass argument of memfd_fcntl as int Date: Fri, 14 Apr 2023 16:24:58 +0100 Message-Id: <20230414152459.816046-5-Luca.Vizzarro@arm.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20230414152459.816046-1-Luca.Vizzarro@arm.com> References: <20230414152459.816046-1-Luca.Vizzarro@arm.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Rspamd-Queue-Id: D8306160002 X-Rspamd-Server: rspam09 X-Rspam-User: X-Stat-Signature: xy5gt4txg79sgwmc9cpsw6ww365x3ha9 X-HE-Tag: 1681485921-524021 X-HE-Meta: U2FsdGVkX18zD3hX8U7BQpk99nj3e/JU5Vkkuquf1aYvrNgIh4VUj0r4jyaJ+wivSPPlL3wZDQBGQ0sw0rjwBUHbBxS62PhTiG+tCOaU1FiwQtAzFEXzqUXsdKZtbuQTbXdzMW5oPvMGFmd+DfEMDYrBX0MjPMO3LZh5vjBiTWMq9v31he3fUwEf6/SNBZfmI60gBtt2KLnpMzgq4rolKpv1RrnfsgYdnaWdDdKZt7c9La5br+oRzJ0OnHaJLlaAo7QfMvmulYE0qeBnD17lXPMs9me0QrnZzZaY9+VEPf5vtatavOisb/NISOLAIsJEn2I+J5ZpyXYal/EXQtCYYxk4cmRfOuqZYC7tQGRCJod2p6rCNfI6rIvo8hMlKWkCkxHd63fgQdx+ikyjDFNhzW+a8RLEXbCzbK/L2UEH/R1REff+M+starz9x+6VV2Z7nNGCO5Vf50HotdqKNX1Gim1QpTK7O0ncpn2IPeVZ0G+v5cO069P1diEu5RzIP0pKPkoYkOa7uaN+08dBvvlW39MUQRtQvWhFueIuqmH2jNzs2PQlV67hQo248BVuE2DcPb//iP6CjkWVOvmXMjZZDa7t5EZdvgmTX0EM9J1Pw2N2vETqRMKcesabz7qHv1cKIkii5X250AebCCjK3G3acZUOD1SpWVYq5/W4s1SskUW0im9u6W6r+BhxUvGIA/RYFQLoUS2gvh/GxESpxX1SfNaKWF43Fck72AYDZML5RNFSgsbHAw3QkU0QXUmbJCd+ycfdqjNRaHJ+TOCLsWCR+SIA1xE9wOqA7MaP0tKL35VTneQz7sFgm5PpXWxI3+GArK9mEUsePjEZ9w/x3lEZNatDIwdssxMTSlNAmm6QQ+LX1D5+FF93meN8g+3P9JVA1Eh/XoXydZ7phuY5U/DS+9eBnVaHbXgySh7CSVtHWPDMMUbPHA36ED1NnaY5oIM5eWWX+Ox6dyOYeYbJa8K /wFBM9L0 NQxQvN8Ka/XTZ0SiM6chbNRLMK0BUSKgRsYBMaCoYwJvhTdI4H7W5rBwcCHgFt9C/q+3RfAQbdLSR3rRQVw6v3NHaCMt2K90eErHfl3meUMFVr52I0olNIcyDgvbCYDWHU4cyb12XgogYBWxxYuqq8pBp48PzJZWBuwUm468+Mcneq/AzAkwtCmfJHz+dVLiRBR6pFxMzGRqscsR8oryMDvrJzJsyvBpzwTiENA8D0Hgd3GHuoP7YXULDHAWPphjM/HF84iRblzs1/rHLLOZreL7+9l1sYlNR9EXsETp0NcgM07kQb3Xngdk2kYrF/ZzPpCpuJFxhnyTsFXuP3HBGbrun01Te5xeJ+FUh1//391IUxOpPfy7u8+5JFQuNX9j+Gh68+ku1PoMQtoCUj3Mm1p2yru7X2YPfpD2CxF0kzMs/NoUpcWwhwdHiBfw4WpR43qPdN21aPj0QLnF/OVBVShvHG8zLE+1tfrWwtgRJgpTe413jCdDlccP69wCTQ8ty7tVSNgS0SLu3dnt1fQynmsTaUE1BNWpCffxF1JEe836MmDZuGLhFEvdeFm0Hi3bpHnwSZcOMEW7h7IMrjVor7hAKml8RySNcbZ4Z X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: The interface for fcntl expects the argument passed for the command F_ADD_SEALS to be of type int. The current code wrongly treats it as a long. In order to avoid access to undefined bits, we should explicitly cast the argument to int. This commit changes the signature of all the related and helper functions so that they treat the argument as int instead of long. Cc: Andrew Morton Cc: Alexander Viro Cc: Christian Brauner Cc: Jeff Layton Cc: Chuck Lever Cc: Kevin Brodsky Cc: Vincenzo Frascino Cc: Szabolcs Nagy Cc: "Theodore Ts'o" Cc: David Laight Cc: Mark Rutland Cc: linux-fsdevel@vger.kernel.org Cc: linux-mm@kvack.org Cc: linux-morello@op-lists.linaro.org Signed-off-by: Luca Vizzarro --- include/linux/memfd.h | 4 ++-- mm/memfd.c | 6 +----- 2 files changed, 3 insertions(+), 7 deletions(-) diff --git a/include/linux/memfd.h b/include/linux/memfd.h index 4f1600413f91..e7abf6fa4c52 100644 --- a/include/linux/memfd.h +++ b/include/linux/memfd.h @@ -5,9 +5,9 @@ #include #ifdef CONFIG_MEMFD_CREATE -extern long memfd_fcntl(struct file *file, unsigned int cmd, unsigned long arg); +extern long memfd_fcntl(struct file *file, unsigned int cmd, unsigned int arg); #else -static inline long memfd_fcntl(struct file *f, unsigned int c, unsigned long a) +static inline long memfd_fcntl(struct file *f, unsigned int c, unsigned int a) { return -EINVAL; } diff --git a/mm/memfd.c b/mm/memfd.c index a0a7a37e8177..69b90c31d38c 100644 --- a/mm/memfd.c +++ b/mm/memfd.c @@ -243,16 +243,12 @@ static int memfd_get_seals(struct file *file) return seals ? *seals : -EINVAL; } -long memfd_fcntl(struct file *file, unsigned int cmd, unsigned long arg) +long memfd_fcntl(struct file *file, unsigned int cmd, unsigned int arg) { long error; switch (cmd) { case F_ADD_SEALS: - /* disallow upper 32bit */ - if (arg > UINT_MAX) - return -EINVAL; - error = memfd_add_seals(file, arg); break; case F_GET_SEALS: -- 2.34.1