aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/sfc/falcon.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/sfc/falcon.c')
-rw-r--r--drivers/net/sfc/falcon.c30
1 files changed, 12 insertions, 18 deletions
diff --git a/drivers/net/sfc/falcon.c b/drivers/net/sfc/falcon.c
index 7b1c387ff8ef..96cb5d031ed7 100644
--- a/drivers/net/sfc/falcon.c
+++ b/drivers/net/sfc/falcon.c
@@ -952,10 +952,10 @@ static void falcon_handle_rx_bad_index(struct efx_rx_queue *rx_queue,
952 * Also "is multicast" and "matches multicast filter" flags can be used to 952 * Also "is multicast" and "matches multicast filter" flags can be used to
953 * discard non-matching multicast packets. 953 * discard non-matching multicast packets.
954 */ 954 */
955static int falcon_handle_rx_event(struct efx_channel *channel, 955static void falcon_handle_rx_event(struct efx_channel *channel,
956 const efx_qword_t *event) 956 const efx_qword_t *event)
957{ 957{
958 unsigned int rx_ev_q_label, rx_ev_desc_ptr, rx_ev_byte_cnt; 958 unsigned int rx_ev_desc_ptr, rx_ev_byte_cnt;
959 unsigned int rx_ev_hdr_type, rx_ev_mcast_pkt; 959 unsigned int rx_ev_hdr_type, rx_ev_mcast_pkt;
960 unsigned expected_ptr; 960 unsigned expected_ptr;
961 bool rx_ev_pkt_ok, discard = false, checksummed; 961 bool rx_ev_pkt_ok, discard = false, checksummed;
@@ -968,16 +968,14 @@ static int falcon_handle_rx_event(struct efx_channel *channel,
968 rx_ev_hdr_type = EFX_QWORD_FIELD(*event, RX_EV_HDR_TYPE); 968 rx_ev_hdr_type = EFX_QWORD_FIELD(*event, RX_EV_HDR_TYPE);
969 WARN_ON(EFX_QWORD_FIELD(*event, RX_EV_JUMBO_CONT)); 969 WARN_ON(EFX_QWORD_FIELD(*event, RX_EV_JUMBO_CONT));
970 WARN_ON(EFX_QWORD_FIELD(*event, RX_EV_SOP) != 1); 970 WARN_ON(EFX_QWORD_FIELD(*event, RX_EV_SOP) != 1);
971 WARN_ON(EFX_QWORD_FIELD(*event, RX_EV_Q_LABEL) != channel->channel);
971 972
972 rx_ev_q_label = EFX_QWORD_FIELD(*event, RX_EV_Q_LABEL); 973 rx_queue = &efx->rx_queue[channel->channel];
973 rx_queue = &efx->rx_queue[rx_ev_q_label];
974 974
975 rx_ev_desc_ptr = EFX_QWORD_FIELD(*event, RX_EV_DESC_PTR); 975 rx_ev_desc_ptr = EFX_QWORD_FIELD(*event, RX_EV_DESC_PTR);
976 expected_ptr = rx_queue->removed_count & FALCON_RXD_RING_MASK; 976 expected_ptr = rx_queue->removed_count & FALCON_RXD_RING_MASK;
977 if (unlikely(rx_ev_desc_ptr != expected_ptr)) { 977 if (unlikely(rx_ev_desc_ptr != expected_ptr))
978 falcon_handle_rx_bad_index(rx_queue, rx_ev_desc_ptr); 978 falcon_handle_rx_bad_index(rx_queue, rx_ev_desc_ptr);
979 return rx_ev_q_label;
980 }
981 979
982 if (likely(rx_ev_pkt_ok)) { 980 if (likely(rx_ev_pkt_ok)) {
983 /* If packet is marked as OK and packet type is TCP/IPv4 or 981 /* If packet is marked as OK and packet type is TCP/IPv4 or
@@ -1003,8 +1001,6 @@ static int falcon_handle_rx_event(struct efx_channel *channel,
1003 /* Handle received packet */ 1001 /* Handle received packet */
1004 efx_rx_packet(rx_queue, rx_ev_desc_ptr, rx_ev_byte_cnt, 1002 efx_rx_packet(rx_queue, rx_ev_desc_ptr, rx_ev_byte_cnt,
1005 checksummed, discard); 1003 checksummed, discard);
1006
1007 return rx_ev_q_label;
1008} 1004}
1009 1005
1010/* Global events are basically PHY events */ 1006/* Global events are basically PHY events */
@@ -1109,13 +1105,12 @@ static void falcon_handle_driver_event(struct efx_channel *channel,
1109 } 1105 }
1110} 1106}
1111 1107
1112int falcon_process_eventq(struct efx_channel *channel, int *rx_quota) 1108int falcon_process_eventq(struct efx_channel *channel, int rx_quota)
1113{ 1109{
1114 unsigned int read_ptr; 1110 unsigned int read_ptr;
1115 efx_qword_t event, *p_event; 1111 efx_qword_t event, *p_event;
1116 int ev_code; 1112 int ev_code;
1117 int rxq; 1113 int rx_packets = 0;
1118 int rxdmaqs = 0;
1119 1114
1120 read_ptr = channel->eventq_read_ptr; 1115 read_ptr = channel->eventq_read_ptr;
1121 1116
@@ -1137,9 +1132,8 @@ int falcon_process_eventq(struct efx_channel *channel, int *rx_quota)
1137 1132
1138 switch (ev_code) { 1133 switch (ev_code) {
1139 case RX_IP_EV_DECODE: 1134 case RX_IP_EV_DECODE:
1140 rxq = falcon_handle_rx_event(channel, &event); 1135 falcon_handle_rx_event(channel, &event);
1141 rxdmaqs |= (1 << rxq); 1136 ++rx_packets;
1142 (*rx_quota)--;
1143 break; 1137 break;
1144 case TX_IP_EV_DECODE: 1138 case TX_IP_EV_DECODE:
1145 falcon_handle_tx_event(channel, &event); 1139 falcon_handle_tx_event(channel, &event);
@@ -1166,10 +1160,10 @@ int falcon_process_eventq(struct efx_channel *channel, int *rx_quota)
1166 /* Increment read pointer */ 1160 /* Increment read pointer */
1167 read_ptr = (read_ptr + 1) & FALCON_EVQ_MASK; 1161 read_ptr = (read_ptr + 1) & FALCON_EVQ_MASK;
1168 1162
1169 } while (*rx_quota); 1163 } while (rx_packets < rx_quota);
1170 1164
1171 channel->eventq_read_ptr = read_ptr; 1165 channel->eventq_read_ptr = read_ptr;
1172 return rxdmaqs; 1166 return rx_packets;
1173} 1167}
1174 1168
1175void falcon_set_int_moderation(struct efx_channel *channel) 1169void falcon_set_int_moderation(struct efx_channel *channel)