rmi_f34.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611
  1. /*
  2. * Copyright (c) 2007-2016, Synaptics Incorporated
  3. * Copyright (C) 2016 Zodiac Inflight Innovations
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of the GNU General Public License version 2 as published by
  7. * the Free Software Foundation.
  8. */
  9. #include <linux/kernel.h>
  10. #include <linux/rmi.h>
  11. #include <linux/firmware.h>
  12. #include <asm/unaligned.h>
  13. #include <linux/bitops.h>
  14. #include "rmi_driver.h"
  15. #include "rmi_f34.h"
  16. static int rmi_f34_write_bootloader_id(struct f34_data *f34)
  17. {
  18. struct rmi_function *fn = f34->fn;
  19. struct rmi_device *rmi_dev = fn->rmi_dev;
  20. u8 bootloader_id[F34_BOOTLOADER_ID_LEN];
  21. int ret;
  22. ret = rmi_read_block(rmi_dev, fn->fd.query_base_addr,
  23. bootloader_id, sizeof(bootloader_id));
  24. if (ret) {
  25. dev_err(&fn->dev, "%s: Reading bootloader ID failed: %d\n",
  26. __func__, ret);
  27. return ret;
  28. }
  29. rmi_dbg(RMI_DEBUG_FN, &fn->dev, "%s: writing bootloader id '%c%c'\n",
  30. __func__, bootloader_id[0], bootloader_id[1]);
  31. ret = rmi_write_block(rmi_dev,
  32. fn->fd.data_base_addr + F34_BLOCK_DATA_OFFSET,
  33. bootloader_id, sizeof(bootloader_id));
  34. if (ret) {
  35. dev_err(&fn->dev, "Failed to write bootloader ID: %d\n", ret);
  36. return ret;
  37. }
  38. return 0;
  39. }
  40. static int rmi_f34_command(struct f34_data *f34, u8 command,
  41. unsigned int timeout, bool write_bl_id)
  42. {
  43. struct rmi_function *fn = f34->fn;
  44. struct rmi_device *rmi_dev = fn->rmi_dev;
  45. int ret;
  46. if (write_bl_id) {
  47. ret = rmi_f34_write_bootloader_id(f34);
  48. if (ret)
  49. return ret;
  50. }
  51. init_completion(&f34->v5.cmd_done);
  52. ret = rmi_read(rmi_dev, f34->v5.ctrl_address, &f34->v5.status);
  53. if (ret) {
  54. dev_err(&f34->fn->dev,
  55. "%s: Failed to read cmd register: %d (command %#02x)\n",
  56. __func__, ret, command);
  57. return ret;
  58. }
  59. f34->v5.status |= command & 0x0f;
  60. ret = rmi_write(rmi_dev, f34->v5.ctrl_address, f34->v5.status);
  61. if (ret < 0) {
  62. dev_err(&f34->fn->dev,
  63. "Failed to write F34 command %#02x: %d\n",
  64. command, ret);
  65. return ret;
  66. }
  67. if (!wait_for_completion_timeout(&f34->v5.cmd_done,
  68. msecs_to_jiffies(timeout))) {
  69. ret = rmi_read(rmi_dev, f34->v5.ctrl_address, &f34->v5.status);
  70. if (ret) {
  71. dev_err(&f34->fn->dev,
  72. "%s: cmd %#02x timed out: %d\n",
  73. __func__, command, ret);
  74. return ret;
  75. }
  76. if (f34->v5.status & 0x7f) {
  77. dev_err(&f34->fn->dev,
  78. "%s: cmd %#02x timed out, status: %#02x\n",
  79. __func__, command, f34->v5.status);
  80. return -ETIMEDOUT;
  81. }
  82. }
  83. return 0;
  84. }
  85. static irqreturn_t rmi_f34_attention(int irq, void *ctx)
  86. {
  87. struct rmi_function *fn = ctx;
  88. struct f34_data *f34 = dev_get_drvdata(&fn->dev);
  89. int ret;
  90. u8 status;
  91. if (f34->bl_version == 5) {
  92. ret = rmi_read(f34->fn->rmi_dev, f34->v5.ctrl_address,
  93. &status);
  94. rmi_dbg(RMI_DEBUG_FN, &fn->dev, "%s: status: %#02x, ret: %d\n",
  95. __func__, status, ret);
  96. if (!ret && !(status & 0x7f))
  97. complete(&f34->v5.cmd_done);
  98. } else {
  99. ret = rmi_read_block(f34->fn->rmi_dev,
  100. f34->fn->fd.data_base_addr +
  101. f34->v7.off.flash_status,
  102. &status, sizeof(status));
  103. rmi_dbg(RMI_DEBUG_FN, &fn->dev, "%s: status: %#02x, ret: %d\n",
  104. __func__, status, ret);
  105. if (!ret && !(status & 0x1f))
  106. complete(&f34->v7.cmd_done);
  107. }
  108. return IRQ_HANDLED;
  109. }
  110. static int rmi_f34_write_blocks(struct f34_data *f34, const void *data,
  111. int block_count, u8 command)
  112. {
  113. struct rmi_function *fn = f34->fn;
  114. struct rmi_device *rmi_dev = fn->rmi_dev;
  115. u16 address = fn->fd.data_base_addr + F34_BLOCK_DATA_OFFSET;
  116. u8 start_address[] = { 0, 0 };
  117. int i;
  118. int ret;
  119. ret = rmi_write_block(rmi_dev, fn->fd.data_base_addr,
  120. start_address, sizeof(start_address));
  121. if (ret) {
  122. dev_err(&fn->dev, "Failed to write initial zeros: %d\n", ret);
  123. return ret;
  124. }
  125. for (i = 0; i < block_count; i++) {
  126. ret = rmi_write_block(rmi_dev, address,
  127. data, f34->v5.block_size);
  128. if (ret) {
  129. dev_err(&fn->dev,
  130. "failed to write block #%d: %d\n", i, ret);
  131. return ret;
  132. }
  133. ret = rmi_f34_command(f34, command, F34_IDLE_WAIT_MS, false);
  134. if (ret) {
  135. dev_err(&fn->dev,
  136. "Failed to write command for block #%d: %d\n",
  137. i, ret);
  138. return ret;
  139. }
  140. rmi_dbg(RMI_DEBUG_FN, &fn->dev, "wrote block %d of %d\n",
  141. i + 1, block_count);
  142. data += f34->v5.block_size;
  143. f34->update_progress += f34->v5.block_size;
  144. f34->update_status = (f34->update_progress * 100) /
  145. f34->update_size;
  146. }
  147. return 0;
  148. }
  149. static int rmi_f34_write_firmware(struct f34_data *f34, const void *data)
  150. {
  151. return rmi_f34_write_blocks(f34, data, f34->v5.fw_blocks,
  152. F34_WRITE_FW_BLOCK);
  153. }
  154. static int rmi_f34_write_config(struct f34_data *f34, const void *data)
  155. {
  156. return rmi_f34_write_blocks(f34, data, f34->v5.config_blocks,
  157. F34_WRITE_CONFIG_BLOCK);
  158. }
  159. static int rmi_f34_enable_flash(struct f34_data *f34)
  160. {
  161. return rmi_f34_command(f34, F34_ENABLE_FLASH_PROG,
  162. F34_ENABLE_WAIT_MS, true);
  163. }
  164. static int rmi_f34_flash_firmware(struct f34_data *f34,
  165. const struct rmi_f34_firmware *syn_fw)
  166. {
  167. struct rmi_function *fn = f34->fn;
  168. u32 image_size = le32_to_cpu(syn_fw->image_size);
  169. u32 config_size = le32_to_cpu(syn_fw->config_size);
  170. int ret;
  171. f34->update_progress = 0;
  172. f34->update_size = image_size + config_size;
  173. if (image_size) {
  174. dev_info(&fn->dev, "Erasing firmware...\n");
  175. ret = rmi_f34_command(f34, F34_ERASE_ALL,
  176. F34_ERASE_WAIT_MS, true);
  177. if (ret)
  178. return ret;
  179. dev_info(&fn->dev, "Writing firmware (%d bytes)...\n",
  180. image_size);
  181. ret = rmi_f34_write_firmware(f34, syn_fw->data);
  182. if (ret)
  183. return ret;
  184. }
  185. if (config_size) {
  186. /*
  187. * We only need to erase config if we haven't updated
  188. * firmware.
  189. */
  190. if (!image_size) {
  191. dev_info(&fn->dev, "Erasing config...\n");
  192. ret = rmi_f34_command(f34, F34_ERASE_CONFIG,
  193. F34_ERASE_WAIT_MS, true);
  194. if (ret)
  195. return ret;
  196. }
  197. dev_info(&fn->dev, "Writing config (%d bytes)...\n",
  198. config_size);
  199. ret = rmi_f34_write_config(f34, &syn_fw->data[image_size]);
  200. if (ret)
  201. return ret;
  202. }
  203. return 0;
  204. }
  205. static int rmi_f34_update_firmware(struct f34_data *f34,
  206. const struct firmware *fw)
  207. {
  208. const struct rmi_f34_firmware *syn_fw =
  209. (const struct rmi_f34_firmware *)fw->data;
  210. u32 image_size = le32_to_cpu(syn_fw->image_size);
  211. u32 config_size = le32_to_cpu(syn_fw->config_size);
  212. int ret;
  213. BUILD_BUG_ON(offsetof(struct rmi_f34_firmware, data) !=
  214. F34_FW_IMAGE_OFFSET);
  215. rmi_dbg(RMI_DEBUG_FN, &f34->fn->dev,
  216. "FW size:%zd, checksum:%08x, image_size:%d, config_size:%d\n",
  217. fw->size,
  218. le32_to_cpu(syn_fw->checksum),
  219. image_size, config_size);
  220. rmi_dbg(RMI_DEBUG_FN, &f34->fn->dev,
  221. "FW bootloader_id:%02x, product_id:%.*s, info: %02x%02x\n",
  222. syn_fw->bootloader_version,
  223. (int)sizeof(syn_fw->product_id), syn_fw->product_id,
  224. syn_fw->product_info[0], syn_fw->product_info[1]);
  225. if (image_size && image_size != f34->v5.fw_blocks * f34->v5.block_size) {
  226. dev_err(&f34->fn->dev,
  227. "Bad firmware image: fw size %d, expected %d\n",
  228. image_size, f34->v5.fw_blocks * f34->v5.block_size);
  229. ret = -EILSEQ;
  230. goto out;
  231. }
  232. if (config_size &&
  233. config_size != f34->v5.config_blocks * f34->v5.block_size) {
  234. dev_err(&f34->fn->dev,
  235. "Bad firmware image: config size %d, expected %d\n",
  236. config_size,
  237. f34->v5.config_blocks * f34->v5.block_size);
  238. ret = -EILSEQ;
  239. goto out;
  240. }
  241. if (image_size && !config_size) {
  242. dev_err(&f34->fn->dev, "Bad firmware image: no config data\n");
  243. ret = -EILSEQ;
  244. goto out;
  245. }
  246. dev_info(&f34->fn->dev, "Firmware image OK\n");
  247. mutex_lock(&f34->v5.flash_mutex);
  248. ret = rmi_f34_flash_firmware(f34, syn_fw);
  249. mutex_unlock(&f34->v5.flash_mutex);
  250. out:
  251. return ret;
  252. }
  253. static int rmi_f34_status(struct rmi_function *fn)
  254. {
  255. struct f34_data *f34 = dev_get_drvdata(&fn->dev);
  256. /*
  257. * The status is the percentage complete, or once complete,
  258. * zero for success or a negative return code.
  259. */
  260. return f34->update_status;
  261. }
  262. static ssize_t rmi_driver_bootloader_id_show(struct device *dev,
  263. struct device_attribute *dattr,
  264. char *buf)
  265. {
  266. struct rmi_driver_data *data = dev_get_drvdata(dev);
  267. struct rmi_function *fn = data->f34_container;
  268. struct f34_data *f34;
  269. if (fn) {
  270. f34 = dev_get_drvdata(&fn->dev);
  271. if (f34->bl_version == 5)
  272. return scnprintf(buf, PAGE_SIZE, "%c%c\n",
  273. f34->bootloader_id[0],
  274. f34->bootloader_id[1]);
  275. else
  276. return scnprintf(buf, PAGE_SIZE, "V%d.%d\n",
  277. f34->bootloader_id[1],
  278. f34->bootloader_id[0]);
  279. }
  280. return 0;
  281. }
  282. static DEVICE_ATTR(bootloader_id, 0444, rmi_driver_bootloader_id_show, NULL);
  283. static ssize_t rmi_driver_configuration_id_show(struct device *dev,
  284. struct device_attribute *dattr,
  285. char *buf)
  286. {
  287. struct rmi_driver_data *data = dev_get_drvdata(dev);
  288. struct rmi_function *fn = data->f34_container;
  289. struct f34_data *f34;
  290. if (fn) {
  291. f34 = dev_get_drvdata(&fn->dev);
  292. return scnprintf(buf, PAGE_SIZE, "%s\n", f34->configuration_id);
  293. }
  294. return 0;
  295. }
  296. static DEVICE_ATTR(configuration_id, 0444,
  297. rmi_driver_configuration_id_show, NULL);
  298. static int rmi_firmware_update(struct rmi_driver_data *data,
  299. const struct firmware *fw)
  300. {
  301. struct rmi_device *rmi_dev = data->rmi_dev;
  302. struct device *dev = &rmi_dev->dev;
  303. struct f34_data *f34;
  304. int ret;
  305. if (!data->f34_container) {
  306. dev_warn(dev, "%s: No F34 present!\n", __func__);
  307. return -EINVAL;
  308. }
  309. f34 = dev_get_drvdata(&data->f34_container->dev);
  310. if (f34->bl_version == 7) {
  311. if (data->pdt_props & HAS_BSR) {
  312. dev_err(dev, "%s: LTS not supported\n", __func__);
  313. return -ENODEV;
  314. }
  315. } else if (f34->bl_version != 5) {
  316. dev_warn(dev, "F34 V%d not supported!\n",
  317. data->f34_container->fd.function_version);
  318. return -ENODEV;
  319. }
  320. /* Enter flash mode */
  321. if (f34->bl_version == 7)
  322. ret = rmi_f34v7_start_reflash(f34, fw);
  323. else
  324. ret = rmi_f34_enable_flash(f34);
  325. if (ret)
  326. return ret;
  327. rmi_disable_irq(rmi_dev, false);
  328. /* Tear down functions and re-probe */
  329. rmi_free_function_list(rmi_dev);
  330. ret = rmi_probe_interrupts(data);
  331. if (ret)
  332. return ret;
  333. ret = rmi_init_functions(data);
  334. if (ret)
  335. return ret;
  336. if (!data->bootloader_mode || !data->f34_container) {
  337. dev_warn(dev, "%s: No F34 present or not in bootloader!\n",
  338. __func__);
  339. return -EINVAL;
  340. }
  341. rmi_enable_irq(rmi_dev, false);
  342. f34 = dev_get_drvdata(&data->f34_container->dev);
  343. /* Perform firmware update */
  344. if (f34->bl_version == 7)
  345. ret = rmi_f34v7_do_reflash(f34, fw);
  346. else
  347. ret = rmi_f34_update_firmware(f34, fw);
  348. if (ret) {
  349. f34->update_status = ret;
  350. dev_err(&f34->fn->dev,
  351. "Firmware update failed, status: %d\n", ret);
  352. } else {
  353. dev_info(&f34->fn->dev, "Firmware update complete\n");
  354. }
  355. rmi_disable_irq(rmi_dev, false);
  356. /* Re-probe */
  357. rmi_dbg(RMI_DEBUG_FN, dev, "Re-probing device\n");
  358. rmi_free_function_list(rmi_dev);
  359. ret = rmi_scan_pdt(rmi_dev, NULL, rmi_initial_reset);
  360. if (ret < 0)
  361. dev_warn(dev, "RMI reset failed!\n");
  362. ret = rmi_probe_interrupts(data);
  363. if (ret)
  364. return ret;
  365. ret = rmi_init_functions(data);
  366. if (ret)
  367. return ret;
  368. rmi_enable_irq(rmi_dev, false);
  369. if (data->f01_container->dev.driver)
  370. /* Driver already bound, so enable ATTN now. */
  371. return rmi_enable_sensor(rmi_dev);
  372. rmi_dbg(RMI_DEBUG_FN, dev, "%s complete\n", __func__);
  373. return ret;
  374. }
  375. static ssize_t rmi_driver_update_fw_store(struct device *dev,
  376. struct device_attribute *dattr,
  377. const char *buf, size_t count)
  378. {
  379. struct rmi_driver_data *data = dev_get_drvdata(dev);
  380. char fw_name[NAME_MAX];
  381. const struct firmware *fw;
  382. size_t copy_count = count;
  383. int ret;
  384. if (count == 0 || count >= NAME_MAX)
  385. return -EINVAL;
  386. if (buf[count - 1] == '\0' || buf[count - 1] == '\n')
  387. copy_count -= 1;
  388. strncpy(fw_name, buf, copy_count);
  389. fw_name[copy_count] = '\0';
  390. ret = request_firmware(&fw, fw_name, dev);
  391. if (ret)
  392. return ret;
  393. dev_info(dev, "Flashing %s\n", fw_name);
  394. ret = rmi_firmware_update(data, fw);
  395. release_firmware(fw);
  396. return ret ?: count;
  397. }
  398. static DEVICE_ATTR(update_fw, 0200, NULL, rmi_driver_update_fw_store);
  399. static ssize_t rmi_driver_update_fw_status_show(struct device *dev,
  400. struct device_attribute *dattr,
  401. char *buf)
  402. {
  403. struct rmi_driver_data *data = dev_get_drvdata(dev);
  404. int update_status = 0;
  405. if (data->f34_container)
  406. update_status = rmi_f34_status(data->f34_container);
  407. return scnprintf(buf, PAGE_SIZE, "%d\n", update_status);
  408. }
  409. static DEVICE_ATTR(update_fw_status, 0444,
  410. rmi_driver_update_fw_status_show, NULL);
  411. static struct attribute *rmi_firmware_attrs[] = {
  412. &dev_attr_bootloader_id.attr,
  413. &dev_attr_configuration_id.attr,
  414. &dev_attr_update_fw.attr,
  415. &dev_attr_update_fw_status.attr,
  416. NULL
  417. };
  418. static const struct attribute_group rmi_firmware_attr_group = {
  419. .attrs = rmi_firmware_attrs,
  420. };
  421. static int rmi_f34_probe(struct rmi_function *fn)
  422. {
  423. struct f34_data *f34;
  424. unsigned char f34_queries[9];
  425. bool has_config_id;
  426. u8 version = fn->fd.function_version;
  427. int ret;
  428. f34 = devm_kzalloc(&fn->dev, sizeof(struct f34_data), GFP_KERNEL);
  429. if (!f34)
  430. return -ENOMEM;
  431. f34->fn = fn;
  432. dev_set_drvdata(&fn->dev, f34);
  433. /* v5 code only supported version 0, try V7 probe */
  434. if (version > 0)
  435. return rmi_f34v7_probe(f34);
  436. f34->bl_version = 5;
  437. ret = rmi_read_block(fn->rmi_dev, fn->fd.query_base_addr,
  438. f34_queries, sizeof(f34_queries));
  439. if (ret) {
  440. dev_err(&fn->dev, "%s: Failed to query properties\n",
  441. __func__);
  442. return ret;
  443. }
  444. snprintf(f34->bootloader_id, sizeof(f34->bootloader_id),
  445. "%c%c", f34_queries[0], f34_queries[1]);
  446. mutex_init(&f34->v5.flash_mutex);
  447. init_completion(&f34->v5.cmd_done);
  448. f34->v5.block_size = get_unaligned_le16(&f34_queries[3]);
  449. f34->v5.fw_blocks = get_unaligned_le16(&f34_queries[5]);
  450. f34->v5.config_blocks = get_unaligned_le16(&f34_queries[7]);
  451. f34->v5.ctrl_address = fn->fd.data_base_addr + F34_BLOCK_DATA_OFFSET +
  452. f34->v5.block_size;
  453. has_config_id = f34_queries[2] & (1 << 2);
  454. rmi_dbg(RMI_DEBUG_FN, &fn->dev, "Bootloader ID: %s\n",
  455. f34->bootloader_id);
  456. rmi_dbg(RMI_DEBUG_FN, &fn->dev, "Block size: %d\n",
  457. f34->v5.block_size);
  458. rmi_dbg(RMI_DEBUG_FN, &fn->dev, "FW blocks: %d\n",
  459. f34->v5.fw_blocks);
  460. rmi_dbg(RMI_DEBUG_FN, &fn->dev, "CFG blocks: %d\n",
  461. f34->v5.config_blocks);
  462. if (has_config_id) {
  463. ret = rmi_read_block(fn->rmi_dev, fn->fd.control_base_addr,
  464. f34_queries, sizeof(f34_queries));
  465. if (ret) {
  466. dev_err(&fn->dev, "Failed to read F34 config ID\n");
  467. return ret;
  468. }
  469. snprintf(f34->configuration_id, sizeof(f34->configuration_id),
  470. "%02x%02x%02x%02x",
  471. f34_queries[0], f34_queries[1],
  472. f34_queries[2], f34_queries[3]);
  473. rmi_dbg(RMI_DEBUG_FN, &fn->dev, "Configuration ID: %s\n",
  474. f34->configuration_id);
  475. }
  476. return 0;
  477. }
  478. int rmi_f34_create_sysfs(struct rmi_device *rmi_dev)
  479. {
  480. return sysfs_create_group(&rmi_dev->dev.kobj, &rmi_firmware_attr_group);
  481. }
  482. void rmi_f34_remove_sysfs(struct rmi_device *rmi_dev)
  483. {
  484. sysfs_remove_group(&rmi_dev->dev.kobj, &rmi_firmware_attr_group);
  485. }
  486. struct rmi_function_handler rmi_f34_handler = {
  487. .driver = {
  488. .name = "rmi4_f34",
  489. },
  490. .func = 0x34,
  491. .probe = rmi_f34_probe,
  492. .attention = rmi_f34_attention,
  493. };