Re: [PATCH] cifs: move superblock magic defitions to magic.h

From: Jeff Layton
Date: Mon Jan 10 2022 - 19:29:40 EST


On Mon, 2022-01-10 at 18:15 -0600, Steve French wrote:
> Patch looks fine to me. Do you want me to add it to the cifs for-next
> for this merge window, or do you want it merged through a different
> tree?
>

If you can take it in via the cifs tree, then that'd be best. I think
it's a pretty safe patch, but there's no real rush for it. 5.17 or 5.18
is fine.

Thanks,
Jeff

> On Mon, Jan 10, 2022 at 6:00 PM Jeff Layton <jlayton@xxxxxxxxxx> wrote:
> >
> > Help userland apps to identify cifs and smb2 mounts.
> >
> > Signed-off-by: Jeff Layton <jlayton@xxxxxxxxxx>
> > ---
> > fs/cifs/cifsfs.c | 3 ++-
> > fs/cifs/cifsglob.h | 2 --
> > fs/cifs/smb1ops.c | 3 ++-
> > fs/cifs/smb2glob.h | 2 --
> > fs/cifs/smb2ops.c | 5 +++--
> > include/uapi/linux/magic.h | 4 ++++
> > 6 files changed, 11 insertions(+), 8 deletions(-)
> >
> > diff --git a/fs/cifs/cifsfs.c b/fs/cifs/cifsfs.c
> > index dca42aa87d30..5a4d56622d2b 100644
> > --- a/fs/cifs/cifsfs.c
> > +++ b/fs/cifs/cifsfs.c
> > @@ -26,6 +26,7 @@
> > #include <linux/random.h>
> > #include <linux/uuid.h>
> > #include <linux/xattr.h>
> > +#include <uapi/linux/magic.h>
> > #include <net/ipv6.h>
> > #include "cifsfs.h"
> > #include "cifspdu.h"
> > @@ -202,7 +203,7 @@ cifs_read_super(struct super_block *sb)
> > sb->s_time_max = ts.tv_sec;
> > }
> >
> > - sb->s_magic = CIFS_MAGIC_NUMBER;
> > + sb->s_magic = CIFS_SUPER_MAGIC;
> > sb->s_op = &cifs_super_ops;
> > sb->s_xattr = cifs_xattr_handlers;
> > rc = super_setup_bdi(sb);
> > diff --git a/fs/cifs/cifsglob.h b/fs/cifs/cifsglob.h
> > index be74606724c7..50e857e0a311 100644
> > --- a/fs/cifs/cifsglob.h
> > +++ b/fs/cifs/cifsglob.h
> > @@ -24,8 +24,6 @@
> > #include "../smbfs_common/smb2pdu.h"
> > #include "smb2pdu.h"
> >
> > -#define CIFS_MAGIC_NUMBER 0xFF534D42 /* the first four bytes of SMB PDUs */
> > -
> > #define SMB_PATH_MAX 260
> > #define CIFS_PORT 445
> > #define RFC1001_PORT 139
> > diff --git a/fs/cifs/smb1ops.c b/fs/cifs/smb1ops.c
> > index 3b83839fc2c2..dcc8b97e2bbf 100644
> > --- a/fs/cifs/smb1ops.c
> > +++ b/fs/cifs/smb1ops.c
> > @@ -7,6 +7,7 @@
> >
> > #include <linux/pagemap.h>
> > #include <linux/vfs.h>
> > +#include <uapi/linux/magic.h>
> > #include "cifsglob.h"
> > #include "cifsproto.h"
> > #include "cifs_debug.h"
> > @@ -878,7 +879,7 @@ cifs_queryfs(const unsigned int xid, struct cifs_tcon *tcon,
> > {
> > int rc = -EOPNOTSUPP;
> >
> > - buf->f_type = CIFS_MAGIC_NUMBER;
> > + buf->f_type = CIFS_SUPER_MAGIC;
> >
> > /*
> > * We could add a second check for a QFS Unix capability bit
> > diff --git a/fs/cifs/smb2glob.h b/fs/cifs/smb2glob.h
> > index ca692b2283cd..4125fd113cfb 100644
> > --- a/fs/cifs/smb2glob.h
> > +++ b/fs/cifs/smb2glob.h
> > @@ -13,8 +13,6 @@
> > #ifndef _SMB2_GLOB_H
> > #define _SMB2_GLOB_H
> >
> > -#define SMB2_MAGIC_NUMBER 0xFE534D42
> > -
> > /*
> > *****************************************************************
> > * Constants go here
> > diff --git a/fs/cifs/smb2ops.c b/fs/cifs/smb2ops.c
> > index c5b1dea54ebc..57e856c195b5 100644
> > --- a/fs/cifs/smb2ops.c
> > +++ b/fs/cifs/smb2ops.c
> > @@ -13,6 +13,7 @@
> > #include <linux/sort.h>
> > #include <crypto/aead.h>
> > #include <linux/fiemap.h>
> > +#include <uapi/linux/magic.h>
> > #include "cifsfs.h"
> > #include "cifsglob.h"
> > #include "smb2pdu.h"
> > @@ -2747,7 +2748,7 @@ smb2_queryfs(const unsigned int xid, struct cifs_tcon *tcon,
> > goto qfs_exit;
> >
> > rsp = (struct smb2_query_info_rsp *)rsp_iov.iov_base;
> > - buf->f_type = SMB2_MAGIC_NUMBER;
> > + buf->f_type = SMB2_SUPER_MAGIC;
> > info = (struct smb2_fs_full_size_info *)(
> > le16_to_cpu(rsp->OutputBufferOffset) + (char *)rsp);
> > rc = smb2_validate_iov(le16_to_cpu(rsp->OutputBufferOffset),
> > @@ -2789,7 +2790,7 @@ smb311_queryfs(const unsigned int xid, struct cifs_tcon *tcon,
> >
> > rc = SMB311_posix_qfs_info(xid, tcon, fid.persistent_fid,
> > fid.volatile_fid, buf);
> > - buf->f_type = SMB2_MAGIC_NUMBER;
> > + buf->f_type = SMB2_SUPER_MAGIC;
> > SMB2_close(xid, tcon, fid.persistent_fid, fid.volatile_fid);
> > return rc;
> > }
> > diff --git a/include/uapi/linux/magic.h b/include/uapi/linux/magic.h
> > index a3034558b018..9438fd4a79c9 100644
> > --- a/include/uapi/linux/magic.h
> > +++ b/include/uapi/linux/magic.h
> > @@ -53,6 +53,7 @@
> > #define QNX6_SUPER_MAGIC 0x68191122 /* qnx6 fs detection */
> > #define AFS_FS_MAGIC 0x6B414653
> >
> > +
> > #define REISERFS_SUPER_MAGIC 0x52654973 /* used by gcc */
> > /* used by file system utilities that
> > look at the superblock, etc. */
> > @@ -61,6 +62,9 @@
> > #define REISER2FS_JR_SUPER_MAGIC_STRING "ReIsEr3Fs"
> >
> > #define SMB_SUPER_MAGIC 0x517B
> > +#define CIFS_SUPER_MAGIC 0xFF534D42 /* the first four bytes of SMB PDUs */
> > +#define SMB2_SUPER_MAGIC 0xFE534D42
> > +
> > #define CGROUP_SUPER_MAGIC 0x27e0eb
> > #define CGROUP2_SUPER_MAGIC 0x63677270
> >
> > --
> > 2.34.1
> >
>
>

--
Jeff Layton <jlayton@xxxxxxxxxx>