common/sfc_efx/base: limit reported MCDI response length
authorAndy Moreton <amoreton@xilinx.com>
Tue, 18 May 2021 15:10:11 +0000 (18:10 +0300)
committerFerruh Yigit <ferruh.yigit@intel.com>
Wed, 19 May 2021 09:32:49 +0000 (11:32 +0200)
MCDI helper routines in libefx include length checks for response
messages, to ensure that short replies and optional fields are
handled correctly.

If the MCDI response message from the firmware is larger than the
caller's buffer then the response length reported to the caller
should be limited to the buffer size. Otherwise length checks in
the caller may allow reading past the end of the buffer.

Fixes: 6f619653b9b1 ("net/sfc/base: import MCDI implementation")
Cc: stable@dpdk.org
Signed-off-by: Andy Moreton <amoreton@xilinx.com>
Signed-off-by: Ivan Malov <ivan.malov@oktetlabs.ru>
Reviewed-by: Andrew Rybchenko <andrew.rybchenko@oktetlabs.ru>
drivers/common/sfc_efx/base/efx_mcdi.c

index ff676f8..f4e1384 100644 (file)
@@ -516,6 +516,9 @@ efx_mcdi_finish_response(
        bytes = MIN(emrp->emr_out_length_used, emrp->emr_out_length);
        efx_mcdi_read_response(enp, emrp->emr_out_buf, resp_off, bytes);
 
+       /* Report bytes copied to caller (response message may be larger) */
+       emrp->emr_out_length_used = bytes;
+
 #if EFSYS_OPT_MCDI_LOGGING
        if (emtp->emt_logger != NULL) {
                emtp->emt_logger(emtp->emt_context,