a2mp.c 22 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025
  1. /*
  2. Copyright (c) 2010,2011 Code Aurora Forum. All rights reserved.
  3. Copyright (c) 2011,2012 Intel Corp.
  4. This program is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License version 2 and
  6. only version 2 as published by the Free Software Foundation.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. */
  12. #include <net/bluetooth/bluetooth.h>
  13. #include <net/bluetooth/hci_core.h>
  14. #include <net/bluetooth/l2cap.h>
  15. #include "a2mp.h"
  16. #include "amp.h"
  17. #define A2MP_FEAT_EXT 0x8000
  18. /* Global AMP Manager list */
  19. static LIST_HEAD(amp_mgr_list);
  20. static DEFINE_MUTEX(amp_mgr_list_lock);
  21. /* A2MP build & send command helper functions */
  22. static struct a2mp_cmd *__a2mp_build(u8 code, u8 ident, u16 len, void *data)
  23. {
  24. struct a2mp_cmd *cmd;
  25. int plen;
  26. plen = sizeof(*cmd) + len;
  27. cmd = kzalloc(plen, GFP_KERNEL);
  28. if (!cmd)
  29. return NULL;
  30. cmd->code = code;
  31. cmd->ident = ident;
  32. cmd->len = cpu_to_le16(len);
  33. memcpy(cmd->data, data, len);
  34. return cmd;
  35. }
  36. static void a2mp_send(struct amp_mgr *mgr, u8 code, u8 ident, u16 len, void *data)
  37. {
  38. struct l2cap_chan *chan = mgr->a2mp_chan;
  39. struct a2mp_cmd *cmd;
  40. u16 total_len = len + sizeof(*cmd);
  41. struct kvec iv;
  42. struct msghdr msg;
  43. cmd = __a2mp_build(code, ident, len, data);
  44. if (!cmd)
  45. return;
  46. iv.iov_base = cmd;
  47. iv.iov_len = total_len;
  48. memset(&msg, 0, sizeof(msg));
  49. iov_iter_kvec(&msg.msg_iter, WRITE | ITER_KVEC, &iv, 1, total_len);
  50. l2cap_chan_send(chan, &msg, total_len);
  51. kfree(cmd);
  52. }
  53. static u8 __next_ident(struct amp_mgr *mgr)
  54. {
  55. if (++mgr->ident == 0)
  56. mgr->ident = 1;
  57. return mgr->ident;
  58. }
  59. static struct amp_mgr *amp_mgr_lookup_by_state(u8 state)
  60. {
  61. struct amp_mgr *mgr;
  62. mutex_lock(&amp_mgr_list_lock);
  63. list_for_each_entry(mgr, &amp_mgr_list, list) {
  64. if (test_and_clear_bit(state, &mgr->state)) {
  65. amp_mgr_get(mgr);
  66. mutex_unlock(&amp_mgr_list_lock);
  67. return mgr;
  68. }
  69. }
  70. mutex_unlock(&amp_mgr_list_lock);
  71. return NULL;
  72. }
  73. /* hci_dev_list shall be locked */
  74. static void __a2mp_add_cl(struct amp_mgr *mgr, struct a2mp_cl *cl)
  75. {
  76. struct hci_dev *hdev;
  77. int i = 1;
  78. cl[0].id = AMP_ID_BREDR;
  79. cl[0].type = AMP_TYPE_BREDR;
  80. cl[0].status = AMP_STATUS_BLUETOOTH_ONLY;
  81. list_for_each_entry(hdev, &hci_dev_list, list) {
  82. if (hdev->dev_type == HCI_AMP) {
  83. cl[i].id = hdev->id;
  84. cl[i].type = hdev->amp_type;
  85. if (test_bit(HCI_UP, &hdev->flags))
  86. cl[i].status = hdev->amp_status;
  87. else
  88. cl[i].status = AMP_STATUS_POWERED_DOWN;
  89. i++;
  90. }
  91. }
  92. }
  93. /* Processing A2MP messages */
  94. static int a2mp_command_rej(struct amp_mgr *mgr, struct sk_buff *skb,
  95. struct a2mp_cmd *hdr)
  96. {
  97. struct a2mp_cmd_rej *rej = (void *) skb->data;
  98. if (le16_to_cpu(hdr->len) < sizeof(*rej))
  99. return -EINVAL;
  100. BT_DBG("ident %d reason %d", hdr->ident, le16_to_cpu(rej->reason));
  101. skb_pull(skb, sizeof(*rej));
  102. return 0;
  103. }
  104. static int a2mp_discover_req(struct amp_mgr *mgr, struct sk_buff *skb,
  105. struct a2mp_cmd *hdr)
  106. {
  107. struct a2mp_discov_req *req = (void *) skb->data;
  108. u16 len = le16_to_cpu(hdr->len);
  109. struct a2mp_discov_rsp *rsp;
  110. u16 ext_feat;
  111. u8 num_ctrl;
  112. struct hci_dev *hdev;
  113. if (len < sizeof(*req))
  114. return -EINVAL;
  115. skb_pull(skb, sizeof(*req));
  116. ext_feat = le16_to_cpu(req->ext_feat);
  117. BT_DBG("mtu %d efm 0x%4.4x", le16_to_cpu(req->mtu), ext_feat);
  118. /* check that packet is not broken for now */
  119. while (ext_feat & A2MP_FEAT_EXT) {
  120. if (len < sizeof(ext_feat))
  121. return -EINVAL;
  122. ext_feat = get_unaligned_le16(skb->data);
  123. BT_DBG("efm 0x%4.4x", ext_feat);
  124. len -= sizeof(ext_feat);
  125. skb_pull(skb, sizeof(ext_feat));
  126. }
  127. read_lock(&hci_dev_list_lock);
  128. /* at minimum the BR/EDR needs to be listed */
  129. num_ctrl = 1;
  130. list_for_each_entry(hdev, &hci_dev_list, list) {
  131. if (hdev->dev_type == HCI_AMP)
  132. num_ctrl++;
  133. }
  134. len = num_ctrl * sizeof(struct a2mp_cl) + sizeof(*rsp);
  135. rsp = kmalloc(len, GFP_ATOMIC);
  136. if (!rsp) {
  137. read_unlock(&hci_dev_list_lock);
  138. return -ENOMEM;
  139. }
  140. rsp->mtu = cpu_to_le16(L2CAP_A2MP_DEFAULT_MTU);
  141. rsp->ext_feat = 0;
  142. __a2mp_add_cl(mgr, rsp->cl);
  143. read_unlock(&hci_dev_list_lock);
  144. a2mp_send(mgr, A2MP_DISCOVER_RSP, hdr->ident, len, rsp);
  145. kfree(rsp);
  146. return 0;
  147. }
  148. static int a2mp_discover_rsp(struct amp_mgr *mgr, struct sk_buff *skb,
  149. struct a2mp_cmd *hdr)
  150. {
  151. struct a2mp_discov_rsp *rsp = (void *) skb->data;
  152. u16 len = le16_to_cpu(hdr->len);
  153. struct a2mp_cl *cl;
  154. u16 ext_feat;
  155. bool found = false;
  156. if (len < sizeof(*rsp))
  157. return -EINVAL;
  158. len -= sizeof(*rsp);
  159. skb_pull(skb, sizeof(*rsp));
  160. ext_feat = le16_to_cpu(rsp->ext_feat);
  161. BT_DBG("mtu %d efm 0x%4.4x", le16_to_cpu(rsp->mtu), ext_feat);
  162. /* check that packet is not broken for now */
  163. while (ext_feat & A2MP_FEAT_EXT) {
  164. if (len < sizeof(ext_feat))
  165. return -EINVAL;
  166. ext_feat = get_unaligned_le16(skb->data);
  167. BT_DBG("efm 0x%4.4x", ext_feat);
  168. len -= sizeof(ext_feat);
  169. skb_pull(skb, sizeof(ext_feat));
  170. }
  171. cl = (void *) skb->data;
  172. while (len >= sizeof(*cl)) {
  173. BT_DBG("Remote AMP id %d type %d status %d", cl->id, cl->type,
  174. cl->status);
  175. if (cl->id != AMP_ID_BREDR && cl->type != AMP_TYPE_BREDR) {
  176. struct a2mp_info_req req;
  177. found = true;
  178. req.id = cl->id;
  179. a2mp_send(mgr, A2MP_GETINFO_REQ, __next_ident(mgr),
  180. sizeof(req), &req);
  181. }
  182. len -= sizeof(*cl);
  183. cl = (void *) skb_pull(skb, sizeof(*cl));
  184. }
  185. /* Fall back to L2CAP init sequence */
  186. if (!found) {
  187. struct l2cap_conn *conn = mgr->l2cap_conn;
  188. struct l2cap_chan *chan;
  189. mutex_lock(&conn->chan_lock);
  190. list_for_each_entry(chan, &conn->chan_l, list) {
  191. BT_DBG("chan %p state %s", chan,
  192. state_to_string(chan->state));
  193. if (chan->scid == L2CAP_CID_A2MP)
  194. continue;
  195. l2cap_chan_lock(chan);
  196. if (chan->state == BT_CONNECT)
  197. l2cap_send_conn_req(chan);
  198. l2cap_chan_unlock(chan);
  199. }
  200. mutex_unlock(&conn->chan_lock);
  201. }
  202. return 0;
  203. }
  204. static int a2mp_change_notify(struct amp_mgr *mgr, struct sk_buff *skb,
  205. struct a2mp_cmd *hdr)
  206. {
  207. struct a2mp_cl *cl = (void *) skb->data;
  208. while (skb->len >= sizeof(*cl)) {
  209. BT_DBG("Controller id %d type %d status %d", cl->id, cl->type,
  210. cl->status);
  211. cl = (struct a2mp_cl *) skb_pull(skb, sizeof(*cl));
  212. }
  213. /* TODO send A2MP_CHANGE_RSP */
  214. return 0;
  215. }
  216. static int a2mp_getinfo_req(struct amp_mgr *mgr, struct sk_buff *skb,
  217. struct a2mp_cmd *hdr)
  218. {
  219. struct a2mp_info_req *req = (void *) skb->data;
  220. struct hci_dev *hdev;
  221. if (le16_to_cpu(hdr->len) < sizeof(*req))
  222. return -EINVAL;
  223. BT_DBG("id %d", req->id);
  224. hdev = hci_dev_get(req->id);
  225. if (!hdev || hdev->dev_type != HCI_AMP) {
  226. struct a2mp_info_rsp rsp;
  227. rsp.id = req->id;
  228. rsp.status = A2MP_STATUS_INVALID_CTRL_ID;
  229. a2mp_send(mgr, A2MP_GETINFO_RSP, hdr->ident, sizeof(rsp),
  230. &rsp);
  231. goto done;
  232. }
  233. set_bit(READ_LOC_AMP_INFO, &mgr->state);
  234. hci_send_cmd(hdev, HCI_OP_READ_LOCAL_AMP_INFO, 0, NULL);
  235. done:
  236. if (hdev)
  237. hci_dev_put(hdev);
  238. skb_pull(skb, sizeof(*req));
  239. return 0;
  240. }
  241. static int a2mp_getinfo_rsp(struct amp_mgr *mgr, struct sk_buff *skb,
  242. struct a2mp_cmd *hdr)
  243. {
  244. struct a2mp_info_rsp *rsp = (struct a2mp_info_rsp *) skb->data;
  245. struct a2mp_amp_assoc_req req;
  246. struct amp_ctrl *ctrl;
  247. if (le16_to_cpu(hdr->len) < sizeof(*rsp))
  248. return -EINVAL;
  249. BT_DBG("id %d status 0x%2.2x", rsp->id, rsp->status);
  250. if (rsp->status)
  251. return -EINVAL;
  252. ctrl = amp_ctrl_add(mgr, rsp->id);
  253. if (!ctrl)
  254. return -ENOMEM;
  255. req.id = rsp->id;
  256. a2mp_send(mgr, A2MP_GETAMPASSOC_REQ, __next_ident(mgr), sizeof(req),
  257. &req);
  258. skb_pull(skb, sizeof(*rsp));
  259. return 0;
  260. }
  261. static int a2mp_getampassoc_req(struct amp_mgr *mgr, struct sk_buff *skb,
  262. struct a2mp_cmd *hdr)
  263. {
  264. struct a2mp_amp_assoc_req *req = (void *) skb->data;
  265. struct hci_dev *hdev;
  266. struct amp_mgr *tmp;
  267. if (le16_to_cpu(hdr->len) < sizeof(*req))
  268. return -EINVAL;
  269. BT_DBG("id %d", req->id);
  270. /* Make sure that other request is not processed */
  271. tmp = amp_mgr_lookup_by_state(READ_LOC_AMP_ASSOC);
  272. hdev = hci_dev_get(req->id);
  273. if (!hdev || hdev->amp_type == AMP_TYPE_BREDR || tmp) {
  274. struct a2mp_amp_assoc_rsp rsp;
  275. rsp.id = req->id;
  276. if (tmp) {
  277. rsp.status = A2MP_STATUS_COLLISION_OCCURED;
  278. amp_mgr_put(tmp);
  279. } else {
  280. rsp.status = A2MP_STATUS_INVALID_CTRL_ID;
  281. }
  282. a2mp_send(mgr, A2MP_GETAMPASSOC_RSP, hdr->ident, sizeof(rsp),
  283. &rsp);
  284. goto done;
  285. }
  286. amp_read_loc_assoc(hdev, mgr);
  287. done:
  288. if (hdev)
  289. hci_dev_put(hdev);
  290. skb_pull(skb, sizeof(*req));
  291. return 0;
  292. }
  293. static int a2mp_getampassoc_rsp(struct amp_mgr *mgr, struct sk_buff *skb,
  294. struct a2mp_cmd *hdr)
  295. {
  296. struct a2mp_amp_assoc_rsp *rsp = (void *) skb->data;
  297. u16 len = le16_to_cpu(hdr->len);
  298. struct hci_dev *hdev;
  299. struct amp_ctrl *ctrl;
  300. struct hci_conn *hcon;
  301. size_t assoc_len;
  302. if (len < sizeof(*rsp))
  303. return -EINVAL;
  304. assoc_len = len - sizeof(*rsp);
  305. BT_DBG("id %d status 0x%2.2x assoc len %zu", rsp->id, rsp->status,
  306. assoc_len);
  307. if (rsp->status)
  308. return -EINVAL;
  309. /* Save remote ASSOC data */
  310. ctrl = amp_ctrl_lookup(mgr, rsp->id);
  311. if (ctrl) {
  312. u8 *assoc;
  313. assoc = kmemdup(rsp->amp_assoc, assoc_len, GFP_KERNEL);
  314. if (!assoc) {
  315. amp_ctrl_put(ctrl);
  316. return -ENOMEM;
  317. }
  318. ctrl->assoc = assoc;
  319. ctrl->assoc_len = assoc_len;
  320. ctrl->assoc_rem_len = assoc_len;
  321. ctrl->assoc_len_so_far = 0;
  322. amp_ctrl_put(ctrl);
  323. }
  324. /* Create Phys Link */
  325. hdev = hci_dev_get(rsp->id);
  326. if (!hdev)
  327. return -EINVAL;
  328. hcon = phylink_add(hdev, mgr, rsp->id, true);
  329. if (!hcon)
  330. goto done;
  331. BT_DBG("Created hcon %p: loc:%d -> rem:%d", hcon, hdev->id, rsp->id);
  332. mgr->bredr_chan->remote_amp_id = rsp->id;
  333. amp_create_phylink(hdev, mgr, hcon);
  334. done:
  335. hci_dev_put(hdev);
  336. skb_pull(skb, len);
  337. return 0;
  338. }
  339. static int a2mp_createphyslink_req(struct amp_mgr *mgr, struct sk_buff *skb,
  340. struct a2mp_cmd *hdr)
  341. {
  342. struct a2mp_physlink_req *req = (void *) skb->data;
  343. struct a2mp_physlink_rsp rsp;
  344. struct hci_dev *hdev;
  345. struct hci_conn *hcon;
  346. struct amp_ctrl *ctrl;
  347. if (le16_to_cpu(hdr->len) < sizeof(*req))
  348. return -EINVAL;
  349. BT_DBG("local_id %d, remote_id %d", req->local_id, req->remote_id);
  350. rsp.local_id = req->remote_id;
  351. rsp.remote_id = req->local_id;
  352. hdev = hci_dev_get(req->remote_id);
  353. if (!hdev || hdev->amp_type == AMP_TYPE_BREDR) {
  354. rsp.status = A2MP_STATUS_INVALID_CTRL_ID;
  355. goto send_rsp;
  356. }
  357. ctrl = amp_ctrl_lookup(mgr, rsp.remote_id);
  358. if (!ctrl) {
  359. ctrl = amp_ctrl_add(mgr, rsp.remote_id);
  360. if (ctrl) {
  361. amp_ctrl_get(ctrl);
  362. } else {
  363. rsp.status = A2MP_STATUS_UNABLE_START_LINK_CREATION;
  364. goto send_rsp;
  365. }
  366. }
  367. if (ctrl) {
  368. size_t assoc_len = le16_to_cpu(hdr->len) - sizeof(*req);
  369. u8 *assoc;
  370. assoc = kmemdup(req->amp_assoc, assoc_len, GFP_KERNEL);
  371. if (!assoc) {
  372. amp_ctrl_put(ctrl);
  373. return -ENOMEM;
  374. }
  375. ctrl->assoc = assoc;
  376. ctrl->assoc_len = assoc_len;
  377. ctrl->assoc_rem_len = assoc_len;
  378. ctrl->assoc_len_so_far = 0;
  379. amp_ctrl_put(ctrl);
  380. }
  381. hcon = phylink_add(hdev, mgr, req->local_id, false);
  382. if (hcon) {
  383. amp_accept_phylink(hdev, mgr, hcon);
  384. rsp.status = A2MP_STATUS_SUCCESS;
  385. } else {
  386. rsp.status = A2MP_STATUS_UNABLE_START_LINK_CREATION;
  387. }
  388. send_rsp:
  389. if (hdev)
  390. hci_dev_put(hdev);
  391. /* Reply error now and success after HCI Write Remote AMP Assoc
  392. command complete with success status
  393. */
  394. if (rsp.status != A2MP_STATUS_SUCCESS) {
  395. a2mp_send(mgr, A2MP_CREATEPHYSLINK_RSP, hdr->ident,
  396. sizeof(rsp), &rsp);
  397. } else {
  398. set_bit(WRITE_REMOTE_AMP_ASSOC, &mgr->state);
  399. mgr->ident = hdr->ident;
  400. }
  401. skb_pull(skb, le16_to_cpu(hdr->len));
  402. return 0;
  403. }
  404. static int a2mp_discphyslink_req(struct amp_mgr *mgr, struct sk_buff *skb,
  405. struct a2mp_cmd *hdr)
  406. {
  407. struct a2mp_physlink_req *req = (void *) skb->data;
  408. struct a2mp_physlink_rsp rsp;
  409. struct hci_dev *hdev;
  410. struct hci_conn *hcon;
  411. if (le16_to_cpu(hdr->len) < sizeof(*req))
  412. return -EINVAL;
  413. BT_DBG("local_id %d remote_id %d", req->local_id, req->remote_id);
  414. rsp.local_id = req->remote_id;
  415. rsp.remote_id = req->local_id;
  416. rsp.status = A2MP_STATUS_SUCCESS;
  417. hdev = hci_dev_get(req->remote_id);
  418. if (!hdev) {
  419. rsp.status = A2MP_STATUS_INVALID_CTRL_ID;
  420. goto send_rsp;
  421. }
  422. hcon = hci_conn_hash_lookup_ba(hdev, AMP_LINK,
  423. &mgr->l2cap_conn->hcon->dst);
  424. if (!hcon) {
  425. BT_ERR("No phys link exist");
  426. rsp.status = A2MP_STATUS_NO_PHYSICAL_LINK_EXISTS;
  427. goto clean;
  428. }
  429. /* TODO Disconnect Phys Link here */
  430. clean:
  431. hci_dev_put(hdev);
  432. send_rsp:
  433. a2mp_send(mgr, A2MP_DISCONNPHYSLINK_RSP, hdr->ident, sizeof(rsp), &rsp);
  434. skb_pull(skb, sizeof(*req));
  435. return 0;
  436. }
  437. static inline int a2mp_cmd_rsp(struct amp_mgr *mgr, struct sk_buff *skb,
  438. struct a2mp_cmd *hdr)
  439. {
  440. BT_DBG("ident %d code 0x%2.2x", hdr->ident, hdr->code);
  441. skb_pull(skb, le16_to_cpu(hdr->len));
  442. return 0;
  443. }
  444. /* Handle A2MP signalling */
  445. static int a2mp_chan_recv_cb(struct l2cap_chan *chan, struct sk_buff *skb)
  446. {
  447. struct a2mp_cmd *hdr;
  448. struct amp_mgr *mgr = chan->data;
  449. int err = 0;
  450. amp_mgr_get(mgr);
  451. while (skb->len >= sizeof(*hdr)) {
  452. u16 len;
  453. hdr = (void *) skb->data;
  454. len = le16_to_cpu(hdr->len);
  455. BT_DBG("code 0x%2.2x id %d len %u", hdr->code, hdr->ident, len);
  456. skb_pull(skb, sizeof(*hdr));
  457. if (len > skb->len || !hdr->ident) {
  458. err = -EINVAL;
  459. break;
  460. }
  461. mgr->ident = hdr->ident;
  462. switch (hdr->code) {
  463. case A2MP_COMMAND_REJ:
  464. a2mp_command_rej(mgr, skb, hdr);
  465. break;
  466. case A2MP_DISCOVER_REQ:
  467. err = a2mp_discover_req(mgr, skb, hdr);
  468. break;
  469. case A2MP_CHANGE_NOTIFY:
  470. err = a2mp_change_notify(mgr, skb, hdr);
  471. break;
  472. case A2MP_GETINFO_REQ:
  473. err = a2mp_getinfo_req(mgr, skb, hdr);
  474. break;
  475. case A2MP_GETAMPASSOC_REQ:
  476. err = a2mp_getampassoc_req(mgr, skb, hdr);
  477. break;
  478. case A2MP_CREATEPHYSLINK_REQ:
  479. err = a2mp_createphyslink_req(mgr, skb, hdr);
  480. break;
  481. case A2MP_DISCONNPHYSLINK_REQ:
  482. err = a2mp_discphyslink_req(mgr, skb, hdr);
  483. break;
  484. case A2MP_DISCOVER_RSP:
  485. err = a2mp_discover_rsp(mgr, skb, hdr);
  486. break;
  487. case A2MP_GETINFO_RSP:
  488. err = a2mp_getinfo_rsp(mgr, skb, hdr);
  489. break;
  490. case A2MP_GETAMPASSOC_RSP:
  491. err = a2mp_getampassoc_rsp(mgr, skb, hdr);
  492. break;
  493. case A2MP_CHANGE_RSP:
  494. case A2MP_CREATEPHYSLINK_RSP:
  495. case A2MP_DISCONNPHYSLINK_RSP:
  496. err = a2mp_cmd_rsp(mgr, skb, hdr);
  497. break;
  498. default:
  499. BT_ERR("Unknown A2MP sig cmd 0x%2.2x", hdr->code);
  500. err = -EINVAL;
  501. break;
  502. }
  503. }
  504. if (err) {
  505. struct a2mp_cmd_rej rej;
  506. rej.reason = cpu_to_le16(0);
  507. hdr = (void *) skb->data;
  508. BT_DBG("Send A2MP Rej: cmd 0x%2.2x err %d", hdr->code, err);
  509. a2mp_send(mgr, A2MP_COMMAND_REJ, hdr->ident, sizeof(rej),
  510. &rej);
  511. }
  512. /* Always free skb and return success error code to prevent
  513. from sending L2CAP Disconnect over A2MP channel */
  514. kfree_skb(skb);
  515. amp_mgr_put(mgr);
  516. return 0;
  517. }
  518. static void a2mp_chan_close_cb(struct l2cap_chan *chan)
  519. {
  520. l2cap_chan_put(chan);
  521. }
  522. static void a2mp_chan_state_change_cb(struct l2cap_chan *chan, int state,
  523. int err)
  524. {
  525. struct amp_mgr *mgr = chan->data;
  526. if (!mgr)
  527. return;
  528. BT_DBG("chan %p state %s", chan, state_to_string(state));
  529. chan->state = state;
  530. switch (state) {
  531. case BT_CLOSED:
  532. if (mgr)
  533. amp_mgr_put(mgr);
  534. break;
  535. }
  536. }
  537. static struct sk_buff *a2mp_chan_alloc_skb_cb(struct l2cap_chan *chan,
  538. unsigned long hdr_len,
  539. unsigned long len, int nb)
  540. {
  541. struct sk_buff *skb;
  542. skb = bt_skb_alloc(hdr_len + len, GFP_KERNEL);
  543. if (!skb)
  544. return ERR_PTR(-ENOMEM);
  545. return skb;
  546. }
  547. static const struct l2cap_ops a2mp_chan_ops = {
  548. .name = "L2CAP A2MP channel",
  549. .recv = a2mp_chan_recv_cb,
  550. .close = a2mp_chan_close_cb,
  551. .state_change = a2mp_chan_state_change_cb,
  552. .alloc_skb = a2mp_chan_alloc_skb_cb,
  553. /* Not implemented for A2MP */
  554. .new_connection = l2cap_chan_no_new_connection,
  555. .teardown = l2cap_chan_no_teardown,
  556. .ready = l2cap_chan_no_ready,
  557. .defer = l2cap_chan_no_defer,
  558. .resume = l2cap_chan_no_resume,
  559. .set_shutdown = l2cap_chan_no_set_shutdown,
  560. .get_sndtimeo = l2cap_chan_no_get_sndtimeo,
  561. };
  562. static struct l2cap_chan *a2mp_chan_open(struct l2cap_conn *conn, bool locked)
  563. {
  564. struct l2cap_chan *chan;
  565. int err;
  566. chan = l2cap_chan_create();
  567. if (!chan)
  568. return NULL;
  569. BT_DBG("chan %p", chan);
  570. chan->chan_type = L2CAP_CHAN_FIXED;
  571. chan->scid = L2CAP_CID_A2MP;
  572. chan->dcid = L2CAP_CID_A2MP;
  573. chan->omtu = L2CAP_A2MP_DEFAULT_MTU;
  574. chan->imtu = L2CAP_A2MP_DEFAULT_MTU;
  575. chan->flush_to = L2CAP_DEFAULT_FLUSH_TO;
  576. chan->ops = &a2mp_chan_ops;
  577. l2cap_chan_set_defaults(chan);
  578. chan->remote_max_tx = chan->max_tx;
  579. chan->remote_tx_win = chan->tx_win;
  580. chan->retrans_timeout = L2CAP_DEFAULT_RETRANS_TO;
  581. chan->monitor_timeout = L2CAP_DEFAULT_MONITOR_TO;
  582. skb_queue_head_init(&chan->tx_q);
  583. chan->mode = L2CAP_MODE_ERTM;
  584. err = l2cap_ertm_init(chan);
  585. if (err < 0) {
  586. l2cap_chan_del(chan, 0);
  587. return NULL;
  588. }
  589. chan->conf_state = 0;
  590. if (locked)
  591. __l2cap_chan_add(conn, chan);
  592. else
  593. l2cap_chan_add(conn, chan);
  594. chan->remote_mps = chan->omtu;
  595. chan->mps = chan->omtu;
  596. chan->state = BT_CONNECTED;
  597. return chan;
  598. }
  599. /* AMP Manager functions */
  600. struct amp_mgr *amp_mgr_get(struct amp_mgr *mgr)
  601. {
  602. BT_DBG("mgr %p orig refcnt %d", mgr, atomic_read(&mgr->kref.refcount));
  603. kref_get(&mgr->kref);
  604. return mgr;
  605. }
  606. static void amp_mgr_destroy(struct kref *kref)
  607. {
  608. struct amp_mgr *mgr = container_of(kref, struct amp_mgr, kref);
  609. BT_DBG("mgr %p", mgr);
  610. mutex_lock(&amp_mgr_list_lock);
  611. list_del(&mgr->list);
  612. mutex_unlock(&amp_mgr_list_lock);
  613. amp_ctrl_list_flush(mgr);
  614. kfree(mgr);
  615. }
  616. int amp_mgr_put(struct amp_mgr *mgr)
  617. {
  618. BT_DBG("mgr %p orig refcnt %d", mgr, atomic_read(&mgr->kref.refcount));
  619. return kref_put(&mgr->kref, &amp_mgr_destroy);
  620. }
  621. static struct amp_mgr *amp_mgr_create(struct l2cap_conn *conn, bool locked)
  622. {
  623. struct amp_mgr *mgr;
  624. struct l2cap_chan *chan;
  625. mgr = kzalloc(sizeof(*mgr), GFP_KERNEL);
  626. if (!mgr)
  627. return NULL;
  628. BT_DBG("conn %p mgr %p", conn, mgr);
  629. mgr->l2cap_conn = conn;
  630. chan = a2mp_chan_open(conn, locked);
  631. if (!chan) {
  632. kfree(mgr);
  633. return NULL;
  634. }
  635. mgr->a2mp_chan = chan;
  636. chan->data = mgr;
  637. conn->hcon->amp_mgr = mgr;
  638. kref_init(&mgr->kref);
  639. /* Remote AMP ctrl list initialization */
  640. INIT_LIST_HEAD(&mgr->amp_ctrls);
  641. mutex_init(&mgr->amp_ctrls_lock);
  642. mutex_lock(&amp_mgr_list_lock);
  643. list_add(&mgr->list, &amp_mgr_list);
  644. mutex_unlock(&amp_mgr_list_lock);
  645. return mgr;
  646. }
  647. struct l2cap_chan *a2mp_channel_create(struct l2cap_conn *conn,
  648. struct sk_buff *skb)
  649. {
  650. struct amp_mgr *mgr;
  651. if (conn->hcon->type != ACL_LINK)
  652. return NULL;
  653. mgr = amp_mgr_create(conn, false);
  654. if (!mgr) {
  655. BT_ERR("Could not create AMP manager");
  656. return NULL;
  657. }
  658. BT_DBG("mgr: %p chan %p", mgr, mgr->a2mp_chan);
  659. return mgr->a2mp_chan;
  660. }
  661. void a2mp_send_getinfo_rsp(struct hci_dev *hdev)
  662. {
  663. struct amp_mgr *mgr;
  664. struct a2mp_info_rsp rsp;
  665. mgr = amp_mgr_lookup_by_state(READ_LOC_AMP_INFO);
  666. if (!mgr)
  667. return;
  668. BT_DBG("%s mgr %p", hdev->name, mgr);
  669. rsp.id = hdev->id;
  670. rsp.status = A2MP_STATUS_INVALID_CTRL_ID;
  671. if (hdev->amp_type != AMP_TYPE_BREDR) {
  672. rsp.status = 0;
  673. rsp.total_bw = cpu_to_le32(hdev->amp_total_bw);
  674. rsp.max_bw = cpu_to_le32(hdev->amp_max_bw);
  675. rsp.min_latency = cpu_to_le32(hdev->amp_min_latency);
  676. rsp.pal_cap = cpu_to_le16(hdev->amp_pal_cap);
  677. rsp.assoc_size = cpu_to_le16(hdev->amp_assoc_size);
  678. }
  679. a2mp_send(mgr, A2MP_GETINFO_RSP, mgr->ident, sizeof(rsp), &rsp);
  680. amp_mgr_put(mgr);
  681. }
  682. void a2mp_send_getampassoc_rsp(struct hci_dev *hdev, u8 status)
  683. {
  684. struct amp_mgr *mgr;
  685. struct amp_assoc *loc_assoc = &hdev->loc_assoc;
  686. struct a2mp_amp_assoc_rsp *rsp;
  687. size_t len;
  688. mgr = amp_mgr_lookup_by_state(READ_LOC_AMP_ASSOC);
  689. if (!mgr)
  690. return;
  691. BT_DBG("%s mgr %p", hdev->name, mgr);
  692. len = sizeof(struct a2mp_amp_assoc_rsp) + loc_assoc->len;
  693. rsp = kzalloc(len, GFP_KERNEL);
  694. if (!rsp) {
  695. amp_mgr_put(mgr);
  696. return;
  697. }
  698. rsp->id = hdev->id;
  699. if (status) {
  700. rsp->status = A2MP_STATUS_INVALID_CTRL_ID;
  701. } else {
  702. rsp->status = A2MP_STATUS_SUCCESS;
  703. memcpy(rsp->amp_assoc, loc_assoc->data, loc_assoc->len);
  704. }
  705. a2mp_send(mgr, A2MP_GETAMPASSOC_RSP, mgr->ident, len, rsp);
  706. amp_mgr_put(mgr);
  707. kfree(rsp);
  708. }
  709. void a2mp_send_create_phy_link_req(struct hci_dev *hdev, u8 status)
  710. {
  711. struct amp_mgr *mgr;
  712. struct amp_assoc *loc_assoc = &hdev->loc_assoc;
  713. struct a2mp_physlink_req *req;
  714. struct l2cap_chan *bredr_chan;
  715. size_t len;
  716. mgr = amp_mgr_lookup_by_state(READ_LOC_AMP_ASSOC_FINAL);
  717. if (!mgr)
  718. return;
  719. len = sizeof(*req) + loc_assoc->len;
  720. BT_DBG("%s mgr %p assoc_len %zu", hdev->name, mgr, len);
  721. req = kzalloc(len, GFP_KERNEL);
  722. if (!req) {
  723. amp_mgr_put(mgr);
  724. return;
  725. }
  726. bredr_chan = mgr->bredr_chan;
  727. if (!bredr_chan)
  728. goto clean;
  729. req->local_id = hdev->id;
  730. req->remote_id = bredr_chan->remote_amp_id;
  731. memcpy(req->amp_assoc, loc_assoc->data, loc_assoc->len);
  732. a2mp_send(mgr, A2MP_CREATEPHYSLINK_REQ, __next_ident(mgr), len, req);
  733. clean:
  734. amp_mgr_put(mgr);
  735. kfree(req);
  736. }
  737. void a2mp_send_create_phy_link_rsp(struct hci_dev *hdev, u8 status)
  738. {
  739. struct amp_mgr *mgr;
  740. struct a2mp_physlink_rsp rsp;
  741. struct hci_conn *hs_hcon;
  742. mgr = amp_mgr_lookup_by_state(WRITE_REMOTE_AMP_ASSOC);
  743. if (!mgr)
  744. return;
  745. hs_hcon = hci_conn_hash_lookup_state(hdev, AMP_LINK, BT_CONNECT);
  746. if (!hs_hcon) {
  747. rsp.status = A2MP_STATUS_UNABLE_START_LINK_CREATION;
  748. } else {
  749. rsp.remote_id = hs_hcon->remote_id;
  750. rsp.status = A2MP_STATUS_SUCCESS;
  751. }
  752. BT_DBG("%s mgr %p hs_hcon %p status %u", hdev->name, mgr, hs_hcon,
  753. status);
  754. rsp.local_id = hdev->id;
  755. a2mp_send(mgr, A2MP_CREATEPHYSLINK_RSP, mgr->ident, sizeof(rsp), &rsp);
  756. amp_mgr_put(mgr);
  757. }
  758. void a2mp_discover_amp(struct l2cap_chan *chan)
  759. {
  760. struct l2cap_conn *conn = chan->conn;
  761. struct amp_mgr *mgr = conn->hcon->amp_mgr;
  762. struct a2mp_discov_req req;
  763. BT_DBG("chan %p conn %p mgr %p", chan, conn, mgr);
  764. if (!mgr) {
  765. mgr = amp_mgr_create(conn, true);
  766. if (!mgr)
  767. return;
  768. }
  769. mgr->bredr_chan = chan;
  770. req.mtu = cpu_to_le16(L2CAP_A2MP_DEFAULT_MTU);
  771. req.ext_feat = 0;
  772. a2mp_send(mgr, A2MP_DISCOVER_REQ, 1, sizeof(req), &req);
  773. }