hci.c 68 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263
  1. /*
  2. * QEMU Bluetooth HCI logic.
  3. *
  4. * Copyright (C) 2007 OpenMoko, Inc.
  5. * Copyright (C) 2008 Andrzej Zaborowski <balrog@zabor.org>
  6. *
  7. * This program is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU General Public License as
  9. * published by the Free Software Foundation; either version 2 of
  10. * the License, or (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, see <http://www.gnu.org/licenses/>.
  19. */
  20. #include "qemu/osdep.h"
  21. #include "qemu/error-report.h"
  22. #include "qapi/error.h"
  23. #include "qemu/timer.h"
  24. #include "hw/usb.h"
  25. #include "sysemu/bt.h"
  26. #include "hw/bt.h"
  27. #include "qapi/qmp/qerror.h"
  28. #include "sysemu/replay.h"
  29. #include "qemu/cutils.h"
  30. struct bt_hci_s {
  31. uint8_t *(*evt_packet)(void *opaque);
  32. void (*evt_submit)(void *opaque, int len);
  33. void *opaque;
  34. uint8_t evt_buf[256];
  35. uint8_t acl_buf[4096];
  36. int acl_len;
  37. uint16_t asb_handle;
  38. uint16_t psb_handle;
  39. int last_cmd; /* Note: Always little-endian */
  40. struct bt_device_s *conn_req_host;
  41. struct {
  42. int inquire;
  43. int periodic;
  44. int responses_left;
  45. int responses;
  46. QEMUTimer *inquiry_done;
  47. QEMUTimer *inquiry_next;
  48. int inquiry_length;
  49. int inquiry_period;
  50. int inquiry_mode;
  51. #define HCI_HANDLE_OFFSET 0x20
  52. #define HCI_HANDLES_MAX 0x10
  53. struct bt_hci_master_link_s {
  54. struct bt_link_s *link;
  55. void (*lmp_acl_data)(struct bt_link_s *link,
  56. const uint8_t *data, int start, int len);
  57. QEMUTimer *acl_mode_timer;
  58. } handle[HCI_HANDLES_MAX];
  59. uint32_t role_bmp;
  60. int last_handle;
  61. int connecting;
  62. bdaddr_t awaiting_bdaddr[HCI_HANDLES_MAX];
  63. } lm;
  64. uint8_t event_mask[8];
  65. uint16_t voice_setting; /* Notw: Always little-endian */
  66. uint16_t conn_accept_tout;
  67. QEMUTimer *conn_accept_timer;
  68. struct HCIInfo info;
  69. struct bt_device_s device;
  70. Error *replay_blocker;
  71. };
  72. #define DEFAULT_RSSI_DBM 20
  73. #define hci_from_info(ptr) container_of((ptr), struct bt_hci_s, info)
  74. #define hci_from_device(ptr) container_of((ptr), struct bt_hci_s, device)
  75. struct bt_hci_link_s {
  76. struct bt_link_s btlink;
  77. uint16_t handle; /* Local */
  78. };
  79. /* LMP layer emulation */
  80. #if 0
  81. static void bt_submit_lmp(struct bt_device_s *bt, int length, uint8_t *data)
  82. {
  83. int resp, resplen, error, op, tr;
  84. uint8_t respdata[17];
  85. if (length < 1)
  86. return;
  87. tr = *data & 1;
  88. op = *(data ++) >> 1;
  89. resp = LMP_ACCEPTED;
  90. resplen = 2;
  91. respdata[1] = op;
  92. error = 0;
  93. length --;
  94. if (op >= 0x7c) { /* Extended opcode */
  95. op |= *(data ++) << 8;
  96. resp = LMP_ACCEPTED_EXT;
  97. resplen = 4;
  98. respdata[0] = op >> 8;
  99. respdata[1] = op & 0xff;
  100. length --;
  101. }
  102. switch (op) {
  103. case LMP_ACCEPTED:
  104. /* data[0] Op code
  105. */
  106. if (length < 1) {
  107. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  108. goto not_accepted;
  109. }
  110. resp = 0;
  111. break;
  112. case LMP_ACCEPTED_EXT:
  113. /* data[0] Escape op code
  114. * data[1] Extended op code
  115. */
  116. if (length < 2) {
  117. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  118. goto not_accepted;
  119. }
  120. resp = 0;
  121. break;
  122. case LMP_NOT_ACCEPTED:
  123. /* data[0] Op code
  124. * data[1] Error code
  125. */
  126. if (length < 2) {
  127. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  128. goto not_accepted;
  129. }
  130. resp = 0;
  131. break;
  132. case LMP_NOT_ACCEPTED_EXT:
  133. /* data[0] Op code
  134. * data[1] Extended op code
  135. * data[2] Error code
  136. */
  137. if (length < 3) {
  138. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  139. goto not_accepted;
  140. }
  141. resp = 0;
  142. break;
  143. case LMP_HOST_CONNECTION_REQ:
  144. break;
  145. case LMP_SETUP_COMPLETE:
  146. resp = LMP_SETUP_COMPLETE;
  147. resplen = 1;
  148. bt->setup = 1;
  149. break;
  150. case LMP_DETACH:
  151. /* data[0] Error code
  152. */
  153. if (length < 1) {
  154. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  155. goto not_accepted;
  156. }
  157. bt->setup = 0;
  158. resp = 0;
  159. break;
  160. case LMP_SUPERVISION_TIMEOUT:
  161. /* data[0,1] Supervision timeout
  162. */
  163. if (length < 2) {
  164. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  165. goto not_accepted;
  166. }
  167. resp = 0;
  168. break;
  169. case LMP_QUALITY_OF_SERVICE:
  170. resp = 0;
  171. /* Fall through */
  172. case LMP_QOS_REQ:
  173. /* data[0,1] Poll interval
  174. * data[2] N(BC)
  175. */
  176. if (length < 3) {
  177. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  178. goto not_accepted;
  179. }
  180. break;
  181. case LMP_MAX_SLOT:
  182. resp = 0;
  183. /* Fall through */
  184. case LMP_MAX_SLOT_REQ:
  185. /* data[0] Max slots
  186. */
  187. if (length < 1) {
  188. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  189. goto not_accepted;
  190. }
  191. break;
  192. case LMP_AU_RAND:
  193. case LMP_IN_RAND:
  194. case LMP_COMB_KEY:
  195. /* data[0-15] Random number
  196. */
  197. if (length < 16) {
  198. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  199. goto not_accepted;
  200. }
  201. if (op == LMP_AU_RAND) {
  202. if (bt->key_present) {
  203. resp = LMP_SRES;
  204. resplen = 5;
  205. /* XXX: [Part H] Section 6.1 on page 801 */
  206. } else {
  207. error = HCI_PIN_OR_KEY_MISSING;
  208. goto not_accepted;
  209. }
  210. } else if (op == LMP_IN_RAND) {
  211. error = HCI_PAIRING_NOT_ALLOWED;
  212. goto not_accepted;
  213. } else {
  214. /* XXX: [Part H] Section 3.2 on page 779 */
  215. resp = LMP_UNIT_KEY;
  216. resplen = 17;
  217. memcpy(respdata + 1, bt->key, 16);
  218. error = HCI_UNIT_LINK_KEY_USED;
  219. goto not_accepted;
  220. }
  221. break;
  222. case LMP_UNIT_KEY:
  223. /* data[0-15] Key
  224. */
  225. if (length < 16) {
  226. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  227. goto not_accepted;
  228. }
  229. memcpy(bt->key, data, 16);
  230. bt->key_present = 1;
  231. break;
  232. case LMP_SRES:
  233. /* data[0-3] Authentication response
  234. */
  235. if (length < 4) {
  236. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  237. goto not_accepted;
  238. }
  239. break;
  240. case LMP_CLKOFFSET_REQ:
  241. resp = LMP_CLKOFFSET_RES;
  242. resplen = 3;
  243. respdata[1] = 0x33;
  244. respdata[2] = 0x33;
  245. break;
  246. case LMP_CLKOFFSET_RES:
  247. /* data[0,1] Clock offset
  248. * (Slave to master only)
  249. */
  250. if (length < 2) {
  251. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  252. goto not_accepted;
  253. }
  254. break;
  255. case LMP_VERSION_REQ:
  256. case LMP_VERSION_RES:
  257. /* data[0] VersNr
  258. * data[1,2] CompId
  259. * data[3,4] SubVersNr
  260. */
  261. if (length < 5) {
  262. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  263. goto not_accepted;
  264. }
  265. if (op == LMP_VERSION_REQ) {
  266. resp = LMP_VERSION_RES;
  267. resplen = 6;
  268. respdata[1] = 0x20;
  269. respdata[2] = 0xff;
  270. respdata[3] = 0xff;
  271. respdata[4] = 0xff;
  272. respdata[5] = 0xff;
  273. } else
  274. resp = 0;
  275. break;
  276. case LMP_FEATURES_REQ:
  277. case LMP_FEATURES_RES:
  278. /* data[0-7] Features
  279. */
  280. if (length < 8) {
  281. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  282. goto not_accepted;
  283. }
  284. if (op == LMP_FEATURES_REQ) {
  285. resp = LMP_FEATURES_RES;
  286. resplen = 9;
  287. respdata[1] = (bt->lmp_caps >> 0) & 0xff;
  288. respdata[2] = (bt->lmp_caps >> 8) & 0xff;
  289. respdata[3] = (bt->lmp_caps >> 16) & 0xff;
  290. respdata[4] = (bt->lmp_caps >> 24) & 0xff;
  291. respdata[5] = (bt->lmp_caps >> 32) & 0xff;
  292. respdata[6] = (bt->lmp_caps >> 40) & 0xff;
  293. respdata[7] = (bt->lmp_caps >> 48) & 0xff;
  294. respdata[8] = (bt->lmp_caps >> 56) & 0xff;
  295. } else
  296. resp = 0;
  297. break;
  298. case LMP_NAME_REQ:
  299. /* data[0] Name offset
  300. */
  301. if (length < 1) {
  302. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  303. goto not_accepted;
  304. }
  305. resp = LMP_NAME_RES;
  306. resplen = 17;
  307. respdata[1] = data[0];
  308. respdata[2] = strlen(bt->lmp_name);
  309. memset(respdata + 3, 0x00, 14);
  310. if (respdata[2] > respdata[1])
  311. memcpy(respdata + 3, bt->lmp_name + respdata[1],
  312. respdata[2] - respdata[1]);
  313. break;
  314. case LMP_NAME_RES:
  315. /* data[0] Name offset
  316. * data[1] Name length
  317. * data[2-15] Name fragment
  318. */
  319. if (length < 16) {
  320. error = HCI_UNSUPPORTED_LMP_PARAMETER_VALUE;
  321. goto not_accepted;
  322. }
  323. resp = 0;
  324. break;
  325. default:
  326. error = HCI_UNKNOWN_LMP_PDU;
  327. /* Fall through */
  328. not_accepted:
  329. if (op >> 8) {
  330. resp = LMP_NOT_ACCEPTED_EXT;
  331. resplen = 5;
  332. respdata[0] = op >> 8;
  333. respdata[1] = op & 0xff;
  334. respdata[2] = error;
  335. } else {
  336. resp = LMP_NOT_ACCEPTED;
  337. resplen = 3;
  338. respdata[0] = op & 0xff;
  339. respdata[1] = error;
  340. }
  341. }
  342. if (resp == 0)
  343. return;
  344. if (resp >> 8) {
  345. respdata[0] = resp >> 8;
  346. respdata[1] = resp & 0xff;
  347. } else
  348. respdata[0] = resp & 0xff;
  349. respdata[0] <<= 1;
  350. respdata[0] |= tr;
  351. }
  352. static void bt_submit_raw_acl(struct bt_piconet_s *net, int length, uint8_t *data)
  353. {
  354. struct bt_device_s *slave;
  355. if (length < 1)
  356. return;
  357. slave = 0;
  358. #if 0
  359. slave = net->slave;
  360. #endif
  361. switch (data[0] & 3) {
  362. case LLID_ACLC:
  363. bt_submit_lmp(slave, length - 1, data + 1);
  364. break;
  365. case LLID_ACLU_START:
  366. #if 0
  367. bt_sumbit_l2cap(slave, length - 1, data + 1, (data[0] >> 2) & 1);
  368. breka;
  369. #endif
  370. default:
  371. case LLID_ACLU_CONT:
  372. break;
  373. }
  374. }
  375. #endif
  376. /* HCI layer emulation */
  377. /* Note: we could ignore endianness because unswapped handles will still
  378. * be valid as connection identifiers for the guest - they don't have to
  379. * be continuously allocated. We do it though, to preserve similar
  380. * behaviour between hosts. Some things, like the BD_ADDR cannot be
  381. * preserved though (for example if a real hci is used). */
  382. #define HNDL(raw) cpu_to_le16(raw)
  383. static const uint8_t bt_event_reserved_mask[8] = {
  384. 0xff, 0x9f, 0xfb, 0xff, 0x07, 0x18, 0x00, 0x00,
  385. };
  386. static void null_hci_send(struct HCIInfo *hci, const uint8_t *data, int len)
  387. {
  388. }
  389. static int null_hci_addr_set(struct HCIInfo *hci, const uint8_t *bd_addr)
  390. {
  391. return -ENOTSUP;
  392. }
  393. struct HCIInfo null_hci = {
  394. .cmd_send = null_hci_send,
  395. .sco_send = null_hci_send,
  396. .acl_send = null_hci_send,
  397. .bdaddr_set = null_hci_addr_set,
  398. };
  399. static inline uint8_t *bt_hci_event_start(struct bt_hci_s *hci,
  400. int evt, int len)
  401. {
  402. uint8_t *packet, mask;
  403. int mask_byte;
  404. if (len > 255) {
  405. error_report("%s: HCI event params too long (%ib)", __func__, len);
  406. exit(-1);
  407. }
  408. mask_byte = (evt - 1) >> 3;
  409. mask = 1 << ((evt - 1) & 3);
  410. if (mask & bt_event_reserved_mask[mask_byte] & ~hci->event_mask[mask_byte])
  411. return NULL;
  412. packet = hci->evt_packet(hci->opaque);
  413. packet[0] = evt;
  414. packet[1] = len;
  415. return &packet[2];
  416. }
  417. static inline void bt_hci_event(struct bt_hci_s *hci, int evt,
  418. void *params, int len)
  419. {
  420. uint8_t *packet = bt_hci_event_start(hci, evt, len);
  421. if (!packet)
  422. return;
  423. if (len)
  424. memcpy(packet, params, len);
  425. hci->evt_submit(hci->opaque, len + 2);
  426. }
  427. static inline void bt_hci_event_status(struct bt_hci_s *hci, int status)
  428. {
  429. evt_cmd_status params = {
  430. .status = status,
  431. .ncmd = 1,
  432. .opcode = hci->last_cmd,
  433. };
  434. bt_hci_event(hci, EVT_CMD_STATUS, &params, EVT_CMD_STATUS_SIZE);
  435. }
  436. static inline void bt_hci_event_complete(struct bt_hci_s *hci,
  437. void *ret, int len)
  438. {
  439. uint8_t *packet = bt_hci_event_start(hci, EVT_CMD_COMPLETE,
  440. len + EVT_CMD_COMPLETE_SIZE);
  441. evt_cmd_complete *params = (evt_cmd_complete *) packet;
  442. if (!packet)
  443. return;
  444. params->ncmd = 1;
  445. params->opcode = hci->last_cmd;
  446. if (len)
  447. memcpy(&packet[EVT_CMD_COMPLETE_SIZE], ret, len);
  448. hci->evt_submit(hci->opaque, len + EVT_CMD_COMPLETE_SIZE + 2);
  449. }
  450. static void bt_hci_inquiry_done(void *opaque)
  451. {
  452. struct bt_hci_s *hci = (struct bt_hci_s *) opaque;
  453. uint8_t status = HCI_SUCCESS;
  454. if (!hci->lm.periodic)
  455. hci->lm.inquire = 0;
  456. /* The specification is inconsistent about this one. Page 565 reads
  457. * "The event parameters of Inquiry Complete event will have a summary
  458. * of the result from the Inquiry process, which reports the number of
  459. * nearby Bluetooth devices that responded [so hci->responses].", but
  460. * Event Parameters (see page 729) has only Status. */
  461. bt_hci_event(hci, EVT_INQUIRY_COMPLETE, &status, 1);
  462. }
  463. static void bt_hci_inquiry_result_standard(struct bt_hci_s *hci,
  464. struct bt_device_s *slave)
  465. {
  466. inquiry_info params = {
  467. .num_responses = 1,
  468. .bdaddr = BAINIT(&slave->bd_addr),
  469. .pscan_rep_mode = 0x00, /* R0 */
  470. .pscan_period_mode = 0x00, /* P0 - deprecated */
  471. .pscan_mode = 0x00, /* Standard scan - deprecated */
  472. .dev_class[0] = slave->class[0],
  473. .dev_class[1] = slave->class[1],
  474. .dev_class[2] = slave->class[2],
  475. /* TODO: return the clkoff *differenece* */
  476. .clock_offset = slave->clkoff, /* Note: no swapping */
  477. };
  478. bt_hci_event(hci, EVT_INQUIRY_RESULT, &params, INQUIRY_INFO_SIZE);
  479. }
  480. static void bt_hci_inquiry_result_with_rssi(struct bt_hci_s *hci,
  481. struct bt_device_s *slave)
  482. {
  483. inquiry_info_with_rssi params = {
  484. .num_responses = 1,
  485. .bdaddr = BAINIT(&slave->bd_addr),
  486. .pscan_rep_mode = 0x00, /* R0 */
  487. .pscan_period_mode = 0x00, /* P0 - deprecated */
  488. .dev_class[0] = slave->class[0],
  489. .dev_class[1] = slave->class[1],
  490. .dev_class[2] = slave->class[2],
  491. /* TODO: return the clkoff *differenece* */
  492. .clock_offset = slave->clkoff, /* Note: no swapping */
  493. .rssi = DEFAULT_RSSI_DBM,
  494. };
  495. bt_hci_event(hci, EVT_INQUIRY_RESULT_WITH_RSSI,
  496. &params, INQUIRY_INFO_WITH_RSSI_SIZE);
  497. }
  498. static void bt_hci_inquiry_result(struct bt_hci_s *hci,
  499. struct bt_device_s *slave)
  500. {
  501. if (!slave->inquiry_scan || !hci->lm.responses_left)
  502. return;
  503. hci->lm.responses_left --;
  504. hci->lm.responses ++;
  505. switch (hci->lm.inquiry_mode) {
  506. case 0x00:
  507. bt_hci_inquiry_result_standard(hci, slave);
  508. return;
  509. case 0x01:
  510. bt_hci_inquiry_result_with_rssi(hci, slave);
  511. return;
  512. default:
  513. error_report("%s: bad inquiry mode %02x", __func__,
  514. hci->lm.inquiry_mode);
  515. exit(-1);
  516. }
  517. }
  518. static void bt_hci_mod_timer_1280ms(QEMUTimer *timer, int period)
  519. {
  520. timer_mod(timer, qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL) +
  521. (uint64_t)(period << 7) * 10000000);
  522. }
  523. static void bt_hci_inquiry_start(struct bt_hci_s *hci, int length)
  524. {
  525. struct bt_device_s *slave;
  526. hci->lm.inquiry_length = length;
  527. for (slave = hci->device.net->slave; slave; slave = slave->next)
  528. /* Don't uncover ourselves. */
  529. if (slave != &hci->device)
  530. bt_hci_inquiry_result(hci, slave);
  531. /* TODO: register for a callback on a new device's addition to the
  532. * scatternet so that if it's added before inquiry_length expires,
  533. * an Inquiry Result is generated immediately. Alternatively re-loop
  534. * through the devices on the inquiry_length expiration and report
  535. * devices not seen before. */
  536. if (hci->lm.responses_left)
  537. bt_hci_mod_timer_1280ms(hci->lm.inquiry_done, hci->lm.inquiry_length);
  538. else
  539. bt_hci_inquiry_done(hci);
  540. if (hci->lm.periodic)
  541. bt_hci_mod_timer_1280ms(hci->lm.inquiry_next, hci->lm.inquiry_period);
  542. }
  543. static void bt_hci_inquiry_next(void *opaque)
  544. {
  545. struct bt_hci_s *hci = (struct bt_hci_s *) opaque;
  546. hci->lm.responses_left += hci->lm.responses;
  547. hci->lm.responses = 0;
  548. bt_hci_inquiry_start(hci, hci->lm.inquiry_length);
  549. }
  550. static inline int bt_hci_handle_bad(struct bt_hci_s *hci, uint16_t handle)
  551. {
  552. return !(handle & HCI_HANDLE_OFFSET) ||
  553. handle >= (HCI_HANDLE_OFFSET | HCI_HANDLES_MAX) ||
  554. !hci->lm.handle[handle & ~HCI_HANDLE_OFFSET].link;
  555. }
  556. static inline int bt_hci_role_master(struct bt_hci_s *hci, uint16_t handle)
  557. {
  558. return !!(hci->lm.role_bmp & (1 << (handle & ~HCI_HANDLE_OFFSET)));
  559. }
  560. static inline struct bt_device_s *bt_hci_remote_dev(struct bt_hci_s *hci,
  561. uint16_t handle)
  562. {
  563. struct bt_link_s *link = hci->lm.handle[handle & ~HCI_HANDLE_OFFSET].link;
  564. return bt_hci_role_master(hci, handle) ? link->slave : link->host;
  565. }
  566. static void bt_hci_mode_tick(void *opaque);
  567. static void bt_hci_lmp_link_establish(struct bt_hci_s *hci,
  568. struct bt_link_s *link, int master)
  569. {
  570. hci->lm.handle[hci->lm.last_handle].link = link;
  571. if (master) {
  572. /* We are the master side of an ACL link */
  573. hci->lm.role_bmp |= 1 << hci->lm.last_handle;
  574. hci->lm.handle[hci->lm.last_handle].lmp_acl_data =
  575. link->slave->lmp_acl_data;
  576. } else {
  577. /* We are the slave side of an ACL link */
  578. hci->lm.role_bmp &= ~(1 << hci->lm.last_handle);
  579. hci->lm.handle[hci->lm.last_handle].lmp_acl_data =
  580. link->host->lmp_acl_resp;
  581. }
  582. /* Mode */
  583. if (master) {
  584. link->acl_mode = acl_active;
  585. hci->lm.handle[hci->lm.last_handle].acl_mode_timer =
  586. timer_new_ns(QEMU_CLOCK_VIRTUAL, bt_hci_mode_tick, link);
  587. }
  588. }
  589. static void bt_hci_lmp_link_teardown(struct bt_hci_s *hci, uint16_t handle)
  590. {
  591. handle &= ~HCI_HANDLE_OFFSET;
  592. hci->lm.handle[handle].link = NULL;
  593. if (bt_hci_role_master(hci, handle)) {
  594. timer_del(hci->lm.handle[handle].acl_mode_timer);
  595. timer_free(hci->lm.handle[handle].acl_mode_timer);
  596. }
  597. }
  598. static int bt_hci_connect(struct bt_hci_s *hci, bdaddr_t *bdaddr)
  599. {
  600. struct bt_device_s *slave;
  601. struct bt_link_s link;
  602. for (slave = hci->device.net->slave; slave; slave = slave->next)
  603. if (slave->page_scan && !bacmp(&slave->bd_addr, bdaddr))
  604. break;
  605. if (!slave || slave == &hci->device)
  606. return -ENODEV;
  607. bacpy(&hci->lm.awaiting_bdaddr[hci->lm.connecting ++], &slave->bd_addr);
  608. link.slave = slave;
  609. link.host = &hci->device;
  610. link.slave->lmp_connection_request(&link); /* Always last */
  611. return 0;
  612. }
  613. static void bt_hci_connection_reject(struct bt_hci_s *hci,
  614. struct bt_device_s *host, uint8_t because)
  615. {
  616. struct bt_link_s link = {
  617. .slave = &hci->device,
  618. .host = host,
  619. /* Rest uninitialised */
  620. };
  621. host->reject_reason = because;
  622. host->lmp_connection_complete(&link);
  623. }
  624. static void bt_hci_connection_reject_event(struct bt_hci_s *hci,
  625. bdaddr_t *bdaddr)
  626. {
  627. evt_conn_complete params;
  628. params.status = HCI_NO_CONNECTION;
  629. params.handle = 0;
  630. bacpy(&params.bdaddr, bdaddr);
  631. params.link_type = ACL_LINK;
  632. params.encr_mode = 0x00; /* Encryption not required */
  633. bt_hci_event(hci, EVT_CONN_COMPLETE, &params, EVT_CONN_COMPLETE_SIZE);
  634. }
  635. static void bt_hci_connection_accept(struct bt_hci_s *hci,
  636. struct bt_device_s *host)
  637. {
  638. struct bt_hci_link_s *link = g_malloc0(sizeof(struct bt_hci_link_s));
  639. evt_conn_complete params;
  640. uint16_t handle;
  641. uint8_t status = HCI_SUCCESS;
  642. int tries = HCI_HANDLES_MAX;
  643. /* Make a connection handle */
  644. do {
  645. while (hci->lm.handle[++ hci->lm.last_handle].link && -- tries)
  646. hci->lm.last_handle &= HCI_HANDLES_MAX - 1;
  647. handle = hci->lm.last_handle | HCI_HANDLE_OFFSET;
  648. } while ((handle == hci->asb_handle || handle == hci->psb_handle) &&
  649. tries);
  650. if (!tries) {
  651. g_free(link);
  652. bt_hci_connection_reject(hci, host, HCI_REJECTED_LIMITED_RESOURCES);
  653. status = HCI_NO_CONNECTION;
  654. goto complete;
  655. }
  656. link->btlink.slave = &hci->device;
  657. link->btlink.host = host;
  658. link->handle = handle;
  659. /* Link established */
  660. bt_hci_lmp_link_establish(hci, &link->btlink, 0);
  661. complete:
  662. params.status = status;
  663. params.handle = HNDL(handle);
  664. bacpy(&params.bdaddr, &host->bd_addr);
  665. params.link_type = ACL_LINK;
  666. params.encr_mode = 0x00; /* Encryption not required */
  667. bt_hci_event(hci, EVT_CONN_COMPLETE, &params, EVT_CONN_COMPLETE_SIZE);
  668. /* Neets to be done at the very end because it can trigger a (nested)
  669. * disconnected, in case the other and had cancelled the request
  670. * locally. */
  671. if (status == HCI_SUCCESS) {
  672. host->reject_reason = 0;
  673. host->lmp_connection_complete(&link->btlink);
  674. }
  675. }
  676. static void bt_hci_lmp_connection_request(struct bt_link_s *link)
  677. {
  678. struct bt_hci_s *hci = hci_from_device(link->slave);
  679. evt_conn_request params;
  680. if (hci->conn_req_host) {
  681. bt_hci_connection_reject(hci, link->host,
  682. HCI_REJECTED_LIMITED_RESOURCES);
  683. return;
  684. }
  685. hci->conn_req_host = link->host;
  686. /* TODO: if masked and auto-accept, then auto-accept,
  687. * if masked and not auto-accept, then auto-reject */
  688. /* TODO: kick the hci->conn_accept_timer, timeout after
  689. * hci->conn_accept_tout * 0.625 msec */
  690. bacpy(&params.bdaddr, &link->host->bd_addr);
  691. memcpy(&params.dev_class, &link->host->class, sizeof(params.dev_class));
  692. params.link_type = ACL_LINK;
  693. bt_hci_event(hci, EVT_CONN_REQUEST, &params, EVT_CONN_REQUEST_SIZE);
  694. }
  695. static void bt_hci_conn_accept_timeout(void *opaque)
  696. {
  697. struct bt_hci_s *hci = (struct bt_hci_s *) opaque;
  698. if (!hci->conn_req_host)
  699. /* Already accepted or rejected. If the other end cancelled the
  700. * connection request then we still have to reject or accept it
  701. * and then we'll get a disconnect. */
  702. return;
  703. /* TODO */
  704. }
  705. /* Remove from the list of devices which we wanted to connect to and
  706. * are awaiting a response from. If the callback sees a response from
  707. * a device which is not on the list it will assume it's a connection
  708. * that's been cancelled by the host in the meantime and immediately
  709. * try to detach the link and send a Connection Complete. */
  710. static int bt_hci_lmp_connection_ready(struct bt_hci_s *hci,
  711. bdaddr_t *bdaddr)
  712. {
  713. int i;
  714. for (i = 0; i < hci->lm.connecting; i ++)
  715. if (!bacmp(&hci->lm.awaiting_bdaddr[i], bdaddr)) {
  716. if (i < -- hci->lm.connecting)
  717. bacpy(&hci->lm.awaiting_bdaddr[i],
  718. &hci->lm.awaiting_bdaddr[hci->lm.connecting]);
  719. return 0;
  720. }
  721. return 1;
  722. }
  723. static void bt_hci_lmp_connection_complete(struct bt_link_s *link)
  724. {
  725. struct bt_hci_s *hci = hci_from_device(link->host);
  726. evt_conn_complete params;
  727. uint16_t handle;
  728. uint8_t status = HCI_SUCCESS;
  729. int tries = HCI_HANDLES_MAX;
  730. if (bt_hci_lmp_connection_ready(hci, &link->slave->bd_addr)) {
  731. if (!hci->device.reject_reason)
  732. link->slave->lmp_disconnect_slave(link);
  733. handle = 0;
  734. status = HCI_NO_CONNECTION;
  735. goto complete;
  736. }
  737. if (hci->device.reject_reason) {
  738. handle = 0;
  739. status = hci->device.reject_reason;
  740. goto complete;
  741. }
  742. /* Make a connection handle */
  743. do {
  744. while (hci->lm.handle[++ hci->lm.last_handle].link && -- tries)
  745. hci->lm.last_handle &= HCI_HANDLES_MAX - 1;
  746. handle = hci->lm.last_handle | HCI_HANDLE_OFFSET;
  747. } while ((handle == hci->asb_handle || handle == hci->psb_handle) &&
  748. tries);
  749. if (!tries) {
  750. link->slave->lmp_disconnect_slave(link);
  751. status = HCI_NO_CONNECTION;
  752. goto complete;
  753. }
  754. /* Link established */
  755. link->handle = handle;
  756. bt_hci_lmp_link_establish(hci, link, 1);
  757. complete:
  758. params.status = status;
  759. params.handle = HNDL(handle);
  760. params.link_type = ACL_LINK;
  761. bacpy(&params.bdaddr, &link->slave->bd_addr);
  762. params.encr_mode = 0x00; /* Encryption not required */
  763. bt_hci_event(hci, EVT_CONN_COMPLETE, &params, EVT_CONN_COMPLETE_SIZE);
  764. }
  765. static void bt_hci_disconnect(struct bt_hci_s *hci,
  766. uint16_t handle, int reason)
  767. {
  768. struct bt_link_s *btlink =
  769. hci->lm.handle[handle & ~HCI_HANDLE_OFFSET].link;
  770. struct bt_hci_link_s *link;
  771. evt_disconn_complete params;
  772. if (bt_hci_role_master(hci, handle)) {
  773. btlink->slave->reject_reason = reason;
  774. btlink->slave->lmp_disconnect_slave(btlink);
  775. /* The link pointer is invalid from now on */
  776. goto complete;
  777. }
  778. btlink->host->reject_reason = reason;
  779. btlink->host->lmp_disconnect_master(btlink);
  780. /* We are the slave, we get to clean this burden */
  781. link = (struct bt_hci_link_s *) btlink;
  782. g_free(link);
  783. complete:
  784. bt_hci_lmp_link_teardown(hci, handle);
  785. params.status = HCI_SUCCESS;
  786. params.handle = HNDL(handle);
  787. params.reason = HCI_CONNECTION_TERMINATED;
  788. bt_hci_event(hci, EVT_DISCONN_COMPLETE,
  789. &params, EVT_DISCONN_COMPLETE_SIZE);
  790. }
  791. /* TODO: use only one function */
  792. static void bt_hci_lmp_disconnect_host(struct bt_link_s *link)
  793. {
  794. struct bt_hci_s *hci = hci_from_device(link->host);
  795. uint16_t handle = link->handle;
  796. evt_disconn_complete params;
  797. bt_hci_lmp_link_teardown(hci, handle);
  798. params.status = HCI_SUCCESS;
  799. params.handle = HNDL(handle);
  800. params.reason = hci->device.reject_reason;
  801. bt_hci_event(hci, EVT_DISCONN_COMPLETE,
  802. &params, EVT_DISCONN_COMPLETE_SIZE);
  803. }
  804. static void bt_hci_lmp_disconnect_slave(struct bt_link_s *btlink)
  805. {
  806. struct bt_hci_link_s *link = (struct bt_hci_link_s *) btlink;
  807. struct bt_hci_s *hci = hci_from_device(btlink->slave);
  808. uint16_t handle = link->handle;
  809. evt_disconn_complete params;
  810. g_free(link);
  811. bt_hci_lmp_link_teardown(hci, handle);
  812. params.status = HCI_SUCCESS;
  813. params.handle = HNDL(handle);
  814. params.reason = hci->device.reject_reason;
  815. bt_hci_event(hci, EVT_DISCONN_COMPLETE,
  816. &params, EVT_DISCONN_COMPLETE_SIZE);
  817. }
  818. static int bt_hci_name_req(struct bt_hci_s *hci, bdaddr_t *bdaddr)
  819. {
  820. struct bt_device_s *slave;
  821. evt_remote_name_req_complete params;
  822. for (slave = hci->device.net->slave; slave; slave = slave->next)
  823. if (slave->page_scan && !bacmp(&slave->bd_addr, bdaddr))
  824. break;
  825. if (!slave)
  826. return -ENODEV;
  827. bt_hci_event_status(hci, HCI_SUCCESS);
  828. params.status = HCI_SUCCESS;
  829. bacpy(&params.bdaddr, &slave->bd_addr);
  830. pstrcpy(params.name, sizeof(params.name), slave->lmp_name ?: "");
  831. bt_hci_event(hci, EVT_REMOTE_NAME_REQ_COMPLETE,
  832. &params, EVT_REMOTE_NAME_REQ_COMPLETE_SIZE);
  833. return 0;
  834. }
  835. static int bt_hci_features_req(struct bt_hci_s *hci, uint16_t handle)
  836. {
  837. struct bt_device_s *slave;
  838. evt_read_remote_features_complete params;
  839. if (bt_hci_handle_bad(hci, handle))
  840. return -ENODEV;
  841. slave = bt_hci_remote_dev(hci, handle);
  842. bt_hci_event_status(hci, HCI_SUCCESS);
  843. params.status = HCI_SUCCESS;
  844. params.handle = HNDL(handle);
  845. params.features[0] = (slave->lmp_caps >> 0) & 0xff;
  846. params.features[1] = (slave->lmp_caps >> 8) & 0xff;
  847. params.features[2] = (slave->lmp_caps >> 16) & 0xff;
  848. params.features[3] = (slave->lmp_caps >> 24) & 0xff;
  849. params.features[4] = (slave->lmp_caps >> 32) & 0xff;
  850. params.features[5] = (slave->lmp_caps >> 40) & 0xff;
  851. params.features[6] = (slave->lmp_caps >> 48) & 0xff;
  852. params.features[7] = (slave->lmp_caps >> 56) & 0xff;
  853. bt_hci_event(hci, EVT_READ_REMOTE_FEATURES_COMPLETE,
  854. &params, EVT_READ_REMOTE_FEATURES_COMPLETE_SIZE);
  855. return 0;
  856. }
  857. static int bt_hci_version_req(struct bt_hci_s *hci, uint16_t handle)
  858. {
  859. evt_read_remote_version_complete params;
  860. if (bt_hci_handle_bad(hci, handle))
  861. return -ENODEV;
  862. bt_hci_remote_dev(hci, handle);
  863. bt_hci_event_status(hci, HCI_SUCCESS);
  864. params.status = HCI_SUCCESS;
  865. params.handle = HNDL(handle);
  866. params.lmp_ver = 0x03;
  867. params.manufacturer = cpu_to_le16(0xa000);
  868. params.lmp_subver = cpu_to_le16(0xa607);
  869. bt_hci_event(hci, EVT_READ_REMOTE_VERSION_COMPLETE,
  870. &params, EVT_READ_REMOTE_VERSION_COMPLETE_SIZE);
  871. return 0;
  872. }
  873. static int bt_hci_clkoffset_req(struct bt_hci_s *hci, uint16_t handle)
  874. {
  875. struct bt_device_s *slave;
  876. evt_read_clock_offset_complete params;
  877. if (bt_hci_handle_bad(hci, handle))
  878. return -ENODEV;
  879. slave = bt_hci_remote_dev(hci, handle);
  880. bt_hci_event_status(hci, HCI_SUCCESS);
  881. params.status = HCI_SUCCESS;
  882. params.handle = HNDL(handle);
  883. /* TODO: return the clkoff *differenece* */
  884. params.clock_offset = slave->clkoff; /* Note: no swapping */
  885. bt_hci_event(hci, EVT_READ_CLOCK_OFFSET_COMPLETE,
  886. &params, EVT_READ_CLOCK_OFFSET_COMPLETE_SIZE);
  887. return 0;
  888. }
  889. static void bt_hci_event_mode(struct bt_hci_s *hci, struct bt_link_s *link,
  890. uint16_t handle)
  891. {
  892. evt_mode_change params = {
  893. .status = HCI_SUCCESS,
  894. .handle = HNDL(handle),
  895. .mode = link->acl_mode,
  896. .interval = cpu_to_le16(link->acl_interval),
  897. };
  898. bt_hci_event(hci, EVT_MODE_CHANGE, &params, EVT_MODE_CHANGE_SIZE);
  899. }
  900. static void bt_hci_lmp_mode_change_master(struct bt_hci_s *hci,
  901. struct bt_link_s *link, int mode, uint16_t interval)
  902. {
  903. link->acl_mode = mode;
  904. link->acl_interval = interval;
  905. bt_hci_event_mode(hci, link, link->handle);
  906. link->slave->lmp_mode_change(link);
  907. }
  908. static void bt_hci_lmp_mode_change_slave(struct bt_link_s *btlink)
  909. {
  910. struct bt_hci_link_s *link = (struct bt_hci_link_s *) btlink;
  911. struct bt_hci_s *hci = hci_from_device(btlink->slave);
  912. bt_hci_event_mode(hci, btlink, link->handle);
  913. }
  914. static int bt_hci_mode_change(struct bt_hci_s *hci, uint16_t handle,
  915. int interval, int mode)
  916. {
  917. struct bt_hci_master_link_s *link;
  918. if (bt_hci_handle_bad(hci, handle) || !bt_hci_role_master(hci, handle))
  919. return -ENODEV;
  920. link = &hci->lm.handle[handle & ~HCI_HANDLE_OFFSET];
  921. if (link->link->acl_mode != acl_active) {
  922. bt_hci_event_status(hci, HCI_COMMAND_DISALLOWED);
  923. return 0;
  924. }
  925. bt_hci_event_status(hci, HCI_SUCCESS);
  926. timer_mod(link->acl_mode_timer, qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL) +
  927. ((uint64_t)interval * 625) * 1000);
  928. bt_hci_lmp_mode_change_master(hci, link->link, mode, interval);
  929. return 0;
  930. }
  931. static int bt_hci_mode_cancel(struct bt_hci_s *hci, uint16_t handle, int mode)
  932. {
  933. struct bt_hci_master_link_s *link;
  934. if (bt_hci_handle_bad(hci, handle) || !bt_hci_role_master(hci, handle))
  935. return -ENODEV;
  936. link = &hci->lm.handle[handle & ~HCI_HANDLE_OFFSET];
  937. if (link->link->acl_mode != mode) {
  938. bt_hci_event_status(hci, HCI_COMMAND_DISALLOWED);
  939. return 0;
  940. }
  941. bt_hci_event_status(hci, HCI_SUCCESS);
  942. timer_del(link->acl_mode_timer);
  943. bt_hci_lmp_mode_change_master(hci, link->link, acl_active, 0);
  944. return 0;
  945. }
  946. static void bt_hci_mode_tick(void *opaque)
  947. {
  948. struct bt_link_s *link = opaque;
  949. struct bt_hci_s *hci = hci_from_device(link->host);
  950. bt_hci_lmp_mode_change_master(hci, link, acl_active, 0);
  951. }
  952. static void bt_hci_reset(struct bt_hci_s *hci)
  953. {
  954. hci->acl_len = 0;
  955. hci->last_cmd = 0;
  956. hci->lm.connecting = 0;
  957. hci->event_mask[0] = 0xff;
  958. hci->event_mask[1] = 0xff;
  959. hci->event_mask[2] = 0xff;
  960. hci->event_mask[3] = 0xff;
  961. hci->event_mask[4] = 0xff;
  962. hci->event_mask[5] = 0x1f;
  963. hci->event_mask[6] = 0x00;
  964. hci->event_mask[7] = 0x00;
  965. hci->device.inquiry_scan = 0;
  966. hci->device.page_scan = 0;
  967. g_free((void *) hci->device.lmp_name);
  968. hci->device.lmp_name = NULL;
  969. hci->device.class[0] = 0x00;
  970. hci->device.class[1] = 0x00;
  971. hci->device.class[2] = 0x00;
  972. hci->voice_setting = 0x0000;
  973. hci->conn_accept_tout = 0x1f40;
  974. hci->lm.inquiry_mode = 0x00;
  975. hci->psb_handle = 0x000;
  976. hci->asb_handle = 0x000;
  977. /* XXX: timer_del(sl->acl_mode_timer); for all links */
  978. timer_del(hci->lm.inquiry_done);
  979. timer_del(hci->lm.inquiry_next);
  980. timer_del(hci->conn_accept_timer);
  981. }
  982. static void bt_hci_read_local_version_rp(struct bt_hci_s *hci)
  983. {
  984. read_local_version_rp lv = {
  985. .status = HCI_SUCCESS,
  986. .hci_ver = 0x03,
  987. .hci_rev = cpu_to_le16(0xa607),
  988. .lmp_ver = 0x03,
  989. .manufacturer = cpu_to_le16(0xa000),
  990. .lmp_subver = cpu_to_le16(0xa607),
  991. };
  992. bt_hci_event_complete(hci, &lv, READ_LOCAL_VERSION_RP_SIZE);
  993. }
  994. static void bt_hci_read_local_commands_rp(struct bt_hci_s *hci)
  995. {
  996. read_local_commands_rp lc = {
  997. .status = HCI_SUCCESS,
  998. .commands = {
  999. /* Keep updated! */
  1000. /* Also, keep in sync with hci->device.lmp_caps in bt_new_hci */
  1001. 0xbf, 0x80, 0xf9, 0x03, 0xb2, 0xc0, 0x03, 0xc3,
  1002. 0x00, 0x0f, 0x80, 0x00, 0xc0, 0x00, 0xe8, 0x13,
  1003. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  1004. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  1005. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  1006. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  1007. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  1008. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  1009. },
  1010. };
  1011. bt_hci_event_complete(hci, &lc, READ_LOCAL_COMMANDS_RP_SIZE);
  1012. }
  1013. static void bt_hci_read_local_features_rp(struct bt_hci_s *hci)
  1014. {
  1015. read_local_features_rp lf = {
  1016. .status = HCI_SUCCESS,
  1017. .features = {
  1018. (hci->device.lmp_caps >> 0) & 0xff,
  1019. (hci->device.lmp_caps >> 8) & 0xff,
  1020. (hci->device.lmp_caps >> 16) & 0xff,
  1021. (hci->device.lmp_caps >> 24) & 0xff,
  1022. (hci->device.lmp_caps >> 32) & 0xff,
  1023. (hci->device.lmp_caps >> 40) & 0xff,
  1024. (hci->device.lmp_caps >> 48) & 0xff,
  1025. (hci->device.lmp_caps >> 56) & 0xff,
  1026. },
  1027. };
  1028. bt_hci_event_complete(hci, &lf, READ_LOCAL_FEATURES_RP_SIZE);
  1029. }
  1030. static void bt_hci_read_local_ext_features_rp(struct bt_hci_s *hci, int page)
  1031. {
  1032. read_local_ext_features_rp lef = {
  1033. .status = HCI_SUCCESS,
  1034. .page_num = page,
  1035. .max_page_num = 0x00,
  1036. .features = {
  1037. /* Keep updated! */
  1038. 0x5f, 0x35, 0x85, 0x7e, 0x9b, 0x19, 0x00, 0x80,
  1039. },
  1040. };
  1041. if (page)
  1042. memset(lef.features, 0, sizeof(lef.features));
  1043. bt_hci_event_complete(hci, &lef, READ_LOCAL_EXT_FEATURES_RP_SIZE);
  1044. }
  1045. static void bt_hci_read_buffer_size_rp(struct bt_hci_s *hci)
  1046. {
  1047. read_buffer_size_rp bs = {
  1048. /* This can be made configurable, for one standard USB dongle HCI
  1049. * the four values are cpu_to_le16(0x0180), 0x40,
  1050. * cpu_to_le16(0x0008), cpu_to_le16(0x0008). */
  1051. .status = HCI_SUCCESS,
  1052. .acl_mtu = cpu_to_le16(0x0200),
  1053. .sco_mtu = 0,
  1054. .acl_max_pkt = cpu_to_le16(0x0001),
  1055. .sco_max_pkt = cpu_to_le16(0x0000),
  1056. };
  1057. bt_hci_event_complete(hci, &bs, READ_BUFFER_SIZE_RP_SIZE);
  1058. }
  1059. /* Deprecated in V2.0 (page 661) */
  1060. static void bt_hci_read_country_code_rp(struct bt_hci_s *hci)
  1061. {
  1062. read_country_code_rp cc ={
  1063. .status = HCI_SUCCESS,
  1064. .country_code = 0x00, /* North America & Europe^1 and Japan */
  1065. };
  1066. bt_hci_event_complete(hci, &cc, READ_COUNTRY_CODE_RP_SIZE);
  1067. /* ^1. Except France, sorry */
  1068. }
  1069. static void bt_hci_read_bd_addr_rp(struct bt_hci_s *hci)
  1070. {
  1071. read_bd_addr_rp ba = {
  1072. .status = HCI_SUCCESS,
  1073. .bdaddr = BAINIT(&hci->device.bd_addr),
  1074. };
  1075. bt_hci_event_complete(hci, &ba, READ_BD_ADDR_RP_SIZE);
  1076. }
  1077. static int bt_hci_link_quality_rp(struct bt_hci_s *hci, uint16_t handle)
  1078. {
  1079. read_link_quality_rp lq = {
  1080. .status = HCI_SUCCESS,
  1081. .handle = HNDL(handle),
  1082. .link_quality = 0xff,
  1083. };
  1084. if (bt_hci_handle_bad(hci, handle))
  1085. lq.status = HCI_NO_CONNECTION;
  1086. bt_hci_event_complete(hci, &lq, READ_LINK_QUALITY_RP_SIZE);
  1087. return 0;
  1088. }
  1089. /* Generate a Command Complete event with only the Status parameter */
  1090. static inline void bt_hci_event_complete_status(struct bt_hci_s *hci,
  1091. uint8_t status)
  1092. {
  1093. bt_hci_event_complete(hci, &status, 1);
  1094. }
  1095. static inline void bt_hci_event_complete_conn_cancel(struct bt_hci_s *hci,
  1096. uint8_t status, bdaddr_t *bd_addr)
  1097. {
  1098. create_conn_cancel_rp params = {
  1099. .status = status,
  1100. .bdaddr = BAINIT(bd_addr),
  1101. };
  1102. bt_hci_event_complete(hci, &params, CREATE_CONN_CANCEL_RP_SIZE);
  1103. }
  1104. static inline void bt_hci_event_auth_complete(struct bt_hci_s *hci,
  1105. uint16_t handle)
  1106. {
  1107. evt_auth_complete params = {
  1108. .status = HCI_SUCCESS,
  1109. .handle = HNDL(handle),
  1110. };
  1111. bt_hci_event(hci, EVT_AUTH_COMPLETE, &params, EVT_AUTH_COMPLETE_SIZE);
  1112. }
  1113. static inline void bt_hci_event_encrypt_change(struct bt_hci_s *hci,
  1114. uint16_t handle, uint8_t mode)
  1115. {
  1116. evt_encrypt_change params = {
  1117. .status = HCI_SUCCESS,
  1118. .handle = HNDL(handle),
  1119. .encrypt = mode,
  1120. };
  1121. bt_hci_event(hci, EVT_ENCRYPT_CHANGE, &params, EVT_ENCRYPT_CHANGE_SIZE);
  1122. }
  1123. static inline void bt_hci_event_complete_name_cancel(struct bt_hci_s *hci,
  1124. bdaddr_t *bd_addr)
  1125. {
  1126. remote_name_req_cancel_rp params = {
  1127. .status = HCI_INVALID_PARAMETERS,
  1128. .bdaddr = BAINIT(bd_addr),
  1129. };
  1130. bt_hci_event_complete(hci, &params, REMOTE_NAME_REQ_CANCEL_RP_SIZE);
  1131. }
  1132. static inline void bt_hci_event_read_remote_ext_features(struct bt_hci_s *hci,
  1133. uint16_t handle)
  1134. {
  1135. evt_read_remote_ext_features_complete params = {
  1136. .status = HCI_UNSUPPORTED_FEATURE,
  1137. .handle = HNDL(handle),
  1138. /* Rest uninitialised */
  1139. };
  1140. bt_hci_event(hci, EVT_READ_REMOTE_EXT_FEATURES_COMPLETE,
  1141. &params, EVT_READ_REMOTE_EXT_FEATURES_COMPLETE_SIZE);
  1142. }
  1143. static inline void bt_hci_event_complete_lmp_handle(struct bt_hci_s *hci,
  1144. uint16_t handle)
  1145. {
  1146. read_lmp_handle_rp params = {
  1147. .status = HCI_NO_CONNECTION,
  1148. .handle = HNDL(handle),
  1149. .reserved = 0,
  1150. /* Rest uninitialised */
  1151. };
  1152. bt_hci_event_complete(hci, &params, READ_LMP_HANDLE_RP_SIZE);
  1153. }
  1154. static inline void bt_hci_event_complete_role_discovery(struct bt_hci_s *hci,
  1155. int status, uint16_t handle, int master)
  1156. {
  1157. role_discovery_rp params = {
  1158. .status = status,
  1159. .handle = HNDL(handle),
  1160. .role = master ? 0x00 : 0x01,
  1161. };
  1162. bt_hci_event_complete(hci, &params, ROLE_DISCOVERY_RP_SIZE);
  1163. }
  1164. static inline void bt_hci_event_complete_flush(struct bt_hci_s *hci,
  1165. int status, uint16_t handle)
  1166. {
  1167. flush_rp params = {
  1168. .status = status,
  1169. .handle = HNDL(handle),
  1170. };
  1171. bt_hci_event_complete(hci, &params, FLUSH_RP_SIZE);
  1172. }
  1173. static inline void bt_hci_event_complete_read_local_name(struct bt_hci_s *hci)
  1174. {
  1175. read_local_name_rp params;
  1176. params.status = HCI_SUCCESS;
  1177. memset(params.name, 0, sizeof(params.name));
  1178. if (hci->device.lmp_name)
  1179. pstrcpy(params.name, sizeof(params.name), hci->device.lmp_name);
  1180. bt_hci_event_complete(hci, &params, READ_LOCAL_NAME_RP_SIZE);
  1181. }
  1182. static inline void bt_hci_event_complete_read_conn_accept_timeout(
  1183. struct bt_hci_s *hci)
  1184. {
  1185. read_conn_accept_timeout_rp params = {
  1186. .status = HCI_SUCCESS,
  1187. .timeout = cpu_to_le16(hci->conn_accept_tout),
  1188. };
  1189. bt_hci_event_complete(hci, &params, READ_CONN_ACCEPT_TIMEOUT_RP_SIZE);
  1190. }
  1191. static inline void bt_hci_event_complete_read_scan_enable(struct bt_hci_s *hci)
  1192. {
  1193. read_scan_enable_rp params = {
  1194. .status = HCI_SUCCESS,
  1195. .enable =
  1196. (hci->device.inquiry_scan ? SCAN_INQUIRY : 0) |
  1197. (hci->device.page_scan ? SCAN_PAGE : 0),
  1198. };
  1199. bt_hci_event_complete(hci, &params, READ_SCAN_ENABLE_RP_SIZE);
  1200. }
  1201. static inline void bt_hci_event_complete_read_local_class(struct bt_hci_s *hci)
  1202. {
  1203. read_class_of_dev_rp params;
  1204. params.status = HCI_SUCCESS;
  1205. memcpy(params.dev_class, hci->device.class, sizeof(params.dev_class));
  1206. bt_hci_event_complete(hci, &params, READ_CLASS_OF_DEV_RP_SIZE);
  1207. }
  1208. static inline void bt_hci_event_complete_voice_setting(struct bt_hci_s *hci)
  1209. {
  1210. read_voice_setting_rp params = {
  1211. .status = HCI_SUCCESS,
  1212. .voice_setting = hci->voice_setting, /* Note: no swapping */
  1213. };
  1214. bt_hci_event_complete(hci, &params, READ_VOICE_SETTING_RP_SIZE);
  1215. }
  1216. static inline void bt_hci_event_complete_read_inquiry_mode(
  1217. struct bt_hci_s *hci)
  1218. {
  1219. read_inquiry_mode_rp params = {
  1220. .status = HCI_SUCCESS,
  1221. .mode = hci->lm.inquiry_mode,
  1222. };
  1223. bt_hci_event_complete(hci, &params, READ_INQUIRY_MODE_RP_SIZE);
  1224. }
  1225. static inline void bt_hci_event_num_comp_pkts(struct bt_hci_s *hci,
  1226. uint16_t handle, int packets)
  1227. {
  1228. uint16_t buf[EVT_NUM_COMP_PKTS_SIZE(1) / 2 + 1];
  1229. evt_num_comp_pkts *params = (void *) ((uint8_t *) buf + 1);
  1230. params->num_hndl = 1;
  1231. params->connection->handle = HNDL(handle);
  1232. params->connection->num_packets = cpu_to_le16(packets);
  1233. bt_hci_event(hci, EVT_NUM_COMP_PKTS, params, EVT_NUM_COMP_PKTS_SIZE(1));
  1234. }
  1235. static void bt_submit_hci(struct HCIInfo *info,
  1236. const uint8_t *data, int length)
  1237. {
  1238. struct bt_hci_s *hci = hci_from_info(info);
  1239. uint16_t cmd;
  1240. int paramlen, i;
  1241. if (length < HCI_COMMAND_HDR_SIZE)
  1242. goto short_hci;
  1243. memcpy(&hci->last_cmd, data, 2);
  1244. cmd = (data[1] << 8) | data[0];
  1245. paramlen = data[2];
  1246. if (cmd_opcode_ogf(cmd) == 0 || cmd_opcode_ocf(cmd) == 0) /* NOP */
  1247. return;
  1248. data += HCI_COMMAND_HDR_SIZE;
  1249. length -= HCI_COMMAND_HDR_SIZE;
  1250. if (paramlen > length)
  1251. return;
  1252. #define PARAM(cmd, param) (((cmd##_cp *) data)->param)
  1253. #define PARAM16(cmd, param) lduw_le_p(&PARAM(cmd, param))
  1254. #define PARAMHANDLE(cmd) PARAM16(cmd, handle)
  1255. #define LENGTH_CHECK(cmd) if (length < sizeof(cmd##_cp)) goto short_hci
  1256. /* Note: the supported commands bitmask in bt_hci_read_local_commands_rp
  1257. * needs to be updated every time a command is implemented here! */
  1258. switch (cmd) {
  1259. case cmd_opcode_pack(OGF_LINK_CTL, OCF_INQUIRY):
  1260. LENGTH_CHECK(inquiry);
  1261. if (PARAM(inquiry, length) < 1) {
  1262. bt_hci_event_complete_status(hci, HCI_INVALID_PARAMETERS);
  1263. break;
  1264. }
  1265. hci->lm.inquire = 1;
  1266. hci->lm.periodic = 0;
  1267. hci->lm.responses_left = PARAM(inquiry, num_rsp) ?: INT_MAX;
  1268. hci->lm.responses = 0;
  1269. bt_hci_event_status(hci, HCI_SUCCESS);
  1270. bt_hci_inquiry_start(hci, PARAM(inquiry, length));
  1271. break;
  1272. case cmd_opcode_pack(OGF_LINK_CTL, OCF_INQUIRY_CANCEL):
  1273. if (!hci->lm.inquire || hci->lm.periodic) {
  1274. fprintf(stderr, "%s: Inquiry Cancel should only be issued after "
  1275. "the Inquiry command has been issued, a Command "
  1276. "Status event has been received for the Inquiry "
  1277. "command, and before the Inquiry Complete event "
  1278. "occurs", __func__);
  1279. bt_hci_event_complete_status(hci, HCI_COMMAND_DISALLOWED);
  1280. break;
  1281. }
  1282. hci->lm.inquire = 0;
  1283. timer_del(hci->lm.inquiry_done);
  1284. bt_hci_event_complete_status(hci, HCI_SUCCESS);
  1285. break;
  1286. case cmd_opcode_pack(OGF_LINK_CTL, OCF_PERIODIC_INQUIRY):
  1287. LENGTH_CHECK(periodic_inquiry);
  1288. if (!(PARAM(periodic_inquiry, length) <
  1289. PARAM16(periodic_inquiry, min_period) &&
  1290. PARAM16(periodic_inquiry, min_period) <
  1291. PARAM16(periodic_inquiry, max_period)) ||
  1292. PARAM(periodic_inquiry, length) < 1 ||
  1293. PARAM16(periodic_inquiry, min_period) < 2 ||
  1294. PARAM16(periodic_inquiry, max_period) < 3) {
  1295. bt_hci_event_complete_status(hci, HCI_INVALID_PARAMETERS);
  1296. break;
  1297. }
  1298. hci->lm.inquire = 1;
  1299. hci->lm.periodic = 1;
  1300. hci->lm.responses_left = PARAM(periodic_inquiry, num_rsp);
  1301. hci->lm.responses = 0;
  1302. hci->lm.inquiry_period = PARAM16(periodic_inquiry, max_period);
  1303. bt_hci_event_complete_status(hci, HCI_SUCCESS);
  1304. bt_hci_inquiry_start(hci, PARAM(periodic_inquiry, length));
  1305. break;
  1306. case cmd_opcode_pack(OGF_LINK_CTL, OCF_EXIT_PERIODIC_INQUIRY):
  1307. if (!hci->lm.inquire || !hci->lm.periodic) {
  1308. fprintf(stderr, "%s: Inquiry Cancel should only be issued after "
  1309. "the Inquiry command has been issued, a Command "
  1310. "Status event has been received for the Inquiry "
  1311. "command, and before the Inquiry Complete event "
  1312. "occurs", __func__);
  1313. bt_hci_event_complete_status(hci, HCI_COMMAND_DISALLOWED);
  1314. break;
  1315. }
  1316. hci->lm.inquire = 0;
  1317. timer_del(hci->lm.inquiry_done);
  1318. timer_del(hci->lm.inquiry_next);
  1319. bt_hci_event_complete_status(hci, HCI_SUCCESS);
  1320. break;
  1321. case cmd_opcode_pack(OGF_LINK_CTL, OCF_CREATE_CONN):
  1322. LENGTH_CHECK(create_conn);
  1323. if (hci->lm.connecting >= HCI_HANDLES_MAX) {
  1324. bt_hci_event_status(hci, HCI_REJECTED_LIMITED_RESOURCES);
  1325. break;
  1326. }
  1327. bt_hci_event_status(hci, HCI_SUCCESS);
  1328. if (bt_hci_connect(hci, &PARAM(create_conn, bdaddr)))
  1329. bt_hci_connection_reject_event(hci, &PARAM(create_conn, bdaddr));
  1330. break;
  1331. case cmd_opcode_pack(OGF_LINK_CTL, OCF_DISCONNECT):
  1332. LENGTH_CHECK(disconnect);
  1333. if (bt_hci_handle_bad(hci, PARAMHANDLE(disconnect))) {
  1334. bt_hci_event_status(hci, HCI_NO_CONNECTION);
  1335. break;
  1336. }
  1337. bt_hci_event_status(hci, HCI_SUCCESS);
  1338. bt_hci_disconnect(hci, PARAMHANDLE(disconnect),
  1339. PARAM(disconnect, reason));
  1340. break;
  1341. case cmd_opcode_pack(OGF_LINK_CTL, OCF_CREATE_CONN_CANCEL):
  1342. LENGTH_CHECK(create_conn_cancel);
  1343. if (bt_hci_lmp_connection_ready(hci,
  1344. &PARAM(create_conn_cancel, bdaddr))) {
  1345. for (i = 0; i < HCI_HANDLES_MAX; i ++)
  1346. if (bt_hci_role_master(hci, i) && hci->lm.handle[i].link &&
  1347. !bacmp(&hci->lm.handle[i].link->slave->bd_addr,
  1348. &PARAM(create_conn_cancel, bdaddr)))
  1349. break;
  1350. bt_hci_event_complete_conn_cancel(hci, i < HCI_HANDLES_MAX ?
  1351. HCI_ACL_CONNECTION_EXISTS : HCI_NO_CONNECTION,
  1352. &PARAM(create_conn_cancel, bdaddr));
  1353. } else
  1354. bt_hci_event_complete_conn_cancel(hci, HCI_SUCCESS,
  1355. &PARAM(create_conn_cancel, bdaddr));
  1356. break;
  1357. case cmd_opcode_pack(OGF_LINK_CTL, OCF_ACCEPT_CONN_REQ):
  1358. LENGTH_CHECK(accept_conn_req);
  1359. if (!hci->conn_req_host ||
  1360. bacmp(&PARAM(accept_conn_req, bdaddr),
  1361. &hci->conn_req_host->bd_addr)) {
  1362. bt_hci_event_status(hci, HCI_INVALID_PARAMETERS);
  1363. break;
  1364. }
  1365. bt_hci_event_status(hci, HCI_SUCCESS);
  1366. bt_hci_connection_accept(hci, hci->conn_req_host);
  1367. hci->conn_req_host = NULL;
  1368. break;
  1369. case cmd_opcode_pack(OGF_LINK_CTL, OCF_REJECT_CONN_REQ):
  1370. LENGTH_CHECK(reject_conn_req);
  1371. if (!hci->conn_req_host ||
  1372. bacmp(&PARAM(reject_conn_req, bdaddr),
  1373. &hci->conn_req_host->bd_addr)) {
  1374. bt_hci_event_status(hci, HCI_INVALID_PARAMETERS);
  1375. break;
  1376. }
  1377. bt_hci_event_status(hci, HCI_SUCCESS);
  1378. bt_hci_connection_reject(hci, hci->conn_req_host,
  1379. PARAM(reject_conn_req, reason));
  1380. bt_hci_connection_reject_event(hci, &hci->conn_req_host->bd_addr);
  1381. hci->conn_req_host = NULL;
  1382. break;
  1383. case cmd_opcode_pack(OGF_LINK_CTL, OCF_AUTH_REQUESTED):
  1384. LENGTH_CHECK(auth_requested);
  1385. if (bt_hci_handle_bad(hci, PARAMHANDLE(auth_requested)))
  1386. bt_hci_event_status(hci, HCI_NO_CONNECTION);
  1387. else {
  1388. bt_hci_event_status(hci, HCI_SUCCESS);
  1389. bt_hci_event_auth_complete(hci, PARAMHANDLE(auth_requested));
  1390. }
  1391. break;
  1392. case cmd_opcode_pack(OGF_LINK_CTL, OCF_SET_CONN_ENCRYPT):
  1393. LENGTH_CHECK(set_conn_encrypt);
  1394. if (bt_hci_handle_bad(hci, PARAMHANDLE(set_conn_encrypt)))
  1395. bt_hci_event_status(hci, HCI_NO_CONNECTION);
  1396. else {
  1397. bt_hci_event_status(hci, HCI_SUCCESS);
  1398. bt_hci_event_encrypt_change(hci,
  1399. PARAMHANDLE(set_conn_encrypt),
  1400. PARAM(set_conn_encrypt, encrypt));
  1401. }
  1402. break;
  1403. case cmd_opcode_pack(OGF_LINK_CTL, OCF_REMOTE_NAME_REQ):
  1404. LENGTH_CHECK(remote_name_req);
  1405. if (bt_hci_name_req(hci, &PARAM(remote_name_req, bdaddr)))
  1406. bt_hci_event_status(hci, HCI_NO_CONNECTION);
  1407. break;
  1408. case cmd_opcode_pack(OGF_LINK_CTL, OCF_REMOTE_NAME_REQ_CANCEL):
  1409. LENGTH_CHECK(remote_name_req_cancel);
  1410. bt_hci_event_complete_name_cancel(hci,
  1411. &PARAM(remote_name_req_cancel, bdaddr));
  1412. break;
  1413. case cmd_opcode_pack(OGF_LINK_CTL, OCF_READ_REMOTE_FEATURES):
  1414. LENGTH_CHECK(read_remote_features);
  1415. if (bt_hci_features_req(hci, PARAMHANDLE(read_remote_features)))
  1416. bt_hci_event_status(hci, HCI_NO_CONNECTION);
  1417. break;
  1418. case cmd_opcode_pack(OGF_LINK_CTL, OCF_READ_REMOTE_EXT_FEATURES):
  1419. LENGTH_CHECK(read_remote_ext_features);
  1420. if (bt_hci_handle_bad(hci, PARAMHANDLE(read_remote_ext_features)))
  1421. bt_hci_event_status(hci, HCI_NO_CONNECTION);
  1422. else {
  1423. bt_hci_event_status(hci, HCI_SUCCESS);
  1424. bt_hci_event_read_remote_ext_features(hci,
  1425. PARAMHANDLE(read_remote_ext_features));
  1426. }
  1427. break;
  1428. case cmd_opcode_pack(OGF_LINK_CTL, OCF_READ_REMOTE_VERSION):
  1429. LENGTH_CHECK(read_remote_version);
  1430. if (bt_hci_version_req(hci, PARAMHANDLE(read_remote_version)))
  1431. bt_hci_event_status(hci, HCI_NO_CONNECTION);
  1432. break;
  1433. case cmd_opcode_pack(OGF_LINK_CTL, OCF_READ_CLOCK_OFFSET):
  1434. LENGTH_CHECK(read_clock_offset);
  1435. if (bt_hci_clkoffset_req(hci, PARAMHANDLE(read_clock_offset)))
  1436. bt_hci_event_status(hci, HCI_NO_CONNECTION);
  1437. break;
  1438. case cmd_opcode_pack(OGF_LINK_CTL, OCF_READ_LMP_HANDLE):
  1439. LENGTH_CHECK(read_lmp_handle);
  1440. /* TODO: */
  1441. bt_hci_event_complete_lmp_handle(hci, PARAMHANDLE(read_lmp_handle));
  1442. break;
  1443. case cmd_opcode_pack(OGF_LINK_POLICY, OCF_HOLD_MODE):
  1444. LENGTH_CHECK(hold_mode);
  1445. if (PARAM16(hold_mode, min_interval) >
  1446. PARAM16(hold_mode, max_interval) ||
  1447. PARAM16(hold_mode, min_interval) < 0x0002 ||
  1448. PARAM16(hold_mode, max_interval) > 0xff00 ||
  1449. (PARAM16(hold_mode, min_interval) & 1) ||
  1450. (PARAM16(hold_mode, max_interval) & 1)) {
  1451. bt_hci_event_status(hci, HCI_INVALID_PARAMETERS);
  1452. break;
  1453. }
  1454. if (bt_hci_mode_change(hci, PARAMHANDLE(hold_mode),
  1455. PARAM16(hold_mode, max_interval),
  1456. acl_hold))
  1457. bt_hci_event_status(hci, HCI_NO_CONNECTION);
  1458. break;
  1459. case cmd_opcode_pack(OGF_LINK_POLICY, OCF_PARK_MODE):
  1460. LENGTH_CHECK(park_mode);
  1461. if (PARAM16(park_mode, min_interval) >
  1462. PARAM16(park_mode, max_interval) ||
  1463. PARAM16(park_mode, min_interval) < 0x000e ||
  1464. (PARAM16(park_mode, min_interval) & 1) ||
  1465. (PARAM16(park_mode, max_interval) & 1)) {
  1466. bt_hci_event_status(hci, HCI_INVALID_PARAMETERS);
  1467. break;
  1468. }
  1469. if (bt_hci_mode_change(hci, PARAMHANDLE(park_mode),
  1470. PARAM16(park_mode, max_interval),
  1471. acl_parked))
  1472. bt_hci_event_status(hci, HCI_NO_CONNECTION);
  1473. break;
  1474. case cmd_opcode_pack(OGF_LINK_POLICY, OCF_EXIT_PARK_MODE):
  1475. LENGTH_CHECK(exit_park_mode);
  1476. if (bt_hci_mode_cancel(hci, PARAMHANDLE(exit_park_mode),
  1477. acl_parked))
  1478. bt_hci_event_status(hci, HCI_NO_CONNECTION);
  1479. break;
  1480. case cmd_opcode_pack(OGF_LINK_POLICY, OCF_ROLE_DISCOVERY):
  1481. LENGTH_CHECK(role_discovery);
  1482. if (bt_hci_handle_bad(hci, PARAMHANDLE(role_discovery)))
  1483. bt_hci_event_complete_role_discovery(hci,
  1484. HCI_NO_CONNECTION, PARAMHANDLE(role_discovery), 0);
  1485. else
  1486. bt_hci_event_complete_role_discovery(hci,
  1487. HCI_SUCCESS, PARAMHANDLE(role_discovery),
  1488. bt_hci_role_master(hci,
  1489. PARAMHANDLE(role_discovery)));
  1490. break;
  1491. case cmd_opcode_pack(OGF_HOST_CTL, OCF_SET_EVENT_MASK):
  1492. LENGTH_CHECK(set_event_mask);
  1493. memcpy(hci->event_mask, PARAM(set_event_mask, mask), 8);
  1494. bt_hci_event_complete_status(hci, HCI_SUCCESS);
  1495. break;
  1496. case cmd_opcode_pack(OGF_HOST_CTL, OCF_RESET):
  1497. bt_hci_reset(hci);
  1498. bt_hci_event_status(hci, HCI_SUCCESS);
  1499. break;
  1500. case cmd_opcode_pack(OGF_HOST_CTL, OCF_SET_EVENT_FLT):
  1501. if (length >= 1 && PARAM(set_event_flt, flt_type) == FLT_CLEAR_ALL)
  1502. /* No length check */;
  1503. else
  1504. LENGTH_CHECK(set_event_flt);
  1505. /* Filters are not implemented */
  1506. bt_hci_event_complete_status(hci, HCI_SUCCESS);
  1507. break;
  1508. case cmd_opcode_pack(OGF_HOST_CTL, OCF_FLUSH):
  1509. LENGTH_CHECK(flush);
  1510. if (bt_hci_handle_bad(hci, PARAMHANDLE(flush)))
  1511. bt_hci_event_complete_flush(hci,
  1512. HCI_NO_CONNECTION, PARAMHANDLE(flush));
  1513. else {
  1514. /* TODO: ordering? */
  1515. bt_hci_event(hci, EVT_FLUSH_OCCURRED,
  1516. &PARAM(flush, handle),
  1517. EVT_FLUSH_OCCURRED_SIZE);
  1518. bt_hci_event_complete_flush(hci,
  1519. HCI_SUCCESS, PARAMHANDLE(flush));
  1520. }
  1521. break;
  1522. case cmd_opcode_pack(OGF_HOST_CTL, OCF_CHANGE_LOCAL_NAME):
  1523. LENGTH_CHECK(change_local_name);
  1524. g_free((void *) hci->device.lmp_name);
  1525. hci->device.lmp_name = g_strndup(PARAM(change_local_name, name),
  1526. sizeof(PARAM(change_local_name, name)));
  1527. bt_hci_event_complete_status(hci, HCI_SUCCESS);
  1528. break;
  1529. case cmd_opcode_pack(OGF_HOST_CTL, OCF_READ_LOCAL_NAME):
  1530. bt_hci_event_complete_read_local_name(hci);
  1531. break;
  1532. case cmd_opcode_pack(OGF_HOST_CTL, OCF_READ_CONN_ACCEPT_TIMEOUT):
  1533. bt_hci_event_complete_read_conn_accept_timeout(hci);
  1534. break;
  1535. case cmd_opcode_pack(OGF_HOST_CTL, OCF_WRITE_CONN_ACCEPT_TIMEOUT):
  1536. /* TODO */
  1537. LENGTH_CHECK(write_conn_accept_timeout);
  1538. if (PARAM16(write_conn_accept_timeout, timeout) < 0x0001 ||
  1539. PARAM16(write_conn_accept_timeout, timeout) > 0xb540) {
  1540. bt_hci_event_complete_status(hci, HCI_INVALID_PARAMETERS);
  1541. break;
  1542. }
  1543. hci->conn_accept_tout = PARAM16(write_conn_accept_timeout, timeout);
  1544. bt_hci_event_complete_status(hci, HCI_SUCCESS);
  1545. break;
  1546. case cmd_opcode_pack(OGF_HOST_CTL, OCF_READ_SCAN_ENABLE):
  1547. bt_hci_event_complete_read_scan_enable(hci);
  1548. break;
  1549. case cmd_opcode_pack(OGF_HOST_CTL, OCF_WRITE_SCAN_ENABLE):
  1550. LENGTH_CHECK(write_scan_enable);
  1551. /* TODO: check that the remaining bits are all 0 */
  1552. hci->device.inquiry_scan =
  1553. !!(PARAM(write_scan_enable, scan_enable) & SCAN_INQUIRY);
  1554. hci->device.page_scan =
  1555. !!(PARAM(write_scan_enable, scan_enable) & SCAN_PAGE);
  1556. bt_hci_event_complete_status(hci, HCI_SUCCESS);
  1557. break;
  1558. case cmd_opcode_pack(OGF_HOST_CTL, OCF_READ_CLASS_OF_DEV):
  1559. bt_hci_event_complete_read_local_class(hci);
  1560. break;
  1561. case cmd_opcode_pack(OGF_HOST_CTL, OCF_WRITE_CLASS_OF_DEV):
  1562. LENGTH_CHECK(write_class_of_dev);
  1563. memcpy(hci->device.class, PARAM(write_class_of_dev, dev_class),
  1564. sizeof(PARAM(write_class_of_dev, dev_class)));
  1565. bt_hci_event_complete_status(hci, HCI_SUCCESS);
  1566. break;
  1567. case cmd_opcode_pack(OGF_HOST_CTL, OCF_READ_VOICE_SETTING):
  1568. bt_hci_event_complete_voice_setting(hci);
  1569. break;
  1570. case cmd_opcode_pack(OGF_HOST_CTL, OCF_WRITE_VOICE_SETTING):
  1571. LENGTH_CHECK(write_voice_setting);
  1572. hci->voice_setting = PARAM(write_voice_setting, voice_setting);
  1573. bt_hci_event_complete_status(hci, HCI_SUCCESS);
  1574. break;
  1575. case cmd_opcode_pack(OGF_HOST_CTL, OCF_HOST_NUMBER_OF_COMPLETED_PACKETS):
  1576. if (length < data[0] * 2 + 1)
  1577. goto short_hci;
  1578. for (i = 0; i < data[0]; i ++)
  1579. if (bt_hci_handle_bad(hci,
  1580. data[i * 2 + 1] | (data[i * 2 + 2] << 8)))
  1581. bt_hci_event_complete_status(hci, HCI_INVALID_PARAMETERS);
  1582. break;
  1583. case cmd_opcode_pack(OGF_HOST_CTL, OCF_READ_INQUIRY_MODE):
  1584. /* Only if (local_features[3] & 0x40) && (local_commands[12] & 0x40)
  1585. * else
  1586. * goto unknown_command */
  1587. bt_hci_event_complete_read_inquiry_mode(hci);
  1588. break;
  1589. case cmd_opcode_pack(OGF_HOST_CTL, OCF_WRITE_INQUIRY_MODE):
  1590. /* Only if (local_features[3] & 0x40) && (local_commands[12] & 0x80)
  1591. * else
  1592. * goto unknown_command */
  1593. LENGTH_CHECK(write_inquiry_mode);
  1594. if (PARAM(write_inquiry_mode, mode) > 0x01) {
  1595. bt_hci_event_complete_status(hci, HCI_INVALID_PARAMETERS);
  1596. break;
  1597. }
  1598. hci->lm.inquiry_mode = PARAM(write_inquiry_mode, mode);
  1599. bt_hci_event_complete_status(hci, HCI_SUCCESS);
  1600. break;
  1601. case cmd_opcode_pack(OGF_INFO_PARAM, OCF_READ_LOCAL_VERSION):
  1602. bt_hci_read_local_version_rp(hci);
  1603. break;
  1604. case cmd_opcode_pack(OGF_INFO_PARAM, OCF_READ_LOCAL_COMMANDS):
  1605. bt_hci_read_local_commands_rp(hci);
  1606. break;
  1607. case cmd_opcode_pack(OGF_INFO_PARAM, OCF_READ_LOCAL_FEATURES):
  1608. bt_hci_read_local_features_rp(hci);
  1609. break;
  1610. case cmd_opcode_pack(OGF_INFO_PARAM, OCF_READ_LOCAL_EXT_FEATURES):
  1611. LENGTH_CHECK(read_local_ext_features);
  1612. bt_hci_read_local_ext_features_rp(hci,
  1613. PARAM(read_local_ext_features, page_num));
  1614. break;
  1615. case cmd_opcode_pack(OGF_INFO_PARAM, OCF_READ_BUFFER_SIZE):
  1616. bt_hci_read_buffer_size_rp(hci);
  1617. break;
  1618. case cmd_opcode_pack(OGF_INFO_PARAM, OCF_READ_COUNTRY_CODE):
  1619. bt_hci_read_country_code_rp(hci);
  1620. break;
  1621. case cmd_opcode_pack(OGF_INFO_PARAM, OCF_READ_BD_ADDR):
  1622. bt_hci_read_bd_addr_rp(hci);
  1623. break;
  1624. case cmd_opcode_pack(OGF_STATUS_PARAM, OCF_READ_LINK_QUALITY):
  1625. LENGTH_CHECK(read_link_quality);
  1626. bt_hci_link_quality_rp(hci, PARAMHANDLE(read_link_quality));
  1627. break;
  1628. default:
  1629. bt_hci_event_status(hci, HCI_UNKNOWN_COMMAND);
  1630. break;
  1631. short_hci:
  1632. error_report("%s: HCI packet too short (%iB)", __func__, length);
  1633. bt_hci_event_status(hci, HCI_INVALID_PARAMETERS);
  1634. break;
  1635. }
  1636. }
  1637. /* We could perform fragmentation here, we can't do "recombination" because
  1638. * at this layer the length of the payload is not know ahead, so we only
  1639. * know that a packet contained the last fragment of the SDU when the next
  1640. * SDU starts. */
  1641. static inline void bt_hci_lmp_acl_data(struct bt_hci_s *hci, uint16_t handle,
  1642. const uint8_t *data, int start, int len)
  1643. {
  1644. struct hci_acl_hdr *pkt = (void *) hci->acl_buf;
  1645. /* TODO: packet flags */
  1646. /* TODO: avoid memcpy'ing */
  1647. if (len + HCI_ACL_HDR_SIZE > sizeof(hci->acl_buf)) {
  1648. error_report("%s: can't take ACL packets %i bytes long",
  1649. __func__, len);
  1650. return;
  1651. }
  1652. memcpy(hci->acl_buf + HCI_ACL_HDR_SIZE, data, len);
  1653. pkt->handle = cpu_to_le16(
  1654. acl_handle_pack(handle, start ? ACL_START : ACL_CONT));
  1655. pkt->dlen = cpu_to_le16(len);
  1656. hci->info.acl_recv(hci->info.opaque,
  1657. hci->acl_buf, len + HCI_ACL_HDR_SIZE);
  1658. }
  1659. static void bt_hci_lmp_acl_data_slave(struct bt_link_s *btlink,
  1660. const uint8_t *data, int start, int len)
  1661. {
  1662. struct bt_hci_link_s *link = (struct bt_hci_link_s *) btlink;
  1663. bt_hci_lmp_acl_data(hci_from_device(btlink->slave),
  1664. link->handle, data, start, len);
  1665. }
  1666. static void bt_hci_lmp_acl_data_host(struct bt_link_s *link,
  1667. const uint8_t *data, int start, int len)
  1668. {
  1669. bt_hci_lmp_acl_data(hci_from_device(link->host),
  1670. link->handle, data, start, len);
  1671. }
  1672. static void bt_submit_acl(struct HCIInfo *info,
  1673. const uint8_t *data, int length)
  1674. {
  1675. struct bt_hci_s *hci = hci_from_info(info);
  1676. uint16_t handle;
  1677. int datalen, flags;
  1678. struct bt_link_s *link;
  1679. if (length < HCI_ACL_HDR_SIZE) {
  1680. error_report("%s: ACL packet too short (%iB)", __func__, length);
  1681. return;
  1682. }
  1683. handle = acl_handle((data[1] << 8) | data[0]);
  1684. flags = acl_flags((data[1] << 8) | data[0]);
  1685. datalen = (data[3] << 8) | data[2];
  1686. data += HCI_ACL_HDR_SIZE;
  1687. length -= HCI_ACL_HDR_SIZE;
  1688. if (bt_hci_handle_bad(hci, handle)) {
  1689. error_report("%s: invalid ACL handle %03x", __func__, handle);
  1690. /* TODO: signal an error */
  1691. return;
  1692. }
  1693. handle &= ~HCI_HANDLE_OFFSET;
  1694. if (datalen > length) {
  1695. error_report("%s: ACL packet too short (%iB < %iB)",
  1696. __func__, length, datalen);
  1697. return;
  1698. }
  1699. link = hci->lm.handle[handle].link;
  1700. if ((flags & ~3) == ACL_ACTIVE_BCAST) {
  1701. if (!hci->asb_handle)
  1702. hci->asb_handle = handle;
  1703. else if (handle != hci->asb_handle) {
  1704. error_report("%s: Bad handle %03x in Active Slave Broadcast",
  1705. __func__, handle);
  1706. /* TODO: signal an error */
  1707. return;
  1708. }
  1709. /* TODO */
  1710. }
  1711. if ((flags & ~3) == ACL_PICO_BCAST) {
  1712. if (!hci->psb_handle)
  1713. hci->psb_handle = handle;
  1714. else if (handle != hci->psb_handle) {
  1715. error_report("%s: Bad handle %03x in Parked Slave Broadcast",
  1716. __func__, handle);
  1717. /* TODO: signal an error */
  1718. return;
  1719. }
  1720. /* TODO */
  1721. }
  1722. /* TODO: increase counter and send EVT_NUM_COMP_PKTS */
  1723. bt_hci_event_num_comp_pkts(hci, handle | HCI_HANDLE_OFFSET, 1);
  1724. /* Do this last as it can trigger further events even in this HCI */
  1725. hci->lm.handle[handle].lmp_acl_data(link, data,
  1726. (flags & 3) == ACL_START, length);
  1727. }
  1728. static void bt_submit_sco(struct HCIInfo *info,
  1729. const uint8_t *data, int length)
  1730. {
  1731. struct bt_hci_s *hci = hci_from_info(info);
  1732. uint16_t handle;
  1733. int datalen;
  1734. if (length < 3)
  1735. return;
  1736. handle = acl_handle((data[1] << 8) | data[0]);
  1737. datalen = data[2];
  1738. length -= 3;
  1739. if (bt_hci_handle_bad(hci, handle)) {
  1740. error_report("%s: invalid SCO handle %03x", __func__, handle);
  1741. return;
  1742. }
  1743. if (datalen > length) {
  1744. error_report("%s: SCO packet too short (%iB < %iB)",
  1745. __func__, length, datalen);
  1746. return;
  1747. }
  1748. /* TODO */
  1749. /* TODO: increase counter and send EVT_NUM_COMP_PKTS if synchronous
  1750. * Flow Control is enabled.
  1751. * (See Read/Write_Synchronous_Flow_Control_Enable on page 513 and
  1752. * page 514.) */
  1753. }
  1754. static uint8_t *bt_hci_evt_packet(void *opaque)
  1755. {
  1756. /* TODO: allocate a packet from upper layer */
  1757. struct bt_hci_s *s = opaque;
  1758. return s->evt_buf;
  1759. }
  1760. static void bt_hci_evt_submit(void *opaque, int len)
  1761. {
  1762. /* TODO: notify upper layer */
  1763. struct bt_hci_s *s = opaque;
  1764. s->info.evt_recv(s->info.opaque, s->evt_buf, len);
  1765. }
  1766. static int bt_hci_bdaddr_set(struct HCIInfo *info, const uint8_t *bd_addr)
  1767. {
  1768. struct bt_hci_s *hci = hci_from_info(info);
  1769. bacpy(&hci->device.bd_addr, (const bdaddr_t *) bd_addr);
  1770. return 0;
  1771. }
  1772. static void bt_hci_done(struct HCIInfo *info);
  1773. static void bt_hci_destroy(struct bt_device_s *dev)
  1774. {
  1775. struct bt_hci_s *hci = hci_from_device(dev);
  1776. bt_hci_done(&hci->info);
  1777. }
  1778. struct HCIInfo *bt_new_hci(struct bt_scatternet_s *net)
  1779. {
  1780. struct bt_hci_s *s = g_malloc0(sizeof(struct bt_hci_s));
  1781. s->lm.inquiry_done = timer_new_ns(QEMU_CLOCK_VIRTUAL, bt_hci_inquiry_done, s);
  1782. s->lm.inquiry_next = timer_new_ns(QEMU_CLOCK_VIRTUAL, bt_hci_inquiry_next, s);
  1783. s->conn_accept_timer =
  1784. timer_new_ns(QEMU_CLOCK_VIRTUAL, bt_hci_conn_accept_timeout, s);
  1785. s->evt_packet = bt_hci_evt_packet;
  1786. s->evt_submit = bt_hci_evt_submit;
  1787. s->opaque = s;
  1788. bt_device_init(&s->device, net);
  1789. s->device.lmp_connection_request = bt_hci_lmp_connection_request;
  1790. s->device.lmp_connection_complete = bt_hci_lmp_connection_complete;
  1791. s->device.lmp_disconnect_master = bt_hci_lmp_disconnect_host;
  1792. s->device.lmp_disconnect_slave = bt_hci_lmp_disconnect_slave;
  1793. s->device.lmp_acl_data = bt_hci_lmp_acl_data_slave;
  1794. s->device.lmp_acl_resp = bt_hci_lmp_acl_data_host;
  1795. s->device.lmp_mode_change = bt_hci_lmp_mode_change_slave;
  1796. /* Keep updated! */
  1797. /* Also keep in sync with supported commands bitmask in
  1798. * bt_hci_read_local_commands_rp */
  1799. s->device.lmp_caps = 0x8000199b7e85355fll;
  1800. bt_hci_reset(s);
  1801. s->info.cmd_send = bt_submit_hci;
  1802. s->info.sco_send = bt_submit_sco;
  1803. s->info.acl_send = bt_submit_acl;
  1804. s->info.bdaddr_set = bt_hci_bdaddr_set;
  1805. s->device.handle_destroy = bt_hci_destroy;
  1806. error_setg(&s->replay_blocker, QERR_REPLAY_NOT_SUPPORTED, "-bt hci");
  1807. replay_add_blocker(s->replay_blocker);
  1808. return &s->info;
  1809. }
  1810. struct HCIInfo *hci_init(const char *str)
  1811. {
  1812. char *endp;
  1813. struct bt_scatternet_s *vlan = 0;
  1814. if (!strcmp(str, "null"))
  1815. /* null */
  1816. return &null_hci;
  1817. else if (!strncmp(str, "host", 4) && (str[4] == '\0' || str[4] == ':'))
  1818. /* host[:hciN] */
  1819. return bt_host_hci(str[4] ? str + 5 : "hci0");
  1820. else if (!strncmp(str, "hci", 3)) {
  1821. /* hci[,vlan=n] */
  1822. if (str[3]) {
  1823. if (!strncmp(str + 3, ",vlan=", 6)) {
  1824. vlan = qemu_find_bt_vlan(strtol(str + 9, &endp, 0));
  1825. if (*endp)
  1826. vlan = 0;
  1827. }
  1828. } else
  1829. vlan = qemu_find_bt_vlan(0);
  1830. if (vlan)
  1831. return bt_new_hci(vlan);
  1832. }
  1833. error_report("Unknown bluetooth HCI `%s'.", str);
  1834. return 0;
  1835. }
  1836. static void bt_hci_done(struct HCIInfo *info)
  1837. {
  1838. struct bt_hci_s *hci = hci_from_info(info);
  1839. int handle;
  1840. bt_device_done(&hci->device);
  1841. g_free((void *) hci->device.lmp_name);
  1842. /* Be gentle and send DISCONNECT to all connected peers and those
  1843. * currently waiting for us to accept or reject a connection request.
  1844. * This frees the links. */
  1845. if (hci->conn_req_host) {
  1846. bt_hci_connection_reject(hci,
  1847. hci->conn_req_host, HCI_OE_POWER_OFF);
  1848. return;
  1849. }
  1850. for (handle = HCI_HANDLE_OFFSET;
  1851. handle < (HCI_HANDLE_OFFSET | HCI_HANDLES_MAX); handle ++)
  1852. if (!bt_hci_handle_bad(hci, handle))
  1853. bt_hci_disconnect(hci, handle, HCI_OE_POWER_OFF);
  1854. /* TODO: this is not enough actually, there may be slaves from whom
  1855. * we have requested a connection who will soon (or not) respond with
  1856. * an accept or a reject, so we should also check if hci->lm.connecting
  1857. * is non-zero and if so, avoid freeing the hci but otherwise disappear
  1858. * from all qemu social life (e.g. stop scanning and request to be
  1859. * removed from s->device.net) and arrange for
  1860. * s->device.lmp_connection_complete to free the remaining bits once
  1861. * hci->lm.awaiting_bdaddr[] is empty. */
  1862. timer_free(hci->lm.inquiry_done);
  1863. timer_free(hci->lm.inquiry_next);
  1864. timer_free(hci->conn_accept_timer);
  1865. g_free(hci);
  1866. }