fsi-master-aspeed.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. // Copyright (C) IBM Corporation 2018
  3. // FSI master driver for AST2600
  4. #include <linux/clk.h>
  5. #include <linux/delay.h>
  6. #include <linux/fsi.h>
  7. #include <linux/io.h>
  8. #include <linux/mfd/syscon.h>
  9. #include <linux/module.h>
  10. #include <linux/mutex.h>
  11. #include <linux/of.h>
  12. #include <linux/platform_device.h>
  13. #include <linux/regmap.h>
  14. #include <linux/slab.h>
  15. #include <linux/iopoll.h>
  16. #include <linux/gpio/consumer.h>
  17. #include "fsi-master.h"
  18. struct fsi_master_aspeed {
  19. struct fsi_master master;
  20. struct mutex lock; /* protect HW access */
  21. struct device *dev;
  22. void __iomem *base;
  23. struct clk *clk;
  24. struct gpio_desc *cfam_reset_gpio;
  25. };
  26. #define to_fsi_master_aspeed(m) \
  27. container_of(m, struct fsi_master_aspeed, master)
  28. /* Control register (size 0x400) */
  29. static const u32 ctrl_base = 0x80000000;
  30. static const u32 fsi_base = 0xa0000000;
  31. #define OPB_FSI_VER 0x00
  32. #define OPB_TRIGGER 0x04
  33. #define OPB_CTRL_BASE 0x08
  34. #define OPB_FSI_BASE 0x0c
  35. #define OPB_CLK_SYNC 0x3c
  36. #define OPB_IRQ_CLEAR 0x40
  37. #define OPB_IRQ_MASK 0x44
  38. #define OPB_IRQ_STATUS 0x48
  39. #define OPB0_SELECT 0x10
  40. #define OPB0_RW 0x14
  41. #define OPB0_XFER_SIZE 0x18
  42. #define OPB0_FSI_ADDR 0x1c
  43. #define OPB0_FSI_DATA_W 0x20
  44. #define OPB0_STATUS 0x80
  45. #define OPB0_FSI_DATA_R 0x84
  46. #define OPB0_WRITE_ORDER1 0x4c
  47. #define OPB0_WRITE_ORDER2 0x50
  48. #define OPB1_WRITE_ORDER1 0x54
  49. #define OPB1_WRITE_ORDER2 0x58
  50. #define OPB0_READ_ORDER1 0x5c
  51. #define OPB1_READ_ORDER2 0x60
  52. #define OPB_RETRY_COUNTER 0x64
  53. /* OPBn_STATUS */
  54. #define STATUS_HALFWORD_ACK BIT(0)
  55. #define STATUS_FULLWORD_ACK BIT(1)
  56. #define STATUS_ERR_ACK BIT(2)
  57. #define STATUS_RETRY BIT(3)
  58. #define STATUS_TIMEOUT BIT(4)
  59. /* OPB_IRQ_MASK */
  60. #define OPB1_XFER_ACK_EN BIT(17)
  61. #define OPB0_XFER_ACK_EN BIT(16)
  62. /* OPB_RW */
  63. #define CMD_READ BIT(0)
  64. #define CMD_WRITE 0
  65. /* OPBx_XFER_SIZE */
  66. #define XFER_FULLWORD (BIT(1) | BIT(0))
  67. #define XFER_HALFWORD (BIT(0))
  68. #define XFER_BYTE (0)
  69. #define CREATE_TRACE_POINTS
  70. #include <trace/events/fsi_master_aspeed.h>
  71. #define FSI_LINK_ENABLE_SETUP_TIME 10 /* in mS */
  72. /* Run the bus at maximum speed by default */
  73. #define FSI_DIVISOR_DEFAULT 1
  74. #define FSI_DIVISOR_CABLED 2
  75. static u16 aspeed_fsi_divisor = FSI_DIVISOR_DEFAULT;
  76. module_param_named(bus_div,aspeed_fsi_divisor, ushort, 0);
  77. #define OPB_POLL_TIMEOUT 500
  78. static int __opb_write(struct fsi_master_aspeed *aspeed, u32 addr,
  79. u32 val, u32 transfer_size)
  80. {
  81. void __iomem *base = aspeed->base;
  82. u32 reg, status;
  83. int ret;
  84. /*
  85. * The ordering of these writes up until the trigger
  86. * write does not matter, so use writel_relaxed.
  87. */
  88. writel_relaxed(CMD_WRITE, base + OPB0_RW);
  89. writel_relaxed(transfer_size, base + OPB0_XFER_SIZE);
  90. writel_relaxed(addr, base + OPB0_FSI_ADDR);
  91. writel_relaxed(val, base + OPB0_FSI_DATA_W);
  92. writel_relaxed(0x1, base + OPB_IRQ_CLEAR);
  93. writel(0x1, base + OPB_TRIGGER);
  94. ret = readl_poll_timeout(base + OPB_IRQ_STATUS, reg,
  95. (reg & OPB0_XFER_ACK_EN) != 0,
  96. 0, OPB_POLL_TIMEOUT);
  97. status = readl(base + OPB0_STATUS);
  98. trace_fsi_master_aspeed_opb_write(addr, val, transfer_size, status, reg);
  99. /* Return error when poll timed out */
  100. if (ret)
  101. return ret;
  102. /* Command failed, master will reset */
  103. if (status & STATUS_ERR_ACK)
  104. return -EIO;
  105. return 0;
  106. }
  107. static int opb_writeb(struct fsi_master_aspeed *aspeed, u32 addr, u8 val)
  108. {
  109. return __opb_write(aspeed, addr, val, XFER_BYTE);
  110. }
  111. static int opb_writew(struct fsi_master_aspeed *aspeed, u32 addr, __be16 val)
  112. {
  113. return __opb_write(aspeed, addr, (__force u16)val, XFER_HALFWORD);
  114. }
  115. static int opb_writel(struct fsi_master_aspeed *aspeed, u32 addr, __be32 val)
  116. {
  117. return __opb_write(aspeed, addr, (__force u32)val, XFER_FULLWORD);
  118. }
  119. static int __opb_read(struct fsi_master_aspeed *aspeed, uint32_t addr,
  120. u32 transfer_size, void *out)
  121. {
  122. void __iomem *base = aspeed->base;
  123. u32 result, reg;
  124. int status, ret;
  125. /*
  126. * The ordering of these writes up until the trigger
  127. * write does not matter, so use writel_relaxed.
  128. */
  129. writel_relaxed(CMD_READ, base + OPB0_RW);
  130. writel_relaxed(transfer_size, base + OPB0_XFER_SIZE);
  131. writel_relaxed(addr, base + OPB0_FSI_ADDR);
  132. writel_relaxed(0x1, base + OPB_IRQ_CLEAR);
  133. writel(0x1, base + OPB_TRIGGER);
  134. ret = readl_poll_timeout(base + OPB_IRQ_STATUS, reg,
  135. (reg & OPB0_XFER_ACK_EN) != 0,
  136. 0, OPB_POLL_TIMEOUT);
  137. status = readl(base + OPB0_STATUS);
  138. result = readl(base + OPB0_FSI_DATA_R);
  139. trace_fsi_master_aspeed_opb_read(addr, transfer_size, result,
  140. readl(base + OPB0_STATUS),
  141. reg);
  142. /* Return error when poll timed out */
  143. if (ret)
  144. return ret;
  145. /* Command failed, master will reset */
  146. if (status & STATUS_ERR_ACK)
  147. return -EIO;
  148. if (out) {
  149. switch (transfer_size) {
  150. case XFER_BYTE:
  151. *(u8 *)out = result;
  152. break;
  153. case XFER_HALFWORD:
  154. *(u16 *)out = result;
  155. break;
  156. case XFER_FULLWORD:
  157. *(u32 *)out = result;
  158. break;
  159. default:
  160. return -EINVAL;
  161. }
  162. }
  163. return 0;
  164. }
  165. static int opb_readl(struct fsi_master_aspeed *aspeed, uint32_t addr, __be32 *out)
  166. {
  167. return __opb_read(aspeed, addr, XFER_FULLWORD, out);
  168. }
  169. static int opb_readw(struct fsi_master_aspeed *aspeed, uint32_t addr, __be16 *out)
  170. {
  171. return __opb_read(aspeed, addr, XFER_HALFWORD, (void *)out);
  172. }
  173. static int opb_readb(struct fsi_master_aspeed *aspeed, uint32_t addr, u8 *out)
  174. {
  175. return __opb_read(aspeed, addr, XFER_BYTE, (void *)out);
  176. }
  177. static int check_errors(struct fsi_master_aspeed *aspeed, int err)
  178. {
  179. int ret;
  180. if (trace_fsi_master_aspeed_opb_error_enabled()) {
  181. __be32 mresp0, mstap0, mesrb0;
  182. opb_readl(aspeed, ctrl_base + FSI_MRESP0, &mresp0);
  183. opb_readl(aspeed, ctrl_base + FSI_MSTAP0, &mstap0);
  184. opb_readl(aspeed, ctrl_base + FSI_MESRB0, &mesrb0);
  185. trace_fsi_master_aspeed_opb_error(
  186. be32_to_cpu(mresp0),
  187. be32_to_cpu(mstap0),
  188. be32_to_cpu(mesrb0));
  189. }
  190. if (err == -EIO) {
  191. /* Check MAEB (0x70) ? */
  192. /* Then clear errors in master */
  193. ret = opb_writel(aspeed, ctrl_base + FSI_MRESP0,
  194. cpu_to_be32(FSI_MRESP_RST_ALL_MASTER));
  195. if (ret) {
  196. /* TODO: log? return different code? */
  197. return ret;
  198. }
  199. /* TODO: confirm that 0x70 was okay */
  200. }
  201. /* This will pass through timeout errors */
  202. return err;
  203. }
  204. static int aspeed_master_read(struct fsi_master *master, int link,
  205. uint8_t id, uint32_t addr, void *val, size_t size)
  206. {
  207. struct fsi_master_aspeed *aspeed = to_fsi_master_aspeed(master);
  208. int ret;
  209. if (id > 0x3)
  210. return -EINVAL;
  211. addr |= id << 21;
  212. addr += link * FSI_HUB_LINK_SIZE;
  213. mutex_lock(&aspeed->lock);
  214. switch (size) {
  215. case 1:
  216. ret = opb_readb(aspeed, fsi_base + addr, val);
  217. break;
  218. case 2:
  219. ret = opb_readw(aspeed, fsi_base + addr, val);
  220. break;
  221. case 4:
  222. ret = opb_readl(aspeed, fsi_base + addr, val);
  223. break;
  224. default:
  225. ret = -EINVAL;
  226. goto done;
  227. }
  228. ret = check_errors(aspeed, ret);
  229. done:
  230. mutex_unlock(&aspeed->lock);
  231. return ret;
  232. }
  233. static int aspeed_master_write(struct fsi_master *master, int link,
  234. uint8_t id, uint32_t addr, const void *val, size_t size)
  235. {
  236. struct fsi_master_aspeed *aspeed = to_fsi_master_aspeed(master);
  237. int ret;
  238. if (id > 0x3)
  239. return -EINVAL;
  240. addr |= id << 21;
  241. addr += link * FSI_HUB_LINK_SIZE;
  242. mutex_lock(&aspeed->lock);
  243. switch (size) {
  244. case 1:
  245. ret = opb_writeb(aspeed, fsi_base + addr, *(u8 *)val);
  246. break;
  247. case 2:
  248. ret = opb_writew(aspeed, fsi_base + addr, *(__be16 *)val);
  249. break;
  250. case 4:
  251. ret = opb_writel(aspeed, fsi_base + addr, *(__be32 *)val);
  252. break;
  253. default:
  254. ret = -EINVAL;
  255. goto done;
  256. }
  257. ret = check_errors(aspeed, ret);
  258. done:
  259. mutex_unlock(&aspeed->lock);
  260. return ret;
  261. }
  262. static int aspeed_master_link_enable(struct fsi_master *master, int link,
  263. bool enable)
  264. {
  265. struct fsi_master_aspeed *aspeed = to_fsi_master_aspeed(master);
  266. int idx, bit, ret;
  267. __be32 reg;
  268. idx = link / 32;
  269. bit = link % 32;
  270. reg = cpu_to_be32(0x80000000 >> bit);
  271. mutex_lock(&aspeed->lock);
  272. if (!enable) {
  273. ret = opb_writel(aspeed, ctrl_base + FSI_MCENP0 + (4 * idx), reg);
  274. goto done;
  275. }
  276. ret = opb_writel(aspeed, ctrl_base + FSI_MSENP0 + (4 * idx), reg);
  277. if (ret)
  278. goto done;
  279. mdelay(FSI_LINK_ENABLE_SETUP_TIME);
  280. done:
  281. mutex_unlock(&aspeed->lock);
  282. return ret;
  283. }
  284. static int aspeed_master_term(struct fsi_master *master, int link, uint8_t id)
  285. {
  286. uint32_t addr;
  287. __be32 cmd;
  288. addr = 0x4;
  289. cmd = cpu_to_be32(0xecc00000);
  290. return aspeed_master_write(master, link, id, addr, &cmd, 4);
  291. }
  292. static int aspeed_master_break(struct fsi_master *master, int link)
  293. {
  294. uint32_t addr;
  295. __be32 cmd;
  296. addr = 0x0;
  297. cmd = cpu_to_be32(0xc0de0000);
  298. return aspeed_master_write(master, link, 0, addr, &cmd, 4);
  299. }
  300. static void aspeed_master_release(struct device *dev)
  301. {
  302. struct fsi_master_aspeed *aspeed =
  303. to_fsi_master_aspeed(dev_to_fsi_master(dev));
  304. kfree(aspeed);
  305. }
  306. /* mmode encoders */
  307. static inline u32 fsi_mmode_crs0(u32 x)
  308. {
  309. return (x & FSI_MMODE_CRS0MASK) << FSI_MMODE_CRS0SHFT;
  310. }
  311. static inline u32 fsi_mmode_crs1(u32 x)
  312. {
  313. return (x & FSI_MMODE_CRS1MASK) << FSI_MMODE_CRS1SHFT;
  314. }
  315. static int aspeed_master_init(struct fsi_master_aspeed *aspeed)
  316. {
  317. __be32 reg;
  318. reg = cpu_to_be32(FSI_MRESP_RST_ALL_MASTER | FSI_MRESP_RST_ALL_LINK
  319. | FSI_MRESP_RST_MCR | FSI_MRESP_RST_PYE);
  320. opb_writel(aspeed, ctrl_base + FSI_MRESP0, reg);
  321. /* Initialize the MFSI (hub master) engine */
  322. reg = cpu_to_be32(FSI_MRESP_RST_ALL_MASTER | FSI_MRESP_RST_ALL_LINK
  323. | FSI_MRESP_RST_MCR | FSI_MRESP_RST_PYE);
  324. opb_writel(aspeed, ctrl_base + FSI_MRESP0, reg);
  325. reg = cpu_to_be32(FSI_MECTRL_EOAE | FSI_MECTRL_P8_AUTO_TERM);
  326. opb_writel(aspeed, ctrl_base + FSI_MECTRL, reg);
  327. reg = cpu_to_be32(FSI_MMODE_ECRC | FSI_MMODE_EPC | FSI_MMODE_RELA
  328. | fsi_mmode_crs0(aspeed_fsi_divisor)
  329. | fsi_mmode_crs1(aspeed_fsi_divisor)
  330. | FSI_MMODE_P8_TO_LSB);
  331. dev_info(aspeed->dev, "mmode set to %08x (divisor %d)\n",
  332. be32_to_cpu(reg), aspeed_fsi_divisor);
  333. opb_writel(aspeed, ctrl_base + FSI_MMODE, reg);
  334. reg = cpu_to_be32(0xffff0000);
  335. opb_writel(aspeed, ctrl_base + FSI_MDLYR, reg);
  336. reg = cpu_to_be32(~0);
  337. opb_writel(aspeed, ctrl_base + FSI_MSENP0, reg);
  338. /* Leave enabled long enough for master logic to set up */
  339. mdelay(FSI_LINK_ENABLE_SETUP_TIME);
  340. opb_writel(aspeed, ctrl_base + FSI_MCENP0, reg);
  341. opb_readl(aspeed, ctrl_base + FSI_MAEB, NULL);
  342. reg = cpu_to_be32(FSI_MRESP_RST_ALL_MASTER | FSI_MRESP_RST_ALL_LINK);
  343. opb_writel(aspeed, ctrl_base + FSI_MRESP0, reg);
  344. opb_readl(aspeed, ctrl_base + FSI_MLEVP0, NULL);
  345. /* Reset the master bridge */
  346. reg = cpu_to_be32(FSI_MRESB_RST_GEN);
  347. opb_writel(aspeed, ctrl_base + FSI_MRESB0, reg);
  348. reg = cpu_to_be32(FSI_MRESB_RST_ERR);
  349. opb_writel(aspeed, ctrl_base + FSI_MRESB0, reg);
  350. return 0;
  351. }
  352. static ssize_t cfam_reset_store(struct device *dev, struct device_attribute *attr,
  353. const char *buf, size_t count)
  354. {
  355. struct fsi_master_aspeed *aspeed = dev_get_drvdata(dev);
  356. trace_fsi_master_aspeed_cfam_reset(true);
  357. mutex_lock(&aspeed->lock);
  358. gpiod_set_value(aspeed->cfam_reset_gpio, 1);
  359. usleep_range(900, 1000);
  360. gpiod_set_value(aspeed->cfam_reset_gpio, 0);
  361. usleep_range(900, 1000);
  362. opb_writel(aspeed, ctrl_base + FSI_MRESP0, cpu_to_be32(FSI_MRESP_RST_ALL_MASTER));
  363. mutex_unlock(&aspeed->lock);
  364. trace_fsi_master_aspeed_cfam_reset(false);
  365. return count;
  366. }
  367. static DEVICE_ATTR(cfam_reset, 0200, NULL, cfam_reset_store);
  368. static int setup_cfam_reset(struct fsi_master_aspeed *aspeed)
  369. {
  370. struct device *dev = aspeed->dev;
  371. struct gpio_desc *gpio;
  372. int rc;
  373. gpio = devm_gpiod_get_optional(dev, "cfam-reset", GPIOD_OUT_LOW);
  374. if (IS_ERR(gpio))
  375. return PTR_ERR(gpio);
  376. if (!gpio)
  377. return 0;
  378. aspeed->cfam_reset_gpio = gpio;
  379. rc = device_create_file(dev, &dev_attr_cfam_reset);
  380. if (rc) {
  381. devm_gpiod_put(dev, gpio);
  382. return rc;
  383. }
  384. return 0;
  385. }
  386. static int tacoma_cabled_fsi_fixup(struct device *dev)
  387. {
  388. struct gpio_desc *routing_gpio, *mux_gpio;
  389. int gpio;
  390. /*
  391. * The routing GPIO is a jumper indicating we should mux for the
  392. * externally connected FSI cable.
  393. */
  394. routing_gpio = devm_gpiod_get_optional(dev, "fsi-routing",
  395. GPIOD_IN | GPIOD_FLAGS_BIT_NONEXCLUSIVE);
  396. if (IS_ERR(routing_gpio))
  397. return PTR_ERR(routing_gpio);
  398. if (!routing_gpio)
  399. return 0;
  400. mux_gpio = devm_gpiod_get_optional(dev, "fsi-mux", GPIOD_ASIS);
  401. if (IS_ERR(mux_gpio))
  402. return PTR_ERR(mux_gpio);
  403. if (!mux_gpio)
  404. return 0;
  405. gpio = gpiod_get_value(routing_gpio);
  406. if (gpio < 0)
  407. return gpio;
  408. /* If the routing GPIO is high we should set the mux to low. */
  409. if (gpio) {
  410. /*
  411. * Cable signal integrity means we should run the bus
  412. * slightly slower. Do not override if a kernel param
  413. * has already overridden.
  414. */
  415. if (aspeed_fsi_divisor == FSI_DIVISOR_DEFAULT)
  416. aspeed_fsi_divisor = FSI_DIVISOR_CABLED;
  417. gpiod_direction_output(mux_gpio, 0);
  418. dev_info(dev, "FSI configured for external cable\n");
  419. } else {
  420. gpiod_direction_output(mux_gpio, 1);
  421. }
  422. devm_gpiod_put(dev, routing_gpio);
  423. return 0;
  424. }
  425. static int fsi_master_aspeed_probe(struct platform_device *pdev)
  426. {
  427. struct fsi_master_aspeed *aspeed;
  428. int rc, links, reg;
  429. __be32 raw;
  430. rc = tacoma_cabled_fsi_fixup(&pdev->dev);
  431. if (rc) {
  432. dev_err(&pdev->dev, "Tacoma FSI cable fixup failed\n");
  433. return rc;
  434. }
  435. aspeed = kzalloc(sizeof(*aspeed), GFP_KERNEL);
  436. if (!aspeed)
  437. return -ENOMEM;
  438. aspeed->dev = &pdev->dev;
  439. aspeed->base = devm_platform_ioremap_resource(pdev, 0);
  440. if (IS_ERR(aspeed->base)) {
  441. rc = PTR_ERR(aspeed->base);
  442. goto err_free_aspeed;
  443. }
  444. aspeed->clk = devm_clk_get(aspeed->dev, NULL);
  445. if (IS_ERR(aspeed->clk)) {
  446. dev_err(aspeed->dev, "couldn't get clock\n");
  447. rc = PTR_ERR(aspeed->clk);
  448. goto err_free_aspeed;
  449. }
  450. rc = clk_prepare_enable(aspeed->clk);
  451. if (rc) {
  452. dev_err(aspeed->dev, "couldn't enable clock\n");
  453. goto err_free_aspeed;
  454. }
  455. rc = setup_cfam_reset(aspeed);
  456. if (rc) {
  457. dev_err(&pdev->dev, "CFAM reset GPIO setup failed\n");
  458. }
  459. writel(0x1, aspeed->base + OPB_CLK_SYNC);
  460. writel(OPB1_XFER_ACK_EN | OPB0_XFER_ACK_EN,
  461. aspeed->base + OPB_IRQ_MASK);
  462. /* TODO: determine an appropriate value */
  463. writel(0x10, aspeed->base + OPB_RETRY_COUNTER);
  464. writel(ctrl_base, aspeed->base + OPB_CTRL_BASE);
  465. writel(fsi_base, aspeed->base + OPB_FSI_BASE);
  466. /* Set read data order */
  467. writel(0x00030b1b, aspeed->base + OPB0_READ_ORDER1);
  468. /* Set write data order */
  469. writel(0x0011101b, aspeed->base + OPB0_WRITE_ORDER1);
  470. writel(0x0c330f3f, aspeed->base + OPB0_WRITE_ORDER2);
  471. /*
  472. * Select OPB0 for all operations.
  473. * Will need to be reworked when enabling DMA or anything that uses
  474. * OPB1.
  475. */
  476. writel(0x1, aspeed->base + OPB0_SELECT);
  477. rc = opb_readl(aspeed, ctrl_base + FSI_MVER, &raw);
  478. if (rc) {
  479. dev_err(&pdev->dev, "failed to read hub version\n");
  480. goto err_release;
  481. }
  482. reg = be32_to_cpu(raw);
  483. links = (reg >> 8) & 0xff;
  484. dev_info(&pdev->dev, "hub version %08x (%d links)\n", reg, links);
  485. aspeed->master.dev.parent = &pdev->dev;
  486. aspeed->master.dev.release = aspeed_master_release;
  487. aspeed->master.dev.of_node = of_node_get(dev_of_node(&pdev->dev));
  488. aspeed->master.n_links = links;
  489. aspeed->master.read = aspeed_master_read;
  490. aspeed->master.write = aspeed_master_write;
  491. aspeed->master.send_break = aspeed_master_break;
  492. aspeed->master.term = aspeed_master_term;
  493. aspeed->master.link_enable = aspeed_master_link_enable;
  494. dev_set_drvdata(&pdev->dev, aspeed);
  495. mutex_init(&aspeed->lock);
  496. aspeed_master_init(aspeed);
  497. rc = fsi_master_register(&aspeed->master);
  498. if (rc)
  499. goto err_release;
  500. /* At this point, fsi_master_register performs the device_initialize(),
  501. * and holds the sole reference on master.dev. This means the device
  502. * will be freed (via ->release) during any subsequent call to
  503. * fsi_master_unregister. We add our own reference to it here, so we
  504. * can perform cleanup (in _remove()) without it being freed before
  505. * we're ready.
  506. */
  507. get_device(&aspeed->master.dev);
  508. return 0;
  509. err_release:
  510. clk_disable_unprepare(aspeed->clk);
  511. err_free_aspeed:
  512. kfree(aspeed);
  513. return rc;
  514. }
  515. static int fsi_master_aspeed_remove(struct platform_device *pdev)
  516. {
  517. struct fsi_master_aspeed *aspeed = platform_get_drvdata(pdev);
  518. fsi_master_unregister(&aspeed->master);
  519. clk_disable_unprepare(aspeed->clk);
  520. return 0;
  521. }
  522. static const struct of_device_id fsi_master_aspeed_match[] = {
  523. { .compatible = "aspeed,ast2600-fsi-master" },
  524. { },
  525. };
  526. MODULE_DEVICE_TABLE(of, fsi_master_aspeed_match);
  527. static struct platform_driver fsi_master_aspeed_driver = {
  528. .driver = {
  529. .name = "fsi-master-aspeed",
  530. .of_match_table = fsi_master_aspeed_match,
  531. },
  532. .probe = fsi_master_aspeed_probe,
  533. .remove = fsi_master_aspeed_remove,
  534. };
  535. module_platform_driver(fsi_master_aspeed_driver);
  536. MODULE_LICENSE("GPL");