a2mp.c 22 KB

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