struct net_device *ndev = (struct net_device *)0;
        struct ti_hecc_priv *priv;
        struct device_node *np = pdev->dev.of_node;
-       struct resource *irq;
        struct regulator *reg_xceiver;
        int err = -ENODEV;
 
                goto probe_exit_candev;
        }
 
-       irq = platform_get_resource(pdev, IORESOURCE_IRQ, 0);
-       if (!irq) {
-               dev_err(&pdev->dev, "No irq resource\n");
+       ndev->irq = platform_get_irq(pdev, 0);
+       if (ndev->irq < 0) {
+               err = ndev->irq;
                goto probe_exit_candev;
        }
 
        priv->can.ctrlmode_supported = CAN_CTRLMODE_3_SAMPLES;
 
        spin_lock_init(&priv->mbx_lock);
-       ndev->irq = irq->start;
        ndev->flags |= IFF_ECHO;
        platform_set_drvdata(pdev, ndev);
        SET_NETDEV_DEV(ndev, &pdev->dev);