Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp4373637pxb; Tue, 31 Aug 2021 03:40:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJys4qYhSM50XRdG3g3LvhnKYddu1u78NzE8+8985BY0XtdYZSTwZP/K0SXAqGBswyBA2y7a X-Received: by 2002:a02:bb16:: with SMTP id y22mr2173495jan.129.1630406452251; Tue, 31 Aug 2021 03:40:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630406452; cv=none; d=google.com; s=arc-20160816; b=yqYSiWBGCXqBWqFhffh8TziMs0n0H/nObBuhAIWrYI70UIDrq7ebWTuy/KogFwjus9 Exb3kZZsiB9NFzEhkhXUoxdUO/JncW1RSs1UXmZ5eHCXnjzp9VAlli+UOiHbbF+Ql0sx ODYrdHwo7YDGWt1XVI3bJbEpaKw7hDhl/XjNiTtGq8b4e7/3uK4lrJMbPUddEcbCghLx 2NIOrWRzOu0LDGUqVbMcsv8DchTnMF6GdjsJ4pm0AV2BCDa851S6rsHmK2sA7tEc1Epv qY15X5Bx9qROfKelEvzoFgIcEmB/QVFyYMZ/2+AE0sGg892EYtLmAG6Pk+mHHDx3JK0p DfGA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=CkhRtVDUgb41zlq5OfgVAHJFRMwL0PptQO/kVg6fccA=; b=0DYaFPfkpjB3TiCaN+X2IrUi8PV0KDR3PuQCAKikMu0dgiy2O3zOH5vJtMiP1TwoMl b1k7espAugtvEgoJ1ShMyFqxD7rRHngTBWdddj2UFF94Z6DzlH80Q0KSVxWTBjo1JbkP cRvskySeBQdjF+kKTY4VoBESrdJTkTnui9m2WO9IvrB9Pj5wjGZsxuukJP93XV2rILx0 zxsGaEfk/rXnHcXmOF71ncAxmMfwzoxrR5Y0xC6sDgeEfhOX5Jmm2yxbzbDtlx5LYKpM 90s+ZhVdvi4pipxak5nN54N7aSNOU2D8gRNE6W32oof9w/s1NZVr4qf5HQ4crWiI7TUO re0w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=wb1QmOQo; 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=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s20si16391455ioa.93.2021.08.31.03.40.40; Tue, 31 Aug 2021 03:40:52 -0700 (PDT) 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=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=wb1QmOQo; 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=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S241293AbhHaKku (ORCPT + 99 others); Tue, 31 Aug 2021 06:40:50 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39076 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241112AbhHaKi3 (ORCPT ); Tue, 31 Aug 2021 06:38:29 -0400 Received: from mail-pf1-x429.google.com (mail-pf1-x429.google.com [IPv6:2607:f8b0:4864:20::429]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 80AB1C061292 for ; Tue, 31 Aug 2021 03:37:15 -0700 (PDT) Received: by mail-pf1-x429.google.com with SMTP id v123so14575759pfb.11 for ; Tue, 31 Aug 2021 03:37:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=CkhRtVDUgb41zlq5OfgVAHJFRMwL0PptQO/kVg6fccA=; b=wb1QmOQoMFVShBMn9y6KTytH5q1BZ0H1hJ3YO5uXgTFjLoGaoSepJJ5OlbhccHu/AJ wAiGO67xMVtU0t2LrJWcMBK/NhTSX6ZkR3DOqmyntbAg6jf+Cr1K9Cw8Xhb1KbRfFq5f 0PiM2QpjLxqt7Y8TQAgsTNp6GYrUDvE9Lh/oajmuWt89WT4dDtxIROjBFBxpqguUKBU7 LLMz+DXMsZEm4Eg593FHxtTTvCsA6fIWSzAN4+6DPx7X3FPKVNWqVAX/Kck7QYFDzzcC d2NfPV00YlGSbPc1qoUeYTZUD6zpXTRPBo7PsZ9aFWAnnS/G89GxBIlH9Z/mgTPMxFx/ rbnA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=CkhRtVDUgb41zlq5OfgVAHJFRMwL0PptQO/kVg6fccA=; b=HZ0ovvBgSeL2m5NPm6PrF3C8WDrt5UNzBx4TXATg8OIKoI7PG5lZDgG5wRFOZKdcCp yg864XFbrTdP0e+hjyIxWb9ByD1QR4pIyVCYAdEH7FbNFxATT+78JBaZcD7tt5iJwuKY Oc97KE5mB4phk9iCfbzl9vNjQqSDedDbFnmoWvSAZfj2pYNEepltX0q7RlsgS0asBWku ZKVOBnfI4LJ8yI0NBOrs2IOofcmw38xIxfxaSuw9V+ohKphtwzLMm2JwJQsfIpITYAv1 XawTxZioycdAEw8H/M/ZcJU/4yc6VRmlAzvNC7j5jDBueApgYaDgacdRV56ggAT9eaY6 H3lw== X-Gm-Message-State: AOAM530wgosB2bM2R0c/paqGSManJNd7HTWrnmysGxGdbaBf3WtyVLgo rL0m0gQbPxBFOmRtJ0I7Hf3X X-Received: by 2002:aa7:999c:0:b0:3f2:8100:79c2 with SMTP id k28-20020aa7999c000000b003f2810079c2mr22685875pfh.80.1630406235060; Tue, 31 Aug 2021 03:37:15 -0700 (PDT) Received: from localhost ([139.177.225.253]) by smtp.gmail.com with ESMTPSA id 15sm2641504pjw.39.2021.08.31.03.37.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 31 Aug 2021 03:37:14 -0700 (PDT) From: Xie Yongji To: mst@redhat.com, jasowang@redhat.com, stefanha@redhat.com, sgarzare@redhat.com, parav@nvidia.com, hch@infradead.org, christian.brauner@canonical.com, rdunlap@infradead.org, willy@infradead.org, viro@zeniv.linux.org.uk, axboe@kernel.dk, bcrl@kvack.org, corbet@lwn.net, mika.penttila@nextfour.com, dan.carpenter@oracle.com, joro@8bytes.org, gregkh@linuxfoundation.org, zhe.he@windriver.com, xiaodong.liu@intel.com, joe@perches.com, robin.murphy@arm.com, will@kernel.org, john.garry@huawei.com Cc: songmuchun@bytedance.com, virtualization@lists.linux-foundation.org, netdev@vger.kernel.org, kvm@vger.kernel.org, linux-fsdevel@vger.kernel.org, iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org Subject: [PATCH v13 03/13] file: Export receive_fd() to modules Date: Tue, 31 Aug 2021 18:36:24 +0800 Message-Id: <20210831103634.33-4-xieyongji@bytedance.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210831103634.33-1-xieyongji@bytedance.com> References: <20210831103634.33-1-xieyongji@bytedance.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Export receive_fd() so that some modules can use it to pass file descriptor between processes without missing any security stuffs. Signed-off-by: Xie Yongji Acked-by: Jason Wang --- fs/file.c | 6 ++++++ include/linux/file.h | 7 +++---- 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/fs/file.c b/fs/file.c index 86dc9956af32..210e540672aa 100644 --- a/fs/file.c +++ b/fs/file.c @@ -1134,6 +1134,12 @@ int receive_fd_replace(int new_fd, struct file *file, unsigned int o_flags) return new_fd; } +int receive_fd(struct file *file, unsigned int o_flags) +{ + return __receive_fd(file, NULL, o_flags); +} +EXPORT_SYMBOL_GPL(receive_fd); + static int ksys_dup3(unsigned int oldfd, unsigned int newfd, int flags) { int err = -EBADF; diff --git a/include/linux/file.h b/include/linux/file.h index 2de2e4613d7b..51e830b4fe3a 100644 --- a/include/linux/file.h +++ b/include/linux/file.h @@ -94,6 +94,9 @@ extern void fd_install(unsigned int fd, struct file *file); extern int __receive_fd(struct file *file, int __user *ufd, unsigned int o_flags); + +extern int receive_fd(struct file *file, unsigned int o_flags); + static inline int receive_fd_user(struct file *file, int __user *ufd, unsigned int o_flags) { @@ -101,10 +104,6 @@ static inline int receive_fd_user(struct file *file, int __user *ufd, return -EFAULT; return __receive_fd(file, ufd, o_flags); } -static inline int receive_fd(struct file *file, unsigned int o_flags) -{ - return __receive_fd(file, NULL, o_flags); -} int receive_fd_replace(int new_fd, struct file *file, unsigned int o_flags); extern void flush_delayed_fput(void); -- 2.11.0