[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <52B6FAED.3070709@mellanox.com>
Date: Sun, 22 Dec 2013 16:45:01 +0200
From: Or Gerlitz <ogerlitz@...lanox.com>
To: Joe Perches <joe@...ches.com>
CC: <davem@...emloft.net>, <netdev@...r.kernel.org>,
<amirv@...lanox.com>, <yanb@...lanox.com>, <ast@...mgrid.com>,
Matan Barak <matanb@...lanox.com>
Subject: Re: [PATCH net-next V1 2/2] net/mlx4_en: Add netdev support for TCP/IP
offloads of vxlan tunneling
On 22/12/2013 16:19, Joe Perches wrote:
> On Sun, 2013-12-22 at 16:00 +0200, Or Gerlitz wrote:
>
> trivia:
>
>> diff --git a/drivers/net/ethernet/mellanox/mlx4/en_netdev.c b/drivers/net/ethernet/mellanox/mlx4/en_netdev.c
> []
>> @@ -1061,6 +1126,10 @@ static void mlx4_en_do_multicast(struct mlx4_en_priv *priv,
>> if (err)
>> en_err(priv, "Fail to attach multicast address\n");
>>
>> + err = mlx4_en_tunnel_steer_add(priv, &mc_list[10], priv->base_qpn,
>> + &mclist->tunnel_reg_id);
>> + if (err)
>> + en_err(priv, "Failed to attach multicast address\n");
> Overly indented if/en_err here.
thanks! will fix
>
>> @@ -2400,6 +2478,14 @@ int mlx4_en_init_netdev(struct mlx4_en_dev *mdev, int port,
>> if (mdev->dev->caps.steering_mode != MLX4_STEERING_MODE_A0)
>> dev->priv_flags |= IFF_UNICAST_FLT;
>>
>> + if ((mdev->dev->caps.tunnel_offload_mode == MLX4_TUNNEL_OFFLOAD_MODE_VXLAN)) {
>> + dev->hw_enc_features = NETIF_F_SG | NETIF_F_IP_CSUM |
>> + NETIF_F_RXCSUM | NETIF_F_TSO |
>> + NETIF_F_GSO_UDP_TUNNEL;
>> + dev->hw_features |= NETIF_F_GSO_UDP_TUNNEL;
>> + dev->features |= NETIF_F_GSO_UDP_TUNNEL;
> Perhaps hw_enc_features should be |= as well.
> NETIF_F_SG is set in register_netdevice() for hw_enc_features.
>
>> diff --git a/drivers/net/ethernet/mellanox/mlx4/en_resources.c b/drivers/net/ethernet/mellanox/mlx4/en_resources.c
> []
>> @@ -68,6 +68,12 @@ void mlx4_en_fill_qp_context(struct mlx4_en_priv *priv, int size, int stride,
>> context->db_rec_addr = cpu_to_be64(priv->res.db.dma << 2);
>> if (!(dev->features & NETIF_F_HW_VLAN_CTAG_RX))
>> context->param3 |= cpu_to_be32(1 << 30);
>> +
>> + if (!is_tx && !rss &&
>> + (mdev->dev->caps.tunnel_offload_mode == MLX4_TUNNEL_OFFLOAD_MODE_VXLAN)) {
>> + en_dbg(HW, priv, "Setting RX qp %x tunnel mode to RX tunneled & non-tunneled\n", qpn);
>> + context->srqn |= cpu_to_be32(7 << 28); /* this fills bits 30:28 */
> Is that bit setting 0 based or 1 based?
1 based, any issue with that?
anyway, the Ethernet driver doesn't use this word (context->srqn), so I
will make it = and not |= for being clear robust.
>
>> diff --git a/drivers/net/ethernet/mellanox/mlx4/en_rx.c b/drivers/net/ethernet/mellanox/mlx4/en_rx.c
> []
>> @@ -628,7 +628,7 @@ int mlx4_en_process_rx_cq(struct net_device *dev, struct mlx4_en_cq *cq, int bud
>> int nr;
>> unsigned int length;
>> int polled = 0;
>> - int ip_summed;
>> + int ip_summed, l2_tunnel;
> Maybe nicer as bool
>
>
OK
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists