[dpdk-dev,v2] examples/l2fwd: check if user portmask is valid
Checks
Commit Message
User can pass portmask with any value, even invalid mask. The code
checks against actual portmask.
Signed-off-by: Vipin Varghese <vipin.varghese@intel.com>
---
V2 Changes:
- correct the spelling in comment - Vipin
---
examples/l2fwd/main.c | 5 +++++
1 file changed, 5 insertions(+)
Comments
> -----Original Message-----
> From: Varghese, Vipin
> Sent: Thursday, February 1, 2018 6:59 PM
> To: dev@dpdk.org
> Cc: stable@dpdk.org; De Lara Guarch, Pablo
> <pablo.de.lara.guarch@intel.com>; Richardson, Bruce
> <bruce.richardson@intel.com>; Varghese, Vipin
> <vipin.varghese@intel.com>
> Subject: [PATCH v2] examples/l2fwd: check if user portmask is valid
>
> User can pass portmask with any value, even invalid mask. The code checks
> against actual portmask.
>
> Signed-off-by: Vipin Varghese <vipin.varghese@intel.com>
> ---
>
> V2 Changes:
> - correct the spelling in comment - Vipin
I think there is no need to CC stable here, so I will remove it from the list.
Acked-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
> > User can pass portmask with any value, even invalid mask. The code checks
> > against actual portmask.
> >
> > Signed-off-by: Vipin Varghese <vipin.varghese@intel.com>
> > ---
> >
> > V2 Changes:
> > - correct the spelling in comment - Vipin
>
> I think there is no need to CC stable here, so I will remove it from the list.
>
> Acked-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Applied, thanks
@@ -549,6 +549,11 @@ enum {
if (nb_ports == 0)
rte_exit(EXIT_FAILURE, "No Ethernet ports - bye\n");
+ /* check port mask to possible port mask */
+ if (l2fwd_enabled_port_mask & ~((1 << nb_ports) - 1))
+ rte_exit(EXIT_FAILURE, "Invalid portmask; possible (0x%x)\n",
+ (1 << nb_ports) - 1);
+
/* reset l2fwd_dst_ports */
for (portid = 0; portid < RTE_MAX_ETHPORTS; portid++)
l2fwd_dst_ports[portid] = 0;