diff options
| author | Chen-Yu Tsai <wens@csie.org> | 2025-07-15 23:34:10 +0800 | 
|---|---|---|
| committer | Chen-Yu Tsai <wens@csie.org> | 2025-07-15 23:34:10 +0800 | 
| commit | ca5ad734d30f30a577f705926d6e16a87513a2a7 (patch) | |
| tree | b5fb169a86ac59892bd3b60c2df13e8a7cef360d /drivers/net/macsec.c | |
| parent | 082c6a2d06c0831d236760a29953355845eee988 (diff) | |
| parent | f99d4fccd2185176baf4ecac9a49d280fc62b953 (diff) | |
Merge branch 'dt' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/linux-pm into sunxi/dt-for-6.17
Signed-off-by: Chen-Yu Tsai <wens@csie.org>
Diffstat (limited to 'drivers/net/macsec.c')
| -rw-r--r-- | drivers/net/macsec.c | 40 | 
1 files changed, 34 insertions, 6 deletions
| diff --git a/drivers/net/macsec.c b/drivers/net/macsec.c index 3d315e30ee47..7edbe76b5455 100644 --- a/drivers/net/macsec.c +++ b/drivers/net/macsec.c @@ -247,15 +247,39 @@ static sci_t make_sci(const u8 *addr, __be16 port)  	return sci;  } -static sci_t macsec_frame_sci(struct macsec_eth_header *hdr, bool sci_present) +static sci_t macsec_active_sci(struct macsec_secy *secy)  { -	sci_t sci; +	struct macsec_rx_sc *rx_sc = rcu_dereference_bh(secy->rx_sc); + +	/* Case single RX SC */ +	if (rx_sc && !rcu_dereference_bh(rx_sc->next)) +		return (rx_sc->active) ? rx_sc->sci : 0; +	/* Case no RX SC or multiple */ +	else +		return 0; +} + +static sci_t macsec_frame_sci(struct macsec_eth_header *hdr, bool sci_present, +			      struct macsec_rxh_data *rxd) +{ +	struct macsec_dev *macsec; +	sci_t sci = 0; -	if (sci_present) +	/* SC = 1 */ +	if (sci_present) {  		memcpy(&sci, hdr->secure_channel_id,  		       sizeof(hdr->secure_channel_id)); -	else +	/* SC = 0; ES = 0 */ +	} else if ((!(hdr->tci_an & (MACSEC_TCI_ES | MACSEC_TCI_SC))) && +		   (list_is_singular(&rxd->secys))) { +		/* Only one SECY should exist on this scenario */ +		macsec = list_first_or_null_rcu(&rxd->secys, struct macsec_dev, +						secys); +		if (macsec) +			return macsec_active_sci(&macsec->secy); +	} else {  		sci = make_sci(hdr->eth.h_source, MACSEC_PORT_ES); +	}  	return sci;  } @@ -1109,7 +1133,7 @@ static rx_handler_result_t macsec_handle_frame(struct sk_buff **pskb)  	struct macsec_rxh_data *rxd;  	struct macsec_dev *macsec;  	unsigned int len; -	sci_t sci; +	sci_t sci = 0;  	u32 hdr_pn;  	bool cbit;  	struct pcpu_rx_sc_stats *rxsc_stats; @@ -1156,11 +1180,14 @@ static rx_handler_result_t macsec_handle_frame(struct sk_buff **pskb)  	macsec_skb_cb(skb)->has_sci = !!(hdr->tci_an & MACSEC_TCI_SC);  	macsec_skb_cb(skb)->assoc_num = hdr->tci_an & MACSEC_AN_MASK; -	sci = macsec_frame_sci(hdr, macsec_skb_cb(skb)->has_sci);  	rcu_read_lock();  	rxd = macsec_data_rcu(skb->dev); +	sci = macsec_frame_sci(hdr, macsec_skb_cb(skb)->has_sci, rxd); +	if (!sci) +		goto drop_nosc; +  	list_for_each_entry_rcu(macsec, &rxd->secys, secys) {  		struct macsec_rx_sc *sc = find_rx_sc(&macsec->secy, sci); @@ -1283,6 +1310,7 @@ drop:  	macsec_rxsa_put(rx_sa);  drop_nosa:  	macsec_rxsc_put(rx_sc); +drop_nosc:  	rcu_read_unlock();  drop_direct:  	kfree_skb(skb); | 
