swr-haptics.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2020-2021, The Linux Foundation. All rights reserved.
  4. */
  5. #include <linux/device.h>
  6. #include <linux/init.h>
  7. #include <linux/module.h>
  8. #include <linux/platform_device.h>
  9. #include <linux/regmap.h>
  10. #include <linux/regulator/consumer.h>
  11. #include <linux/slab.h>
  12. #include <soc/soundwire.h>
  13. #include <sound/soc.h>
  14. #include <sound/soc-dapm.h>
  15. #define HAPTICS_RATES (SNDRV_PCM_RATE_8000 | SNDRV_PCM_RATE_16000 |\
  16. SNDRV_PCM_RATE_32000 | SNDRV_PCM_RATE_48000 |\
  17. SNDRV_PCM_RATE_96000 | SNDRV_PCM_RATE_192000 |\
  18. SNDRV_PCM_RATE_384000)
  19. #define HAPTICS_FORMATS (SNDRV_PCM_FMTBIT_S16_LE |\
  20. SNDRV_PCM_FMTBIT_S24_LE |\
  21. SNDRV_PCM_FMTBIT_S24_3LE | SNDRV_PCM_FMTBIT_S32_LE)
  22. /* SWR register definition */
  23. #define SWR_HAP_ACCESS_BASE 0x3000
  24. #define FIFO_WR_READY_REG (SWR_HAP_ACCESS_BASE + 0x8)
  25. #define NUM_PAT_SMPL_REG (SWR_HAP_ACCESS_BASE + 0x9)
  26. #define SWR_WR_ACCESS_REG (SWR_HAP_ACCESS_BASE + 0xa)
  27. #define CAL_TLRA_STATUS_MSB_REG (SWR_HAP_ACCESS_BASE + 0xb)
  28. #define CAL_TLRA_STATUS_LSB_REG (SWR_HAP_ACCESS_BASE + 0xc)
  29. #define AUTO_RES_CAL_DONE_REG (SWR_HAP_ACCESS_BASE + 0xd)
  30. #define SWR_READ_DATA_REG (SWR_HAP_ACCESS_BASE + 0x80)
  31. #define SWR_PLAY_REG (SWR_HAP_ACCESS_BASE + 0x81)
  32. #define SWR_VMAX_REG (SWR_HAP_ACCESS_BASE + 0x82)
  33. #define SWR_PLAY_BIT BIT(7)
  34. #define SWR_BRAKE_EN_BIT BIT(3)
  35. #define SWR_PLAY_SRC_MASK GENMASK(2, 0)
  36. #define SWR_PLAY_SRC_VAL_SWR 4
  37. #define SWR_HAP_REG_MAX (SWR_HAP_ACCESS_BASE + 0xff)
  38. static struct reg_default swr_hap_reg_defaults[] = {
  39. {FIFO_WR_READY_REG, 1},
  40. {NUM_PAT_SMPL_REG, 8},
  41. {SWR_WR_ACCESS_REG, 1},
  42. {CAL_TLRA_STATUS_MSB_REG, 0},
  43. {CAL_TLRA_STATUS_LSB_REG, 0},
  44. {AUTO_RES_CAL_DONE_REG, 0},
  45. {SWR_READ_DATA_REG, 0},
  46. {SWR_PLAY_REG, 4},
  47. {SWR_VMAX_REG, 0},
  48. };
  49. enum {
  50. PORT_ID_DT_IDX,
  51. NUM_CH_DT_IDX,
  52. CH_MASK_DT_IDX,
  53. CH_RATE_DT_IDX,
  54. PORT_TYPE_DT_IDX,
  55. NUM_SWR_PORT_DT_PARAMS,
  56. };
  57. struct swr_port {
  58. u8 port_id;
  59. u8 ch_mask;
  60. u32 ch_rate;
  61. u8 num_ch;
  62. u8 port_type;
  63. };
  64. struct swr_haptics_dev {
  65. struct device *dev;
  66. struct swr_device *swr_slave;
  67. struct snd_soc_component *component;
  68. struct regmap *regmap;
  69. struct swr_port port;
  70. struct regulator *slave_vdd;
  71. bool slave_enabled;
  72. u8 vmax;
  73. };
  74. static bool swr_hap_volatile_register(struct device *dev, unsigned int reg)
  75. {
  76. switch (reg) {
  77. case SWR_READ_DATA_REG:
  78. case SWR_PLAY_REG:
  79. case SWR_VMAX_REG:
  80. return 1;
  81. default:
  82. return 0;
  83. }
  84. }
  85. static bool swr_hap_readable_register(struct device *dev, unsigned int reg)
  86. {
  87. if (reg <= SWR_HAP_ACCESS_BASE)
  88. return 0;
  89. return 1;
  90. }
  91. static bool swr_hap_writeable_register(struct device *dev, unsigned int reg)
  92. {
  93. if (reg <= SWR_HAP_ACCESS_BASE)
  94. return 0;
  95. switch (reg) {
  96. case FIFO_WR_READY_REG:
  97. case NUM_PAT_SMPL_REG:
  98. case SWR_WR_ACCESS_REG:
  99. case CAL_TLRA_STATUS_MSB_REG:
  100. case CAL_TLRA_STATUS_LSB_REG:
  101. case AUTO_RES_CAL_DONE_REG:
  102. case SWR_READ_DATA_REG:
  103. return 0;
  104. }
  105. return 1;
  106. }
  107. static int swr_haptics_slave_enable(struct swr_haptics_dev *swr_hap)
  108. {
  109. int rc;
  110. if (swr_hap->slave_enabled)
  111. return 0;
  112. rc = regulator_enable(swr_hap->slave_vdd);
  113. if (rc < 0) {
  114. dev_err(swr_hap->dev, "%s: enable swr-slave-vdd failed, rc=%d\n",
  115. __func__, rc);
  116. return rc;
  117. }
  118. dev_dbg(swr_hap->dev, "%s: enable swr-slave-vdd success\n", __func__);
  119. swr_hap->slave_enabled = true;
  120. return 0;
  121. }
  122. static int swr_haptics_slave_disable(struct swr_haptics_dev *swr_hap)
  123. {
  124. int rc;
  125. if (!swr_hap->slave_enabled)
  126. return 0;
  127. rc = regulator_disable(swr_hap->slave_vdd);
  128. if (rc < 0) {
  129. dev_err(swr_hap->dev, "%s: disable swr-slave-vdd failed, rc=%d\n",
  130. __func__, rc);
  131. return rc;
  132. }
  133. dev_dbg(swr_hap->dev, "%s: disable swr-slave-vdd success\n", __func__);
  134. swr_hap->slave_enabled = false;
  135. return 0;
  136. }
  137. struct regmap_config swr_hap_regmap_config = {
  138. .reg_bits = 16,
  139. .val_bits = 8,
  140. .cache_type = REGCACHE_RBTREE,
  141. .reg_defaults = swr_hap_reg_defaults,
  142. .num_reg_defaults = ARRAY_SIZE(swr_hap_reg_defaults),
  143. .max_register = SWR_HAP_REG_MAX,
  144. .volatile_reg = swr_hap_volatile_register,
  145. .readable_reg = swr_hap_readable_register,
  146. .writeable_reg = swr_hap_writeable_register,
  147. .reg_format_endian = REGMAP_ENDIAN_NATIVE,
  148. .val_format_endian = REGMAP_ENDIAN_NATIVE,
  149. .can_multi_write = true,
  150. };
  151. static const struct snd_kcontrol_new hap_swr_dac_port[] = {
  152. SOC_DAPM_SINGLE("Switch", SND_SOC_NOPM, 0, 1, 0)
  153. };
  154. static int hap_enable_swr_dac_port(struct snd_soc_dapm_widget *w,
  155. struct snd_kcontrol *kcontrol, int event)
  156. {
  157. struct snd_soc_component *swr_hap_comp =
  158. snd_soc_dapm_to_component(w->dapm);
  159. struct swr_haptics_dev *swr_hap;
  160. u8 port_id, ch_mask, num_ch, port_type, num_port;
  161. u32 ch_rate;
  162. unsigned int val;
  163. int rc;
  164. if (!swr_hap_comp) {
  165. pr_err("%s: swr_hap_component is NULL\n", __func__);
  166. return -EINVAL;
  167. }
  168. swr_hap = snd_soc_component_get_drvdata(swr_hap_comp);
  169. if (!swr_hap) {
  170. pr_err("%s: get swr_haptics_dev failed\n", __func__);
  171. return -ENODEV;
  172. }
  173. dev_dbg(swr_hap->dev, "%s: %s event %d\n", __func__, w->name, event);
  174. num_port = 1;
  175. port_id = swr_hap->port.port_id;
  176. ch_mask = swr_hap->port.ch_mask;
  177. ch_rate = swr_hap->port.ch_rate;
  178. num_ch = swr_hap->port.num_ch;
  179. port_type = swr_hap->port.port_type;
  180. switch (event) {
  181. case SND_SOC_DAPM_PRE_PMU:
  182. rc = regmap_write(swr_hap->regmap, SWR_VMAX_REG, swr_hap->vmax);
  183. if (rc) {
  184. dev_err(swr_hap->dev, "%s: SWR_VMAX update failed, rc=%d\n",
  185. __func__, rc);
  186. return rc;
  187. }
  188. regmap_read(swr_hap->regmap, SWR_VMAX_REG, &val);
  189. regmap_read(swr_hap->regmap, SWR_READ_DATA_REG, &val);
  190. dev_dbg(swr_hap->dev, "%s: swr_vmax is set to 0x%x\n", __func__, val);
  191. swr_device_wakeup_vote(swr_hap->swr_slave);
  192. swr_connect_port(swr_hap->swr_slave, &port_id, num_port,
  193. &ch_mask, &ch_rate, &num_ch, &port_type);
  194. break;
  195. case SND_SOC_DAPM_POST_PMU:
  196. swr_slvdev_datapath_control(swr_hap->swr_slave,
  197. swr_hap->swr_slave->dev_num, true);
  198. /* trigger SWR play */
  199. val = SWR_PLAY_BIT | SWR_PLAY_SRC_VAL_SWR;
  200. rc = regmap_write(swr_hap->regmap, SWR_PLAY_REG, val);
  201. if (rc) {
  202. dev_err(swr_hap->dev, "%s: Enable SWR_PLAY failed, rc=%d\n",
  203. __func__, rc);
  204. return rc;
  205. }
  206. break;
  207. case SND_SOC_DAPM_PRE_PMD:
  208. /* stop SWR play */
  209. val = 0;
  210. rc = regmap_write(swr_hap->regmap, SWR_PLAY_REG, val);
  211. if (rc) {
  212. dev_err(swr_hap->dev, "%s: Enable SWR_PLAY failed, rc=%d\n",
  213. __func__, rc);
  214. return rc;
  215. }
  216. break;
  217. case SND_SOC_DAPM_POST_PMD:
  218. swr_disconnect_port(swr_hap->swr_slave, &port_id, num_port,
  219. &ch_mask, &port_type);
  220. swr_slvdev_datapath_control(swr_hap->swr_slave,
  221. swr_hap->swr_slave->dev_num, false);
  222. swr_device_wakeup_unvote(swr_hap->swr_slave);
  223. break;
  224. default:
  225. break;
  226. }
  227. return 0;
  228. }
  229. static int haptics_vmax_get(struct snd_kcontrol *kcontrol,
  230. struct snd_ctl_elem_value *ucontrol)
  231. {
  232. struct snd_soc_component *component =
  233. snd_soc_kcontrol_component(kcontrol);
  234. struct swr_haptics_dev *swr_hap =
  235. snd_soc_component_get_drvdata(component);
  236. pr_debug("%s: vmax %u\n", __func__, swr_hap->vmax);
  237. ucontrol->value.integer.value[0] = swr_hap->vmax;
  238. return 0;
  239. }
  240. static int haptics_vmax_put(struct snd_kcontrol *kcontrol,
  241. struct snd_ctl_elem_value *ucontrol)
  242. {
  243. struct snd_soc_component *component =
  244. snd_soc_kcontrol_component(kcontrol);
  245. struct swr_haptics_dev *swr_hap =
  246. snd_soc_component_get_drvdata(component);
  247. swr_hap->vmax = ucontrol->value.integer.value[0];
  248. pr_debug("%s: vmax %u\n", __func__, swr_hap->vmax);
  249. return 0;
  250. }
  251. static const struct snd_kcontrol_new haptics_snd_controls[] = {
  252. SOC_SINGLE_EXT("Haptics Amplitude Step", SND_SOC_NOPM, 0, 100, 0,
  253. haptics_vmax_get, haptics_vmax_put),
  254. };
  255. static const struct snd_soc_dapm_widget haptics_comp_dapm_widgets[] = {
  256. SND_SOC_DAPM_INPUT("HAP_IN"),
  257. SND_SOC_DAPM_MIXER_E("SWR DAC_Port", SND_SOC_NOPM, 0, 0,
  258. hap_swr_dac_port, ARRAY_SIZE(hap_swr_dac_port),
  259. hap_enable_swr_dac_port,
  260. SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU |
  261. SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMD),
  262. SND_SOC_DAPM_SPK("HAP_OUT", NULL),
  263. };
  264. static const struct snd_soc_dapm_route haptics_comp_dapm_route[] = {
  265. {"SWR DAC_Port", "Switch", "HAP_IN"},
  266. {"HAP_OUT", NULL, "SWR DAC_Port"},
  267. };
  268. static int haptics_comp_probe(struct snd_soc_component *component)
  269. {
  270. struct snd_soc_dapm_context *dapm;
  271. struct swr_haptics_dev *swr_hap =
  272. snd_soc_component_get_drvdata(component);
  273. if (!swr_hap) {
  274. pr_err("%s: get swr_haptics_dev failed\n", __func__);
  275. return -EINVAL;
  276. }
  277. snd_soc_component_init_regmap(component, swr_hap->regmap);
  278. dapm = snd_soc_component_get_dapm(component);
  279. if (dapm && dapm->component) {
  280. snd_soc_dapm_ignore_suspend(dapm, "HAP_IN");
  281. snd_soc_dapm_ignore_suspend(dapm, "HAP_OUT");
  282. }
  283. return 0;
  284. }
  285. static void haptics_comp_remove(struct snd_soc_component *component)
  286. {
  287. }
  288. static const struct snd_soc_component_driver swr_haptics_component = {
  289. .name = "swr-haptics",
  290. .probe = haptics_comp_probe,
  291. .remove = haptics_comp_remove,
  292. .controls = haptics_snd_controls,
  293. .num_controls = ARRAY_SIZE(haptics_snd_controls),
  294. .dapm_widgets = haptics_comp_dapm_widgets,
  295. .num_dapm_widgets = ARRAY_SIZE(haptics_comp_dapm_widgets),
  296. .dapm_routes = haptics_comp_dapm_route,
  297. .num_dapm_routes = ARRAY_SIZE(haptics_comp_dapm_route),
  298. };
  299. static struct snd_soc_dai_driver haptics_dai[] = {
  300. {
  301. .name = "swr_haptics",
  302. .playback = {
  303. .stream_name = "HAPTICS_AIF Playback",
  304. .rates = HAPTICS_RATES,
  305. .formats = HAPTICS_FORMATS,
  306. .rate_max = 192000,
  307. .rate_min = 8000,
  308. .channels_min = 1,
  309. .channels_max = 1,
  310. },
  311. },
  312. };
  313. static int swr_haptics_parse_port_mapping(struct swr_device *sdev)
  314. {
  315. struct swr_haptics_dev *swr_hap = swr_get_dev_data(sdev);
  316. u32 port_cfg[NUM_SWR_PORT_DT_PARAMS];
  317. int rc;
  318. if (!swr_hap) {
  319. dev_err(&sdev->dev, "%s: get swr_haptics_dev failed\n",
  320. __func__);
  321. return -EINVAL;
  322. }
  323. rc = of_property_read_u32_array(sdev->dev.of_node, "qcom,rx_swr_ch_map",
  324. port_cfg, NUM_SWR_PORT_DT_PARAMS);
  325. if (rc < 0) {
  326. dev_err(swr_hap->dev, "%s: Get qcom,rx_swr_ch_map failed, rc=%d\n",
  327. __func__, rc);
  328. return -EINVAL;
  329. }
  330. swr_hap->port.port_id = (u8) port_cfg[PORT_ID_DT_IDX];
  331. swr_hap->port.num_ch = (u8) port_cfg[NUM_CH_DT_IDX];
  332. swr_hap->port.ch_mask = (u8) port_cfg[CH_MASK_DT_IDX];
  333. swr_hap->port.ch_rate = port_cfg[CH_RATE_DT_IDX];
  334. swr_hap->port.port_type = (u8) port_cfg[PORT_TYPE_DT_IDX];
  335. dev_dbg(swr_hap->dev, "%s: port_id = %d, ch_mask = %d, ch_rate = %d, num_ch = %d, port_type = %d\n",
  336. __func__, swr_hap->port.port_id,
  337. swr_hap->port.ch_mask, swr_hap->port.ch_rate,
  338. swr_hap->port.num_ch, swr_hap->port.port_type);
  339. return 0;
  340. }
  341. static int swr_haptics_probe(struct swr_device *sdev)
  342. {
  343. struct swr_haptics_dev *swr_hap;
  344. int rc;
  345. u8 devnum;
  346. int retry = 5;
  347. swr_hap = devm_kzalloc(&sdev->dev,
  348. sizeof(struct swr_haptics_dev), GFP_KERNEL);
  349. if (!swr_hap)
  350. return -ENOMEM;
  351. /* VMAX default to 5V */
  352. swr_hap->vmax = 100;
  353. swr_hap->swr_slave = sdev;
  354. swr_hap->dev = &sdev->dev;
  355. swr_set_dev_data(sdev, swr_hap);
  356. rc = swr_haptics_parse_port_mapping(sdev);
  357. if (rc < 0) {
  358. dev_err(swr_hap->dev, "%s: failed to parse swr port mapping, rc=%d\n",
  359. __func__, rc);
  360. goto clean;
  361. }
  362. swr_hap->slave_vdd = devm_regulator_get(swr_hap->dev, "swr-slave");
  363. if (IS_ERR(swr_hap->slave_vdd)) {
  364. rc = PTR_ERR(swr_hap->slave_vdd);
  365. if (rc != -EPROBE_DEFER)
  366. dev_err(swr_hap->dev, "%s: get swr-slave-supply failed, rc=%d\n",
  367. __func__, rc);
  368. goto clean;
  369. }
  370. rc = swr_haptics_slave_enable(swr_hap);
  371. if (rc < 0) {
  372. dev_err(swr_hap->dev, "%s: enable swr-slave-vdd failed, rc=%d\n",
  373. __func__, rc);
  374. goto clean;
  375. }
  376. do {
  377. /* Add delay for soundwire enumeration */
  378. usleep_range(500, 510);
  379. rc = swr_get_logical_dev_num(sdev, sdev->addr, &devnum);
  380. } while (rc && --retry);
  381. if (rc) {
  382. dev_err(swr_hap->dev, "%s: failed to get devnum for swr-haptics, rc=%d\n",
  383. __func__, rc);
  384. rc = -EPROBE_DEFER;
  385. goto dev_err;
  386. }
  387. sdev->dev_num = devnum;
  388. swr_hap->regmap = devm_regmap_init_swr(sdev, &swr_hap_regmap_config);
  389. if (IS_ERR(swr_hap->regmap)) {
  390. rc = PTR_ERR(swr_hap->regmap);
  391. dev_err(swr_hap->dev, "%s: init regmap failed, rc=%d\n",
  392. __func__, rc);
  393. goto dev_err;
  394. }
  395. rc = snd_soc_register_component(&sdev->dev,
  396. &swr_haptics_component, haptics_dai, ARRAY_SIZE(haptics_dai));
  397. if (rc) {
  398. dev_err(swr_hap->dev, "%s: register swr_haptics component failed, rc=%d\n",
  399. __func__, rc);
  400. goto dev_err;
  401. }
  402. return 0;
  403. dev_err:
  404. swr_haptics_slave_disable(swr_hap);
  405. swr_remove_device(sdev);
  406. clean:
  407. swr_set_dev_data(sdev, NULL);
  408. return rc;
  409. }
  410. static int swr_haptics_remove(struct swr_device *sdev)
  411. {
  412. struct swr_haptics_dev *swr_hap;
  413. int rc = 0;
  414. swr_hap = swr_get_dev_data(sdev);
  415. if (!swr_hap) {
  416. dev_err(&sdev->dev, "%s: no data for swr_hap\n", __func__);
  417. rc = -ENODEV;
  418. goto clean;
  419. }
  420. rc = swr_haptics_slave_disable(swr_hap);
  421. if (rc < 0) {
  422. dev_err(swr_hap->dev, "%s: disable swr-slave failed, rc=%d\n",
  423. __func__, rc);
  424. goto clean;
  425. }
  426. clean:
  427. snd_soc_unregister_component(&sdev->dev);
  428. swr_set_dev_data(sdev, NULL);
  429. return rc;
  430. }
  431. static int swr_haptics_device_up(struct swr_device *sdev)
  432. {
  433. struct swr_haptics_dev *swr_hap;
  434. swr_hap = swr_get_dev_data(sdev);
  435. if (!swr_hap) {
  436. dev_err(&sdev->dev, "%s: no data for swr_hap\n", __func__);
  437. return -ENODEV;
  438. }
  439. /* Take SWR slave out of reset */
  440. return swr_haptics_slave_enable(swr_hap);
  441. }
  442. static int swr_haptics_device_down(struct swr_device *sdev)
  443. {
  444. struct swr_haptics_dev *swr_hap = swr_get_dev_data(sdev);
  445. if (!swr_hap) {
  446. dev_err(&sdev->dev, "%s: no data for swr_hap\n", __func__);
  447. return -ENODEV;
  448. }
  449. /* Put SWR slave into reset */
  450. return swr_haptics_slave_disable(swr_hap);
  451. }
  452. static int swr_haptics_suspend(struct device *dev)
  453. {
  454. struct swr_haptics_dev *swr_hap;
  455. int rc = 0;
  456. swr_hap = swr_get_dev_data(to_swr_device(dev));
  457. if (!swr_hap) {
  458. dev_err(dev, "%s: no data for swr_hap\n", __func__);
  459. return -ENODEV;
  460. }
  461. trace_printk("%s: suspended\n", __func__);
  462. return rc;
  463. }
  464. static int swr_haptics_resume(struct device *dev)
  465. {
  466. struct swr_haptics_dev *swr_hap;
  467. int rc = 0;
  468. swr_hap = swr_get_dev_data(to_swr_device(dev));
  469. if (!swr_hap) {
  470. dev_err(dev, "%s: no data for swr_hap\n", __func__);
  471. return -ENODEV;
  472. }
  473. trace_printk("%s: resumed\n", __func__);
  474. return rc;
  475. }
  476. static const struct of_device_id swr_haptics_match_table[] = {
  477. { .compatible = "qcom,swr-haptics", },
  478. { .compatible = "qcom,pm8350b-swr-haptics", },
  479. { },
  480. };
  481. static const struct swr_device_id swr_haptics_id[] = {
  482. {"swr-haptics", 0},
  483. {"pm8350b-swr-haptics", 0},
  484. {},
  485. };
  486. static const struct dev_pm_ops swr_haptics_pm_ops = {
  487. .suspend = swr_haptics_suspend,
  488. .resume = swr_haptics_resume,
  489. };
  490. static struct swr_driver swr_haptics_driver = {
  491. .driver = {
  492. .name = "swr-haptics",
  493. .owner = THIS_MODULE,
  494. .pm = &swr_haptics_pm_ops,
  495. .of_match_table = swr_haptics_match_table,
  496. },
  497. .probe = swr_haptics_probe,
  498. .remove = swr_haptics_remove,
  499. .id_table = swr_haptics_id,
  500. .device_up = swr_haptics_device_up,
  501. .device_down = swr_haptics_device_down,
  502. };
  503. static int __init swr_haptics_init(void)
  504. {
  505. return swr_driver_register(&swr_haptics_driver);
  506. }
  507. static void __exit swr_haptics_exit(void)
  508. {
  509. swr_driver_unregister(&swr_haptics_driver);
  510. }
  511. module_init(swr_haptics_init);
  512. module_exit(swr_haptics_exit);
  513. MODULE_DESCRIPTION("SWR haptics driver");
  514. MODULE_LICENSE("GPL v2");