#include <linux/can.h>
 #include <linux/can/dev.h>
 #include <linux/can/error.h>
+#include <linux/can/led.h>
 #include <linux/can/platform/flexcan.h>
 #include <linux/clk.h>
 #include <linux/delay.h>
        stats->rx_packets++;
        stats->rx_bytes += cf->can_dlc;
 
+       can_led_event(dev, CAN_LED_EVENT_RX);
+
        return 1;
 }
 
        if (reg_iflag1 & (1 << FLEXCAN_TX_BUF_ID)) {
                stats->tx_bytes += can_get_echo_skb(dev, 0);
                stats->tx_packets++;
+               can_led_event(dev, CAN_LED_EVENT_TX);
                flexcan_write((1 << FLEXCAN_TX_BUF_ID), ®s->iflag1);
                netif_wake_queue(dev);
        }
        err = flexcan_chip_start(dev);
        if (err)
                goto out_close;
+
+       can_led_event(dev, CAN_LED_EVENT_OPEN);
+
        napi_enable(&priv->napi);
        netif_start_queue(dev);
 
 
        close_candev(dev);
 
+       can_led_event(dev, CAN_LED_EVENT_STOP);
+
        return 0;
 }
 
                goto failed_register;
        }
 
+       devm_can_led_init(dev);
+
        dev_info(&pdev->dev, "device registered (reg_base=%p, irq=%d)\n",
                 priv->base, dev->irq);