blob: 7c1f2750de7eff72964b0ee12bbbbb47aa74283f [file] [log] [blame]
From 9b4db2713a0cabb9805c2e0770ac5e886e14d8cc Mon Sep 17 00:00:00 2001
From: Colin Ian King <>
Date: Thu, 12 Mar 2020 15:04:30 +0000
Subject: [PATCH] net: systemport: fix index check to avoid an array out of
bounds access
commit c0368595c1639947839c0db8294ee96aca0b3b86 upstream.
Currently the bounds check on index is off by one and can lead to
an out of bounds access on array priv->filters_loc when index is
Fixes: bb9051a2b230 ("net: systemport: Add support for WAKE_FILTER")
Signed-off-by: Colin Ian King <>
Signed-off-by: David S. Miller <>
Signed-off-by: Paul Gortmaker <>
diff --git a/drivers/net/ethernet/broadcom/bcmsysport.c b/drivers/net/ethernet/broadcom/bcmsysport.c
index 16dfbd104925..58b207770d34 100644
--- a/drivers/net/ethernet/broadcom/bcmsysport.c
+++ b/drivers/net/ethernet/broadcom/bcmsysport.c
@@ -2136,7 +2136,7 @@ static int bcm_sysport_rule_set(struct bcm_sysport_priv *priv,
return -ENOSPC;
index = find_first_zero_bit(priv->filters, RXCHK_BRCM_TAG_MAX);
- if (index > RXCHK_BRCM_TAG_MAX)
+ if (index >= RXCHK_BRCM_TAG_MAX)
return -ENOSPC;
/* Location is the classification ID, and index is the position