char *data_end;
        struct dfs_referral_level_3 *ref;
 
+       if (rsp_size < sizeof(*rsp)) {
+               cifs_dbg(VFS | ONCE,
+                        "%s: header is malformed (size is %u, must be %zu)\n",
+                        __func__, rsp_size, sizeof(*rsp));
+               rc = -EINVAL;
+               goto parse_DFS_referrals_exit;
+       }
+
        *num_of_nodes = le16_to_cpu(rsp->NumberOfReferrals);
 
        if (*num_of_nodes < 1) {
                goto parse_DFS_referrals_exit;
        }
 
+       if (sizeof(*rsp) + *num_of_nodes * sizeof(REFERRAL3) > rsp_size) {
+               cifs_dbg(VFS | ONCE,
+                        "%s: malformed buffer (size is %u, must be at least %zu)\n",
+                        __func__, rsp_size,
+                        sizeof(*rsp) + *num_of_nodes * sizeof(REFERRAL3));
+               rc = -EINVAL;
+               goto parse_DFS_referrals_exit;
+       }
+
        ref = (struct dfs_referral_level_3 *) &(rsp->referrals);
        if (ref->VersionNumber != cpu_to_le16(3)) {
                cifs_dbg(VFS, "Referrals of V%d version are not supported, should be V3\n",