]> git.droids-corp.org - dpdk.git/commitdiff
net/ice: fix null pointer dereferences for tunnels
authorXiaolong Ye <xiaolong.ye@intel.com>
Mon, 5 Aug 2019 09:15:11 +0000 (17:15 +0800)
committerQi Zhang <qi.z.zhang@intel.com>
Tue, 6 Aug 2019 11:09:04 +0000 (13:09 +0200)
This patch fixes two null pointer dereferences in flow code detected by
coverity scan.

Coverity issue: 345815, 345816
Fixes: 94f00800d78b ("net/ice: fix VXLAN/NVGRE flow matching")
Signed-off-by: Xiaolong Ye <xiaolong.ye@intel.com>
Acked-by: Qi Zhang <qi.z.zhang@intel.com>
drivers/net/ice/ice_generic_flow.c

index 5fcf4289cf2db44a33878f3761621a66292a8339..1c0adc779167d6e8cfffd0552f3ba35f567a8518 100644 (file)
@@ -464,7 +464,7 @@ static uint64_t ice_get_flow_field(const struct rte_flow_item pattern[],
                                           "Invalid VXLAN item");
                                return 0;
                        }
-                       if (vxlan_mask->vni[0] == UINT8_MAX &&
+                       if (vxlan_mask && vxlan_mask->vni[0] == UINT8_MAX &&
                                        vxlan_mask->vni[1] == UINT8_MAX &&
                                        vxlan_mask->vni[2] == UINT8_MAX)
                                input_set |= ICE_INSET_TUN_ID;
@@ -486,7 +486,7 @@ static uint64_t ice_get_flow_field(const struct rte_flow_item pattern[],
                                           "Invalid NVGRE item");
                                return 0;
                        }
-                       if (nvgre_mask->tni[0] == UINT8_MAX &&
+                       if (nvgre_mask && nvgre_mask->tni[0] == UINT8_MAX &&
                                        nvgre_mask->tni[1] == UINT8_MAX &&
                                        nvgre_mask->tni[2] == UINT8_MAX)
                                input_set |= ICE_INSET_TUN_ID;