xref: /linux/drivers/net/can/ifi_canfd/ifi_canfd.c (revision 0883c2c06fb5bcf5b9e008270827e63c09a88c1e)
1 /*
2  * CAN bus driver for IFI CANFD controller
3  *
4  * Copyright (C) 2016 Marek Vasut <marex@denx.de>
5  *
6  * Details about this controller can be found at
7  * http://www.ifi-pld.de/IP/CANFD/canfd.html
8  *
9  * This file is licensed under the terms of the GNU General Public
10  * License version 2. This program is licensed "as is" without any
11  * warranty of any kind, whether express or implied.
12  */
13 
14 #include <linux/clk.h>
15 #include <linux/delay.h>
16 #include <linux/interrupt.h>
17 #include <linux/io.h>
18 #include <linux/kernel.h>
19 #include <linux/module.h>
20 #include <linux/netdevice.h>
21 #include <linux/of.h>
22 #include <linux/of_device.h>
23 #include <linux/platform_device.h>
24 
25 #include <linux/can/dev.h>
26 
27 #define IFI_CANFD_STCMD				0x0
28 #define IFI_CANFD_STCMD_HARDRESET		0xDEADCAFD
29 #define IFI_CANFD_STCMD_ENABLE			BIT(0)
30 #define IFI_CANFD_STCMD_ERROR_ACTIVE		BIT(2)
31 #define IFI_CANFD_STCMD_ERROR_PASSIVE		BIT(3)
32 #define IFI_CANFD_STCMD_BUSOFF			BIT(4)
33 #define IFI_CANFD_STCMD_BUSMONITOR		BIT(16)
34 #define IFI_CANFD_STCMD_LOOPBACK		BIT(18)
35 #define IFI_CANFD_STCMD_DISABLE_CANFD		BIT(24)
36 #define IFI_CANFD_STCMD_ENABLE_ISO		BIT(25)
37 #define IFI_CANFD_STCMD_ENABLE_7_9_8_8_TIMING	BIT(26)
38 #define IFI_CANFD_STCMD_NORMAL_MODE		((u32)BIT(31))
39 
40 #define IFI_CANFD_RXSTCMD			0x4
41 #define IFI_CANFD_RXSTCMD_REMOVE_MSG		BIT(0)
42 #define IFI_CANFD_RXSTCMD_RESET			BIT(7)
43 #define IFI_CANFD_RXSTCMD_EMPTY			BIT(8)
44 #define IFI_CANFD_RXSTCMD_OVERFLOW		BIT(13)
45 
46 #define IFI_CANFD_TXSTCMD			0x8
47 #define IFI_CANFD_TXSTCMD_ADD_MSG		BIT(0)
48 #define IFI_CANFD_TXSTCMD_HIGH_PRIO		BIT(1)
49 #define IFI_CANFD_TXSTCMD_RESET			BIT(7)
50 #define IFI_CANFD_TXSTCMD_EMPTY			BIT(8)
51 #define IFI_CANFD_TXSTCMD_FULL			BIT(12)
52 #define IFI_CANFD_TXSTCMD_OVERFLOW		BIT(13)
53 
54 #define IFI_CANFD_INTERRUPT			0xc
55 #define IFI_CANFD_INTERRUPT_ERROR_WARNING	BIT(1)
56 #define IFI_CANFD_INTERRUPT_ERROR_COUNTER	BIT(10)
57 #define IFI_CANFD_INTERRUPT_TXFIFO_EMPTY	BIT(16)
58 #define IFI_CANFD_INTERRUPT_TXFIFO_REMOVE	BIT(22)
59 #define IFI_CANFD_INTERRUPT_RXFIFO_NEMPTY	BIT(24)
60 #define IFI_CANFD_INTERRUPT_RXFIFO_NEMPTY_PER	BIT(25)
61 #define IFI_CANFD_INTERRUPT_SET_IRQ		((u32)BIT(31))
62 
63 #define IFI_CANFD_IRQMASK			0x10
64 #define IFI_CANFD_IRQMASK_SET_ERR		BIT(7)
65 #define IFI_CANFD_IRQMASK_SET_TS		BIT(15)
66 #define IFI_CANFD_IRQMASK_TXFIFO_EMPTY		BIT(16)
67 #define IFI_CANFD_IRQMASK_SET_TX		BIT(23)
68 #define IFI_CANFD_IRQMASK_RXFIFO_NEMPTY		BIT(24)
69 #define IFI_CANFD_IRQMASK_SET_RX		((u32)BIT(31))
70 
71 #define IFI_CANFD_TIME				0x14
72 #define IFI_CANFD_FTIME				0x18
73 #define IFI_CANFD_TIME_TIMEB_OFF		0
74 #define IFI_CANFD_TIME_TIMEA_OFF		8
75 #define IFI_CANFD_TIME_PRESCALE_OFF		16
76 #define IFI_CANFD_TIME_SJW_OFF_7_9_8_8		25
77 #define IFI_CANFD_TIME_SJW_OFF_4_12_6_6		28
78 #define IFI_CANFD_TIME_SET_SJW_4_12_6_6		BIT(6)
79 #define IFI_CANFD_TIME_SET_TIMEB_4_12_6_6	BIT(7)
80 #define IFI_CANFD_TIME_SET_PRESC_4_12_6_6	BIT(14)
81 #define IFI_CANFD_TIME_SET_TIMEA_4_12_6_6	BIT(15)
82 
83 #define IFI_CANFD_TDELAY			0x1c
84 
85 #define IFI_CANFD_ERROR				0x20
86 #define IFI_CANFD_ERROR_TX_OFFSET		0
87 #define IFI_CANFD_ERROR_TX_MASK			0xff
88 #define IFI_CANFD_ERROR_RX_OFFSET		16
89 #define IFI_CANFD_ERROR_RX_MASK			0xff
90 
91 #define IFI_CANFD_ERRCNT			0x24
92 
93 #define IFI_CANFD_SUSPEND			0x28
94 
95 #define IFI_CANFD_REPEAT			0x2c
96 
97 #define IFI_CANFD_TRAFFIC			0x30
98 
99 #define IFI_CANFD_TSCONTROL			0x34
100 
101 #define IFI_CANFD_TSC				0x38
102 
103 #define IFI_CANFD_TST				0x3c
104 
105 #define IFI_CANFD_RES1				0x40
106 
107 #define IFI_CANFD_ERROR_CTR			0x44
108 #define IFI_CANFD_ERROR_CTR_UNLOCK_MAGIC	0x21302899
109 #define IFI_CANFD_ERROR_CTR_OVERLOAD_FIRST	BIT(0)
110 #define IFI_CANFD_ERROR_CTR_ACK_ERROR_FIRST	BIT(1)
111 #define IFI_CANFD_ERROR_CTR_BIT0_ERROR_FIRST	BIT(2)
112 #define IFI_CANFD_ERROR_CTR_BIT1_ERROR_FIRST	BIT(3)
113 #define IFI_CANFD_ERROR_CTR_STUFF_ERROR_FIRST	BIT(4)
114 #define IFI_CANFD_ERROR_CTR_CRC_ERROR_FIRST	BIT(5)
115 #define IFI_CANFD_ERROR_CTR_FORM_ERROR_FIRST	BIT(6)
116 #define IFI_CANFD_ERROR_CTR_OVERLOAD_ALL	BIT(8)
117 #define IFI_CANFD_ERROR_CTR_ACK_ERROR_ALL	BIT(9)
118 #define IFI_CANFD_ERROR_CTR_BIT0_ERROR_ALL	BIT(10)
119 #define IFI_CANFD_ERROR_CTR_BIT1_ERROR_ALL	BIT(11)
120 #define IFI_CANFD_ERROR_CTR_STUFF_ERROR_ALL	BIT(12)
121 #define IFI_CANFD_ERROR_CTR_CRC_ERROR_ALL	BIT(13)
122 #define IFI_CANFD_ERROR_CTR_FORM_ERROR_ALL	BIT(14)
123 #define IFI_CANFD_ERROR_CTR_BITPOSITION_OFFSET	16
124 #define IFI_CANFD_ERROR_CTR_BITPOSITION_MASK	0xff
125 #define IFI_CANFD_ERROR_CTR_ER_RESET		BIT(30)
126 #define IFI_CANFD_ERROR_CTR_ER_ENABLE		((u32)BIT(31))
127 
128 #define IFI_CANFD_PAR				0x48
129 
130 #define IFI_CANFD_CANCLOCK			0x4c
131 
132 #define IFI_CANFD_SYSCLOCK			0x50
133 
134 #define IFI_CANFD_VER				0x54
135 
136 #define IFI_CANFD_IP_ID				0x58
137 #define IFI_CANFD_IP_ID_VALUE			0xD073CAFD
138 
139 #define IFI_CANFD_TEST				0x5c
140 
141 #define IFI_CANFD_RXFIFO_TS_63_32		0x60
142 
143 #define IFI_CANFD_RXFIFO_TS_31_0		0x64
144 
145 #define IFI_CANFD_RXFIFO_DLC			0x68
146 #define IFI_CANFD_RXFIFO_DLC_DLC_OFFSET		0
147 #define IFI_CANFD_RXFIFO_DLC_DLC_MASK		0xf
148 #define IFI_CANFD_RXFIFO_DLC_RTR		BIT(4)
149 #define IFI_CANFD_RXFIFO_DLC_EDL		BIT(5)
150 #define IFI_CANFD_RXFIFO_DLC_BRS		BIT(6)
151 #define IFI_CANFD_RXFIFO_DLC_ESI		BIT(7)
152 #define IFI_CANFD_RXFIFO_DLC_OBJ_OFFSET		8
153 #define IFI_CANFD_RXFIFO_DLC_OBJ_MASK		0x1ff
154 #define IFI_CANFD_RXFIFO_DLC_FNR_OFFSET		24
155 #define IFI_CANFD_RXFIFO_DLC_FNR_MASK		0xff
156 
157 #define IFI_CANFD_RXFIFO_ID			0x6c
158 #define IFI_CANFD_RXFIFO_ID_ID_OFFSET		0
159 #define IFI_CANFD_RXFIFO_ID_ID_STD_MASK		CAN_SFF_MASK
160 #define IFI_CANFD_RXFIFO_ID_ID_STD_OFFSET	0
161 #define IFI_CANFD_RXFIFO_ID_ID_STD_WIDTH	10
162 #define IFI_CANFD_RXFIFO_ID_ID_XTD_MASK		CAN_EFF_MASK
163 #define IFI_CANFD_RXFIFO_ID_ID_XTD_OFFSET	11
164 #define IFI_CANFD_RXFIFO_ID_ID_XTD_WIDTH	18
165 #define IFI_CANFD_RXFIFO_ID_IDE			BIT(29)
166 
167 #define IFI_CANFD_RXFIFO_DATA			0x70	/* 0x70..0xac */
168 
169 #define IFI_CANFD_TXFIFO_SUSPEND_US		0xb0
170 
171 #define IFI_CANFD_TXFIFO_REPEATCOUNT		0xb4
172 
173 #define IFI_CANFD_TXFIFO_DLC			0xb8
174 #define IFI_CANFD_TXFIFO_DLC_DLC_OFFSET		0
175 #define IFI_CANFD_TXFIFO_DLC_DLC_MASK		0xf
176 #define IFI_CANFD_TXFIFO_DLC_RTR		BIT(4)
177 #define IFI_CANFD_TXFIFO_DLC_EDL		BIT(5)
178 #define IFI_CANFD_TXFIFO_DLC_BRS		BIT(6)
179 #define IFI_CANFD_TXFIFO_DLC_FNR_OFFSET		24
180 #define IFI_CANFD_TXFIFO_DLC_FNR_MASK		0xff
181 
182 #define IFI_CANFD_TXFIFO_ID			0xbc
183 #define IFI_CANFD_TXFIFO_ID_ID_OFFSET		0
184 #define IFI_CANFD_TXFIFO_ID_ID_STD_MASK		CAN_SFF_MASK
185 #define IFI_CANFD_TXFIFO_ID_ID_STD_OFFSET	0
186 #define IFI_CANFD_TXFIFO_ID_ID_STD_WIDTH	10
187 #define IFI_CANFD_TXFIFO_ID_ID_XTD_MASK		CAN_EFF_MASK
188 #define IFI_CANFD_TXFIFO_ID_ID_XTD_OFFSET	11
189 #define IFI_CANFD_TXFIFO_ID_ID_XTD_WIDTH	18
190 #define IFI_CANFD_TXFIFO_ID_IDE			BIT(29)
191 
192 #define IFI_CANFD_TXFIFO_DATA			0xc0	/* 0xb0..0xfc */
193 
194 #define IFI_CANFD_FILTER_MASK(n)		(0x800 + ((n) * 8) + 0)
195 #define IFI_CANFD_FILTER_MASK_EXT		BIT(29)
196 #define IFI_CANFD_FILTER_MASK_EDL		BIT(30)
197 #define IFI_CANFD_FILTER_MASK_VALID		((u32)BIT(31))
198 
199 #define IFI_CANFD_FILTER_IDENT(n)		(0x800 + ((n) * 8) + 4)
200 #define IFI_CANFD_FILTER_IDENT_IDE		BIT(29)
201 #define IFI_CANFD_FILTER_IDENT_CANFD		BIT(30)
202 #define IFI_CANFD_FILTER_IDENT_VALID		((u32)BIT(31))
203 
204 /* IFI CANFD private data structure */
205 struct ifi_canfd_priv {
206 	struct can_priv		can;	/* must be the first member */
207 	struct napi_struct	napi;
208 	struct net_device	*ndev;
209 	void __iomem		*base;
210 };
211 
212 static void ifi_canfd_irq_enable(struct net_device *ndev, bool enable)
213 {
214 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
215 	u32 enirq = 0;
216 
217 	if (enable) {
218 		enirq = IFI_CANFD_IRQMASK_TXFIFO_EMPTY |
219 			IFI_CANFD_IRQMASK_RXFIFO_NEMPTY;
220 		if (priv->can.ctrlmode & CAN_CTRLMODE_BERR_REPORTING)
221 			enirq |= IFI_CANFD_INTERRUPT_ERROR_COUNTER;
222 	}
223 
224 	writel(IFI_CANFD_IRQMASK_SET_ERR |
225 	       IFI_CANFD_IRQMASK_SET_TS |
226 	       IFI_CANFD_IRQMASK_SET_TX |
227 	       IFI_CANFD_IRQMASK_SET_RX | enirq,
228 	       priv->base + IFI_CANFD_IRQMASK);
229 }
230 
231 static void ifi_canfd_read_fifo(struct net_device *ndev)
232 {
233 	struct net_device_stats *stats = &ndev->stats;
234 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
235 	struct canfd_frame *cf;
236 	struct sk_buff *skb;
237 	const u32 rx_irq_mask = IFI_CANFD_INTERRUPT_RXFIFO_NEMPTY |
238 				IFI_CANFD_INTERRUPT_RXFIFO_NEMPTY_PER;
239 	u32 rxdlc, rxid;
240 	u32 dlc, id;
241 	int i;
242 
243 	rxdlc = readl(priv->base + IFI_CANFD_RXFIFO_DLC);
244 	if (rxdlc & IFI_CANFD_RXFIFO_DLC_EDL)
245 		skb = alloc_canfd_skb(ndev, &cf);
246 	else
247 		skb = alloc_can_skb(ndev, (struct can_frame **)&cf);
248 
249 	if (!skb) {
250 		stats->rx_dropped++;
251 		return;
252 	}
253 
254 	dlc = (rxdlc >> IFI_CANFD_RXFIFO_DLC_DLC_OFFSET) &
255 	      IFI_CANFD_RXFIFO_DLC_DLC_MASK;
256 	if (rxdlc & IFI_CANFD_RXFIFO_DLC_EDL)
257 		cf->len = can_dlc2len(dlc);
258 	else
259 		cf->len = get_can_dlc(dlc);
260 
261 	rxid = readl(priv->base + IFI_CANFD_RXFIFO_ID);
262 	id = (rxid >> IFI_CANFD_RXFIFO_ID_ID_OFFSET);
263 	if (id & IFI_CANFD_RXFIFO_ID_IDE) {
264 		id &= IFI_CANFD_RXFIFO_ID_ID_XTD_MASK;
265 		/*
266 		 * In case the Extended ID frame is received, the standard
267 		 * and extended part of the ID are swapped in the register,
268 		 * so swap them back to obtain the correct ID.
269 		 */
270 		id = (id >> IFI_CANFD_RXFIFO_ID_ID_XTD_OFFSET) |
271 		     ((id & IFI_CANFD_RXFIFO_ID_ID_STD_MASK) <<
272 		       IFI_CANFD_RXFIFO_ID_ID_XTD_WIDTH);
273 		id |= CAN_EFF_FLAG;
274 	} else {
275 		id &= IFI_CANFD_RXFIFO_ID_ID_STD_MASK;
276 	}
277 	cf->can_id = id;
278 
279 	if (rxdlc & IFI_CANFD_RXFIFO_DLC_ESI) {
280 		cf->flags |= CANFD_ESI;
281 		netdev_dbg(ndev, "ESI Error\n");
282 	}
283 
284 	if (!(rxdlc & IFI_CANFD_RXFIFO_DLC_EDL) &&
285 	    (rxdlc & IFI_CANFD_RXFIFO_DLC_RTR)) {
286 		cf->can_id |= CAN_RTR_FLAG;
287 	} else {
288 		if (rxdlc & IFI_CANFD_RXFIFO_DLC_BRS)
289 			cf->flags |= CANFD_BRS;
290 
291 		for (i = 0; i < cf->len; i += 4) {
292 			*(u32 *)(cf->data + i) =
293 				readl(priv->base + IFI_CANFD_RXFIFO_DATA + i);
294 		}
295 	}
296 
297 	/* Remove the packet from FIFO */
298 	writel(IFI_CANFD_RXSTCMD_REMOVE_MSG, priv->base + IFI_CANFD_RXSTCMD);
299 	writel(rx_irq_mask, priv->base + IFI_CANFD_INTERRUPT);
300 
301 	stats->rx_packets++;
302 	stats->rx_bytes += cf->len;
303 
304 	netif_receive_skb(skb);
305 }
306 
307 static int ifi_canfd_do_rx_poll(struct net_device *ndev, int quota)
308 {
309 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
310 	u32 pkts = 0;
311 	u32 rxst;
312 
313 	rxst = readl(priv->base + IFI_CANFD_RXSTCMD);
314 	if (rxst & IFI_CANFD_RXSTCMD_EMPTY) {
315 		netdev_dbg(ndev, "No messages in RX FIFO\n");
316 		return 0;
317 	}
318 
319 	for (;;) {
320 		if (rxst & IFI_CANFD_RXSTCMD_EMPTY)
321 			break;
322 		if (quota <= 0)
323 			break;
324 
325 		ifi_canfd_read_fifo(ndev);
326 		quota--;
327 		pkts++;
328 		rxst = readl(priv->base + IFI_CANFD_RXSTCMD);
329 	}
330 
331 	if (pkts)
332 		can_led_event(ndev, CAN_LED_EVENT_RX);
333 
334 	return pkts;
335 }
336 
337 static int ifi_canfd_handle_lost_msg(struct net_device *ndev)
338 {
339 	struct net_device_stats *stats = &ndev->stats;
340 	struct sk_buff *skb;
341 	struct can_frame *frame;
342 
343 	netdev_err(ndev, "RX FIFO overflow, message(s) lost.\n");
344 
345 	stats->rx_errors++;
346 	stats->rx_over_errors++;
347 
348 	skb = alloc_can_err_skb(ndev, &frame);
349 	if (unlikely(!skb))
350 		return 0;
351 
352 	frame->can_id |= CAN_ERR_CRTL;
353 	frame->data[1] = CAN_ERR_CRTL_RX_OVERFLOW;
354 
355 	netif_receive_skb(skb);
356 
357 	return 1;
358 }
359 
360 static int ifi_canfd_handle_lec_err(struct net_device *ndev, const u32 errctr)
361 {
362 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
363 	struct net_device_stats *stats = &ndev->stats;
364 	struct can_frame *cf;
365 	struct sk_buff *skb;
366 	const u32 errmask = IFI_CANFD_ERROR_CTR_OVERLOAD_FIRST |
367 			    IFI_CANFD_ERROR_CTR_ACK_ERROR_FIRST |
368 			    IFI_CANFD_ERROR_CTR_BIT0_ERROR_FIRST |
369 			    IFI_CANFD_ERROR_CTR_BIT1_ERROR_FIRST |
370 			    IFI_CANFD_ERROR_CTR_STUFF_ERROR_FIRST |
371 			    IFI_CANFD_ERROR_CTR_CRC_ERROR_FIRST |
372 			    IFI_CANFD_ERROR_CTR_FORM_ERROR_FIRST;
373 
374 	if (!(errctr & errmask))	/* No error happened. */
375 		return 0;
376 
377 	priv->can.can_stats.bus_error++;
378 	stats->rx_errors++;
379 
380 	/* Propagate the error condition to the CAN stack. */
381 	skb = alloc_can_err_skb(ndev, &cf);
382 	if (unlikely(!skb))
383 		return 0;
384 
385 	/* Read the error counter register and check for new errors. */
386 	cf->can_id |= CAN_ERR_PROT | CAN_ERR_BUSERROR;
387 
388 	if (errctr & IFI_CANFD_ERROR_CTR_OVERLOAD_FIRST)
389 		cf->data[2] |= CAN_ERR_PROT_OVERLOAD;
390 
391 	if (errctr & IFI_CANFD_ERROR_CTR_ACK_ERROR_FIRST)
392 		cf->data[3] = CAN_ERR_PROT_LOC_ACK;
393 
394 	if (errctr & IFI_CANFD_ERROR_CTR_BIT0_ERROR_FIRST)
395 		cf->data[2] |= CAN_ERR_PROT_BIT0;
396 
397 	if (errctr & IFI_CANFD_ERROR_CTR_BIT1_ERROR_FIRST)
398 		cf->data[2] |= CAN_ERR_PROT_BIT1;
399 
400 	if (errctr & IFI_CANFD_ERROR_CTR_STUFF_ERROR_FIRST)
401 		cf->data[2] |= CAN_ERR_PROT_STUFF;
402 
403 	if (errctr & IFI_CANFD_ERROR_CTR_CRC_ERROR_FIRST)
404 		cf->data[3] = CAN_ERR_PROT_LOC_CRC_SEQ;
405 
406 	if (errctr & IFI_CANFD_ERROR_CTR_FORM_ERROR_FIRST)
407 		cf->data[2] |= CAN_ERR_PROT_FORM;
408 
409 	/* Reset the error counter, ack the IRQ and re-enable the counter. */
410 	writel(IFI_CANFD_ERROR_CTR_ER_RESET, priv->base + IFI_CANFD_ERROR_CTR);
411 	writel(IFI_CANFD_INTERRUPT_ERROR_COUNTER,
412 	       priv->base + IFI_CANFD_INTERRUPT);
413 	writel(IFI_CANFD_ERROR_CTR_ER_ENABLE, priv->base + IFI_CANFD_ERROR_CTR);
414 
415 	stats->rx_packets++;
416 	stats->rx_bytes += cf->can_dlc;
417 	netif_receive_skb(skb);
418 
419 	return 1;
420 }
421 
422 static int ifi_canfd_get_berr_counter(const struct net_device *ndev,
423 				      struct can_berr_counter *bec)
424 {
425 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
426 	u32 err;
427 
428 	err = readl(priv->base + IFI_CANFD_ERROR);
429 	bec->rxerr = (err >> IFI_CANFD_ERROR_RX_OFFSET) &
430 		     IFI_CANFD_ERROR_RX_MASK;
431 	bec->txerr = (err >> IFI_CANFD_ERROR_TX_OFFSET) &
432 		     IFI_CANFD_ERROR_TX_MASK;
433 
434 	return 0;
435 }
436 
437 static int ifi_canfd_handle_state_change(struct net_device *ndev,
438 					 enum can_state new_state)
439 {
440 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
441 	struct net_device_stats *stats = &ndev->stats;
442 	struct can_frame *cf;
443 	struct sk_buff *skb;
444 	struct can_berr_counter bec;
445 
446 	switch (new_state) {
447 	case CAN_STATE_ERROR_ACTIVE:
448 		/* error warning state */
449 		priv->can.can_stats.error_warning++;
450 		priv->can.state = CAN_STATE_ERROR_WARNING;
451 		break;
452 	case CAN_STATE_ERROR_PASSIVE:
453 		/* error passive state */
454 		priv->can.can_stats.error_passive++;
455 		priv->can.state = CAN_STATE_ERROR_PASSIVE;
456 		break;
457 	case CAN_STATE_BUS_OFF:
458 		/* bus-off state */
459 		priv->can.state = CAN_STATE_BUS_OFF;
460 		ifi_canfd_irq_enable(ndev, 0);
461 		priv->can.can_stats.bus_off++;
462 		can_bus_off(ndev);
463 		break;
464 	default:
465 		break;
466 	}
467 
468 	/* propagate the error condition to the CAN stack */
469 	skb = alloc_can_err_skb(ndev, &cf);
470 	if (unlikely(!skb))
471 		return 0;
472 
473 	ifi_canfd_get_berr_counter(ndev, &bec);
474 
475 	switch (new_state) {
476 	case CAN_STATE_ERROR_ACTIVE:
477 		/* error warning state */
478 		cf->can_id |= CAN_ERR_CRTL;
479 		cf->data[1] = (bec.txerr > bec.rxerr) ?
480 			CAN_ERR_CRTL_TX_WARNING :
481 			CAN_ERR_CRTL_RX_WARNING;
482 		cf->data[6] = bec.txerr;
483 		cf->data[7] = bec.rxerr;
484 		break;
485 	case CAN_STATE_ERROR_PASSIVE:
486 		/* error passive state */
487 		cf->can_id |= CAN_ERR_CRTL;
488 		cf->data[1] |= CAN_ERR_CRTL_RX_PASSIVE;
489 		if (bec.txerr > 127)
490 			cf->data[1] |= CAN_ERR_CRTL_TX_PASSIVE;
491 		cf->data[6] = bec.txerr;
492 		cf->data[7] = bec.rxerr;
493 		break;
494 	case CAN_STATE_BUS_OFF:
495 		/* bus-off state */
496 		cf->can_id |= CAN_ERR_BUSOFF;
497 		break;
498 	default:
499 		break;
500 	}
501 
502 	stats->rx_packets++;
503 	stats->rx_bytes += cf->can_dlc;
504 	netif_receive_skb(skb);
505 
506 	return 1;
507 }
508 
509 static int ifi_canfd_handle_state_errors(struct net_device *ndev, u32 stcmd)
510 {
511 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
512 	int work_done = 0;
513 	u32 isr;
514 
515 	/*
516 	 * The ErrWarn condition is a little special, since the bit is
517 	 * located in the INTERRUPT register instead of STCMD register.
518 	 */
519 	isr = readl(priv->base + IFI_CANFD_INTERRUPT);
520 	if ((isr & IFI_CANFD_INTERRUPT_ERROR_WARNING) &&
521 	    (priv->can.state != CAN_STATE_ERROR_WARNING)) {
522 		/* Clear the interrupt */
523 		writel(IFI_CANFD_INTERRUPT_ERROR_WARNING,
524 		       priv->base + IFI_CANFD_INTERRUPT);
525 		netdev_dbg(ndev, "Error, entered warning state\n");
526 		work_done += ifi_canfd_handle_state_change(ndev,
527 						CAN_STATE_ERROR_WARNING);
528 	}
529 
530 	if ((stcmd & IFI_CANFD_STCMD_ERROR_PASSIVE) &&
531 	    (priv->can.state != CAN_STATE_ERROR_PASSIVE)) {
532 		netdev_dbg(ndev, "Error, entered passive state\n");
533 		work_done += ifi_canfd_handle_state_change(ndev,
534 						CAN_STATE_ERROR_PASSIVE);
535 	}
536 
537 	if ((stcmd & IFI_CANFD_STCMD_BUSOFF) &&
538 	    (priv->can.state != CAN_STATE_BUS_OFF)) {
539 		netdev_dbg(ndev, "Error, entered bus-off state\n");
540 		work_done += ifi_canfd_handle_state_change(ndev,
541 						CAN_STATE_BUS_OFF);
542 	}
543 
544 	return work_done;
545 }
546 
547 static int ifi_canfd_poll(struct napi_struct *napi, int quota)
548 {
549 	struct net_device *ndev = napi->dev;
550 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
551 	const u32 stcmd_state_mask = IFI_CANFD_STCMD_ERROR_PASSIVE |
552 				     IFI_CANFD_STCMD_BUSOFF;
553 	int work_done = 0;
554 
555 	u32 stcmd = readl(priv->base + IFI_CANFD_STCMD);
556 	u32 rxstcmd = readl(priv->base + IFI_CANFD_STCMD);
557 	u32 errctr = readl(priv->base + IFI_CANFD_ERROR_CTR);
558 
559 	/* Handle bus state changes */
560 	if ((stcmd & stcmd_state_mask) ||
561 	    ((stcmd & IFI_CANFD_STCMD_ERROR_ACTIVE) == 0))
562 		work_done += ifi_canfd_handle_state_errors(ndev, stcmd);
563 
564 	/* Handle lost messages on RX */
565 	if (rxstcmd & IFI_CANFD_RXSTCMD_OVERFLOW)
566 		work_done += ifi_canfd_handle_lost_msg(ndev);
567 
568 	/* Handle lec errors on the bus */
569 	if (priv->can.ctrlmode & CAN_CTRLMODE_BERR_REPORTING)
570 		work_done += ifi_canfd_handle_lec_err(ndev, errctr);
571 
572 	/* Handle normal messages on RX */
573 	if (!(rxstcmd & IFI_CANFD_RXSTCMD_EMPTY))
574 		work_done += ifi_canfd_do_rx_poll(ndev, quota - work_done);
575 
576 	if (work_done < quota) {
577 		napi_complete(napi);
578 		ifi_canfd_irq_enable(ndev, 1);
579 	}
580 
581 	return work_done;
582 }
583 
584 static irqreturn_t ifi_canfd_isr(int irq, void *dev_id)
585 {
586 	struct net_device *ndev = (struct net_device *)dev_id;
587 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
588 	struct net_device_stats *stats = &ndev->stats;
589 	const u32 rx_irq_mask = IFI_CANFD_INTERRUPT_RXFIFO_NEMPTY |
590 				IFI_CANFD_INTERRUPT_RXFIFO_NEMPTY_PER |
591 				IFI_CANFD_INTERRUPT_ERROR_WARNING |
592 				IFI_CANFD_INTERRUPT_ERROR_COUNTER;
593 	const u32 tx_irq_mask = IFI_CANFD_INTERRUPT_TXFIFO_EMPTY |
594 				IFI_CANFD_INTERRUPT_TXFIFO_REMOVE;
595 	const u32 clr_irq_mask = ~((u32)(IFI_CANFD_INTERRUPT_SET_IRQ |
596 					 IFI_CANFD_INTERRUPT_ERROR_WARNING));
597 	u32 isr;
598 
599 	isr = readl(priv->base + IFI_CANFD_INTERRUPT);
600 
601 	/* No interrupt */
602 	if (isr == 0)
603 		return IRQ_NONE;
604 
605 	/* Clear all pending interrupts but ErrWarn */
606 	writel(clr_irq_mask, priv->base + IFI_CANFD_INTERRUPT);
607 
608 	/* RX IRQ or bus warning, start NAPI */
609 	if (isr & rx_irq_mask) {
610 		ifi_canfd_irq_enable(ndev, 0);
611 		napi_schedule(&priv->napi);
612 	}
613 
614 	/* TX IRQ */
615 	if (isr & IFI_CANFD_INTERRUPT_TXFIFO_REMOVE) {
616 		stats->tx_bytes += can_get_echo_skb(ndev, 0);
617 		stats->tx_packets++;
618 		can_led_event(ndev, CAN_LED_EVENT_TX);
619 	}
620 
621 	if (isr & tx_irq_mask)
622 		netif_wake_queue(ndev);
623 
624 	return IRQ_HANDLED;
625 }
626 
627 static const struct can_bittiming_const ifi_canfd_bittiming_const = {
628 	.name		= KBUILD_MODNAME,
629 	.tseg1_min	= 1,	/* Time segment 1 = prop_seg + phase_seg1 */
630 	.tseg1_max	= 256,
631 	.tseg2_min	= 2,	/* Time segment 2 = phase_seg2 */
632 	.tseg2_max	= 256,
633 	.sjw_max	= 128,
634 	.brp_min	= 2,
635 	.brp_max	= 512,
636 	.brp_inc	= 1,
637 };
638 
639 static void ifi_canfd_set_bittiming(struct net_device *ndev)
640 {
641 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
642 	const struct can_bittiming *bt = &priv->can.bittiming;
643 	const struct can_bittiming *dbt = &priv->can.data_bittiming;
644 	u16 brp, sjw, tseg1, tseg2;
645 
646 	/* Configure bit timing */
647 	brp = bt->brp - 2;
648 	sjw = bt->sjw - 1;
649 	tseg1 = bt->prop_seg + bt->phase_seg1 - 1;
650 	tseg2 = bt->phase_seg2 - 2;
651 	writel((tseg2 << IFI_CANFD_TIME_TIMEB_OFF) |
652 	       (tseg1 << IFI_CANFD_TIME_TIMEA_OFF) |
653 	       (brp << IFI_CANFD_TIME_PRESCALE_OFF) |
654 	       (sjw << IFI_CANFD_TIME_SJW_OFF_7_9_8_8),
655 	       priv->base + IFI_CANFD_TIME);
656 
657 	/* Configure data bit timing */
658 	brp = dbt->brp - 2;
659 	sjw = dbt->sjw - 1;
660 	tseg1 = dbt->prop_seg + dbt->phase_seg1 - 1;
661 	tseg2 = dbt->phase_seg2 - 2;
662 	writel((tseg2 << IFI_CANFD_TIME_TIMEB_OFF) |
663 	       (tseg1 << IFI_CANFD_TIME_TIMEA_OFF) |
664 	       (brp << IFI_CANFD_TIME_PRESCALE_OFF) |
665 	       (sjw << IFI_CANFD_TIME_SJW_OFF_7_9_8_8),
666 	       priv->base + IFI_CANFD_FTIME);
667 }
668 
669 static void ifi_canfd_set_filter(struct net_device *ndev, const u32 id,
670 				 const u32 mask, const u32 ident)
671 {
672 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
673 
674 	writel(mask, priv->base + IFI_CANFD_FILTER_MASK(id));
675 	writel(ident, priv->base + IFI_CANFD_FILTER_IDENT(id));
676 }
677 
678 static void ifi_canfd_set_filters(struct net_device *ndev)
679 {
680 	/* Receive all CAN frames (standard ID) */
681 	ifi_canfd_set_filter(ndev, 0,
682 			     IFI_CANFD_FILTER_MASK_VALID |
683 			     IFI_CANFD_FILTER_MASK_EXT,
684 			     IFI_CANFD_FILTER_IDENT_VALID);
685 
686 	/* Receive all CAN frames (extended ID) */
687 	ifi_canfd_set_filter(ndev, 1,
688 			     IFI_CANFD_FILTER_MASK_VALID |
689 			     IFI_CANFD_FILTER_MASK_EXT,
690 			     IFI_CANFD_FILTER_IDENT_VALID |
691 			     IFI_CANFD_FILTER_IDENT_IDE);
692 
693 	/* Receive all CANFD frames */
694 	ifi_canfd_set_filter(ndev, 2,
695 			     IFI_CANFD_FILTER_MASK_VALID |
696 			     IFI_CANFD_FILTER_MASK_EDL |
697 			     IFI_CANFD_FILTER_MASK_EXT,
698 			     IFI_CANFD_FILTER_IDENT_VALID |
699 			     IFI_CANFD_FILTER_IDENT_CANFD |
700 			     IFI_CANFD_FILTER_IDENT_IDE);
701 }
702 
703 static void ifi_canfd_start(struct net_device *ndev)
704 {
705 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
706 	u32 stcmd;
707 
708 	/* Reset the IP */
709 	writel(IFI_CANFD_STCMD_HARDRESET, priv->base + IFI_CANFD_STCMD);
710 	writel(IFI_CANFD_STCMD_ENABLE_7_9_8_8_TIMING,
711 	       priv->base + IFI_CANFD_STCMD);
712 
713 	ifi_canfd_set_bittiming(ndev);
714 	ifi_canfd_set_filters(ndev);
715 
716 	/* Reset FIFOs */
717 	writel(IFI_CANFD_RXSTCMD_RESET, priv->base + IFI_CANFD_RXSTCMD);
718 	writel(0, priv->base + IFI_CANFD_RXSTCMD);
719 	writel(IFI_CANFD_TXSTCMD_RESET, priv->base + IFI_CANFD_TXSTCMD);
720 	writel(0, priv->base + IFI_CANFD_TXSTCMD);
721 
722 	/* Repeat transmission until successful */
723 	writel(0, priv->base + IFI_CANFD_REPEAT);
724 	writel(0, priv->base + IFI_CANFD_SUSPEND);
725 
726 	/* Clear all pending interrupts */
727 	writel((u32)(~IFI_CANFD_INTERRUPT_SET_IRQ),
728 	       priv->base + IFI_CANFD_INTERRUPT);
729 
730 	stcmd = IFI_CANFD_STCMD_ENABLE | IFI_CANFD_STCMD_NORMAL_MODE |
731 		IFI_CANFD_STCMD_ENABLE_7_9_8_8_TIMING;
732 
733 	if (priv->can.ctrlmode & CAN_CTRLMODE_LISTENONLY)
734 		stcmd |= IFI_CANFD_STCMD_BUSMONITOR;
735 
736 	if (priv->can.ctrlmode & CAN_CTRLMODE_LOOPBACK)
737 		stcmd |= IFI_CANFD_STCMD_LOOPBACK;
738 
739 	if ((priv->can.ctrlmode & CAN_CTRLMODE_FD) &&
740 	    !(priv->can.ctrlmode & CAN_CTRLMODE_FD_NON_ISO))
741 		stcmd |= IFI_CANFD_STCMD_ENABLE_ISO;
742 
743 	if (!(priv->can.ctrlmode & CAN_CTRLMODE_FD))
744 		stcmd |= IFI_CANFD_STCMD_DISABLE_CANFD;
745 
746 	priv->can.state = CAN_STATE_ERROR_ACTIVE;
747 
748 	ifi_canfd_irq_enable(ndev, 1);
749 
750 	/* Unlock, reset and enable the error counter. */
751 	writel(IFI_CANFD_ERROR_CTR_UNLOCK_MAGIC,
752 	       priv->base + IFI_CANFD_ERROR_CTR);
753 	writel(IFI_CANFD_ERROR_CTR_ER_RESET, priv->base + IFI_CANFD_ERROR_CTR);
754 	writel(IFI_CANFD_ERROR_CTR_ER_ENABLE, priv->base + IFI_CANFD_ERROR_CTR);
755 
756 	/* Enable controller */
757 	writel(stcmd, priv->base + IFI_CANFD_STCMD);
758 }
759 
760 static void ifi_canfd_stop(struct net_device *ndev)
761 {
762 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
763 
764 	/* Reset and disable the error counter. */
765 	writel(IFI_CANFD_ERROR_CTR_ER_RESET, priv->base + IFI_CANFD_ERROR_CTR);
766 	writel(0, priv->base + IFI_CANFD_ERROR_CTR);
767 
768 	/* Reset the IP */
769 	writel(IFI_CANFD_STCMD_HARDRESET, priv->base + IFI_CANFD_STCMD);
770 
771 	/* Mask all interrupts */
772 	writel(~0, priv->base + IFI_CANFD_IRQMASK);
773 
774 	/* Clear all pending interrupts */
775 	writel((u32)(~IFI_CANFD_INTERRUPT_SET_IRQ),
776 	       priv->base + IFI_CANFD_INTERRUPT);
777 
778 	/* Set the state as STOPPED */
779 	priv->can.state = CAN_STATE_STOPPED;
780 }
781 
782 static int ifi_canfd_set_mode(struct net_device *ndev, enum can_mode mode)
783 {
784 	switch (mode) {
785 	case CAN_MODE_START:
786 		ifi_canfd_start(ndev);
787 		netif_wake_queue(ndev);
788 		break;
789 	default:
790 		return -EOPNOTSUPP;
791 	}
792 
793 	return 0;
794 }
795 
796 static int ifi_canfd_open(struct net_device *ndev)
797 {
798 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
799 	int ret;
800 
801 	ret = open_candev(ndev);
802 	if (ret) {
803 		netdev_err(ndev, "Failed to open CAN device\n");
804 		return ret;
805 	}
806 
807 	/* Register interrupt handler */
808 	ret = request_irq(ndev->irq, ifi_canfd_isr, IRQF_SHARED,
809 			  ndev->name, ndev);
810 	if (ret < 0) {
811 		netdev_err(ndev, "Failed to request interrupt\n");
812 		goto err_irq;
813 	}
814 
815 	ifi_canfd_start(ndev);
816 
817 	can_led_event(ndev, CAN_LED_EVENT_OPEN);
818 	napi_enable(&priv->napi);
819 	netif_start_queue(ndev);
820 
821 	return 0;
822 err_irq:
823 	close_candev(ndev);
824 	return ret;
825 }
826 
827 static int ifi_canfd_close(struct net_device *ndev)
828 {
829 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
830 
831 	netif_stop_queue(ndev);
832 	napi_disable(&priv->napi);
833 
834 	ifi_canfd_stop(ndev);
835 
836 	free_irq(ndev->irq, ndev);
837 
838 	close_candev(ndev);
839 
840 	can_led_event(ndev, CAN_LED_EVENT_STOP);
841 
842 	return 0;
843 }
844 
845 static netdev_tx_t ifi_canfd_start_xmit(struct sk_buff *skb,
846 					struct net_device *ndev)
847 {
848 	struct ifi_canfd_priv *priv = netdev_priv(ndev);
849 	struct canfd_frame *cf = (struct canfd_frame *)skb->data;
850 	u32 txst, txid, txdlc;
851 	int i;
852 
853 	if (can_dropped_invalid_skb(ndev, skb))
854 		return NETDEV_TX_OK;
855 
856 	/* Check if the TX buffer is full */
857 	txst = readl(priv->base + IFI_CANFD_TXSTCMD);
858 	if (txst & IFI_CANFD_TXSTCMD_FULL) {
859 		netif_stop_queue(ndev);
860 		netdev_err(ndev, "BUG! TX FIFO full when queue awake!\n");
861 		return NETDEV_TX_BUSY;
862 	}
863 
864 	netif_stop_queue(ndev);
865 
866 	if (cf->can_id & CAN_EFF_FLAG) {
867 		txid = cf->can_id & CAN_EFF_MASK;
868 		/*
869 		 * In case the Extended ID frame is transmitted, the
870 		 * standard and extended part of the ID are swapped
871 		 * in the register, so swap them back to send the
872 		 * correct ID.
873 		 */
874 		txid = (txid >> IFI_CANFD_TXFIFO_ID_ID_XTD_WIDTH) |
875 		       ((txid & IFI_CANFD_TXFIFO_ID_ID_XTD_MASK) <<
876 		         IFI_CANFD_TXFIFO_ID_ID_XTD_OFFSET);
877 		txid |= IFI_CANFD_TXFIFO_ID_IDE;
878 	} else {
879 		txid = cf->can_id & CAN_SFF_MASK;
880 	}
881 
882 	txdlc = can_len2dlc(cf->len);
883 	if ((priv->can.ctrlmode & CAN_CTRLMODE_FD) && can_is_canfd_skb(skb)) {
884 		txdlc |= IFI_CANFD_TXFIFO_DLC_EDL;
885 		if (cf->flags & CANFD_BRS)
886 			txdlc |= IFI_CANFD_TXFIFO_DLC_BRS;
887 	}
888 
889 	if (cf->can_id & CAN_RTR_FLAG)
890 		txdlc |= IFI_CANFD_TXFIFO_DLC_RTR;
891 
892 	/* message ram configuration */
893 	writel(txid, priv->base + IFI_CANFD_TXFIFO_ID);
894 	writel(txdlc, priv->base + IFI_CANFD_TXFIFO_DLC);
895 
896 	for (i = 0; i < cf->len; i += 4) {
897 		writel(*(u32 *)(cf->data + i),
898 		       priv->base + IFI_CANFD_TXFIFO_DATA + i);
899 	}
900 
901 	writel(0, priv->base + IFI_CANFD_TXFIFO_REPEATCOUNT);
902 	writel(0, priv->base + IFI_CANFD_TXFIFO_SUSPEND_US);
903 
904 	can_put_echo_skb(skb, ndev, 0);
905 
906 	/* Start the transmission */
907 	writel(IFI_CANFD_TXSTCMD_ADD_MSG, priv->base + IFI_CANFD_TXSTCMD);
908 
909 	return NETDEV_TX_OK;
910 }
911 
912 static const struct net_device_ops ifi_canfd_netdev_ops = {
913 	.ndo_open	= ifi_canfd_open,
914 	.ndo_stop	= ifi_canfd_close,
915 	.ndo_start_xmit	= ifi_canfd_start_xmit,
916 	.ndo_change_mtu	= can_change_mtu,
917 };
918 
919 static int ifi_canfd_plat_probe(struct platform_device *pdev)
920 {
921 	struct device *dev = &pdev->dev;
922 	struct net_device *ndev;
923 	struct ifi_canfd_priv *priv;
924 	struct resource *res;
925 	void __iomem *addr;
926 	int irq, ret;
927 	u32 id;
928 
929 	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
930 	addr = devm_ioremap_resource(dev, res);
931 	irq = platform_get_irq(pdev, 0);
932 	if (IS_ERR(addr) || irq < 0)
933 		return -EINVAL;
934 
935 	id = readl(addr + IFI_CANFD_IP_ID);
936 	if (id != IFI_CANFD_IP_ID_VALUE) {
937 		dev_err(dev, "This block is not IFI CANFD, id=%08x\n", id);
938 		return -EINVAL;
939 	}
940 
941 	ndev = alloc_candev(sizeof(*priv), 1);
942 	if (!ndev)
943 		return -ENOMEM;
944 
945 	ndev->irq = irq;
946 	ndev->flags |= IFF_ECHO;	/* we support local echo */
947 	ndev->netdev_ops = &ifi_canfd_netdev_ops;
948 
949 	priv = netdev_priv(ndev);
950 	priv->ndev = ndev;
951 	priv->base = addr;
952 
953 	netif_napi_add(ndev, &priv->napi, ifi_canfd_poll, 64);
954 
955 	priv->can.state = CAN_STATE_STOPPED;
956 
957 	priv->can.clock.freq = readl(addr + IFI_CANFD_CANCLOCK);
958 
959 	priv->can.bittiming_const	= &ifi_canfd_bittiming_const;
960 	priv->can.data_bittiming_const	= &ifi_canfd_bittiming_const;
961 	priv->can.do_set_mode		= ifi_canfd_set_mode;
962 	priv->can.do_get_berr_counter	= ifi_canfd_get_berr_counter;
963 
964 	/* IFI CANFD can do both Bosch FD and ISO FD */
965 	priv->can.ctrlmode = CAN_CTRLMODE_FD;
966 
967 	/* IFI CANFD can do both Bosch FD and ISO FD */
968 	priv->can.ctrlmode_supported = CAN_CTRLMODE_LOOPBACK |
969 				       CAN_CTRLMODE_LISTENONLY |
970 				       CAN_CTRLMODE_FD |
971 				       CAN_CTRLMODE_FD_NON_ISO |
972 				       CAN_CTRLMODE_BERR_REPORTING;
973 
974 	platform_set_drvdata(pdev, ndev);
975 	SET_NETDEV_DEV(ndev, dev);
976 
977 	ret = register_candev(ndev);
978 	if (ret) {
979 		dev_err(dev, "Failed to register (ret=%d)\n", ret);
980 		goto err_reg;
981 	}
982 
983 	devm_can_led_init(ndev);
984 
985 	dev_info(dev, "Driver registered: regs=%p, irq=%d, clock=%d\n",
986 		 priv->base, ndev->irq, priv->can.clock.freq);
987 
988 	return 0;
989 
990 err_reg:
991 	free_candev(ndev);
992 	return ret;
993 }
994 
995 static int ifi_canfd_plat_remove(struct platform_device *pdev)
996 {
997 	struct net_device *ndev = platform_get_drvdata(pdev);
998 
999 	unregister_candev(ndev);
1000 	platform_set_drvdata(pdev, NULL);
1001 	free_candev(ndev);
1002 
1003 	return 0;
1004 }
1005 
1006 static const struct of_device_id ifi_canfd_of_table[] = {
1007 	{ .compatible = "ifi,canfd-1.0", .data = NULL },
1008 	{ /* sentinel */ },
1009 };
1010 MODULE_DEVICE_TABLE(of, ifi_canfd_of_table);
1011 
1012 static struct platform_driver ifi_canfd_plat_driver = {
1013 	.driver = {
1014 		.name		= KBUILD_MODNAME,
1015 		.of_match_table	= ifi_canfd_of_table,
1016 	},
1017 	.probe	= ifi_canfd_plat_probe,
1018 	.remove	= ifi_canfd_plat_remove,
1019 };
1020 
1021 module_platform_driver(ifi_canfd_plat_driver);
1022 
1023 MODULE_AUTHOR("Marek Vasut <marex@denx.de>");
1024 MODULE_LICENSE("GPL v2");
1025 MODULE_DESCRIPTION("CAN bus driver for IFI CANFD controller");
1026