|
@@ -889,6 +889,22 @@ static int ravb_phy_init(struct net_device *ndev)
|
|
|
return -ENOENT;
|
|
|
}
|
|
|
|
|
|
+ /* This driver only support 10/100Mbit speeds on Gen3
|
|
|
+ * at this time.
|
|
|
+ */
|
|
|
+ if (priv->chip_id == RCAR_GEN3) {
|
|
|
+ int err;
|
|
|
+
|
|
|
+ err = phy_set_max_speed(phydev, SPEED_100);
|
|
|
+ if (err) {
|
|
|
+ netdev_err(ndev, "failed to limit PHY to 100Mbit/s\n");
|
|
|
+ phy_disconnect(phydev);
|
|
|
+ return err;
|
|
|
+ }
|
|
|
+
|
|
|
+ netdev_info(ndev, "limited PHY to 100Mbit/s\n");
|
|
|
+ }
|
|
|
+
|
|
|
netdev_info(ndev, "attached PHY %d (IRQ %d) to driver %s\n",
|
|
|
phydev->addr, phydev->irq, phydev->drv->name);
|
|
|
|
|
@@ -1197,6 +1213,15 @@ static int ravb_open(struct net_device *ndev)
|
|
|
goto out_napi_off;
|
|
|
}
|
|
|
|
|
|
+ if (priv->chip_id == RCAR_GEN3) {
|
|
|
+ error = request_irq(priv->emac_irq, ravb_interrupt,
|
|
|
+ IRQF_SHARED, ndev->name, ndev);
|
|
|
+ if (error) {
|
|
|
+ netdev_err(ndev, "cannot request IRQ\n");
|
|
|
+ goto out_free_irq;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
/* Device init */
|
|
|
error = ravb_dmac_init(ndev);
|
|
|
if (error)
|
|
@@ -1220,6 +1245,7 @@ out_ptp_stop:
|
|
|
ravb_ptp_stop(ndev);
|
|
|
out_free_irq:
|
|
|
free_irq(ndev->irq, ndev);
|
|
|
+ free_irq(priv->emac_irq, ndev);
|
|
|
out_napi_off:
|
|
|
napi_disable(&priv->napi[RAVB_NC]);
|
|
|
napi_disable(&priv->napi[RAVB_BE]);
|
|
@@ -1625,10 +1651,20 @@ static int ravb_mdio_release(struct ravb_private *priv)
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
+static const struct of_device_id ravb_match_table[] = {
|
|
|
+ { .compatible = "renesas,etheravb-r8a7790", .data = (void *)RCAR_GEN2 },
|
|
|
+ { .compatible = "renesas,etheravb-r8a7794", .data = (void *)RCAR_GEN2 },
|
|
|
+ { .compatible = "renesas,etheravb-r8a7795", .data = (void *)RCAR_GEN3 },
|
|
|
+ { }
|
|
|
+};
|
|
|
+MODULE_DEVICE_TABLE(of, ravb_match_table);
|
|
|
+
|
|
|
static int ravb_probe(struct platform_device *pdev)
|
|
|
{
|
|
|
struct device_node *np = pdev->dev.of_node;
|
|
|
+ const struct of_device_id *match;
|
|
|
struct ravb_private *priv;
|
|
|
+ enum ravb_chip_id chip_id;
|
|
|
struct net_device *ndev;
|
|
|
int error, irq, q;
|
|
|
struct resource *res;
|
|
@@ -1657,7 +1693,14 @@ static int ravb_probe(struct platform_device *pdev)
|
|
|
/* The Ether-specific entries in the device structure. */
|
|
|
ndev->base_addr = res->start;
|
|
|
ndev->dma = -1;
|
|
|
- irq = platform_get_irq(pdev, 0);
|
|
|
+
|
|
|
+ match = of_match_device(of_match_ptr(ravb_match_table), &pdev->dev);
|
|
|
+ chip_id = (enum ravb_chip_id)match->data;
|
|
|
+
|
|
|
+ if (chip_id == RCAR_GEN3)
|
|
|
+ irq = platform_get_irq_byname(pdev, "ch22");
|
|
|
+ else
|
|
|
+ irq = platform_get_irq(pdev, 0);
|
|
|
if (irq < 0) {
|
|
|
error = irq;
|
|
|
goto out_release;
|
|
@@ -1688,6 +1731,17 @@ static int ravb_probe(struct platform_device *pdev)
|
|
|
priv->avb_link_active_low =
|
|
|
of_property_read_bool(np, "renesas,ether-link-active-low");
|
|
|
|
|
|
+ if (chip_id == RCAR_GEN3) {
|
|
|
+ irq = platform_get_irq_byname(pdev, "ch24");
|
|
|
+ if (irq < 0) {
|
|
|
+ error = irq;
|
|
|
+ goto out_release;
|
|
|
+ }
|
|
|
+ priv->emac_irq = irq;
|
|
|
+ }
|
|
|
+
|
|
|
+ priv->chip_id = chip_id;
|
|
|
+
|
|
|
/* Set function */
|
|
|
ndev->netdev_ops = &ravb_netdev_ops;
|
|
|
ndev->ethtool_ops = &ravb_ethtool_ops;
|
|
@@ -1818,13 +1872,6 @@ static const struct dev_pm_ops ravb_dev_pm_ops = {
|
|
|
#define RAVB_PM_OPS NULL
|
|
|
#endif
|
|
|
|
|
|
-static const struct of_device_id ravb_match_table[] = {
|
|
|
- { .compatible = "renesas,etheravb-r8a7790" },
|
|
|
- { .compatible = "renesas,etheravb-r8a7794" },
|
|
|
- { }
|
|
|
-};
|
|
|
-MODULE_DEVICE_TABLE(of, ravb_match_table);
|
|
|
-
|
|
|
static struct platform_driver ravb_driver = {
|
|
|
.probe = ravb_probe,
|
|
|
.remove = ravb_remove,
|