0011-CAN-starfive-Add-CAN-engine-support.patch 37 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316
  1. From 94de8add412dffdfa0389c6ae0f6aaad64d34fcd Mon Sep 17 00:00:00 2001
  2. From: William Qiu <[email protected]>
  3. Date: Thu, 15 Jun 2023 20:15:25 +0800
  4. Subject: [PATCH 11/55] CAN: starfive - Add CAN engine support
  5. Adding device probe StarFive CAN module.
  6. Signed-off-by: William Qiu <[email protected]>
  7. Signed-off-by: Hal Feng <[email protected]>
  8. ---
  9. drivers/net/can/Kconfig | 5 +
  10. drivers/net/can/Makefile | 2 +
  11. drivers/net/can/ipms_canfd.c | 1273 ++++++++++++++++++++++++++++++++++
  12. 3 files changed, 1280 insertions(+)
  13. create mode 100644 drivers/net/can/ipms_canfd.c
  14. --- a/drivers/net/can/Kconfig
  15. +++ b/drivers/net/can/Kconfig
  16. @@ -216,6 +216,11 @@ config CAN_XILINXCAN
  17. Xilinx CAN driver. This driver supports both soft AXI CAN IP and
  18. Zynq CANPS IP.
  19. +config IPMS_CAN
  20. + tristate "IPMS CAN"
  21. + help
  22. + IPMS CANFD driver. This driver supports IPMS CANFD IP.
  23. +
  24. source "drivers/net/can/c_can/Kconfig"
  25. source "drivers/net/can/cc770/Kconfig"
  26. source "drivers/net/can/ctucanfd/Kconfig"
  27. --- a/drivers/net/can/Makefile
  28. +++ b/drivers/net/can/Makefile
  29. @@ -33,5 +33,7 @@ obj-$(CONFIG_CAN_SJA1000) += sja1000/
  30. obj-$(CONFIG_CAN_SUN4I) += sun4i_can.o
  31. obj-$(CONFIG_CAN_TI_HECC) += ti_hecc.o
  32. obj-$(CONFIG_CAN_XILINXCAN) += xilinx_can.o
  33. +obj-$(CONFIG_IPMS_CAN) += ipms_canfd.o
  34. +ccflags-$(CONFIG_IPMS_CAN) := -Wno-error=missing-prototypes
  35. subdir-ccflags-$(CONFIG_CAN_DEBUG_DEVICES) += -DDEBUG
  36. --- /dev/null
  37. +++ b/drivers/net/can/ipms_canfd.c
  38. @@ -0,0 +1,1273 @@
  39. +// SPDX-License-Identifier: GPL-2.0
  40. +/*
  41. + * StarFive Controller Area Network Host Controller Driver
  42. + *
  43. + * Copyright (c) 2022 StarFive Technology Co., Ltd.
  44. + */
  45. +
  46. +#include <linux/clk.h>
  47. +#include <linux/reset.h>
  48. +#include <linux/errno.h>
  49. +#include <linux/init.h>
  50. +#include <linux/interrupt.h>
  51. +#include <linux/io.h>
  52. +#include <linux/kernel.h>
  53. +#include <linux/module.h>
  54. +#include <linux/netdevice.h>
  55. +#include <linux/of.h>
  56. +#include <linux/platform_device.h>
  57. +#include <linux/skbuff.h>
  58. +#include <linux/string.h>
  59. +#include <linux/types.h>
  60. +#include <linux/can/dev.h>
  61. +#include <linux/can/error.h>
  62. +#include <linux/pm_runtime.h>
  63. +#include <linux/of_device.h>
  64. +#include <linux/mfd/syscon.h>
  65. +#include <linux/regmap.h>
  66. +
  67. +#define DRIVER_NAME "ipms_canfd"
  68. +
  69. +/* CAN registers set */
  70. +enum canfd_device_reg {
  71. + CANFD_RUBF_OFFSET = 0x00, /* Receive Buffer Registers 0x00-0x4f */
  72. + CANFD_RUBF_ID_OFFSET = 0x00,
  73. + CANFD_RBUF_CTL_OFFSET = 0x04,
  74. + CANFD_RBUF_DATA_OFFSET = 0x08,
  75. + CANFD_TBUF_OFFSET = 0x50, /* Transmit Buffer Registers 0x50-0x97 */
  76. + CANFD_TBUF_ID_OFFSET = 0x50,
  77. + CANFD_TBUF_CTL_OFFSET = 0x54,
  78. + CANFD_TBUF_DATA_OFFSET = 0x58,
  79. + CANFD_TTS_OFFSET = 0x98, /* Transmission Time Stamp 0x98-0x9f */
  80. + CANFD_CFG_STAT_OFFSET = 0xa0,
  81. + CANFD_TCMD_OFFSET = 0xa1,
  82. + CANFD_TCTRL_OFFSET = 0xa2,
  83. + CANFD_RCTRL_OFFSET = 0xa3,
  84. + CANFD_RTIE_OFFSET = 0xa4,
  85. + CANFD_RTIF_OFFSET = 0xa5,
  86. + CANFD_ERRINT_OFFSET = 0xa6,
  87. + CANFD_LIMIT_OFFSET = 0xa7,
  88. + CANFD_S_SEG_1_OFFSET = 0xa8,
  89. + CANFD_S_SEG_2_OFFSET = 0xa9,
  90. + CANFD_S_SJW_OFFSET = 0xaa,
  91. + CANFD_S_PRESC_OFFSET = 0xab,
  92. + CANFD_F_SEG_1_OFFSET = 0xac,
  93. + CANFD_F_SEG_2_OFFSET = 0xad,
  94. + CANFD_F_SJW_OFFSET = 0xae,
  95. + CANFD_F_PRESC_OFFSET = 0xaf,
  96. + CANFD_EALCAP_OFFSET = 0xb0,
  97. + CANFD_RECNT_OFFSET = 0xb2,
  98. + CANFD_TECNT_OFFSET = 0xb3,
  99. +};
  100. +
  101. +enum canfd_reg_bitchange {
  102. + CAN_FD_SET_RST_MASK = 0x80, /* Set Reset Bit */
  103. + CAN_FD_OFF_RST_MASK = 0x7f, /* Reset Off Bit */
  104. + CAN_FD_SET_FULLCAN_MASK = 0x10, /* set TTTBM as 1->full TTCAN mode */
  105. + CAN_FD_OFF_FULLCAN_MASK = 0xef, /* set TTTBM as 0->separate PTB and STB mode */
  106. + CAN_FD_SET_FIFO_MASK = 0x20, /* set TSMODE as 1->FIFO mode */
  107. + CAN_FD_OFF_FIFO_MASK = 0xdf, /* set TSMODE as 0->Priority mode */
  108. + CAN_FD_SET_TSONE_MASK = 0x04,
  109. + CAN_FD_OFF_TSONE_MASK = 0xfb,
  110. + CAN_FD_SET_TSALL_MASK = 0x02,
  111. + CAN_FD_OFF_TSALL_MASK = 0xfd,
  112. + CAN_FD_LBMEMOD_MASK = 0x40, /* set loop back mode, external */
  113. + CAN_FD_LBMIMOD_MASK = 0x20, /* set loopback internal mode */
  114. + CAN_FD_SET_BUSOFF_MASK = 0x01,
  115. + CAN_FD_OFF_BUSOFF_MASK = 0xfe,
  116. + CAN_FD_SET_TTSEN_MASK = 0x80, /* set ttsen, tts update enable */
  117. + CAN_FD_SET_BRS_MASK = 0x10, /* can fd Bit Rate Switch mask */
  118. + CAN_FD_OFF_BRS_MASK = 0xef,
  119. + CAN_FD_SET_EDL_MASK = 0x20, /* Extended Data Length */
  120. + CAN_FD_OFF_EDL_MASK = 0xdf,
  121. + CAN_FD_SET_DLC_MASK = 0x0f,
  122. + CAN_FD_SET_TENEXT_MASK = 0x40,
  123. + CAN_FD_SET_IDE_MASK = 0x80,
  124. + CAN_FD_OFF_IDE_MASK = 0x7f,
  125. + CAN_FD_SET_RTR_MASK = 0x40,
  126. + CAN_FD_OFF_RTR_MASK = 0xbf,
  127. + CAN_FD_INTR_ALL_MASK = 0xff, /* all interrupts enable mask */
  128. + CAN_FD_SET_RIE_MASK = 0x80,
  129. + CAN_FD_OFF_RIE_MASK = 0x7f,
  130. + CAN_FD_SET_RFIE_MASK = 0x20,
  131. + CAN_FD_OFF_RFIE_MASK = 0xdf,
  132. + CAN_FD_SET_RAFIE_MASK = 0x10,
  133. + CAN_FD_OFF_RAFIE_MASK = 0xef,
  134. + CAN_FD_SET_EIE_MASK = 0x02,
  135. + CAN_FD_OFF_EIE_MASK = 0xfd,
  136. + CAN_FD_TASCTIVE_MASK = 0x02,
  137. + CAN_FD_RASCTIVE_MASK = 0x04,
  138. + CAN_FD_SET_TBSEL_MASK = 0x80, /* message writen in STB */
  139. + CAN_FD_OFF_TBSEL_MASK = 0x7f, /* message writen in PTB */
  140. + CAN_FD_SET_STBY_MASK = 0x20,
  141. + CAN_FD_OFF_STBY_MASK = 0xdf,
  142. + CAN_FD_SET_TPE_MASK = 0x10, /* Transmit primary enable */
  143. + CAN_FD_SET_TPA_MASK = 0x08,
  144. + CAN_FD_SET_SACK_MASK = 0x80,
  145. + CAN_FD_SET_RREL_MASK = 0x10,
  146. + CAN_FD_RSTAT_NOT_EMPTY_MASK = 0x03,
  147. + CAN_FD_SET_RIF_MASK = 0x80,
  148. + CAN_FD_OFF_RIF_MASK = 0x7f,
  149. + CAN_FD_SET_RAFIF_MASK = 0x10,
  150. + CAN_FD_SET_RFIF_MASK = 0x20,
  151. + CAN_FD_SET_TPIF_MASK = 0x08, /* Transmission Primary Interrupt Flag */
  152. + CAN_FD_SET_TSIF_MASK = 0x04,
  153. + CAN_FD_SET_EIF_MASK = 0x02,
  154. + CAN_FD_SET_AIF_MASK = 0x01,
  155. + CAN_FD_SET_EWARN_MASK = 0x80,
  156. + CAN_FD_SET_EPASS_MASK = 0x40,
  157. + CAN_FD_SET_EPIE_MASK = 0x20,
  158. + CAN_FD_SET_EPIF_MASK = 0x10,
  159. + CAN_FD_SET_ALIE_MASK = 0x08,
  160. + CAN_FD_SET_ALIF_MASK = 0x04,
  161. + CAN_FD_SET_BEIE_MASK = 0x02,
  162. + CAN_FD_SET_BEIF_MASK = 0x01,
  163. + CAN_FD_OFF_EPIE_MASK = 0xdf,
  164. + CAN_FD_OFF_BEIE_MASK = 0xfd,
  165. + CAN_FD_SET_AFWL_MASK = 0x40,
  166. + CAN_FD_SET_EWL_MASK = 0x0b,
  167. + CAN_FD_SET_KOER_MASK = 0xe0,
  168. + CAN_FD_SET_BIT_ERROR_MASK = 0x20,
  169. + CAN_FD_SET_FORM_ERROR_MASK = 0x40,
  170. + CAN_FD_SET_STUFF_ERROR_MASK = 0x60,
  171. + CAN_FD_SET_ACK_ERROR_MASK = 0x80,
  172. + CAN_FD_SET_CRC_ERROR_MASK = 0xa0,
  173. + CAN_FD_SET_OTH_ERROR_MASK = 0xc0,
  174. +};
  175. +
  176. +/* seg1,seg2,sjw,prescaler all have 8 bits */
  177. +#define BITS_OF_BITTIMING_REG 8
  178. +
  179. +/* in can_bittiming strucure every field has 32 bits---->u32 */
  180. +#define FBITS_IN_BITTIMING_STR 32
  181. +#define SEG_1_SHIFT 0
  182. +#define SEG_2_SHIFT 8
  183. +#define SJW_SHIFT 16
  184. +#define PRESC_SHIFT 24
  185. +
  186. +/* TTSEN bit used for 32 bit register read or write */
  187. +#define TTSEN_8_32_SHIFT 24
  188. +#define RTR_32_8_SHIFT 24
  189. +
  190. +/* transmit mode */
  191. +#define XMIT_FULL 0
  192. +#define XMIT_SEP_FIFO 1
  193. +#define XMIT_SEP_PRIO 2
  194. +#define XMIT_PTB_MODE 3
  195. +
  196. +enum IPMS_CAN_TYPE {
  197. + IPMS_CAN_TYPY_CAN = 0,
  198. + IPMS_CAN_TYPE_CANFD,
  199. +};
  200. +
  201. +struct ipms_canfd_priv {
  202. + struct can_priv can;
  203. + struct napi_struct napi;
  204. + struct device *dev;
  205. + struct regmap *reg_syscon;
  206. + void __iomem *reg_base;
  207. + u32 (*read_reg)(const struct ipms_canfd_priv *priv, enum canfd_device_reg reg);
  208. + void (*write_reg)(const struct ipms_canfd_priv *priv, enum canfd_device_reg reg, u32 val);
  209. + struct clk *can_clk;
  210. + u32 tx_mode;
  211. + struct reset_control *resets;
  212. + struct clk_bulk_data *clks;
  213. + int nr_clks;
  214. + u32 can_or_canfd;
  215. +};
  216. +
  217. +static struct can_bittiming_const canfd_bittiming_const = {
  218. + .name = DRIVER_NAME,
  219. + .tseg1_min = 2,
  220. + .tseg1_max = 16,
  221. + .tseg2_min = 2,
  222. + .tseg2_max = 8,
  223. + .sjw_max = 4,
  224. + .brp_min = 1,
  225. + .brp_max = 512,
  226. + .brp_inc = 1,
  227. +
  228. +};
  229. +
  230. +static struct can_bittiming_const canfd_data_bittiming_const = {
  231. + .name = DRIVER_NAME,
  232. + .tseg1_min = 1,
  233. + .tseg1_max = 16,
  234. + .tseg2_min = 2,
  235. + .tseg2_max = 8,
  236. + .sjw_max = 8,
  237. + .brp_min = 1,
  238. + .brp_max = 512,
  239. + .brp_inc = 1,
  240. +};
  241. +
  242. +static void canfd_write_reg_le(const struct ipms_canfd_priv *priv,
  243. + enum canfd_device_reg reg, u32 val)
  244. +{
  245. + iowrite32(val, priv->reg_base + reg);
  246. +}
  247. +
  248. +static u32 canfd_read_reg_le(const struct ipms_canfd_priv *priv,
  249. + enum canfd_device_reg reg)
  250. +{
  251. + return ioread32(priv->reg_base + reg);
  252. +}
  253. +
  254. +static inline unsigned char can_ioread8(const void *addr)
  255. +{
  256. + void *addr_down;
  257. + union val {
  258. + u8 val_8[4];
  259. + u32 val_32;
  260. + } val;
  261. + u32 offset = 0;
  262. +
  263. + addr_down = (void *)ALIGN_DOWN((unsigned long)addr, 4);
  264. + offset = addr - addr_down;
  265. + val.val_32 = ioread32(addr_down);
  266. + return val.val_8[offset];
  267. +}
  268. +
  269. +static inline void can_iowrite8(unsigned char value, void *addr)
  270. +{
  271. + void *addr_down;
  272. + union val {
  273. + u8 val_8[4];
  274. + u32 val_32;
  275. + } val;
  276. + u8 offset = 0;
  277. +
  278. + addr_down = (void *)ALIGN_DOWN((unsigned long)addr, 4);
  279. + offset = addr - addr_down;
  280. + val.val_32 = ioread32(addr_down);
  281. + val.val_8[offset] = value;
  282. + iowrite32(val.val_32, addr_down);
  283. +}
  284. +
  285. +static void canfd_reigister_set_bit(const struct ipms_canfd_priv *priv,
  286. + enum canfd_device_reg reg,
  287. + enum canfd_reg_bitchange set_mask)
  288. +{
  289. + void *addr_down;
  290. + union val {
  291. + u8 val_8[4];
  292. + u32 val_32;
  293. + } val;
  294. + u8 offset = 0;
  295. +
  296. + addr_down = (void *)ALIGN_DOWN((unsigned long)(priv->reg_base + reg), 4);
  297. + offset = (priv->reg_base + reg) - addr_down;
  298. + val.val_32 = ioread32(addr_down);
  299. + val.val_8[offset] |= set_mask;
  300. + iowrite32(val.val_32, addr_down);
  301. +}
  302. +
  303. +static void canfd_reigister_off_bit(const struct ipms_canfd_priv *priv,
  304. + enum canfd_device_reg reg,
  305. + enum canfd_reg_bitchange set_mask)
  306. +{
  307. + void *addr_down;
  308. + union val {
  309. + u8 val_8[4];
  310. + u32 val_32;
  311. + } val;
  312. + u8 offset = 0;
  313. +
  314. + addr_down = (void *)ALIGN_DOWN((unsigned long)(priv->reg_base + reg), 4);
  315. + offset = (priv->reg_base + reg) - addr_down;
  316. + val.val_32 = ioread32(addr_down);
  317. + val.val_8[offset] &= set_mask;
  318. + iowrite32(val.val_32, addr_down);
  319. +}
  320. +
  321. +static int canfd_device_driver_bittime_configuration(struct net_device *ndev)
  322. +{
  323. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  324. + struct can_bittiming *bt = &priv->can.bittiming;
  325. + struct can_bittiming *dbt = &priv->can.data_bittiming;
  326. + u32 reset_test, bittiming_temp, dat_bittiming;
  327. +
  328. + reset_test = can_ioread8(priv->reg_base + CANFD_CFG_STAT_OFFSET);
  329. +
  330. + if (!(reset_test & CAN_FD_SET_RST_MASK)) {
  331. + netdev_alert(ndev, "Not in reset mode, cannot set bit timing\n");
  332. + return -EPERM;
  333. + }
  334. +
  335. + bittiming_temp = ((bt->phase_seg1 + bt->prop_seg + 1 - 2) << SEG_1_SHIFT) |
  336. + ((bt->phase_seg2 - 1) << SEG_2_SHIFT) |
  337. + ((bt->sjw - 1) << SJW_SHIFT) |
  338. + ((bt->brp - 1) << PRESC_SHIFT);
  339. +
  340. + /* Check the bittime parameter */
  341. + if ((((int)(bt->phase_seg1 + bt->prop_seg + 1) - 2) < 0) ||
  342. + (((int)(bt->phase_seg2) - 1) < 0) ||
  343. + (((int)(bt->sjw) - 1) < 0) ||
  344. + (((int)(bt->brp) - 1) < 0))
  345. + return -EINVAL;
  346. +
  347. + priv->write_reg(priv, CANFD_S_SEG_1_OFFSET, bittiming_temp);
  348. +
  349. + if (priv->can_or_canfd == IPMS_CAN_TYPE_CANFD) {
  350. + dat_bittiming = ((dbt->phase_seg1 + dbt->prop_seg + 1 - 2) << SEG_1_SHIFT) |
  351. + ((dbt->phase_seg2 - 1) << SEG_2_SHIFT) |
  352. + ((dbt->sjw - 1) << SJW_SHIFT) |
  353. + ((dbt->brp - 1) << PRESC_SHIFT);
  354. +
  355. + if ((((int)(dbt->phase_seg1 + dbt->prop_seg + 1) - 2) < 0) ||
  356. + (((int)(dbt->phase_seg2) - 1) < 0) ||
  357. + (((int)(dbt->sjw) - 1) < 0) ||
  358. + (((int)(dbt->brp) - 1) < 0))
  359. + return -EINVAL;
  360. +
  361. + priv->write_reg(priv, CANFD_F_SEG_1_OFFSET, dat_bittiming);
  362. + }
  363. +
  364. + canfd_reigister_off_bit(priv, CANFD_CFG_STAT_OFFSET, CAN_FD_OFF_RST_MASK);
  365. +
  366. + netdev_dbg(ndev, "Slow bit rate: %08x\n", priv->read_reg(priv, CANFD_S_SEG_1_OFFSET));
  367. + netdev_dbg(ndev, "Fast bit rate: %08x\n", priv->read_reg(priv, CANFD_F_SEG_1_OFFSET));
  368. +
  369. + return 0;
  370. +}
  371. +
  372. +int canfd_get_freebuffer(struct ipms_canfd_priv *priv)
  373. +{
  374. + /* Get next transmit buffer */
  375. + canfd_reigister_set_bit(priv, CANFD_TCTRL_OFFSET, CAN_FD_SET_TENEXT_MASK);
  376. +
  377. + if (can_ioread8(priv->reg_base + CANFD_TCTRL_OFFSET) & CAN_FD_SET_TENEXT_MASK)
  378. + return -1;
  379. +
  380. + return 0;
  381. +}
  382. +
  383. +static void canfd_tx_interrupt(struct net_device *ndev, u8 isr)
  384. +{
  385. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  386. +
  387. + /* wait till transmission of the PTB or STB finished */
  388. + while (isr & (CAN_FD_SET_TPIF_MASK | CAN_FD_SET_TSIF_MASK)) {
  389. + if (isr & CAN_FD_SET_TPIF_MASK)
  390. + canfd_reigister_set_bit(priv, CANFD_RTIF_OFFSET, CAN_FD_SET_TPIF_MASK);
  391. +
  392. + if (isr & CAN_FD_SET_TSIF_MASK)
  393. + canfd_reigister_set_bit(priv, CANFD_RTIF_OFFSET, CAN_FD_SET_TSIF_MASK);
  394. +
  395. + isr = can_ioread8(priv->reg_base + CANFD_RTIF_OFFSET);
  396. + }
  397. + netif_wake_queue(ndev);
  398. +}
  399. +
  400. +static int can_rx(struct net_device *ndev)
  401. +{
  402. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  403. + struct net_device_stats *stats = &ndev->stats;
  404. + struct can_frame *cf;
  405. + struct sk_buff *skb;
  406. + u32 can_id;
  407. + u8 dlc, control, rx_status;
  408. +
  409. + rx_status = can_ioread8(priv->reg_base + CANFD_RCTRL_OFFSET);
  410. +
  411. + if (!(rx_status & CAN_FD_RSTAT_NOT_EMPTY_MASK))
  412. + return 0;
  413. + control = can_ioread8(priv->reg_base + CANFD_RBUF_CTL_OFFSET);
  414. + can_id = priv->read_reg(priv, CANFD_RUBF_ID_OFFSET);
  415. + dlc = can_ioread8(priv->reg_base + CANFD_RBUF_CTL_OFFSET) & CAN_FD_SET_DLC_MASK;
  416. +
  417. + skb = alloc_can_skb(ndev, (struct can_frame **)&cf);
  418. + if (!skb) {
  419. + stats->rx_dropped++;
  420. + return 0;
  421. + }
  422. + cf->can_dlc = can_cc_dlc2len(dlc);
  423. +
  424. + /* change the CANFD id into socketcan id format */
  425. + if (control & CAN_FD_SET_IDE_MASK) {
  426. + cf->can_id = can_id;
  427. + cf->can_id |= CAN_EFF_FLAG;
  428. + } else {
  429. + cf->can_id = can_id;
  430. + cf->can_id &= (~CAN_EFF_FLAG);
  431. + }
  432. +
  433. + if (control & CAN_FD_SET_RTR_MASK)
  434. + cf->can_id |= CAN_RTR_FLAG;
  435. +
  436. + if (!(control & CAN_FD_SET_RTR_MASK)) {
  437. + *((u32 *)(cf->data + 0)) = priv->read_reg(priv, CANFD_RBUF_DATA_OFFSET);
  438. + *((u32 *)(cf->data + 4)) = priv->read_reg(priv, CANFD_RBUF_DATA_OFFSET + 4);
  439. + }
  440. +
  441. + canfd_reigister_set_bit(priv, CANFD_RCTRL_OFFSET, CAN_FD_SET_RREL_MASK);
  442. + stats->rx_bytes += can_fd_dlc2len(cf->can_dlc);
  443. + stats->rx_packets++;
  444. + netif_receive_skb(skb);
  445. +
  446. + return 1;
  447. +}
  448. +
  449. +static int canfd_rx(struct net_device *ndev)
  450. +{
  451. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  452. + struct net_device_stats *stats = &ndev->stats;
  453. + struct canfd_frame *cf;
  454. + struct sk_buff *skb;
  455. + u32 can_id;
  456. + u8 dlc, control, rx_status;
  457. + int i;
  458. +
  459. + rx_status = can_ioread8(priv->reg_base + CANFD_RCTRL_OFFSET);
  460. +
  461. + if (!(rx_status & CAN_FD_RSTAT_NOT_EMPTY_MASK))
  462. + return 0;
  463. + control = can_ioread8(priv->reg_base + CANFD_RBUF_CTL_OFFSET);
  464. + can_id = priv->read_reg(priv, CANFD_RUBF_ID_OFFSET);
  465. + dlc = can_ioread8(priv->reg_base + CANFD_RBUF_CTL_OFFSET) & CAN_FD_SET_DLC_MASK;
  466. +
  467. + if (control & CAN_FD_SET_EDL_MASK)
  468. + /* allocate sk_buffer for canfd frame */
  469. + skb = alloc_canfd_skb(ndev, &cf);
  470. + else
  471. + /* allocate sk_buffer for can frame */
  472. + skb = alloc_can_skb(ndev, (struct can_frame **)&cf);
  473. +
  474. + if (!skb) {
  475. + stats->rx_dropped++;
  476. + return 0;
  477. + }
  478. +
  479. + /* change the CANFD or CAN2.0 data into socketcan data format */
  480. + if (control & CAN_FD_SET_EDL_MASK)
  481. + cf->len = can_fd_dlc2len(dlc);
  482. + else
  483. + cf->len = can_cc_dlc2len(dlc);
  484. +
  485. + /* change the CANFD id into socketcan id format */
  486. + if (control & CAN_FD_SET_EDL_MASK) {
  487. + cf->can_id = can_id;
  488. + if (control & CAN_FD_SET_IDE_MASK)
  489. + cf->can_id |= CAN_EFF_FLAG;
  490. + else
  491. + cf->can_id &= (~CAN_EFF_FLAG);
  492. + } else {
  493. + cf->can_id = can_id;
  494. + if (control & CAN_FD_SET_IDE_MASK)
  495. + cf->can_id |= CAN_EFF_FLAG;
  496. + else
  497. + cf->can_id &= (~CAN_EFF_FLAG);
  498. +
  499. + if (control & CAN_FD_SET_RTR_MASK)
  500. + cf->can_id |= CAN_RTR_FLAG;
  501. + }
  502. +
  503. + /* CANFD frames handed over to SKB */
  504. + if (control & CAN_FD_SET_EDL_MASK) {
  505. + for (i = 0; i < cf->len; i += 4)
  506. + *((u32 *)(cf->data + i)) = priv->read_reg(priv, CANFD_RBUF_DATA_OFFSET + i);
  507. + } else {
  508. + /* skb reads the received datas, if the RTR bit not set */
  509. + if (!(control & CAN_FD_SET_RTR_MASK)) {
  510. + *((u32 *)(cf->data + 0)) = priv->read_reg(priv, CANFD_RBUF_DATA_OFFSET);
  511. + *((u32 *)(cf->data + 4)) = priv->read_reg(priv, CANFD_RBUF_DATA_OFFSET + 4);
  512. + }
  513. + }
  514. +
  515. + canfd_reigister_set_bit(priv, CANFD_RCTRL_OFFSET, CAN_FD_SET_RREL_MASK);
  516. +
  517. + stats->rx_bytes += cf->len;
  518. + stats->rx_packets++;
  519. + netif_receive_skb(skb);
  520. +
  521. + return 1;
  522. +}
  523. +
  524. +static int canfd_rx_poll(struct napi_struct *napi, int quota)
  525. +{
  526. + struct net_device *ndev = napi->dev;
  527. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  528. + int work_done = 0;
  529. + u8 rx_status = 0, control = 0;
  530. +
  531. + control = can_ioread8(priv->reg_base + CANFD_RBUF_CTL_OFFSET);
  532. + rx_status = can_ioread8(priv->reg_base + CANFD_RCTRL_OFFSET);
  533. +
  534. + /* clear receive interrupt and deal with all the received frames */
  535. + while ((rx_status & CAN_FD_RSTAT_NOT_EMPTY_MASK) && (work_done < quota)) {
  536. + (control & CAN_FD_SET_EDL_MASK) ? (work_done += canfd_rx(ndev)) : (work_done += can_rx(ndev));
  537. +
  538. + control = can_ioread8(priv->reg_base + CANFD_RBUF_CTL_OFFSET);
  539. + rx_status = can_ioread8(priv->reg_base + CANFD_RCTRL_OFFSET);
  540. + }
  541. + napi_complete(napi);
  542. + canfd_reigister_set_bit(priv, CANFD_RTIE_OFFSET, CAN_FD_SET_RIE_MASK);
  543. + return work_done;
  544. +}
  545. +
  546. +static void canfd_rxfull_interrupt(struct net_device *ndev, u8 isr)
  547. +{
  548. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  549. +
  550. + if (isr & CAN_FD_SET_RAFIF_MASK)
  551. + canfd_reigister_set_bit(priv, CANFD_RTIF_OFFSET, CAN_FD_SET_RAFIF_MASK);
  552. +
  553. + if (isr & (CAN_FD_SET_RAFIF_MASK | CAN_FD_SET_RFIF_MASK))
  554. + canfd_reigister_set_bit(priv, CANFD_RTIF_OFFSET,
  555. + (CAN_FD_SET_RAFIF_MASK | CAN_FD_SET_RFIF_MASK));
  556. +}
  557. +
  558. +static int set_canfd_xmit_mode(struct net_device *ndev)
  559. +{
  560. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  561. +
  562. + switch (priv->tx_mode) {
  563. + case XMIT_FULL:
  564. + canfd_reigister_set_bit(priv, CANFD_TCTRL_OFFSET, CAN_FD_SET_FULLCAN_MASK);
  565. + break;
  566. + case XMIT_SEP_FIFO:
  567. + canfd_reigister_off_bit(priv, CANFD_TCTRL_OFFSET, CAN_FD_OFF_FULLCAN_MASK);
  568. + canfd_reigister_set_bit(priv, CANFD_TCTRL_OFFSET, CAN_FD_SET_FIFO_MASK);
  569. + canfd_reigister_off_bit(priv, CANFD_TCMD_OFFSET, CAN_FD_SET_TBSEL_MASK);
  570. + break;
  571. + case XMIT_SEP_PRIO:
  572. + canfd_reigister_off_bit(priv, CANFD_TCTRL_OFFSET, CAN_FD_OFF_FULLCAN_MASK);
  573. + canfd_reigister_off_bit(priv, CANFD_TCTRL_OFFSET, CAN_FD_OFF_FIFO_MASK);
  574. + canfd_reigister_off_bit(priv, CANFD_TCMD_OFFSET, CAN_FD_SET_TBSEL_MASK);
  575. + break;
  576. + case XMIT_PTB_MODE:
  577. + canfd_reigister_off_bit(priv, CANFD_TCMD_OFFSET, CAN_FD_OFF_TBSEL_MASK);
  578. + break;
  579. + default:
  580. + break;
  581. + }
  582. + return 0;
  583. +}
  584. +
  585. +static netdev_tx_t canfd_driver_start_xmit(struct sk_buff *skb, struct net_device *ndev)
  586. +{
  587. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  588. + struct canfd_frame *cf = (struct canfd_frame *)skb->data;
  589. + struct net_device_stats *stats = &ndev->stats;
  590. + u32 ttsen, id, ctl, addr_off;
  591. + int i;
  592. +
  593. + priv->tx_mode = XMIT_PTB_MODE;
  594. +
  595. + if (can_dropped_invalid_skb(ndev, skb))
  596. + return NETDEV_TX_OK;
  597. +
  598. + switch (priv->tx_mode) {
  599. + case XMIT_FULL:
  600. + return NETDEV_TX_BUSY;
  601. + case XMIT_PTB_MODE:
  602. + set_canfd_xmit_mode(ndev);
  603. + canfd_reigister_off_bit(priv, CANFD_TCMD_OFFSET, CAN_FD_OFF_STBY_MASK);
  604. +
  605. + if (cf->can_id & CAN_EFF_FLAG) {
  606. + id = (cf->can_id & CAN_EFF_MASK);
  607. + ttsen = 0 << TTSEN_8_32_SHIFT;
  608. + id |= ttsen;
  609. + } else {
  610. + id = (cf->can_id & CAN_SFF_MASK);
  611. + ttsen = 0 << TTSEN_8_32_SHIFT;
  612. + id |= ttsen;
  613. + }
  614. +
  615. + ctl = can_fd_len2dlc(cf->len);
  616. +
  617. + /* transmit can fd frame */
  618. + if (priv->can_or_canfd == IPMS_CAN_TYPE_CANFD) {
  619. + if (can_is_canfd_skb(skb)) {
  620. + if (cf->can_id & CAN_EFF_FLAG)
  621. + ctl |= CAN_FD_SET_IDE_MASK;
  622. + else
  623. + ctl &= CAN_FD_OFF_IDE_MASK;
  624. +
  625. + if (cf->flags & CANFD_BRS)
  626. + ctl |= CAN_FD_SET_BRS_MASK;
  627. +
  628. + ctl |= CAN_FD_SET_EDL_MASK;
  629. +
  630. + addr_off = CANFD_TBUF_DATA_OFFSET;
  631. +
  632. + for (i = 0; i < cf->len; i += 4) {
  633. + priv->write_reg(priv, addr_off,
  634. + *((u32 *)(cf->data + i)));
  635. + addr_off += 4;
  636. + }
  637. + } else {
  638. + ctl &= CAN_FD_OFF_EDL_MASK;
  639. + ctl &= CAN_FD_OFF_BRS_MASK;
  640. +
  641. + if (cf->can_id & CAN_EFF_FLAG)
  642. + ctl |= CAN_FD_SET_IDE_MASK;
  643. + else
  644. + ctl &= CAN_FD_OFF_IDE_MASK;
  645. +
  646. + if (cf->can_id & CAN_RTR_FLAG) {
  647. + ctl |= CAN_FD_SET_RTR_MASK;
  648. + priv->write_reg(priv,
  649. + CANFD_TBUF_ID_OFFSET, id);
  650. + priv->write_reg(priv,
  651. + CANFD_TBUF_CTL_OFFSET, ctl);
  652. + } else {
  653. + ctl &= CAN_FD_OFF_RTR_MASK;
  654. + addr_off = CANFD_TBUF_DATA_OFFSET;
  655. + priv->write_reg(priv, addr_off,
  656. + *((u32 *)(cf->data + 0)));
  657. + priv->write_reg(priv, addr_off + 4,
  658. + *((u32 *)(cf->data + 4)));
  659. + }
  660. + }
  661. + priv->write_reg(priv, CANFD_TBUF_ID_OFFSET, id);
  662. + priv->write_reg(priv, CANFD_TBUF_CTL_OFFSET, ctl);
  663. + addr_off = CANFD_TBUF_DATA_OFFSET;
  664. + } else {
  665. + ctl &= CAN_FD_OFF_EDL_MASK;
  666. + ctl &= CAN_FD_OFF_BRS_MASK;
  667. +
  668. + if (cf->can_id & CAN_EFF_FLAG)
  669. + ctl |= CAN_FD_SET_IDE_MASK;
  670. + else
  671. + ctl &= CAN_FD_OFF_IDE_MASK;
  672. +
  673. + if (cf->can_id & CAN_RTR_FLAG) {
  674. + ctl |= CAN_FD_SET_RTR_MASK;
  675. + priv->write_reg(priv, CANFD_TBUF_ID_OFFSET, id);
  676. + priv->write_reg(priv, CANFD_TBUF_CTL_OFFSET, ctl);
  677. + } else {
  678. + ctl &= CAN_FD_OFF_RTR_MASK;
  679. + priv->write_reg(priv, CANFD_TBUF_ID_OFFSET, id);
  680. + priv->write_reg(priv, CANFD_TBUF_CTL_OFFSET, ctl);
  681. + addr_off = CANFD_TBUF_DATA_OFFSET;
  682. + priv->write_reg(priv, addr_off,
  683. + *((u32 *)(cf->data + 0)));
  684. + priv->write_reg(priv, addr_off + 4,
  685. + *((u32 *)(cf->data + 4)));
  686. + }
  687. + }
  688. + canfd_reigister_set_bit(priv, CANFD_TCMD_OFFSET, CAN_FD_SET_TPE_MASK);
  689. + stats->tx_bytes += cf->len;
  690. + break;
  691. + default:
  692. + break;
  693. + }
  694. +
  695. + /*Due to cache blocking, we need call dev_kfree_skb() here to free the socket
  696. + buffer and return NETDEV_TX_OK */
  697. + dev_kfree_skb(skb);
  698. +
  699. + return NETDEV_TX_OK;
  700. +}
  701. +
  702. +static int set_reset_mode(struct net_device *ndev)
  703. +{
  704. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  705. + u8 ret;
  706. +
  707. + ret = can_ioread8(priv->reg_base + CANFD_CFG_STAT_OFFSET);
  708. + ret |= CAN_FD_SET_RST_MASK;
  709. + can_iowrite8(ret, priv->reg_base + CANFD_CFG_STAT_OFFSET);
  710. +
  711. + return 0;
  712. +}
  713. +
  714. +static void canfd_driver_stop(struct net_device *ndev)
  715. +{
  716. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  717. + int ret;
  718. +
  719. + ret = set_reset_mode(ndev);
  720. + if (ret)
  721. + netdev_err(ndev, "Mode Resetting Failed!\n");
  722. +
  723. + priv->can.state = CAN_STATE_STOPPED;
  724. +}
  725. +
  726. +static int canfd_driver_close(struct net_device *ndev)
  727. +{
  728. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  729. +
  730. + netif_stop_queue(ndev);
  731. + napi_disable(&priv->napi);
  732. + canfd_driver_stop(ndev);
  733. +
  734. + free_irq(ndev->irq, ndev);
  735. + close_candev(ndev);
  736. +
  737. + pm_runtime_put(priv->dev);
  738. +
  739. + return 0;
  740. +}
  741. +
  742. +static enum can_state get_of_chip_status(struct net_device *ndev)
  743. +{
  744. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  745. + u8 can_stat, eir;
  746. +
  747. + can_stat = can_ioread8(priv->reg_base + CANFD_CFG_STAT_OFFSET);
  748. + eir = can_ioread8(priv->reg_base + CANFD_ERRINT_OFFSET);
  749. +
  750. + if (can_stat & CAN_FD_SET_BUSOFF_MASK)
  751. + return CAN_STATE_BUS_OFF;
  752. +
  753. + if ((eir & CAN_FD_SET_EPASS_MASK) && ~(can_stat & CAN_FD_SET_BUSOFF_MASK))
  754. + return CAN_STATE_ERROR_PASSIVE;
  755. +
  756. + if (eir & CAN_FD_SET_EWARN_MASK && ~(eir & CAN_FD_SET_EPASS_MASK))
  757. + return CAN_STATE_ERROR_WARNING;
  758. +
  759. + if (~(eir & CAN_FD_SET_EPASS_MASK))
  760. + return CAN_STATE_ERROR_ACTIVE;
  761. +
  762. + return CAN_STATE_ERROR_ACTIVE;
  763. +}
  764. +
  765. +static void canfd_error_interrupt(struct net_device *ndev, u8 isr, u8 eir)
  766. +{
  767. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  768. + struct net_device_stats *stats = &ndev->stats;
  769. + struct can_frame *cf;
  770. + struct sk_buff *skb;
  771. + u8 koer, recnt = 0, tecnt = 0, can_stat = 0;
  772. +
  773. + skb = alloc_can_err_skb(ndev, &cf);
  774. +
  775. + koer = can_ioread8(priv->reg_base + CANFD_EALCAP_OFFSET) & CAN_FD_SET_KOER_MASK;
  776. + recnt = can_ioread8(priv->reg_base + CANFD_RECNT_OFFSET);
  777. + tecnt = can_ioread8(priv->reg_base + CANFD_TECNT_OFFSET);
  778. +
  779. + /*Read can status*/
  780. + can_stat = can_ioread8(priv->reg_base + CANFD_CFG_STAT_OFFSET);
  781. +
  782. + /* Bus off --->active error mode */
  783. + if ((isr & CAN_FD_SET_EIF_MASK) && priv->can.state == CAN_STATE_BUS_OFF)
  784. + priv->can.state = get_of_chip_status(ndev);
  785. +
  786. + /* State selection */
  787. + if (can_stat & CAN_FD_SET_BUSOFF_MASK) {
  788. + priv->can.state = get_of_chip_status(ndev);
  789. + priv->can.can_stats.bus_off++;
  790. + canfd_reigister_set_bit(priv, CANFD_CFG_STAT_OFFSET, CAN_FD_SET_BUSOFF_MASK);
  791. + can_bus_off(ndev);
  792. + if (skb)
  793. + cf->can_id |= CAN_ERR_BUSOFF;
  794. +
  795. + } else if ((eir & CAN_FD_SET_EPASS_MASK) && ~(can_stat & CAN_FD_SET_BUSOFF_MASK)) {
  796. + priv->can.state = get_of_chip_status(ndev);
  797. + priv->can.can_stats.error_passive++;
  798. + if (skb) {
  799. + cf->can_id |= CAN_ERR_CRTL;
  800. + cf->data[1] |= (recnt > 127) ? CAN_ERR_CRTL_RX_PASSIVE : 0;
  801. + cf->data[1] |= (tecnt > 127) ? CAN_ERR_CRTL_TX_PASSIVE : 0;
  802. + cf->data[6] = tecnt;
  803. + cf->data[7] = recnt;
  804. + }
  805. + } else if (eir & CAN_FD_SET_EWARN_MASK && ~(eir & CAN_FD_SET_EPASS_MASK)) {
  806. + priv->can.state = get_of_chip_status(ndev);
  807. + priv->can.can_stats.error_warning++;
  808. + if (skb) {
  809. + cf->can_id |= CAN_ERR_CRTL;
  810. + cf->data[1] |= (recnt > 95) ? CAN_ERR_CRTL_RX_WARNING : 0;
  811. + cf->data[1] |= (tecnt > 95) ? CAN_ERR_CRTL_TX_WARNING : 0;
  812. + cf->data[6] = tecnt;
  813. + cf->data[7] = recnt;
  814. + }
  815. + }
  816. +
  817. + /* Check for in protocol defined error interrupt */
  818. + if (eir & CAN_FD_SET_BEIF_MASK) {
  819. + if (skb)
  820. + cf->can_id |= CAN_ERR_BUSERROR | CAN_ERR_PROT;
  821. +
  822. + /* bit error interrupt */
  823. + if (koer == CAN_FD_SET_BIT_ERROR_MASK) {
  824. + stats->tx_errors++;
  825. + if (skb) {
  826. + cf->can_id |= CAN_ERR_PROT;
  827. + cf->data[2] = CAN_ERR_PROT_BIT;
  828. + }
  829. + }
  830. + /* format error interrupt */
  831. + if (koer == CAN_FD_SET_FORM_ERROR_MASK) {
  832. + stats->rx_errors++;
  833. + if (skb) {
  834. + cf->can_id |= CAN_ERR_PROT;
  835. + cf->data[2] = CAN_ERR_PROT_FORM;
  836. + }
  837. + }
  838. + /* stuffing error interrupt */
  839. + if (koer == CAN_FD_SET_STUFF_ERROR_MASK) {
  840. + stats->rx_errors++;
  841. + if (skb) {
  842. + cf->can_id |= CAN_ERR_PROT;
  843. + cf->data[3] = CAN_ERR_PROT_STUFF;
  844. + }
  845. + }
  846. + /* ack error interrupt */
  847. + if (koer == CAN_FD_SET_ACK_ERROR_MASK) {
  848. + stats->tx_errors++;
  849. + if (skb) {
  850. + cf->can_id |= CAN_ERR_PROT;
  851. + cf->data[2] = CAN_ERR_PROT_LOC_ACK;
  852. + }
  853. + }
  854. + /* crc error interrupt */
  855. + if (koer == CAN_FD_SET_CRC_ERROR_MASK) {
  856. + stats->rx_errors++;
  857. + if (skb) {
  858. + cf->can_id |= CAN_ERR_PROT;
  859. + cf->data[2] = CAN_ERR_PROT_LOC_CRC_SEQ;
  860. + }
  861. + }
  862. + priv->can.can_stats.bus_error++;
  863. + }
  864. + if (skb) {
  865. + stats->rx_packets++;
  866. + stats->rx_bytes += cf->can_dlc;
  867. + netif_rx(skb);
  868. + }
  869. +
  870. + netdev_dbg(ndev, "Recnt is 0x%02x", can_ioread8(priv->reg_base + CANFD_RECNT_OFFSET));
  871. + netdev_dbg(ndev, "Tecnt is 0x%02x", can_ioread8(priv->reg_base + CANFD_TECNT_OFFSET));
  872. +}
  873. +
  874. +static irqreturn_t canfd_interrupt(int irq, void *dev_id)
  875. +{
  876. + struct net_device *ndev = (struct net_device *)dev_id;
  877. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  878. + u8 isr, eir;
  879. + u8 isr_handled = 0, eir_handled = 0;
  880. +
  881. + /* read the value of interrupt status register */
  882. + isr = can_ioread8(priv->reg_base + CANFD_RTIF_OFFSET);
  883. +
  884. + /* read the value of error interrupt register */
  885. + eir = can_ioread8(priv->reg_base + CANFD_ERRINT_OFFSET);
  886. +
  887. + /* Check for Tx interrupt and Processing it */
  888. + if (isr & (CAN_FD_SET_TPIF_MASK | CAN_FD_SET_TSIF_MASK)) {
  889. + canfd_tx_interrupt(ndev, isr);
  890. + isr_handled |= (CAN_FD_SET_TPIF_MASK | CAN_FD_SET_TSIF_MASK);
  891. + }
  892. + if (isr & (CAN_FD_SET_RAFIF_MASK | CAN_FD_SET_RFIF_MASK)) {
  893. + canfd_rxfull_interrupt(ndev, isr);
  894. + isr_handled |= (CAN_FD_SET_RAFIF_MASK | CAN_FD_SET_RFIF_MASK);
  895. + }
  896. + /* Check Rx interrupt and Processing the receive interrupt routine */
  897. + if (isr & CAN_FD_SET_RIF_MASK) {
  898. + canfd_reigister_off_bit(priv, CANFD_RTIE_OFFSET, CAN_FD_OFF_RIE_MASK);
  899. + canfd_reigister_set_bit(priv, CANFD_RTIF_OFFSET, CAN_FD_SET_RIF_MASK);
  900. +
  901. + napi_schedule(&priv->napi);
  902. + isr_handled |= CAN_FD_SET_RIF_MASK;
  903. + }
  904. + if ((isr & CAN_FD_SET_EIF_MASK) | (eir & (CAN_FD_SET_EPIF_MASK | CAN_FD_SET_BEIF_MASK))) {
  905. + /* reset EPIF and BEIF. Reset EIF */
  906. + canfd_reigister_set_bit(priv, CANFD_ERRINT_OFFSET,
  907. + eir & (CAN_FD_SET_EPIF_MASK | CAN_FD_SET_BEIF_MASK));
  908. + canfd_reigister_set_bit(priv, CANFD_RTIF_OFFSET,
  909. + isr & CAN_FD_SET_EIF_MASK);
  910. +
  911. + canfd_error_interrupt(ndev, isr, eir);
  912. +
  913. + isr_handled |= CAN_FD_SET_EIF_MASK;
  914. + eir_handled |= (CAN_FD_SET_EPIF_MASK | CAN_FD_SET_BEIF_MASK);
  915. + }
  916. + if ((isr_handled == 0) && (eir_handled == 0)) {
  917. + netdev_err(ndev, "Unhandled interrupt!\n");
  918. + return IRQ_NONE;
  919. + }
  920. +
  921. + return IRQ_HANDLED;
  922. +}
  923. +
  924. +static int canfd_chip_start(struct net_device *ndev)
  925. +{
  926. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  927. + int err;
  928. + u8 ret;
  929. +
  930. + err = set_reset_mode(ndev);
  931. + if (err) {
  932. + netdev_err(ndev, "Mode Resetting Failed!\n");
  933. + return err;
  934. + }
  935. +
  936. + err = canfd_device_driver_bittime_configuration(ndev);
  937. + if (err) {
  938. + netdev_err(ndev, "Bittime Setting Failed!\n");
  939. + return err;
  940. + }
  941. +
  942. + /* Set Almost Full Warning Limit */
  943. + canfd_reigister_set_bit(priv, CANFD_LIMIT_OFFSET, CAN_FD_SET_AFWL_MASK);
  944. +
  945. + /* Programmable Error Warning Limit = (EWL+1)*8. Set EWL=11->Error Warning=96 */
  946. + canfd_reigister_set_bit(priv, CANFD_LIMIT_OFFSET, CAN_FD_SET_EWL_MASK);
  947. +
  948. + /* Interrupts enable */
  949. + can_iowrite8(CAN_FD_INTR_ALL_MASK, priv->reg_base + CANFD_RTIE_OFFSET);
  950. +
  951. + /* Error Interrupts enable(Error Passive and Bus Error) */
  952. + canfd_reigister_set_bit(priv, CANFD_ERRINT_OFFSET, CAN_FD_SET_EPIE_MASK);
  953. +
  954. + ret = can_ioread8(priv->reg_base + CANFD_CFG_STAT_OFFSET);
  955. +
  956. + /* Check whether it is loopback mode or normal mode */
  957. + if (priv->can.ctrlmode & CAN_CTRLMODE_LOOPBACK) {
  958. + ret |= CAN_FD_LBMIMOD_MASK;
  959. + } else {
  960. + ret &= ~CAN_FD_LBMEMOD_MASK;
  961. + ret &= ~CAN_FD_LBMIMOD_MASK;
  962. + }
  963. +
  964. + can_iowrite8(ret, priv->reg_base + CANFD_CFG_STAT_OFFSET);
  965. +
  966. + priv->can.state = CAN_STATE_ERROR_ACTIVE;
  967. +
  968. + return 0;
  969. +}
  970. +
  971. +static int canfd_do_set_mode(struct net_device *ndev, enum can_mode mode)
  972. +{
  973. + int ret;
  974. +
  975. + switch (mode) {
  976. + case CAN_MODE_START:
  977. + ret = canfd_chip_start(ndev);
  978. + if (ret) {
  979. + netdev_err(ndev, "Could Not Start CAN device !!\n");
  980. + return ret;
  981. + }
  982. + netif_wake_queue(ndev);
  983. + break;
  984. + default:
  985. + ret = -EOPNOTSUPP;
  986. + break;
  987. + }
  988. +
  989. + return ret;
  990. +}
  991. +
  992. +static int canfd_driver_open(struct net_device *ndev)
  993. +{
  994. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  995. + int ret;
  996. +
  997. + ret = pm_runtime_get_sync(priv->dev);
  998. + if (ret < 0) {
  999. + netdev_err(ndev, "%s: pm_runtime_get failed(%d)\n",
  1000. + __func__, ret);
  1001. + goto err;
  1002. + }
  1003. +
  1004. + /* Set chip into reset mode */
  1005. + ret = set_reset_mode(ndev);
  1006. + if (ret) {
  1007. + netdev_err(ndev, "Mode Resetting Failed!\n");
  1008. + return ret;
  1009. + }
  1010. +
  1011. + /* Common open */
  1012. + ret = open_candev(ndev);
  1013. + if (ret)
  1014. + return ret;
  1015. +
  1016. + /* Register interrupt handler */
  1017. + ret = request_irq(ndev->irq, canfd_interrupt, IRQF_SHARED, ndev->name, ndev);
  1018. + if (ret) {
  1019. + netdev_err(ndev, "Request_irq err: %d\n", ret);
  1020. + goto exit_irq;
  1021. + }
  1022. +
  1023. + ret = canfd_chip_start(ndev);
  1024. + if (ret) {
  1025. + netdev_err(ndev, "Could Not Start CAN device !\n");
  1026. + goto exit_can_start;
  1027. + }
  1028. +
  1029. + napi_enable(&priv->napi);
  1030. + netif_start_queue(ndev);
  1031. +
  1032. + return 0;
  1033. +
  1034. +exit_can_start:
  1035. + free_irq(ndev->irq, ndev);
  1036. +err:
  1037. + pm_runtime_put(priv->dev);
  1038. +exit_irq:
  1039. + close_candev(ndev);
  1040. + return ret;
  1041. +}
  1042. +
  1043. +static int canfd_control_parse_dt(struct ipms_canfd_priv *priv)
  1044. +{
  1045. + struct of_phandle_args args;
  1046. + u32 syscon_mask, syscon_shift;
  1047. + u32 can_or_canfd;
  1048. + u32 syscon_offset, regval;
  1049. + int ret;
  1050. +
  1051. + ret = of_parse_phandle_with_fixed_args(priv->dev->of_node,
  1052. + "starfive,sys-syscon", 3, 0, &args);
  1053. + if (ret) {
  1054. + dev_err(priv->dev, "Failed to parse starfive,sys-syscon\n");
  1055. + return -EINVAL;
  1056. + }
  1057. +
  1058. + priv->reg_syscon = syscon_node_to_regmap(args.np);
  1059. + of_node_put(args.np);
  1060. + if (IS_ERR(priv->reg_syscon))
  1061. + return PTR_ERR(priv->reg_syscon);
  1062. +
  1063. + syscon_offset = args.args[0];
  1064. + syscon_shift = args.args[1];
  1065. + syscon_mask = args.args[2];
  1066. +
  1067. + ret = device_property_read_u32(priv->dev, "syscon,can_or_canfd", &can_or_canfd);
  1068. + if (ret)
  1069. + goto exit_parse;
  1070. +
  1071. + priv->can_or_canfd = can_or_canfd;
  1072. +
  1073. + /* enable can2.0/canfd function */
  1074. + regval = can_or_canfd << syscon_shift;
  1075. + ret = regmap_update_bits(priv->reg_syscon, syscon_offset, syscon_mask, regval);
  1076. + if (ret)
  1077. + return ret;
  1078. + return 0;
  1079. +exit_parse:
  1080. + return ret;
  1081. +}
  1082. +
  1083. +static const struct net_device_ops canfd_netdev_ops = {
  1084. + .ndo_open = canfd_driver_open,
  1085. + .ndo_stop = canfd_driver_close,
  1086. + .ndo_start_xmit = canfd_driver_start_xmit,
  1087. + .ndo_change_mtu = can_change_mtu,
  1088. +};
  1089. +
  1090. +static int canfd_driver_probe(struct platform_device *pdev)
  1091. +{
  1092. + struct net_device *ndev;
  1093. + struct ipms_canfd_priv *priv;
  1094. + void __iomem *addr;
  1095. + int ret;
  1096. + u32 frq;
  1097. +
  1098. + addr = devm_platform_ioremap_resource(pdev, 0);
  1099. + if (IS_ERR(addr)) {
  1100. + ret = PTR_ERR(addr);
  1101. + goto exit;
  1102. + }
  1103. +
  1104. + ndev = alloc_candev(sizeof(struct ipms_canfd_priv), 1);
  1105. + if (!ndev) {
  1106. + ret = -ENOMEM;
  1107. + goto exit;
  1108. + }
  1109. +
  1110. + priv = netdev_priv(ndev);
  1111. + priv->dev = &pdev->dev;
  1112. +
  1113. + ret = canfd_control_parse_dt(priv);
  1114. + if (ret)
  1115. + goto free_exit;
  1116. +
  1117. + priv->nr_clks = devm_clk_bulk_get_all(priv->dev, &priv->clks);
  1118. + if (priv->nr_clks < 0) {
  1119. + dev_err(priv->dev, "Failed to get can clocks\n");
  1120. + ret = -ENODEV;
  1121. + goto free_exit;
  1122. + }
  1123. +
  1124. + ret = clk_bulk_prepare_enable(priv->nr_clks, priv->clks);
  1125. + if (ret) {
  1126. + dev_err(priv->dev, "Failed to enable clocks\n");
  1127. + goto free_exit;
  1128. + }
  1129. +
  1130. + priv->resets = devm_reset_control_array_get_exclusive(priv->dev);
  1131. + if (IS_ERR(priv->resets)) {
  1132. + ret = PTR_ERR(priv->resets);
  1133. + dev_err(priv->dev, "Failed to get can resets");
  1134. + goto clk_exit;
  1135. + }
  1136. +
  1137. + ret = reset_control_deassert(priv->resets);
  1138. + if (ret)
  1139. + goto clk_exit;
  1140. + priv->can.bittiming_const = &canfd_bittiming_const;
  1141. + priv->can.data_bittiming_const = &canfd_data_bittiming_const;
  1142. + priv->can.do_set_mode = canfd_do_set_mode;
  1143. +
  1144. + /* in user space the execution mode can be chosen */
  1145. + if (priv->can_or_canfd == IPMS_CAN_TYPE_CANFD)
  1146. + priv->can.ctrlmode_supported = CAN_CTRLMODE_LOOPBACK | CAN_CTRLMODE_FD;
  1147. + else
  1148. + priv->can.ctrlmode_supported = CAN_CTRLMODE_LOOPBACK;
  1149. + priv->reg_base = addr;
  1150. + priv->write_reg = canfd_write_reg_le;
  1151. + priv->read_reg = canfd_read_reg_le;
  1152. +
  1153. + pm_runtime_enable(&pdev->dev);
  1154. +
  1155. + priv->can_clk = devm_clk_get(&pdev->dev, "core_clk");
  1156. + if (IS_ERR(priv->can_clk)) {
  1157. + dev_err(&pdev->dev, "Device clock not found.\n");
  1158. + ret = PTR_ERR(priv->can_clk);
  1159. + goto reset_exit;
  1160. + }
  1161. +
  1162. + device_property_read_u32(priv->dev, "frequency", &frq);
  1163. + clk_set_rate(priv->can_clk, frq);
  1164. +
  1165. + priv->can.clock.freq = clk_get_rate(priv->can_clk);
  1166. + ndev->irq = platform_get_irq(pdev, 0);
  1167. +
  1168. + /* we support local echo */
  1169. + ndev->flags |= IFF_ECHO;
  1170. + ndev->netdev_ops = &canfd_netdev_ops;
  1171. +
  1172. + platform_set_drvdata(pdev, ndev);
  1173. + SET_NETDEV_DEV(ndev, &pdev->dev);
  1174. +
  1175. + netif_napi_add(ndev, &priv->napi, canfd_rx_poll);
  1176. + ret = register_candev(ndev);
  1177. + if (ret) {
  1178. + dev_err(&pdev->dev, "Fail to register failed (err=%d)\n", ret);
  1179. + goto reset_exit;
  1180. + }
  1181. +
  1182. + dev_dbg(&pdev->dev, "Driver registered: regs=%p, irp=%d, clock=%d\n",
  1183. + priv->reg_base, ndev->irq, priv->can.clock.freq);
  1184. +
  1185. + return 0;
  1186. +
  1187. +reset_exit:
  1188. + reset_control_assert(priv->resets);
  1189. +clk_exit:
  1190. + clk_bulk_disable_unprepare(priv->nr_clks, priv->clks);
  1191. +free_exit:
  1192. + free_candev(ndev);
  1193. +exit:
  1194. + return ret;
  1195. +}
  1196. +
  1197. +static void canfd_driver_remove(struct platform_device *pdev)
  1198. +{
  1199. + struct net_device *ndev = platform_get_drvdata(pdev);
  1200. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  1201. +
  1202. + reset_control_assert(priv->resets);
  1203. + clk_bulk_disable_unprepare(priv->nr_clks, priv->clks);
  1204. + pm_runtime_disable(&pdev->dev);
  1205. +
  1206. + unregister_candev(ndev);
  1207. + netif_napi_del(&priv->napi);
  1208. + free_candev(ndev);
  1209. +}
  1210. +
  1211. +#ifdef CONFIG_PM_SLEEP
  1212. +static int __maybe_unused canfd_suspend(struct device *dev)
  1213. +{
  1214. + struct net_device *ndev = dev_get_drvdata(dev);
  1215. +
  1216. + if (netif_running(ndev)) {
  1217. + netif_stop_queue(ndev);
  1218. + netif_device_detach(ndev);
  1219. + canfd_driver_stop(ndev);
  1220. + }
  1221. +
  1222. + return pm_runtime_force_suspend(dev);
  1223. +}
  1224. +
  1225. +static int __maybe_unused canfd_resume(struct device *dev)
  1226. +{
  1227. + struct net_device *ndev = dev_get_drvdata(dev);
  1228. + int ret;
  1229. +
  1230. + ret = pm_runtime_force_resume(dev);
  1231. + if (ret) {
  1232. + dev_err(dev, "pm_runtime_force_resume failed on resume\n");
  1233. + return ret;
  1234. + }
  1235. +
  1236. + if (netif_running(ndev)) {
  1237. + ret = canfd_chip_start(ndev);
  1238. + if (ret) {
  1239. + dev_err(dev, "canfd_chip_start failed on resume\n");
  1240. + return ret;
  1241. + }
  1242. +
  1243. + netif_device_attach(ndev);
  1244. + netif_start_queue(ndev);
  1245. + }
  1246. +
  1247. + return 0;
  1248. +}
  1249. +#endif
  1250. +
  1251. +#ifdef CONFIG_PM
  1252. +static int canfd_runtime_suspend(struct device *dev)
  1253. +{
  1254. + struct net_device *ndev = dev_get_drvdata(dev);
  1255. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  1256. +
  1257. + reset_control_assert(priv->resets);
  1258. + clk_bulk_disable_unprepare(priv->nr_clks, priv->clks);
  1259. +
  1260. + return 0;
  1261. +}
  1262. +
  1263. +static int canfd_runtime_resume(struct device *dev)
  1264. +{
  1265. + struct net_device *ndev = dev_get_drvdata(dev);
  1266. + struct ipms_canfd_priv *priv = netdev_priv(ndev);
  1267. + int ret;
  1268. +
  1269. + ret = clk_bulk_prepare_enable(priv->nr_clks, priv->clks);
  1270. + if (ret) {
  1271. + dev_err(dev, "Failed to prepare_enable clk\n");
  1272. + return ret;
  1273. + }
  1274. +
  1275. + ret = reset_control_deassert(priv->resets);
  1276. + if (ret) {
  1277. + dev_err(dev, "Failed to deassert reset\n");
  1278. + return ret;
  1279. + }
  1280. +
  1281. + return 0;
  1282. +}
  1283. +#endif
  1284. +
  1285. +static const struct dev_pm_ops canfd_pm_ops = {
  1286. + SET_SYSTEM_SLEEP_PM_OPS(canfd_suspend, canfd_resume)
  1287. + SET_RUNTIME_PM_OPS(canfd_runtime_suspend,
  1288. + canfd_runtime_resume, NULL)
  1289. +};
  1290. +
  1291. +static const struct of_device_id canfd_of_match[] = {
  1292. + { .compatible = "ipms,can" },
  1293. + { }
  1294. +};
  1295. +MODULE_DEVICE_TABLE(of, canfd_of_match);
  1296. +
  1297. +static struct platform_driver can_driver = {
  1298. + .probe = canfd_driver_probe,
  1299. + .remove = canfd_driver_remove,
  1300. + .driver = {
  1301. + .name = DRIVER_NAME,
  1302. + .pm = &canfd_pm_ops,
  1303. + .of_match_table = canfd_of_match,
  1304. + },
  1305. +};
  1306. +
  1307. +module_platform_driver(can_driver);
  1308. +
  1309. +MODULE_DESCRIPTION("ipms can controller driver for StarFive jh7110 SoC");
  1310. +MODULE_AUTHOR("William Qiu<[email protected]");
  1311. +MODULE_LICENSE("GPL");