sinfo = (struct smb2_file_standard_info *)rsp->Buffer;
        delete_pending = ksmbd_inode_pending_delete(fp);
 
-       sinfo->AllocationSize = cpu_to_le64(stat.blocks << 9);
-       sinfo->EndOfFile = S_ISDIR(stat.mode) ? 0 : cpu_to_le64(stat.size);
+       if (ksmbd_stream_fd(fp) == false) {
+               sinfo->AllocationSize = cpu_to_le64(stat.blocks << 9);
+               sinfo->EndOfFile = S_ISDIR(stat.mode) ? 0 : cpu_to_le64(stat.size);
+       } else {
+               sinfo->AllocationSize = cpu_to_le64(fp->stream.size);
+               sinfo->EndOfFile = cpu_to_le64(fp->stream.size);
+       }
        sinfo->NumberOfLinks = cpu_to_le32(get_nlink(&stat) - delete_pending);
        sinfo->DeletePending = delete_pending;
        sinfo->Directory = S_ISDIR(stat.mode) ? 1 : 0;
        file_info->ChangeTime = cpu_to_le64(time);
        file_info->Attributes = fp->f_ci->m_fattr;
        file_info->Pad1 = 0;
-       file_info->AllocationSize =
-               cpu_to_le64(stat.blocks << 9);
-       file_info->EndOfFile = S_ISDIR(stat.mode) ? 0 : cpu_to_le64(stat.size);
+       if (ksmbd_stream_fd(fp) == false) {
+               file_info->AllocationSize =
+                       cpu_to_le64(stat.blocks << 9);
+               file_info->EndOfFile = S_ISDIR(stat.mode) ? 0 : cpu_to_le64(stat.size);
+       } else {
+               file_info->AllocationSize = cpu_to_le64(fp->stream.size);
+               file_info->EndOfFile = cpu_to_le64(fp->stream.size);
+       }
        file_info->NumberOfLinks =
                        cpu_to_le32(get_nlink(&stat) - delete_pending);
        file_info->DeletePending = delete_pending;
        file_info->IndexNumber = cpu_to_le64(stat.ino);
        file_info->EASize = 0;
        file_info->AccessFlags = fp->daccess;
-       file_info->CurrentByteOffset = cpu_to_le64(fp->filp->f_pos);
+       if (ksmbd_stream_fd(fp) == false)
+               file_info->CurrentByteOffset = cpu_to_le64(fp->filp->f_pos);
+       else
+               file_info->CurrentByteOffset = cpu_to_le64(fp->stream.pos);
        file_info->Mode = fp->coption;
        file_info->AlignmentRequirement = 0;
        conv_len = smbConvertToUTF16((__le16 *)file_info->FileName, filename,
        time = ksmbd_UnixTimeToNT(stat.ctime);
        file_info->ChangeTime = cpu_to_le64(time);
        file_info->Attributes = fp->f_ci->m_fattr;
-       file_info->AllocationSize = cpu_to_le64(stat.blocks << 9);
-       file_info->EndOfFile = S_ISDIR(stat.mode) ? 0 : cpu_to_le64(stat.size);
+       if (ksmbd_stream_fd(fp) == false) {
+               file_info->AllocationSize = cpu_to_le64(stat.blocks << 9);
+               file_info->EndOfFile = S_ISDIR(stat.mode) ? 0 : cpu_to_le64(stat.size);
+       } else {
+               file_info->AllocationSize = cpu_to_le64(fp->stream.size);
+               file_info->EndOfFile = cpu_to_le64(fp->stream.size);
+       }
        file_info->Reserved = cpu_to_le32(0);
        rsp->OutputBufferLength =
                cpu_to_le32(sizeof(struct smb2_file_ntwrk_info));
        struct smb2_file_pos_info *file_info;
 
        file_info = (struct smb2_file_pos_info *)rsp->Buffer;
-       file_info->CurrentByteOffset = cpu_to_le64(fp->filp->f_pos);
+       if (ksmbd_stream_fd(fp) == false)
+               file_info->CurrentByteOffset = cpu_to_le64(fp->filp->f_pos);
+       else
+               file_info->CurrentByteOffset = cpu_to_le64(fp->stream.pos);
+
        rsp->OutputBufferLength =
                cpu_to_le32(sizeof(struct smb2_file_pos_info));
 }
        file_info->ChangeTime = cpu_to_le64(time);
        file_info->DosAttributes = fp->f_ci->m_fattr;
        file_info->Inode = cpu_to_le64(stat.ino);
-       file_info->EndOfFile = cpu_to_le64(stat.size);
-       file_info->AllocationSize = cpu_to_le64(stat.blocks << 9);
+       if (ksmbd_stream_fd(fp) == false) {
+               file_info->EndOfFile = cpu_to_le64(stat.size);
+               file_info->AllocationSize = cpu_to_le64(stat.blocks << 9);
+       } else {
+               file_info->EndOfFile = cpu_to_le64(fp->stream.size);
+               file_info->AllocationSize = cpu_to_le64(fp->stream.size);
+       }
        file_info->HardLinks = cpu_to_le32(stat.nlink);
        file_info->Mode = cpu_to_le32(stat.mode & 0777);
        switch (stat.mode & S_IFMT) {
        if (!(fp->daccess & FILE_WRITE_DATA_LE))
                return -EACCES;
 
+       if (ksmbd_stream_fd(fp) == true)
+               return 0;
+
        rc = vfs_getattr(&fp->filp->f_path, &stat, STATX_BASIC_STATS,
                         AT_STATX_SYNC_AS_STAT);
        if (rc)
         * truncate of some filesystem like FAT32 fill zero data in
         * truncated range.
         */
-       if (inode->i_sb->s_magic != MSDOS_SUPER_MAGIC) {
+       if (inode->i_sb->s_magic != MSDOS_SUPER_MAGIC &&
+           ksmbd_stream_fd(fp) == false) {
                ksmbd_debug(SMB, "truncated to newsize %lld\n", newsize);
                rc = ksmbd_vfs_truncate(work, fp, newsize);
                if (rc) {
                return -EINVAL;
        }
 
-       fp->filp->f_pos = current_byte_offset;
+       if (ksmbd_stream_fd(fp) == false)
+               fp->filp->f_pos = current_byte_offset;
+       else {
+               if (current_byte_offset > XATTR_SIZE_MAX)
+                       current_byte_offset = XATTR_SIZE_MAX;
+               fp->stream.pos = current_byte_offset;
+       }
        return 0;
 }