Commit e0eb625a authored by David S. Miller's avatar David S. Miller

Merge branch 'ena-updates'

Shay Agroskin says:

====================
se build_skb and reorganize some code in ENA

this patchset introduces several changes:

- Use build_skb() on RX side.
  This allows to ensure that the headers are in the linear part

- Batch some code into functions and remove some of the code to make it more
  readable and less error prone

- Fix RST format and outdated description in ENA documentation

- Improve cache alignment in the code
====================
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents fa6d61e9 a01f2cd0
...@@ -1042,8 +1042,6 @@ enum ena_admin_aenq_group { ...@@ -1042,8 +1042,6 @@ enum ena_admin_aenq_group {
}; };
enum ena_admin_aenq_notification_syndrome { enum ena_admin_aenq_notification_syndrome {
ENA_ADMIN_SUSPEND = 0,
ENA_ADMIN_RESUME = 1,
ENA_ADMIN_UPDATE_HINTS = 2, ENA_ADMIN_UPDATE_HINTS = 2,
}; };
......
...@@ -1979,7 +1979,8 @@ int ena_com_get_dev_attr_feat(struct ena_com_dev *ena_dev, ...@@ -1979,7 +1979,8 @@ int ena_com_get_dev_attr_feat(struct ena_com_dev *ena_dev,
if (rc) if (rc)
return rc; return rc;
if (get_resp.u.max_queue_ext.version != ENA_FEATURE_MAX_QUEUE_EXT_VER) if (get_resp.u.max_queue_ext.version !=
ENA_FEATURE_MAX_QUEUE_EXT_VER)
return -EINVAL; return -EINVAL;
memcpy(&get_feat_ctx->max_queue_ext, &get_resp.u.max_queue_ext, memcpy(&get_feat_ctx->max_queue_ext, &get_resp.u.max_queue_ext,
......
...@@ -151,11 +151,14 @@ static int ena_com_close_bounce_buffer(struct ena_com_io_sq *io_sq) ...@@ -151,11 +151,14 @@ static int ena_com_close_bounce_buffer(struct ena_com_io_sq *io_sq)
return 0; return 0;
/* bounce buffer was used, so write it and get a new one */ /* bounce buffer was used, so write it and get a new one */
if (pkt_ctrl->idx) { if (likely(pkt_ctrl->idx)) {
rc = ena_com_write_bounce_buffer_to_dev(io_sq, rc = ena_com_write_bounce_buffer_to_dev(io_sq,
pkt_ctrl->curr_bounce_buf); pkt_ctrl->curr_bounce_buf);
if (unlikely(rc)) if (unlikely(rc)) {
netdev_err(ena_com_io_sq_to_ena_dev(io_sq)->net_device,
"Failed to write bounce buffer to device\n");
return rc; return rc;
}
pkt_ctrl->curr_bounce_buf = pkt_ctrl->curr_bounce_buf =
ena_com_get_next_bounce_buffer(&io_sq->bounce_buf_ctrl); ena_com_get_next_bounce_buffer(&io_sq->bounce_buf_ctrl);
...@@ -185,8 +188,11 @@ static int ena_com_sq_update_llq_tail(struct ena_com_io_sq *io_sq) ...@@ -185,8 +188,11 @@ static int ena_com_sq_update_llq_tail(struct ena_com_io_sq *io_sq)
if (!pkt_ctrl->descs_left_in_line) { if (!pkt_ctrl->descs_left_in_line) {
rc = ena_com_write_bounce_buffer_to_dev(io_sq, rc = ena_com_write_bounce_buffer_to_dev(io_sq,
pkt_ctrl->curr_bounce_buf); pkt_ctrl->curr_bounce_buf);
if (unlikely(rc)) if (unlikely(rc)) {
netdev_err(ena_com_io_sq_to_ena_dev(io_sq)->net_device,
"Failed to write bounce buffer to device\n");
return rc; return rc;
}
pkt_ctrl->curr_bounce_buf = pkt_ctrl->curr_bounce_buf =
ena_com_get_next_bounce_buffer(&io_sq->bounce_buf_ctrl); ena_com_get_next_bounce_buffer(&io_sq->bounce_buf_ctrl);
...@@ -406,8 +412,11 @@ int ena_com_prepare_tx(struct ena_com_io_sq *io_sq, ...@@ -406,8 +412,11 @@ int ena_com_prepare_tx(struct ena_com_io_sq *io_sq,
} }
if (unlikely(io_sq->mem_queue_type == ENA_ADMIN_PLACEMENT_POLICY_DEV && if (unlikely(io_sq->mem_queue_type == ENA_ADMIN_PLACEMENT_POLICY_DEV &&
!buffer_to_push)) !buffer_to_push)) {
netdev_err(ena_com_io_sq_to_ena_dev(io_sq)->net_device,
"Push header wasn't provided in LLQ mode\n");
return -EINVAL; return -EINVAL;
}
rc = ena_com_write_header_to_bounce(io_sq, buffer_to_push, header_len); rc = ena_com_write_header_to_bounce(io_sq, buffer_to_push, header_len);
if (unlikely(rc)) if (unlikely(rc))
...@@ -423,6 +432,9 @@ int ena_com_prepare_tx(struct ena_com_io_sq *io_sq, ...@@ -423,6 +432,9 @@ int ena_com_prepare_tx(struct ena_com_io_sq *io_sq,
/* If the caller doesn't want to send packets */ /* If the caller doesn't want to send packets */
if (unlikely(!num_bufs && !header_len)) { if (unlikely(!num_bufs && !header_len)) {
rc = ena_com_close_bounce_buffer(io_sq); rc = ena_com_close_bounce_buffer(io_sq);
if (rc)
netdev_err(ena_com_io_sq_to_ena_dev(io_sq)->net_device,
"Failed to write buffers to LLQ\n");
*nb_hw_desc = io_sq->tail - start_tail; *nb_hw_desc = io_sq->tail - start_tail;
return rc; return rc;
} }
...@@ -482,8 +494,11 @@ int ena_com_prepare_tx(struct ena_com_io_sq *io_sq, ...@@ -482,8 +494,11 @@ int ena_com_prepare_tx(struct ena_com_io_sq *io_sq,
/* The first desc share the same desc as the header */ /* The first desc share the same desc as the header */
if (likely(i != 0)) { if (likely(i != 0)) {
rc = ena_com_sq_update_tail(io_sq); rc = ena_com_sq_update_tail(io_sq);
if (unlikely(rc)) if (unlikely(rc)) {
netdev_err(ena_com_io_sq_to_ena_dev(io_sq)->net_device,
"Failed to update sq tail\n");
return rc; return rc;
}
desc = get_sq_desc(io_sq); desc = get_sq_desc(io_sq);
if (unlikely(!desc)) if (unlikely(!desc))
...@@ -512,8 +527,11 @@ int ena_com_prepare_tx(struct ena_com_io_sq *io_sq, ...@@ -512,8 +527,11 @@ int ena_com_prepare_tx(struct ena_com_io_sq *io_sq,
desc->len_ctrl |= ENA_ETH_IO_TX_DESC_LAST_MASK; desc->len_ctrl |= ENA_ETH_IO_TX_DESC_LAST_MASK;
rc = ena_com_sq_update_tail(io_sq); rc = ena_com_sq_update_tail(io_sq);
if (unlikely(rc)) if (unlikely(rc)) {
netdev_err(ena_com_io_sq_to_ena_dev(io_sq)->net_device,
"Failed to update sq tail of the last descriptor\n");
return rc; return rc;
}
rc = ena_com_close_bounce_buffer(io_sq); rc = ena_com_close_bounce_buffer(io_sq);
......
...@@ -233,10 +233,13 @@ int ena_get_sset_count(struct net_device *netdev, int sset) ...@@ -233,10 +233,13 @@ int ena_get_sset_count(struct net_device *netdev, int sset)
{ {
struct ena_adapter *adapter = netdev_priv(netdev); struct ena_adapter *adapter = netdev_priv(netdev);
if (sset != ETH_SS_STATS) switch (sset) {
return -EOPNOTSUPP; case ETH_SS_STATS:
return ena_get_sw_stats_count(adapter) +
ena_get_hw_stats_count(adapter);
}
return ena_get_sw_stats_count(adapter) + ena_get_hw_stats_count(adapter); return -EOPNOTSUPP;
} }
static void ena_queue_strings(struct ena_adapter *adapter, u8 **data) static void ena_queue_strings(struct ena_adapter *adapter, u8 **data)
...@@ -314,10 +317,11 @@ static void ena_get_ethtool_strings(struct net_device *netdev, ...@@ -314,10 +317,11 @@ static void ena_get_ethtool_strings(struct net_device *netdev,
{ {
struct ena_adapter *adapter = netdev_priv(netdev); struct ena_adapter *adapter = netdev_priv(netdev);
if (sset != ETH_SS_STATS) switch (sset) {
return; case ETH_SS_STATS:
ena_get_strings(adapter, data, adapter->eni_stats_supported);
ena_get_strings(adapter, data, adapter->eni_stats_supported); break;
}
} }
static int ena_get_link_ksettings(struct net_device *netdev, static int ena_get_link_ksettings(struct net_device *netdev,
......
...@@ -55,12 +55,6 @@ ...@@ -55,12 +55,6 @@
#define ENA_TX_WAKEUP_THRESH (MAX_SKB_FRAGS + 2) #define ENA_TX_WAKEUP_THRESH (MAX_SKB_FRAGS + 2)
#define ENA_DEFAULT_RX_COPYBREAK (256 - NET_IP_ALIGN) #define ENA_DEFAULT_RX_COPYBREAK (256 - NET_IP_ALIGN)
/* limit the buffer size to 600 bytes to handle MTU changes from very
* small to very large, in which case the number of buffers per packet
* could exceed ENA_PKT_MAX_BUFS
*/
#define ENA_DEFAULT_MIN_RX_BUFF_ALLOC_SIZE 600
#define ENA_MIN_MTU 128 #define ENA_MIN_MTU 128
#define ENA_NAME_MAX_LEN 20 #define ENA_NAME_MAX_LEN 20
...@@ -135,12 +129,12 @@ struct ena_irq { ...@@ -135,12 +129,12 @@ struct ena_irq {
}; };
struct ena_napi { struct ena_napi {
struct napi_struct napi ____cacheline_aligned; u8 first_interrupt ____cacheline_aligned;
u8 interrupts_masked;
struct napi_struct napi;
struct ena_ring *tx_ring; struct ena_ring *tx_ring;
struct ena_ring *rx_ring; struct ena_ring *rx_ring;
struct ena_ring *xdp_ring; struct ena_ring *xdp_ring;
bool first_interrupt;
bool interrupts_masked;
u32 qid; u32 qid;
struct dim dim; struct dim dim;
}; };
...@@ -212,6 +206,7 @@ struct ena_stats_tx { ...@@ -212,6 +206,7 @@ struct ena_stats_tx {
u64 llq_buffer_copy; u64 llq_buffer_copy;
u64 missed_tx; u64 missed_tx;
u64 unmask_interrupt; u64 unmask_interrupt;
u64 last_napi_jiffies;
}; };
struct ena_stats_rx { struct ena_stats_rx {
...@@ -259,6 +254,10 @@ struct ena_ring { ...@@ -259,6 +254,10 @@ struct ena_ring {
struct bpf_prog *xdp_bpf_prog; struct bpf_prog *xdp_bpf_prog;
struct xdp_rxq_info xdp_rxq; struct xdp_rxq_info xdp_rxq;
spinlock_t xdp_tx_lock; /* synchronize XDP TX/Redirect traffic */ spinlock_t xdp_tx_lock; /* synchronize XDP TX/Redirect traffic */
/* Used for rx queues only to point to the xdp tx ring, to
* which traffic should be redirected from this rx ring.
*/
struct ena_ring *xdp_ring;
u16 next_to_use; u16 next_to_use;
u16 next_to_clean; u16 next_to_clean;
...@@ -271,7 +270,6 @@ struct ena_ring { ...@@ -271,7 +270,6 @@ struct ena_ring {
/* The maximum header length the device can handle */ /* The maximum header length the device can handle */
u8 tx_max_header_size; u8 tx_max_header_size;
bool first_interrupt;
bool disable_meta_caching; bool disable_meta_caching;
u16 no_interrupt_event_cnt; u16 no_interrupt_event_cnt;
...@@ -414,11 +412,6 @@ enum ena_xdp_errors_t { ...@@ -414,11 +412,6 @@ enum ena_xdp_errors_t {
ENA_XDP_NO_ENOUGH_QUEUES, ENA_XDP_NO_ENOUGH_QUEUES,
}; };
static inline bool ena_xdp_queues_present(struct ena_adapter *adapter)
{
return adapter->xdp_first_ring != 0;
}
static inline bool ena_xdp_present(struct ena_adapter *adapter) static inline bool ena_xdp_present(struct ena_adapter *adapter)
{ {
return !!adapter->xdp_bpf_prog; return !!adapter->xdp_bpf_prog;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment