|
@@ -1181,13 +1181,6 @@ int mlx4_en_poll_rx_cq(struct napi_struct *napi, int budget)
|
|
|
return done;
|
|
|
}
|
|
|
|
|
|
-static const int frag_sizes[] = {
|
|
|
- FRAG_SZ0,
|
|
|
- FRAG_SZ1,
|
|
|
- FRAG_SZ2,
|
|
|
- FRAG_SZ3
|
|
|
-};
|
|
|
-
|
|
|
void mlx4_en_calc_rx_buf(struct net_device *dev)
|
|
|
{
|
|
|
struct mlx4_en_priv *priv = netdev_priv(dev);
|
|
@@ -1211,13 +1204,16 @@ void mlx4_en_calc_rx_buf(struct net_device *dev)
|
|
|
int buf_size = 0;
|
|
|
|
|
|
while (buf_size < eff_mtu) {
|
|
|
- priv->frag_info[i].frag_size =
|
|
|
- (eff_mtu > buf_size + frag_sizes[i]) ?
|
|
|
- frag_sizes[i] : eff_mtu - buf_size;
|
|
|
- priv->frag_info[i].frag_stride =
|
|
|
- ALIGN(priv->frag_info[i].frag_size,
|
|
|
- SMP_CACHE_BYTES);
|
|
|
- buf_size += priv->frag_info[i].frag_size;
|
|
|
+ int frag_size = eff_mtu - buf_size;
|
|
|
+
|
|
|
+ if (i < MLX4_EN_MAX_RX_FRAGS - 1)
|
|
|
+ frag_size = min(frag_size, 2048);
|
|
|
+
|
|
|
+ priv->frag_info[i].frag_size = frag_size;
|
|
|
+
|
|
|
+ priv->frag_info[i].frag_stride = ALIGN(frag_size,
|
|
|
+ SMP_CACHE_BYTES);
|
|
|
+ buf_size += frag_size;
|
|
|
i++;
|
|
|
}
|
|
|
priv->rx_page_order = MLX4_EN_ALLOC_PREFER_ORDER;
|