Commit 8f27219a authored by Biju Das's avatar Biju Das Committed by David S. Miller

ravb: Add no_ptp_cfg_active to struct ravb_hw_info

There are some H/W differences for the gPTP feature between
R-Car Gen3, R-Car Gen2, and RZ/G2L as below.

1) On R-Car Gen2, gPTP support is not active in config mode.
2) On R-Car Gen3, gPTP support is active in config mode.
3) RZ/G2L does not support the gPTP feature.

Add a no_ptp_cfg_active hw feature bit to struct ravb_hw_info for
handling gPTP for R-Car Gen2.
Signed-off-by: default avatarBiju Das <biju.das.jz@bp.renesas.com>
Reviewed-by: default avatarLad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 6de19fa0
...@@ -998,6 +998,7 @@ struct ravb_hw_info { ...@@ -998,6 +998,7 @@ struct ravb_hw_info {
unsigned internal_delay:1; /* AVB-DMAC has internal delays */ unsigned internal_delay:1; /* AVB-DMAC has internal delays */
unsigned tx_counters:1; /* E-MAC has TX counters */ unsigned tx_counters:1; /* E-MAC has TX counters */
unsigned multi_irqs:1; /* AVB-DMAC and E-MAC has multiple irqs */ unsigned multi_irqs:1; /* AVB-DMAC and E-MAC has multiple irqs */
unsigned no_ptp_cfg_active:1; /* AVB-DMAC does not support gPTP active in config mode */
}; };
struct ravb_private { struct ravb_private {
......
...@@ -1205,6 +1205,7 @@ static int ravb_set_ringparam(struct net_device *ndev, ...@@ -1205,6 +1205,7 @@ static int ravb_set_ringparam(struct net_device *ndev,
struct ethtool_ringparam *ring) struct ethtool_ringparam *ring)
{ {
struct ravb_private *priv = netdev_priv(ndev); struct ravb_private *priv = netdev_priv(ndev);
const struct ravb_hw_info *info = priv->info;
int error; int error;
if (ring->tx_pending > BE_TX_RING_MAX || if (ring->tx_pending > BE_TX_RING_MAX ||
...@@ -1218,7 +1219,7 @@ static int ravb_set_ringparam(struct net_device *ndev, ...@@ -1218,7 +1219,7 @@ static int ravb_set_ringparam(struct net_device *ndev,
if (netif_running(ndev)) { if (netif_running(ndev)) {
netif_device_detach(ndev); netif_device_detach(ndev);
/* Stop PTP Clock driver */ /* Stop PTP Clock driver */
if (priv->chip_id == RCAR_GEN2) if (info->no_ptp_cfg_active)
ravb_ptp_stop(ndev); ravb_ptp_stop(ndev);
/* Wait for DMA stopping */ /* Wait for DMA stopping */
error = ravb_stop_dma(ndev); error = ravb_stop_dma(ndev);
...@@ -1250,7 +1251,7 @@ static int ravb_set_ringparam(struct net_device *ndev, ...@@ -1250,7 +1251,7 @@ static int ravb_set_ringparam(struct net_device *ndev,
ravb_emac_init(ndev); ravb_emac_init(ndev);
/* Initialise PTP Clock driver */ /* Initialise PTP Clock driver */
if (priv->chip_id == RCAR_GEN2) if (info->no_ptp_cfg_active)
ravb_ptp_init(ndev, priv->pdev); ravb_ptp_init(ndev, priv->pdev);
netif_device_attach(ndev); netif_device_attach(ndev);
...@@ -1390,7 +1391,7 @@ static int ravb_open(struct net_device *ndev) ...@@ -1390,7 +1391,7 @@ static int ravb_open(struct net_device *ndev)
ravb_emac_init(ndev); ravb_emac_init(ndev);
/* Initialise PTP Clock driver */ /* Initialise PTP Clock driver */
if (priv->chip_id == RCAR_GEN2) if (info->no_ptp_cfg_active)
ravb_ptp_init(ndev, priv->pdev); ravb_ptp_init(ndev, priv->pdev);
netif_tx_start_all_queues(ndev); netif_tx_start_all_queues(ndev);
...@@ -1404,7 +1405,7 @@ static int ravb_open(struct net_device *ndev) ...@@ -1404,7 +1405,7 @@ static int ravb_open(struct net_device *ndev)
out_ptp_stop: out_ptp_stop:
/* Stop PTP Clock driver */ /* Stop PTP Clock driver */
if (priv->chip_id == RCAR_GEN2) if (info->no_ptp_cfg_active)
ravb_ptp_stop(ndev); ravb_ptp_stop(ndev);
out_free_irq_nc_tx: out_free_irq_nc_tx:
if (!info->multi_irqs) if (!info->multi_irqs)
...@@ -1445,13 +1446,14 @@ static void ravb_tx_timeout_work(struct work_struct *work) ...@@ -1445,13 +1446,14 @@ static void ravb_tx_timeout_work(struct work_struct *work)
{ {
struct ravb_private *priv = container_of(work, struct ravb_private, struct ravb_private *priv = container_of(work, struct ravb_private,
work); work);
const struct ravb_hw_info *info = priv->info;
struct net_device *ndev = priv->ndev; struct net_device *ndev = priv->ndev;
int error; int error;
netif_tx_stop_all_queues(ndev); netif_tx_stop_all_queues(ndev);
/* Stop PTP Clock driver */ /* Stop PTP Clock driver */
if (priv->chip_id == RCAR_GEN2) if (info->no_ptp_cfg_active)
ravb_ptp_stop(ndev); ravb_ptp_stop(ndev);
/* Wait for DMA stopping */ /* Wait for DMA stopping */
...@@ -1486,7 +1488,7 @@ static void ravb_tx_timeout_work(struct work_struct *work) ...@@ -1486,7 +1488,7 @@ static void ravb_tx_timeout_work(struct work_struct *work)
out: out:
/* Initialise PTP Clock driver */ /* Initialise PTP Clock driver */
if (priv->chip_id == RCAR_GEN2) if (info->no_ptp_cfg_active)
ravb_ptp_init(ndev, priv->pdev); ravb_ptp_init(ndev, priv->pdev);
netif_tx_start_all_queues(ndev); netif_tx_start_all_queues(ndev);
...@@ -1695,7 +1697,7 @@ static int ravb_close(struct net_device *ndev) ...@@ -1695,7 +1697,7 @@ static int ravb_close(struct net_device *ndev)
ravb_write(ndev, 0, TIC); ravb_write(ndev, 0, TIC);
/* Stop PTP Clock driver */ /* Stop PTP Clock driver */
if (priv->chip_id == RCAR_GEN2) if (info->no_ptp_cfg_active)
ravb_ptp_stop(ndev); ravb_ptp_stop(ndev);
/* Set the config mode to stop the AVB-DMAC's processes */ /* Set the config mode to stop the AVB-DMAC's processes */
...@@ -1956,6 +1958,7 @@ static const struct ravb_hw_info ravb_gen2_hw_info = { ...@@ -1956,6 +1958,7 @@ static const struct ravb_hw_info ravb_gen2_hw_info = {
.stats_len = ARRAY_SIZE(ravb_gstrings_stats), .stats_len = ARRAY_SIZE(ravb_gstrings_stats),
.max_rx_len = RX_BUF_SZ + RAVB_ALIGN - 1, .max_rx_len = RX_BUF_SZ + RAVB_ALIGN - 1,
.aligned_tx = 1, .aligned_tx = 1,
.no_ptp_cfg_active = 1,
}; };
static const struct of_device_id ravb_match_table[] = { static const struct of_device_id ravb_match_table[] = {
...@@ -1996,8 +1999,9 @@ static int ravb_set_gti(struct net_device *ndev) ...@@ -1996,8 +1999,9 @@ static int ravb_set_gti(struct net_device *ndev)
static void ravb_set_config_mode(struct net_device *ndev) static void ravb_set_config_mode(struct net_device *ndev)
{ {
struct ravb_private *priv = netdev_priv(ndev); struct ravb_private *priv = netdev_priv(ndev);
const struct ravb_hw_info *info = priv->info;
if (priv->chip_id == RCAR_GEN2) { if (info->no_ptp_cfg_active) {
ravb_modify(ndev, CCC, CCC_OPC, CCC_OPC_CONFIG); ravb_modify(ndev, CCC, CCC_OPC, CCC_OPC_CONFIG);
/* Set CSEL value */ /* Set CSEL value */
ravb_modify(ndev, CCC, CCC_CSEL, CCC_CSEL_HPB); ravb_modify(ndev, CCC, CCC_CSEL, CCC_CSEL_HPB);
......
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