]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
cifs: Put explicit zero byte into SFU block/char types
authorPali Rohár <pali@kernel.org>
Thu, 12 Sep 2024 12:05:44 +0000 (14:05 +0200)
committerSteve French <stfrench@microsoft.com>
Sun, 15 Sep 2024 15:42:45 +0000 (10:42 -0500)
SFU types IntxCHR and IntxBLK are 8 bytes with zero as last byte. Make it
explicit in memcpy and memset calls, so the zero byte is visible in the
code (and not hidden as string trailing nul byte).

It is important for reader to show the last byte for block and char types
because it differs from the last byte of symlink type (which has it 0x01).

Also it is important to show that the type is not nul-term string, but
rather 8 bytes (with some printable bytes).

Signed-off-by: Pali Rohár <pali@kernel.org>
Signed-off-by: Steve French <stfrench@microsoft.com>
fs/smb/client/inode.c
fs/smb/client/smb2ops.c

index e8567ed63f223275117c14ee0c3f04ade1b98847..d8c39989840e20c942fc800c6fd1569e6d606404 100644 (file)
@@ -586,7 +586,7 @@ cifs_sfu_type(struct cifs_fattr *fattr, const char *path,
        rc = tcon->ses->server->ops->sync_read(xid, &fid, &io_parms,
                                        &bytes_read, &pbuf, &buf_type);
        if ((rc == 0) && (bytes_read >= 8)) {
-               if (memcmp("IntxBLK", pbuf, 8) == 0) {
+               if (memcmp("IntxBLK\0", pbuf, 8) == 0) {
                        cifs_dbg(FYI, "Block device\n");
                        fattr->cf_mode |= S_IFBLK;
                        fattr->cf_dtype = DT_BLK;
@@ -598,7 +598,7 @@ cifs_sfu_type(struct cifs_fattr *fattr, const char *path,
                                mnr = le64_to_cpu(*(__le64 *)(pbuf+16));
                                fattr->cf_rdev = MKDEV(mjr, mnr);
                        }
-               } else if (memcmp("IntxCHR", pbuf, 8) == 0) {
+               } else if (memcmp("IntxCHR\0", pbuf, 8) == 0) {
                        cifs_dbg(FYI, "Char device\n");
                        fattr->cf_mode |= S_IFCHR;
                        fattr->cf_dtype = DT_CHR;
index 5f562d21267191a74f8f6bd60bdcf14a908bdb63..a5174bf41e51491478578232a0d6c73b172f3794 100644 (file)
@@ -5072,12 +5072,12 @@ static int __cifs_sfu_make_node(unsigned int xid, struct inode *inode,
 
        switch (mode & S_IFMT) {
        case S_IFCHR:
-               strscpy(pdev.type, "IntxCHR");
+               memcpy(pdev.type, "IntxCHR\0", 8);
                pdev.major = cpu_to_le64(MAJOR(dev));
                pdev.minor = cpu_to_le64(MINOR(dev));
                break;
        case S_IFBLK:
-               strscpy(pdev.type, "IntxBLK");
+               memcpy(pdev.type, "IntxBLK\0", 8);
                pdev.major = cpu_to_le64(MAJOR(dev));
                pdev.minor = cpu_to_le64(MINOR(dev));
                break;