spi-sprd-adi.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669
  1. /*
  2. * Copyright (C) 2017 Spreadtrum Communications Inc.
  3. *
  4. * SPDX-License-Identifier: GPL-2.0
  5. */
  6. #include <linux/delay.h>
  7. #include <linux/hwspinlock.h>
  8. #include <linux/init.h>
  9. #include <linux/io.h>
  10. #include <linux/kernel.h>
  11. #include <linux/module.h>
  12. #include <linux/of.h>
  13. #include <linux/of_device.h>
  14. #include <linux/platform_device.h>
  15. #include <linux/reboot.h>
  16. #include <linux/spi/spi.h>
  17. #include <linux/sizes.h>
  18. /* Registers definitions for ADI controller */
  19. #define REG_ADI_CTRL0 0x4
  20. #define REG_ADI_CHN_PRIL 0x8
  21. #define REG_ADI_CHN_PRIH 0xc
  22. #define REG_ADI_INT_EN 0x10
  23. #define REG_ADI_INT_RAW 0x14
  24. #define REG_ADI_INT_MASK 0x18
  25. #define REG_ADI_INT_CLR 0x1c
  26. #define REG_ADI_GSSI_CFG0 0x20
  27. #define REG_ADI_GSSI_CFG1 0x24
  28. #define REG_ADI_RD_CMD 0x28
  29. #define REG_ADI_RD_DATA 0x2c
  30. #define REG_ADI_ARM_FIFO_STS 0x30
  31. #define REG_ADI_STS 0x34
  32. #define REG_ADI_EVT_FIFO_STS 0x38
  33. #define REG_ADI_ARM_CMD_STS 0x3c
  34. #define REG_ADI_CHN_EN 0x40
  35. #define REG_ADI_CHN_ADDR(id) (0x44 + (id - 2) * 4)
  36. #define REG_ADI_CHN_EN1 0x20c
  37. /* Bits definitions for register REG_ADI_GSSI_CFG0 */
  38. #define BIT_CLK_ALL_ON BIT(30)
  39. /* Bits definitions for register REG_ADI_RD_DATA */
  40. #define BIT_RD_CMD_BUSY BIT(31)
  41. #define RD_ADDR_SHIFT 16
  42. #define RD_VALUE_MASK GENMASK(15, 0)
  43. #define RD_ADDR_MASK GENMASK(30, 16)
  44. /* Bits definitions for register REG_ADI_ARM_FIFO_STS */
  45. #define BIT_FIFO_FULL BIT(11)
  46. #define BIT_FIFO_EMPTY BIT(10)
  47. /*
  48. * ADI slave devices include RTC, ADC, regulator, charger, thermal and so on.
  49. * ADI supports 12/14bit address for r2p0, and additional 17bit for r3p0 or
  50. * later versions. Since bit[1:0] are zero, so the spec describe them as
  51. * 10/12/15bit address mode.
  52. * The 10bit mode supports sigle slave, 12/15bit mode supports 3 slave, the
  53. * high two bits is slave_id.
  54. * The slave devices address offset is 0x8000 for 10/12bit address mode,
  55. * and 0x20000 for 15bit mode.
  56. */
  57. #define ADI_10BIT_SLAVE_ADDR_SIZE SZ_4K
  58. #define ADI_10BIT_SLAVE_OFFSET 0x8000
  59. #define ADI_12BIT_SLAVE_ADDR_SIZE SZ_16K
  60. #define ADI_12BIT_SLAVE_OFFSET 0x8000
  61. #define ADI_15BIT_SLAVE_ADDR_SIZE SZ_128K
  62. #define ADI_15BIT_SLAVE_OFFSET 0x20000
  63. /* Timeout (ms) for the trylock of hardware spinlocks */
  64. #define ADI_HWSPINLOCK_TIMEOUT 5000
  65. /*
  66. * ADI controller has 50 channels including 2 software channels
  67. * and 48 hardware channels.
  68. */
  69. #define ADI_HW_CHNS 50
  70. #define ADI_FIFO_DRAIN_TIMEOUT 1000
  71. #define ADI_READ_TIMEOUT 2000
  72. /*
  73. * Read back address from REG_ADI_RD_DATA bit[30:16] which maps to:
  74. * REG_ADI_RD_CMD bit[14:0] for r2p0
  75. * REG_ADI_RD_CMD bit[16:2] for r3p0
  76. */
  77. #define RDBACK_ADDR_MASK_R2 GENMASK(14, 0)
  78. #define RDBACK_ADDR_MASK_R3 GENMASK(16, 2)
  79. #define RDBACK_ADDR_SHIFT_R3 2
  80. /* Registers definitions for PMIC watchdog controller */
  81. #define REG_WDG_LOAD_LOW 0x0
  82. #define REG_WDG_LOAD_HIGH 0x4
  83. #define REG_WDG_CTRL 0x8
  84. #define REG_WDG_LOCK 0x20
  85. /* Bits definitions for register REG_WDG_CTRL */
  86. #define BIT_WDG_RUN BIT(1)
  87. #define BIT_WDG_NEW BIT(2)
  88. #define BIT_WDG_RST BIT(3)
  89. /* Bits definitions for register REG_MODULE_EN */
  90. #define BIT_WDG_EN BIT(2)
  91. /* Registers definitions for PMIC */
  92. #define PMIC_RST_STATUS 0xee8
  93. #define PMIC_MODULE_EN 0xc08
  94. #define PMIC_CLK_EN 0xc18
  95. #define PMIC_WDG_BASE 0x80
  96. /* Definition of PMIC reset status register */
  97. #define HWRST_STATUS_SECURITY 0x02
  98. #define HWRST_STATUS_RECOVERY 0x20
  99. #define HWRST_STATUS_NORMAL 0x40
  100. #define HWRST_STATUS_ALARM 0x50
  101. #define HWRST_STATUS_SLEEP 0x60
  102. #define HWRST_STATUS_FASTBOOT 0x30
  103. #define HWRST_STATUS_SPECIAL 0x70
  104. #define HWRST_STATUS_PANIC 0x80
  105. #define HWRST_STATUS_CFTREBOOT 0x90
  106. #define HWRST_STATUS_AUTODLOADER 0xa0
  107. #define HWRST_STATUS_IQMODE 0xb0
  108. #define HWRST_STATUS_SPRDISK 0xc0
  109. #define HWRST_STATUS_FACTORYTEST 0xe0
  110. #define HWRST_STATUS_WATCHDOG 0xf0
  111. /* Use default timeout 50 ms that converts to watchdog values */
  112. #define WDG_LOAD_VAL ((50 * 32768) / 1000)
  113. #define WDG_LOAD_MASK GENMASK(15, 0)
  114. #define WDG_UNLOCK_KEY 0xe551
  115. struct sprd_adi_wdg {
  116. u32 base;
  117. u32 rst_sts;
  118. u32 wdg_en;
  119. u32 wdg_clk;
  120. };
  121. struct sprd_adi_data {
  122. u32 slave_offset;
  123. u32 slave_addr_size;
  124. int (*read_check)(u32 val, u32 reg);
  125. int (*restart)(struct notifier_block *this,
  126. unsigned long mode, void *cmd);
  127. void (*wdg_rst)(void *p);
  128. };
  129. struct sprd_adi {
  130. struct spi_controller *ctlr;
  131. struct device *dev;
  132. void __iomem *base;
  133. struct hwspinlock *hwlock;
  134. unsigned long slave_vbase;
  135. unsigned long slave_pbase;
  136. struct notifier_block restart_handler;
  137. const struct sprd_adi_data *data;
  138. };
  139. static int sprd_adi_check_addr(struct sprd_adi *sadi, u32 reg)
  140. {
  141. if (reg >= sadi->data->slave_addr_size) {
  142. dev_err(sadi->dev,
  143. "slave address offset is incorrect, reg = 0x%x\n",
  144. reg);
  145. return -EINVAL;
  146. }
  147. return 0;
  148. }
  149. static int sprd_adi_drain_fifo(struct sprd_adi *sadi)
  150. {
  151. u32 timeout = ADI_FIFO_DRAIN_TIMEOUT;
  152. u32 sts;
  153. do {
  154. sts = readl_relaxed(sadi->base + REG_ADI_ARM_FIFO_STS);
  155. if (sts & BIT_FIFO_EMPTY)
  156. break;
  157. cpu_relax();
  158. } while (--timeout);
  159. if (timeout == 0) {
  160. dev_err(sadi->dev, "drain write fifo timeout\n");
  161. return -EBUSY;
  162. }
  163. return 0;
  164. }
  165. static int sprd_adi_fifo_is_full(struct sprd_adi *sadi)
  166. {
  167. return readl_relaxed(sadi->base + REG_ADI_ARM_FIFO_STS) & BIT_FIFO_FULL;
  168. }
  169. static int sprd_adi_read_check(u32 val, u32 addr)
  170. {
  171. u32 rd_addr;
  172. rd_addr = (val & RD_ADDR_MASK) >> RD_ADDR_SHIFT;
  173. if (rd_addr != addr) {
  174. pr_err("ADI read error, addr = 0x%x, val = 0x%x\n", addr, val);
  175. return -EIO;
  176. }
  177. return 0;
  178. }
  179. static int sprd_adi_read_check_r2(u32 val, u32 reg)
  180. {
  181. return sprd_adi_read_check(val, reg & RDBACK_ADDR_MASK_R2);
  182. }
  183. static int sprd_adi_read_check_r3(u32 val, u32 reg)
  184. {
  185. return sprd_adi_read_check(val, (reg & RDBACK_ADDR_MASK_R3) >> RDBACK_ADDR_SHIFT_R3);
  186. }
  187. static int sprd_adi_read(struct sprd_adi *sadi, u32 reg, u32 *read_val)
  188. {
  189. int read_timeout = ADI_READ_TIMEOUT;
  190. unsigned long flags;
  191. u32 val;
  192. int ret = 0;
  193. if (sadi->hwlock) {
  194. ret = hwspin_lock_timeout_irqsave(sadi->hwlock,
  195. ADI_HWSPINLOCK_TIMEOUT,
  196. &flags);
  197. if (ret) {
  198. dev_err(sadi->dev, "get the hw lock failed\n");
  199. return ret;
  200. }
  201. }
  202. ret = sprd_adi_check_addr(sadi, reg);
  203. if (ret)
  204. goto out;
  205. /*
  206. * Set the slave address offset need to read into RD_CMD register,
  207. * then ADI controller will start to transfer automatically.
  208. */
  209. writel_relaxed(reg, sadi->base + REG_ADI_RD_CMD);
  210. /*
  211. * Wait read operation complete, the BIT_RD_CMD_BUSY will be set
  212. * simultaneously when writing read command to register, and the
  213. * BIT_RD_CMD_BUSY will be cleared after the read operation is
  214. * completed.
  215. */
  216. do {
  217. val = readl_relaxed(sadi->base + REG_ADI_RD_DATA);
  218. if (!(val & BIT_RD_CMD_BUSY))
  219. break;
  220. cpu_relax();
  221. } while (--read_timeout);
  222. if (read_timeout == 0) {
  223. dev_err(sadi->dev, "ADI read timeout\n");
  224. ret = -EBUSY;
  225. goto out;
  226. }
  227. /*
  228. * The return value before adi r5p0 includes data and read register
  229. * address, from bit 0to bit 15 are data, and from bit 16 to bit 30
  230. * are read register address. Then we can check the returned register
  231. * address to validate data.
  232. */
  233. if (sadi->data->read_check) {
  234. ret = sadi->data->read_check(val, reg);
  235. if (ret < 0)
  236. goto out;
  237. }
  238. *read_val = val & RD_VALUE_MASK;
  239. out:
  240. if (sadi->hwlock)
  241. hwspin_unlock_irqrestore(sadi->hwlock, &flags);
  242. return ret;
  243. }
  244. static int sprd_adi_write(struct sprd_adi *sadi, u32 reg, u32 val)
  245. {
  246. u32 timeout = ADI_FIFO_DRAIN_TIMEOUT;
  247. unsigned long flags;
  248. int ret;
  249. if (sadi->hwlock) {
  250. ret = hwspin_lock_timeout_irqsave(sadi->hwlock,
  251. ADI_HWSPINLOCK_TIMEOUT,
  252. &flags);
  253. if (ret) {
  254. dev_err(sadi->dev, "get the hw lock failed\n");
  255. return ret;
  256. }
  257. }
  258. ret = sprd_adi_check_addr(sadi, reg);
  259. if (ret)
  260. goto out;
  261. ret = sprd_adi_drain_fifo(sadi);
  262. if (ret < 0)
  263. goto out;
  264. /*
  265. * we should wait for write fifo is empty before writing data to PMIC
  266. * registers.
  267. */
  268. do {
  269. if (!sprd_adi_fifo_is_full(sadi)) {
  270. /* we need virtual register address to write. */
  271. writel_relaxed(val, (void __iomem *)(sadi->slave_vbase + reg));
  272. break;
  273. }
  274. cpu_relax();
  275. } while (--timeout);
  276. if (timeout == 0) {
  277. dev_err(sadi->dev, "write fifo is full\n");
  278. ret = -EBUSY;
  279. }
  280. out:
  281. if (sadi->hwlock)
  282. hwspin_unlock_irqrestore(sadi->hwlock, &flags);
  283. return ret;
  284. }
  285. static int sprd_adi_transfer_one(struct spi_controller *ctlr,
  286. struct spi_device *spi_dev,
  287. struct spi_transfer *t)
  288. {
  289. struct sprd_adi *sadi = spi_controller_get_devdata(ctlr);
  290. u32 reg, val;
  291. int ret;
  292. if (t->rx_buf) {
  293. reg = *(u32 *)t->rx_buf;
  294. ret = sprd_adi_read(sadi, reg, &val);
  295. *(u32 *)t->rx_buf = val;
  296. } else if (t->tx_buf) {
  297. u32 *p = (u32 *)t->tx_buf;
  298. reg = *p++;
  299. val = *p;
  300. ret = sprd_adi_write(sadi, reg, val);
  301. } else {
  302. dev_err(sadi->dev, "no buffer for transfer\n");
  303. ret = -EINVAL;
  304. }
  305. return ret;
  306. }
  307. static void sprd_adi_set_wdt_rst_mode(void *p)
  308. {
  309. #if IS_ENABLED(CONFIG_SPRD_WATCHDOG)
  310. u32 val;
  311. struct sprd_adi *sadi = (struct sprd_adi *)p;
  312. /* Init watchdog reset mode */
  313. sprd_adi_read(sadi, PMIC_RST_STATUS, &val);
  314. val |= HWRST_STATUS_WATCHDOG;
  315. sprd_adi_write(sadi, PMIC_RST_STATUS, val);
  316. #endif
  317. }
  318. static int sprd_adi_restart(struct notifier_block *this, unsigned long mode,
  319. void *cmd, struct sprd_adi_wdg *wdg)
  320. {
  321. struct sprd_adi *sadi = container_of(this, struct sprd_adi,
  322. restart_handler);
  323. u32 val, reboot_mode = 0;
  324. if (!cmd)
  325. reboot_mode = HWRST_STATUS_NORMAL;
  326. else if (!strncmp(cmd, "recovery", 8))
  327. reboot_mode = HWRST_STATUS_RECOVERY;
  328. else if (!strncmp(cmd, "alarm", 5))
  329. reboot_mode = HWRST_STATUS_ALARM;
  330. else if (!strncmp(cmd, "fastsleep", 9))
  331. reboot_mode = HWRST_STATUS_SLEEP;
  332. else if (!strncmp(cmd, "bootloader", 10))
  333. reboot_mode = HWRST_STATUS_FASTBOOT;
  334. else if (!strncmp(cmd, "panic", 5))
  335. reboot_mode = HWRST_STATUS_PANIC;
  336. else if (!strncmp(cmd, "special", 7))
  337. reboot_mode = HWRST_STATUS_SPECIAL;
  338. else if (!strncmp(cmd, "cftreboot", 9))
  339. reboot_mode = HWRST_STATUS_CFTREBOOT;
  340. else if (!strncmp(cmd, "autodloader", 11))
  341. reboot_mode = HWRST_STATUS_AUTODLOADER;
  342. else if (!strncmp(cmd, "iqmode", 6))
  343. reboot_mode = HWRST_STATUS_IQMODE;
  344. else if (!strncmp(cmd, "sprdisk", 7))
  345. reboot_mode = HWRST_STATUS_SPRDISK;
  346. else if (!strncmp(cmd, "tospanic", 8))
  347. reboot_mode = HWRST_STATUS_SECURITY;
  348. else if (!strncmp(cmd, "factorytest", 11))
  349. reboot_mode = HWRST_STATUS_FACTORYTEST;
  350. else
  351. reboot_mode = HWRST_STATUS_NORMAL;
  352. /* Record the reboot mode */
  353. sprd_adi_read(sadi, wdg->rst_sts, &val);
  354. val &= ~HWRST_STATUS_WATCHDOG;
  355. val |= reboot_mode;
  356. sprd_adi_write(sadi, wdg->rst_sts, val);
  357. /* Enable the interface clock of the watchdog */
  358. sprd_adi_read(sadi, wdg->wdg_en, &val);
  359. val |= BIT_WDG_EN;
  360. sprd_adi_write(sadi, wdg->wdg_en, val);
  361. /* Enable the work clock of the watchdog */
  362. sprd_adi_read(sadi, wdg->wdg_clk, &val);
  363. val |= BIT_WDG_EN;
  364. sprd_adi_write(sadi, wdg->wdg_clk, val);
  365. /* Unlock the watchdog */
  366. sprd_adi_write(sadi, wdg->base + REG_WDG_LOCK, WDG_UNLOCK_KEY);
  367. sprd_adi_read(sadi, wdg->base + REG_WDG_CTRL, &val);
  368. val |= BIT_WDG_NEW;
  369. sprd_adi_write(sadi, wdg->base + REG_WDG_CTRL, val);
  370. /* Load the watchdog timeout value, 50ms is always enough. */
  371. sprd_adi_write(sadi, wdg->base + REG_WDG_LOAD_HIGH, 0);
  372. sprd_adi_write(sadi, wdg->base + REG_WDG_LOAD_LOW,
  373. WDG_LOAD_VAL & WDG_LOAD_MASK);
  374. /* Start the watchdog to reset system */
  375. sprd_adi_read(sadi, wdg->base + REG_WDG_CTRL, &val);
  376. val |= BIT_WDG_RUN | BIT_WDG_RST;
  377. sprd_adi_write(sadi, wdg->base + REG_WDG_CTRL, val);
  378. /* Lock the watchdog */
  379. sprd_adi_write(sadi, wdg->base + REG_WDG_LOCK, ~WDG_UNLOCK_KEY);
  380. mdelay(1000);
  381. dev_emerg(sadi->dev, "Unable to restart system\n");
  382. return NOTIFY_DONE;
  383. }
  384. static int sprd_adi_restart_sc9860(struct notifier_block *this,
  385. unsigned long mode, void *cmd)
  386. {
  387. struct sprd_adi_wdg wdg = {
  388. .base = PMIC_WDG_BASE,
  389. .rst_sts = PMIC_RST_STATUS,
  390. .wdg_en = PMIC_MODULE_EN,
  391. .wdg_clk = PMIC_CLK_EN,
  392. };
  393. return sprd_adi_restart(this, mode, cmd, &wdg);
  394. }
  395. static void sprd_adi_hw_init(struct sprd_adi *sadi)
  396. {
  397. struct device_node *np = sadi->dev->of_node;
  398. int i, size, chn_cnt;
  399. const __be32 *list;
  400. u32 tmp;
  401. /* Set all channels as default priority */
  402. writel_relaxed(0, sadi->base + REG_ADI_CHN_PRIL);
  403. writel_relaxed(0, sadi->base + REG_ADI_CHN_PRIH);
  404. /* Set clock auto gate mode */
  405. tmp = readl_relaxed(sadi->base + REG_ADI_GSSI_CFG0);
  406. tmp &= ~BIT_CLK_ALL_ON;
  407. writel_relaxed(tmp, sadi->base + REG_ADI_GSSI_CFG0);
  408. /* Set hardware channels setting */
  409. list = of_get_property(np, "sprd,hw-channels", &size);
  410. if (!list || !size) {
  411. dev_info(sadi->dev, "no hw channels setting in node\n");
  412. return;
  413. }
  414. chn_cnt = size / 8;
  415. for (i = 0; i < chn_cnt; i++) {
  416. u32 value;
  417. u32 chn_id = be32_to_cpu(*list++);
  418. u32 chn_config = be32_to_cpu(*list++);
  419. /* Channel 0 and 1 are software channels */
  420. if (chn_id < 2)
  421. continue;
  422. writel_relaxed(chn_config, sadi->base +
  423. REG_ADI_CHN_ADDR(chn_id));
  424. if (chn_id < 32) {
  425. value = readl_relaxed(sadi->base + REG_ADI_CHN_EN);
  426. value |= BIT(chn_id);
  427. writel_relaxed(value, sadi->base + REG_ADI_CHN_EN);
  428. } else if (chn_id < ADI_HW_CHNS) {
  429. value = readl_relaxed(sadi->base + REG_ADI_CHN_EN1);
  430. value |= BIT(chn_id - 32);
  431. writel_relaxed(value, sadi->base + REG_ADI_CHN_EN1);
  432. }
  433. }
  434. }
  435. static int sprd_adi_probe(struct platform_device *pdev)
  436. {
  437. struct device_node *np = pdev->dev.of_node;
  438. const struct sprd_adi_data *data;
  439. struct spi_controller *ctlr;
  440. struct sprd_adi *sadi;
  441. struct resource *res;
  442. u16 num_chipselect;
  443. int ret;
  444. if (!np) {
  445. dev_err(&pdev->dev, "can not find the adi bus node\n");
  446. return -ENODEV;
  447. }
  448. data = of_device_get_match_data(&pdev->dev);
  449. if (!data) {
  450. dev_err(&pdev->dev, "no matching driver data found\n");
  451. return -EINVAL;
  452. }
  453. pdev->id = of_alias_get_id(np, "spi");
  454. num_chipselect = of_get_child_count(np);
  455. ctlr = spi_alloc_master(&pdev->dev, sizeof(struct sprd_adi));
  456. if (!ctlr)
  457. return -ENOMEM;
  458. dev_set_drvdata(&pdev->dev, ctlr);
  459. sadi = spi_controller_get_devdata(ctlr);
  460. res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  461. sadi->base = devm_ioremap_resource(&pdev->dev, res);
  462. if (IS_ERR(sadi->base)) {
  463. ret = PTR_ERR(sadi->base);
  464. goto put_ctlr;
  465. }
  466. sadi->slave_vbase = (unsigned long)sadi->base +
  467. data->slave_offset;
  468. sadi->slave_pbase = res->start + data->slave_offset;
  469. sadi->ctlr = ctlr;
  470. sadi->dev = &pdev->dev;
  471. sadi->data = data;
  472. ret = of_hwspin_lock_get_id(np, 0);
  473. if (ret > 0 || (IS_ENABLED(CONFIG_HWSPINLOCK) && ret == 0)) {
  474. sadi->hwlock =
  475. devm_hwspin_lock_request_specific(&pdev->dev, ret);
  476. if (!sadi->hwlock) {
  477. ret = -ENXIO;
  478. goto put_ctlr;
  479. }
  480. } else {
  481. switch (ret) {
  482. case -ENOENT:
  483. dev_info(&pdev->dev, "no hardware spinlock supplied\n");
  484. break;
  485. default:
  486. dev_err_probe(&pdev->dev, ret, "failed to find hwlock id\n");
  487. goto put_ctlr;
  488. }
  489. }
  490. sprd_adi_hw_init(sadi);
  491. if (sadi->data->wdg_rst)
  492. sadi->data->wdg_rst(sadi);
  493. ctlr->dev.of_node = pdev->dev.of_node;
  494. ctlr->bus_num = pdev->id;
  495. ctlr->num_chipselect = num_chipselect;
  496. ctlr->flags = SPI_MASTER_HALF_DUPLEX;
  497. ctlr->bits_per_word_mask = 0;
  498. ctlr->transfer_one = sprd_adi_transfer_one;
  499. ret = devm_spi_register_controller(&pdev->dev, ctlr);
  500. if (ret) {
  501. dev_err(&pdev->dev, "failed to register SPI controller\n");
  502. goto put_ctlr;
  503. }
  504. if (sadi->data->restart) {
  505. sadi->restart_handler.notifier_call = sadi->data->restart;
  506. sadi->restart_handler.priority = 128;
  507. ret = register_restart_handler(&sadi->restart_handler);
  508. if (ret) {
  509. dev_err(&pdev->dev, "can not register restart handler\n");
  510. goto put_ctlr;
  511. }
  512. }
  513. return 0;
  514. put_ctlr:
  515. spi_controller_put(ctlr);
  516. return ret;
  517. }
  518. static int sprd_adi_remove(struct platform_device *pdev)
  519. {
  520. struct spi_controller *ctlr = dev_get_drvdata(&pdev->dev);
  521. struct sprd_adi *sadi = spi_controller_get_devdata(ctlr);
  522. unregister_restart_handler(&sadi->restart_handler);
  523. return 0;
  524. }
  525. static struct sprd_adi_data sc9860_data = {
  526. .slave_offset = ADI_10BIT_SLAVE_OFFSET,
  527. .slave_addr_size = ADI_10BIT_SLAVE_ADDR_SIZE,
  528. .read_check = sprd_adi_read_check_r2,
  529. .restart = sprd_adi_restart_sc9860,
  530. .wdg_rst = sprd_adi_set_wdt_rst_mode,
  531. };
  532. static struct sprd_adi_data sc9863_data = {
  533. .slave_offset = ADI_12BIT_SLAVE_OFFSET,
  534. .slave_addr_size = ADI_12BIT_SLAVE_ADDR_SIZE,
  535. .read_check = sprd_adi_read_check_r3,
  536. };
  537. static struct sprd_adi_data ums512_data = {
  538. .slave_offset = ADI_15BIT_SLAVE_OFFSET,
  539. .slave_addr_size = ADI_15BIT_SLAVE_ADDR_SIZE,
  540. .read_check = sprd_adi_read_check_r3,
  541. };
  542. static const struct of_device_id sprd_adi_of_match[] = {
  543. {
  544. .compatible = "sprd,sc9860-adi",
  545. .data = &sc9860_data,
  546. },
  547. {
  548. .compatible = "sprd,sc9863-adi",
  549. .data = &sc9863_data,
  550. },
  551. {
  552. .compatible = "sprd,ums512-adi",
  553. .data = &ums512_data,
  554. },
  555. { },
  556. };
  557. MODULE_DEVICE_TABLE(of, sprd_adi_of_match);
  558. static struct platform_driver sprd_adi_driver = {
  559. .driver = {
  560. .name = "sprd-adi",
  561. .of_match_table = sprd_adi_of_match,
  562. },
  563. .probe = sprd_adi_probe,
  564. .remove = sprd_adi_remove,
  565. };
  566. module_platform_driver(sprd_adi_driver);
  567. MODULE_DESCRIPTION("Spreadtrum ADI Controller Driver");
  568. MODULE_AUTHOR("Baolin Wang <[email protected]>");
  569. MODULE_LICENSE("GPL v2");