net: atlantic: fix the macsec key length

The key length used to store the macsec key was set to MACSEC_KEYID_LEN
(16), which is an issue as:
- This was never meant to be the key length.
- The key length can be > 16.

Fix this by using MACSEC_MAX_KEY_LEN instead (the max length accepted in
uAPI).

Fixes: 27736563ce ("net: atlantic: MACSec egress offload implementation")
Fixes: 9ff40a751a ("net: atlantic: MACSec ingress offload implementation")
Reported-by: Lior Nahmanson <liorna@nvidia.com>
Signed-off-by: Antoine Tenart <atenart@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Antoine Tenart 2021-06-24 11:38:30 +02:00 committed by David S. Miller
parent c309217f91
commit d67fb4772d

View File

@ -91,7 +91,7 @@ struct aq_macsec_txsc {
u32 hw_sc_idx; u32 hw_sc_idx;
unsigned long tx_sa_idx_busy; unsigned long tx_sa_idx_busy;
const struct macsec_secy *sw_secy; const struct macsec_secy *sw_secy;
u8 tx_sa_key[MACSEC_NUM_AN][MACSEC_KEYID_LEN]; u8 tx_sa_key[MACSEC_NUM_AN][MACSEC_MAX_KEY_LEN];
struct aq_macsec_tx_sc_stats stats; struct aq_macsec_tx_sc_stats stats;
struct aq_macsec_tx_sa_stats tx_sa_stats[MACSEC_NUM_AN]; struct aq_macsec_tx_sa_stats tx_sa_stats[MACSEC_NUM_AN];
}; };
@ -101,7 +101,7 @@ struct aq_macsec_rxsc {
unsigned long rx_sa_idx_busy; unsigned long rx_sa_idx_busy;
const struct macsec_secy *sw_secy; const struct macsec_secy *sw_secy;
const struct macsec_rx_sc *sw_rxsc; const struct macsec_rx_sc *sw_rxsc;
u8 rx_sa_key[MACSEC_NUM_AN][MACSEC_KEYID_LEN]; u8 rx_sa_key[MACSEC_NUM_AN][MACSEC_MAX_KEY_LEN];
struct aq_macsec_rx_sa_stats rx_sa_stats[MACSEC_NUM_AN]; struct aq_macsec_rx_sa_stats rx_sa_stats[MACSEC_NUM_AN];
}; };