From nobody Wed Feb 11 23:44:51 2026 Received: from mail-yb1-f202.google.com (mail-yb1-f202.google.com [209.85.219.202]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 81C4E2C683 for ; Fri, 29 Mar 2024 01:54:07 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.219.202 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711677249; cv=none; b=E6uWhCe+2m1cAavk/89m67emWR6oUqcbLhAokkvmrFsRFBJjbMoimdW3McNVejjyACM0t6dHlYBja4zrNIxt71GxDLAmmkI3HsqqdSdljIvEmabWjh7YyVV1lZBW3XunBVhEl8W8mApZ83kgv2Keb/qA83EQUAKP+G92cacOPKA= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711677249; c=relaxed/simple; bh=WHF1cQ6wftLpEUkLh/arn81XtKeZBIuOooiwZcqzz24=; h=Date:In-Reply-To:Mime-Version:References:Message-ID:Subject:From: To:Cc:Content-Type; b=l2Wg4Nr1FSEQQBeJ/dPVZqy07SvnPS3bNyjTgCluKgsiljrgFeYJfRHqHNjysfxRrtvxKYrHC3BWdBhFVupaDnXDR9+DI+T0iNFk1D0mrxK9X19OZ/woqRhb9t26ZZjqVWXWs7g+ZWexk4bxt9OKyUPEMSDyJ7kddY9GXfgwm3M= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=google.com; spf=pass smtp.mailfrom=flex--drosen.bounces.google.com; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b=ohkuFqn0; arc=none smtp.client-ip=209.85.219.202 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=google.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=flex--drosen.bounces.google.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b="ohkuFqn0" Received: by mail-yb1-f202.google.com with SMTP id 3f1490d57ef6-dcbfe1a42a4so2835172276.2 for ; Thu, 28 Mar 2024 18:54:07 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20230601; t=1711677246; x=1712282046; darn=vger.kernel.org; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:from:to:cc:subject:date:message-id:reply-to; bh=1TWHZ6CjfZzMP0P6lR3s6R//pEvlviDj7MeL1JlKB90=; b=ohkuFqn0UVk+BjOZ6e/RSq+48ILEeFYpINfxRwudlqaBWyFbnkpPawUTBv2CuqMfD1 nKkruG6I9j8NGgSA9NVtg7HFFnTUqmFC29sod1XHXTCBRYdW3S2Ir/T+QbLZT3239gae E3pKZvFzV7WBF8aL/cfmUln6QiwAysATkK9SOwcL7Y/LT4r3vpzE+dtbvj3ImOHvxzcO p5GdAoDK2j2Pj/oOVRZ4bHmUl77HwudnBv7cMP6VYmH3vegQkSeCFVq3Buqg+0w5BDAN bBklfy6rYVEQEw1nKMN8V3/ButYEI+bfHgut2Ye4IsUsZ1OlhTZKMBSPur38HYhTtAv9 vutA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1711677246; x=1712282046; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=1TWHZ6CjfZzMP0P6lR3s6R//pEvlviDj7MeL1JlKB90=; b=Vc1J6D3pqo4jPRzTn37DE4yot6VakLJNMWFSYsYBdl1Hl2E6EvL2EM2yJXiZg0Ozmp TtHtb247lvRkddfsJqSf5TW+ye51c2HUjJ2mpiQtUY10IbicQJuiZiSSON3hwTZTtxh8 aGpi10FcaGmGobSIVrh0m6ux/FqTqUfJOnvrpZp8DQf3vKbIiSVXIckdMOG3neECCKE5 IIux1dirXh75qHmGLU55EYGAIU1iqp/2lQHikGug6Kxn+uC7RDGyV3pB2YWm+EwikerO 8E1NuBbBQ3tikyY2PFfOiJWx7f4fQdMzlHYPWOUiCwAFIu1PWtW8bxoBik5x5jvWXLmR CPqA== X-Forwarded-Encrypted: i=1; AJvYcCWRKjtw48x6Y8nidd3WK2sL0/U6UEI09jPQoe21zbeU7iTVxoiAEq1K0QSBMpQw78fDcyUp6zbS6zuM7QG56opljNUA8AE+JNtLaUFB X-Gm-Message-State: AOJu0YyOI0KogZKy1SZ/rUjZ67pqc7az6zVmS8yDH3Y534M+fdhhLJvK lFuNKQJ/oEknL5Pr66YMmmkXmYlIgGLKZEL+j4y8lTHZD1IcIW06ns6Tg1EDJyunxpARgyeKPR3 TEA== X-Google-Smtp-Source: AGHT+IEi4wBl0taMuZM199uicOLSQKEshdiXi8Hiat+CV3OzSJuBGo9P6id8BJm2lQgMqafkSWILsniPSE4= X-Received: from drosen.mtv.corp.google.com ([2620:15c:211:201:fcce:d6ab:804c:b94b]) (user=drosen job=sendgmr) by 2002:a05:6902:72c:b0:dc2:3441:897f with SMTP id l12-20020a056902072c00b00dc23441897fmr300435ybt.6.1711677246590; Thu, 28 Mar 2024 18:54:06 -0700 (PDT) Date: Thu, 28 Mar 2024 18:53:18 -0700 In-Reply-To: <20240329015351.624249-1-drosen@google.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: Mime-Version: 1.0 References: <20240329015351.624249-1-drosen@google.com> X-Mailer: git-send-email 2.44.0.478.gd926399ef9-goog Message-ID: <20240329015351.624249-4-drosen@google.com> Subject: [RFC PATCH v4 03/36] fuse-bpf: Prepare for fuse-bpf patch From: Daniel Rosenberg To: Miklos Szeredi , bpf@vger.kernel.org, Alexei Starovoitov Cc: Amir Goldstein , linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-unionfs@vger.kernel.org, Daniel Borkmann , John Fastabend , Andrii Nakryiko , Martin KaFai Lau , Song Liu , Eduard Zingerman , Yonghong Song , KP Singh , Stanislav Fomichev , Hao Luo , Jiri Olsa , Shuah Khan , Jonathan Corbet , Joanne Koong , Mykola Lysenko , Christian Brauner , kernel-team@android.com, Daniel Rosenberg , Paul Lawrence Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" This moves some functions and structs around to make the following patch easier to read. Signed-off-by: Daniel Rosenberg Signed-off-by: Paul Lawrence --- fs/fuse/dir.c | 4 ---- fs/fuse/fuse_i.h | 8 ++++++++ fs/fuse/inode.c | 52 ++++++++++++++++++++++++------------------------ 3 files changed, 34 insertions(+), 30 deletions(-) diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c index d19cbf34c634..cd8d6b2f6d78 100644 --- a/fs/fuse/dir.c +++ b/fs/fuse/dir.c @@ -46,10 +46,6 @@ static inline u64 fuse_dentry_time(const struct dentry *= entry) } =20 #else -union fuse_dentry { - u64 time; - struct rcu_head rcu; -}; =20 static inline void __fuse_dentry_settime(struct dentry *dentry, u64 time) { diff --git a/fs/fuse/fuse_i.h b/fs/fuse/fuse_i.h index bcbe34488862..797bcfd6fa06 100644 --- a/fs/fuse/fuse_i.h +++ b/fs/fuse/fuse_i.h @@ -76,6 +76,14 @@ struct fuse_submount_lookup { struct fuse_forget_link *forget; }; =20 +/** FUSE specific dentry data */ +#if BITS_PER_LONG < 64 +union fuse_dentry { + u64 time; + struct rcu_head rcu; +}; +#endif + /** FUSE inode */ struct fuse_inode { /** Inode data */ diff --git a/fs/fuse/inode.c b/fs/fuse/inode.c index 516ea2979a90..8eff618ac47b 100644 --- a/fs/fuse/inode.c +++ b/fs/fuse/inode.c @@ -197,6 +197,32 @@ static ino_t fuse_squash_ino(u64 ino64) return ino; } =20 +static void fuse_fill_attr_from_inode(struct fuse_attr *attr, + const struct fuse_inode *fi) +{ + struct timespec64 atime =3D inode_get_atime(&fi->inode); + struct timespec64 mtime =3D inode_get_mtime(&fi->inode); + struct timespec64 ctime =3D inode_get_ctime(&fi->inode); + + *attr =3D (struct fuse_attr){ + .ino =3D fi->inode.i_ino, + .size =3D fi->inode.i_size, + .blocks =3D fi->inode.i_blocks, + .atime =3D atime.tv_sec, + .mtime =3D mtime.tv_sec, + .ctime =3D ctime.tv_sec, + .atimensec =3D atime.tv_nsec, + .mtimensec =3D mtime.tv_nsec, + .ctimensec =3D ctime.tv_nsec, + .mode =3D fi->inode.i_mode, + .nlink =3D fi->inode.i_nlink, + .uid =3D fi->inode.i_uid.val, + .gid =3D fi->inode.i_gid.val, + .rdev =3D fi->inode.i_rdev, + .blksize =3D 1u << fi->inode.i_blkbits, + }; +} + void fuse_change_attributes_common(struct inode *inode, struct fuse_attr *= attr, struct fuse_statx *sx, u64 attr_valid, u32 cache_mask) @@ -1477,32 +1503,6 @@ void fuse_dev_free(struct fuse_dev *fud) } EXPORT_SYMBOL_GPL(fuse_dev_free); =20 -static void fuse_fill_attr_from_inode(struct fuse_attr *attr, - const struct fuse_inode *fi) -{ - struct timespec64 atime =3D inode_get_atime(&fi->inode); - struct timespec64 mtime =3D inode_get_mtime(&fi->inode); - struct timespec64 ctime =3D inode_get_ctime(&fi->inode); - - *attr =3D (struct fuse_attr){ - .ino =3D fi->inode.i_ino, - .size =3D fi->inode.i_size, - .blocks =3D fi->inode.i_blocks, - .atime =3D atime.tv_sec, - .mtime =3D mtime.tv_sec, - .ctime =3D ctime.tv_sec, - .atimensec =3D atime.tv_nsec, - .mtimensec =3D mtime.tv_nsec, - .ctimensec =3D ctime.tv_nsec, - .mode =3D fi->inode.i_mode, - .nlink =3D fi->inode.i_nlink, - .uid =3D fi->inode.i_uid.val, - .gid =3D fi->inode.i_gid.val, - .rdev =3D fi->inode.i_rdev, - .blksize =3D 1u << fi->inode.i_blkbits, - }; -} - static void fuse_sb_defaults(struct super_block *sb) { sb->s_magic =3D FUSE_SUPER_MAGIC; --=20 2.44.0.478.gd926399ef9-goog