On 8/2/21 1:26 PM, Biju Das wrote: > On R-Car the checksum calculation on RX frames is done by the E-MAC > module, whereas on RZ/G2L it is done by the TOE. > > TOE calculates the checksum of received frames from E-MAC and outputs it to > DMAC. TOE also calculates the checksum of transmission frames from DMAC and > outputs it E-MAC. > > Add net_features and net_hw_features to struct ravb_hw_info, to support > subsequent SoCs without any code changes in the ravb_probe function. > > Signed-off-by: Biju Das <biju.das.jz@xxxxxxxxxxxxxx> > Reviewed-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@xxxxxxxxxxxxxx> [...] > diff --git a/drivers/net/ethernet/renesas/ravb.h b/drivers/net/ethernet/renesas/ravb.h > index b765b2b7d9e9..3df813b2e253 100644 > --- a/drivers/net/ethernet/renesas/ravb.h > +++ b/drivers/net/ethernet/renesas/ravb.h > @@ -991,6 +991,8 @@ enum ravb_chip_id { > struct ravb_hw_info { > const char (*gstrings_stats)[ETH_GSTRING_LEN]; > size_t gstrings_size; > + netdev_features_t net_hw_features; > + netdev_features_t net_features; Do we really need both of these here? It seems like the 'feartures' mirrors the enabled features? > enum ravb_chip_id chip_id; > int num_gstat_queue; > int num_tx_desc; > diff --git a/drivers/net/ethernet/renesas/ravb_main.c b/drivers/net/ethernet/renesas/ravb_main.c > index 7a69668cb512..2ac962b5b8fb 100644 > --- a/drivers/net/ethernet/renesas/ravb_main.c > +++ b/drivers/net/ethernet/renesas/ravb_main.c [...] > @@ -2077,14 +2081,14 @@ static int ravb_probe(struct platform_device *pdev) > if (!ndev) > return -ENOMEM; > > - ndev->features = NETIF_F_RXCSUM; > - ndev->hw_features = NETIF_F_RXCSUM; > + info = of_device_get_match_data(&pdev->dev); > + > + ndev->features = info->net_features; > + ndev->hw_features = info->net_hw_features; What value you plan to set her for GbEth, NETIF_F_HW_CSUM? [...] MBR, Sergei