struct hwrm_fwd_resp_input req = {0};
        struct hwrm_fwd_resp_output *resp = bp->hwrm_cmd_resp_addr;
 
+       if (BNXT_FWD_RESP_SIZE_ERR(msg_size))
+               return -EINVAL;
+
        bnxt_hwrm_cmd_hdr_init(bp, &req, HWRM_FWD_RESP, -1, -1);
 
        /* Set the new target id */
        struct hwrm_reject_fwd_resp_input req = {0};
        struct hwrm_reject_fwd_resp_output *resp = bp->hwrm_cmd_resp_addr;
 
+       if (BNXT_REJ_FWD_RESP_SIZE_ERR(msg_size))
+               return -EINVAL;
+
        bnxt_hwrm_cmd_hdr_init(bp, &req, HWRM_REJECT_FWD_RESP, -1, -1);
        /* Set the new target id */
        req.target_id = cpu_to_le16(vf->fw_fid);
        struct hwrm_exec_fwd_resp_input req = {0};
        struct hwrm_exec_fwd_resp_output *resp = bp->hwrm_cmd_resp_addr;
 
+       if (BNXT_EXEC_FWD_RESP_SIZE_ERR(msg_size))
+               return -EINVAL;
+
        bnxt_hwrm_cmd_hdr_init(bp, &req, HWRM_EXEC_FWD_RESP, -1, -1);
        /* Set the new target id */
        req.target_id = cpu_to_le16(vf->fw_fid);
 
 #ifndef BNXT_SRIOV_H
 #define BNXT_SRIOV_H
 
+#define BNXT_FWD_RESP_SIZE_ERR(n)                                      \
+       ((offsetof(struct hwrm_fwd_resp_input, encap_resp) + n) >       \
+        sizeof(struct hwrm_fwd_resp_input))
+
+#define BNXT_EXEC_FWD_RESP_SIZE_ERR(n)                                 \
+       ((offsetof(struct hwrm_exec_fwd_resp_input, encap_request) + n) >\
+        offsetof(struct hwrm_exec_fwd_resp_input, encap_resp_target_id))
+
+#define BNXT_REJ_FWD_RESP_SIZE_ERR(n)                                  \
+       ((offsetof(struct hwrm_reject_fwd_resp_input, encap_request) + n) >\
+        offsetof(struct hwrm_reject_fwd_resp_input, encap_resp_target_id))
+
 int bnxt_get_vf_config(struct net_device *, int, struct ifla_vf_info *);
 int bnxt_set_vf_mac(struct net_device *, int, u8 *);
 int bnxt_set_vf_vlan(struct net_device *, int, u16, u8, __be16);