rsp.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * The NFC Controller Interface is the communication protocol between an
  4. * NFC Controller (NFCC) and a Device Host (DH).
  5. *
  6. * Copyright (C) 2011 Texas Instruments, Inc.
  7. *
  8. * Written by Ilan Elias <[email protected]>
  9. *
  10. * Acknowledgements:
  11. * This file is based on hci_event.c, which was written
  12. * by Maxim Krasnyansky.
  13. */
  14. #define pr_fmt(fmt) KBUILD_MODNAME ": %s: " fmt, __func__
  15. #include <linux/types.h>
  16. #include <linux/interrupt.h>
  17. #include <linux/bitops.h>
  18. #include <linux/skbuff.h>
  19. #include "../nfc.h"
  20. #include <net/nfc/nci.h>
  21. #include <net/nfc/nci_core.h>
  22. /* Handle NCI Response packets */
  23. static void nci_core_reset_rsp_packet(struct nci_dev *ndev,
  24. const struct sk_buff *skb)
  25. {
  26. const struct nci_core_reset_rsp *rsp = (void *)skb->data;
  27. pr_debug("status 0x%x\n", rsp->status);
  28. /* Handle NCI 1.x ver */
  29. if (skb->len != 1) {
  30. if (rsp->status == NCI_STATUS_OK) {
  31. ndev->nci_ver = rsp->nci_ver;
  32. pr_debug("nci_ver 0x%x, config_status 0x%x\n",
  33. rsp->nci_ver, rsp->config_status);
  34. }
  35. nci_req_complete(ndev, rsp->status);
  36. }
  37. }
  38. static u8 nci_core_init_rsp_packet_v1(struct nci_dev *ndev,
  39. const struct sk_buff *skb)
  40. {
  41. const struct nci_core_init_rsp_1 *rsp_1 = (void *)skb->data;
  42. const struct nci_core_init_rsp_2 *rsp_2;
  43. pr_debug("status 0x%x\n", rsp_1->status);
  44. if (rsp_1->status != NCI_STATUS_OK)
  45. return rsp_1->status;
  46. ndev->nfcc_features = __le32_to_cpu(rsp_1->nfcc_features);
  47. ndev->num_supported_rf_interfaces = rsp_1->num_supported_rf_interfaces;
  48. ndev->num_supported_rf_interfaces =
  49. min((int)ndev->num_supported_rf_interfaces,
  50. NCI_MAX_SUPPORTED_RF_INTERFACES);
  51. memcpy(ndev->supported_rf_interfaces,
  52. rsp_1->supported_rf_interfaces,
  53. ndev->num_supported_rf_interfaces);
  54. rsp_2 = (void *) (skb->data + 6 + rsp_1->num_supported_rf_interfaces);
  55. ndev->max_logical_connections = rsp_2->max_logical_connections;
  56. ndev->max_routing_table_size =
  57. __le16_to_cpu(rsp_2->max_routing_table_size);
  58. ndev->max_ctrl_pkt_payload_len =
  59. rsp_2->max_ctrl_pkt_payload_len;
  60. ndev->max_size_for_large_params =
  61. __le16_to_cpu(rsp_2->max_size_for_large_params);
  62. ndev->manufact_id =
  63. rsp_2->manufact_id;
  64. ndev->manufact_specific_info =
  65. __le32_to_cpu(rsp_2->manufact_specific_info);
  66. return NCI_STATUS_OK;
  67. }
  68. static u8 nci_core_init_rsp_packet_v2(struct nci_dev *ndev,
  69. const struct sk_buff *skb)
  70. {
  71. const struct nci_core_init_rsp_nci_ver2 *rsp = (void *)skb->data;
  72. const u8 *supported_rf_interface = rsp->supported_rf_interfaces;
  73. u8 rf_interface_idx = 0;
  74. u8 rf_extension_cnt = 0;
  75. pr_debug("status %x\n", rsp->status);
  76. if (rsp->status != NCI_STATUS_OK)
  77. return rsp->status;
  78. ndev->nfcc_features = __le32_to_cpu(rsp->nfcc_features);
  79. ndev->num_supported_rf_interfaces = rsp->num_supported_rf_interfaces;
  80. ndev->num_supported_rf_interfaces =
  81. min((int)ndev->num_supported_rf_interfaces,
  82. NCI_MAX_SUPPORTED_RF_INTERFACES);
  83. while (rf_interface_idx < ndev->num_supported_rf_interfaces) {
  84. ndev->supported_rf_interfaces[rf_interface_idx++] = *supported_rf_interface++;
  85. /* skip rf extension parameters */
  86. rf_extension_cnt = *supported_rf_interface++;
  87. supported_rf_interface += rf_extension_cnt;
  88. }
  89. ndev->max_logical_connections = rsp->max_logical_connections;
  90. ndev->max_routing_table_size =
  91. __le16_to_cpu(rsp->max_routing_table_size);
  92. ndev->max_ctrl_pkt_payload_len =
  93. rsp->max_ctrl_pkt_payload_len;
  94. ndev->max_size_for_large_params = NCI_MAX_LARGE_PARAMS_NCI_v2;
  95. return NCI_STATUS_OK;
  96. }
  97. static void nci_core_init_rsp_packet(struct nci_dev *ndev, const struct sk_buff *skb)
  98. {
  99. u8 status = 0;
  100. if (!(ndev->nci_ver & NCI_VER_2_MASK))
  101. status = nci_core_init_rsp_packet_v1(ndev, skb);
  102. else
  103. status = nci_core_init_rsp_packet_v2(ndev, skb);
  104. if (status != NCI_STATUS_OK)
  105. goto exit;
  106. pr_debug("nfcc_features 0x%x\n",
  107. ndev->nfcc_features);
  108. pr_debug("num_supported_rf_interfaces %d\n",
  109. ndev->num_supported_rf_interfaces);
  110. pr_debug("supported_rf_interfaces[0] 0x%x\n",
  111. ndev->supported_rf_interfaces[0]);
  112. pr_debug("supported_rf_interfaces[1] 0x%x\n",
  113. ndev->supported_rf_interfaces[1]);
  114. pr_debug("supported_rf_interfaces[2] 0x%x\n",
  115. ndev->supported_rf_interfaces[2]);
  116. pr_debug("supported_rf_interfaces[3] 0x%x\n",
  117. ndev->supported_rf_interfaces[3]);
  118. pr_debug("max_logical_connections %d\n",
  119. ndev->max_logical_connections);
  120. pr_debug("max_routing_table_size %d\n",
  121. ndev->max_routing_table_size);
  122. pr_debug("max_ctrl_pkt_payload_len %d\n",
  123. ndev->max_ctrl_pkt_payload_len);
  124. pr_debug("max_size_for_large_params %d\n",
  125. ndev->max_size_for_large_params);
  126. pr_debug("manufact_id 0x%x\n",
  127. ndev->manufact_id);
  128. pr_debug("manufact_specific_info 0x%x\n",
  129. ndev->manufact_specific_info);
  130. exit:
  131. nci_req_complete(ndev, status);
  132. }
  133. static void nci_core_set_config_rsp_packet(struct nci_dev *ndev,
  134. const struct sk_buff *skb)
  135. {
  136. const struct nci_core_set_config_rsp *rsp = (void *)skb->data;
  137. pr_debug("status 0x%x\n", rsp->status);
  138. nci_req_complete(ndev, rsp->status);
  139. }
  140. static void nci_rf_disc_map_rsp_packet(struct nci_dev *ndev,
  141. const struct sk_buff *skb)
  142. {
  143. __u8 status = skb->data[0];
  144. pr_debug("status 0x%x\n", status);
  145. nci_req_complete(ndev, status);
  146. }
  147. static void nci_rf_disc_rsp_packet(struct nci_dev *ndev,
  148. const struct sk_buff *skb)
  149. {
  150. struct nci_conn_info *conn_info;
  151. __u8 status = skb->data[0];
  152. pr_debug("status 0x%x\n", status);
  153. if (status == NCI_STATUS_OK) {
  154. atomic_set(&ndev->state, NCI_DISCOVERY);
  155. conn_info = ndev->rf_conn_info;
  156. if (!conn_info) {
  157. conn_info = devm_kzalloc(&ndev->nfc_dev->dev,
  158. sizeof(struct nci_conn_info),
  159. GFP_KERNEL);
  160. if (!conn_info) {
  161. status = NCI_STATUS_REJECTED;
  162. goto exit;
  163. }
  164. conn_info->conn_id = NCI_STATIC_RF_CONN_ID;
  165. INIT_LIST_HEAD(&conn_info->list);
  166. list_add(&conn_info->list, &ndev->conn_info_list);
  167. ndev->rf_conn_info = conn_info;
  168. }
  169. }
  170. exit:
  171. nci_req_complete(ndev, status);
  172. }
  173. static void nci_rf_disc_select_rsp_packet(struct nci_dev *ndev,
  174. const struct sk_buff *skb)
  175. {
  176. __u8 status = skb->data[0];
  177. pr_debug("status 0x%x\n", status);
  178. /* Complete the request on intf_activated_ntf or generic_error_ntf */
  179. if (status != NCI_STATUS_OK)
  180. nci_req_complete(ndev, status);
  181. }
  182. static void nci_rf_deactivate_rsp_packet(struct nci_dev *ndev,
  183. const struct sk_buff *skb)
  184. {
  185. __u8 status = skb->data[0];
  186. pr_debug("status 0x%x\n", status);
  187. /* If target was active, complete the request only in deactivate_ntf */
  188. if ((status != NCI_STATUS_OK) ||
  189. (atomic_read(&ndev->state) != NCI_POLL_ACTIVE)) {
  190. nci_clear_target_list(ndev);
  191. atomic_set(&ndev->state, NCI_IDLE);
  192. nci_req_complete(ndev, status);
  193. }
  194. }
  195. static void nci_nfcee_discover_rsp_packet(struct nci_dev *ndev,
  196. const struct sk_buff *skb)
  197. {
  198. const struct nci_nfcee_discover_rsp *discover_rsp;
  199. if (skb->len != 2) {
  200. nci_req_complete(ndev, NCI_STATUS_NFCEE_PROTOCOL_ERROR);
  201. return;
  202. }
  203. discover_rsp = (struct nci_nfcee_discover_rsp *)skb->data;
  204. if (discover_rsp->status != NCI_STATUS_OK ||
  205. discover_rsp->num_nfcee == 0)
  206. nci_req_complete(ndev, discover_rsp->status);
  207. }
  208. static void nci_nfcee_mode_set_rsp_packet(struct nci_dev *ndev,
  209. const struct sk_buff *skb)
  210. {
  211. __u8 status = skb->data[0];
  212. pr_debug("status 0x%x\n", status);
  213. nci_req_complete(ndev, status);
  214. }
  215. static void nci_core_conn_create_rsp_packet(struct nci_dev *ndev,
  216. const struct sk_buff *skb)
  217. {
  218. __u8 status = skb->data[0];
  219. struct nci_conn_info *conn_info = NULL;
  220. const struct nci_core_conn_create_rsp *rsp;
  221. pr_debug("status 0x%x\n", status);
  222. if (status == NCI_STATUS_OK) {
  223. rsp = (struct nci_core_conn_create_rsp *)skb->data;
  224. conn_info = devm_kzalloc(&ndev->nfc_dev->dev,
  225. sizeof(*conn_info), GFP_KERNEL);
  226. if (!conn_info) {
  227. status = NCI_STATUS_REJECTED;
  228. goto exit;
  229. }
  230. conn_info->dest_params = devm_kzalloc(&ndev->nfc_dev->dev,
  231. sizeof(struct dest_spec_params),
  232. GFP_KERNEL);
  233. if (!conn_info->dest_params) {
  234. status = NCI_STATUS_REJECTED;
  235. goto free_conn_info;
  236. }
  237. conn_info->dest_type = ndev->cur_dest_type;
  238. conn_info->dest_params->id = ndev->cur_params.id;
  239. conn_info->dest_params->protocol = ndev->cur_params.protocol;
  240. conn_info->conn_id = rsp->conn_id;
  241. /* Note: data_exchange_cb and data_exchange_cb_context need to
  242. * be specify out of nci_core_conn_create_rsp_packet
  243. */
  244. INIT_LIST_HEAD(&conn_info->list);
  245. list_add(&conn_info->list, &ndev->conn_info_list);
  246. if (ndev->cur_params.id == ndev->hci_dev->nfcee_id)
  247. ndev->hci_dev->conn_info = conn_info;
  248. conn_info->conn_id = rsp->conn_id;
  249. conn_info->max_pkt_payload_len = rsp->max_ctrl_pkt_payload_len;
  250. atomic_set(&conn_info->credits_cnt, rsp->credits_cnt);
  251. }
  252. free_conn_info:
  253. if (status == NCI_STATUS_REJECTED)
  254. devm_kfree(&ndev->nfc_dev->dev, conn_info);
  255. exit:
  256. nci_req_complete(ndev, status);
  257. }
  258. static void nci_core_conn_close_rsp_packet(struct nci_dev *ndev,
  259. const struct sk_buff *skb)
  260. {
  261. struct nci_conn_info *conn_info;
  262. __u8 status = skb->data[0];
  263. pr_debug("status 0x%x\n", status);
  264. if (status == NCI_STATUS_OK) {
  265. conn_info = nci_get_conn_info_by_conn_id(ndev,
  266. ndev->cur_conn_id);
  267. if (conn_info) {
  268. list_del(&conn_info->list);
  269. if (conn_info == ndev->rf_conn_info)
  270. ndev->rf_conn_info = NULL;
  271. devm_kfree(&ndev->nfc_dev->dev, conn_info);
  272. }
  273. }
  274. nci_req_complete(ndev, status);
  275. }
  276. void nci_rsp_packet(struct nci_dev *ndev, struct sk_buff *skb)
  277. {
  278. __u16 rsp_opcode = nci_opcode(skb->data);
  279. /* we got a rsp, stop the cmd timer */
  280. del_timer(&ndev->cmd_timer);
  281. pr_debug("NCI RX: MT=rsp, PBF=%d, GID=0x%x, OID=0x%x, plen=%d\n",
  282. nci_pbf(skb->data),
  283. nci_opcode_gid(rsp_opcode),
  284. nci_opcode_oid(rsp_opcode),
  285. nci_plen(skb->data));
  286. /* strip the nci control header */
  287. skb_pull(skb, NCI_CTRL_HDR_SIZE);
  288. if (nci_opcode_gid(rsp_opcode) == NCI_GID_PROPRIETARY) {
  289. if (nci_prop_rsp_packet(ndev, rsp_opcode, skb) == -ENOTSUPP) {
  290. pr_err("unsupported rsp opcode 0x%x\n",
  291. rsp_opcode);
  292. }
  293. goto end;
  294. }
  295. switch (rsp_opcode) {
  296. case NCI_OP_CORE_RESET_RSP:
  297. nci_core_reset_rsp_packet(ndev, skb);
  298. break;
  299. case NCI_OP_CORE_INIT_RSP:
  300. nci_core_init_rsp_packet(ndev, skb);
  301. break;
  302. case NCI_OP_CORE_SET_CONFIG_RSP:
  303. nci_core_set_config_rsp_packet(ndev, skb);
  304. break;
  305. case NCI_OP_CORE_CONN_CREATE_RSP:
  306. nci_core_conn_create_rsp_packet(ndev, skb);
  307. break;
  308. case NCI_OP_CORE_CONN_CLOSE_RSP:
  309. nci_core_conn_close_rsp_packet(ndev, skb);
  310. break;
  311. case NCI_OP_RF_DISCOVER_MAP_RSP:
  312. nci_rf_disc_map_rsp_packet(ndev, skb);
  313. break;
  314. case NCI_OP_RF_DISCOVER_RSP:
  315. nci_rf_disc_rsp_packet(ndev, skb);
  316. break;
  317. case NCI_OP_RF_DISCOVER_SELECT_RSP:
  318. nci_rf_disc_select_rsp_packet(ndev, skb);
  319. break;
  320. case NCI_OP_RF_DEACTIVATE_RSP:
  321. nci_rf_deactivate_rsp_packet(ndev, skb);
  322. break;
  323. case NCI_OP_NFCEE_DISCOVER_RSP:
  324. nci_nfcee_discover_rsp_packet(ndev, skb);
  325. break;
  326. case NCI_OP_NFCEE_MODE_SET_RSP:
  327. nci_nfcee_mode_set_rsp_packet(ndev, skb);
  328. break;
  329. default:
  330. pr_err("unknown rsp opcode 0x%x\n", rsp_opcode);
  331. break;
  332. }
  333. nci_core_rsp_packet(ndev, rsp_opcode, skb);
  334. end:
  335. kfree_skb(skb);
  336. /* trigger the next cmd */
  337. atomic_set(&ndev->cmd_cnt, 1);
  338. if (!skb_queue_empty(&ndev->cmd_q))
  339. queue_work(ndev->cmd_wq, &ndev->cmd_work);
  340. }