1 | <!doctype html>
|
---|
2 | <html>
|
---|
3 | <head>
|
---|
4 | <title>/home/haiku/haiku/haiku/src/add-ons/kernel/drivers/bluetooth/h2/h2generic/h2generic.cpp</title>
|
---|
5 | <style type="text/css">
|
---|
6 | body { color:#000000; background-color:#ffffff }
|
---|
7 | body { font-family:Helvetica, sans-serif; font-size:10pt }
|
---|
8 | h1 { font-size:14pt }
|
---|
9 | .code { border-collapse:collapse; width:100%; }
|
---|
10 | .code { font-family: "Monospace", monospace; font-size:10pt }
|
---|
11 | .code { line-height: 1.2em }
|
---|
12 | .comment { color: green; font-style: oblique }
|
---|
13 | .keyword { color: blue }
|
---|
14 | .string_literal { color: red }
|
---|
15 | .directive { color: darkmagenta }
|
---|
16 | .expansion { display: none; }
|
---|
17 | .macro:hover .expansion { display: block; border: 2px solid #FF0000; padding: 2px; background-color:#FFF0F0; font-weight: normal; -webkit-border-radius:5px; -webkit-box-shadow:1px 1px 7px #000; border-radius:5px; box-shadow:1px 1px 7px #000; position: absolute; top: -1em; left:10em; z-index: 1 }
|
---|
18 | .macro { color: darkmagenta; background-color:LemonChiffon; position: relative }
|
---|
19 | .num { width:2.5em; padding-right:2ex; background-color:#eeeeee }
|
---|
20 | .num { text-align:right; font-size:8pt }
|
---|
21 | .num { color:#444444 }
|
---|
22 | .line { padding-left: 1ex; border-left: 3px solid #ccc }
|
---|
23 | .line { white-space: pre }
|
---|
24 | .msg { -webkit-box-shadow:1px 1px 7px #000 }
|
---|
25 | .msg { box-shadow:1px 1px 7px #000 }
|
---|
26 | .msg { -webkit-border-radius:5px }
|
---|
27 | .msg { border-radius:5px }
|
---|
28 | .msg { font-family:Helvetica, sans-serif; font-size:8pt }
|
---|
29 | .msg { float:left }
|
---|
30 | .msg { padding:0.25em 1ex 0.25em 1ex }
|
---|
31 | .msg { margin-top:10px; margin-bottom:10px }
|
---|
32 | .msg { font-weight:bold }
|
---|
33 | .msg { max-width:60em; word-wrap: break-word; white-space: pre-wrap }
|
---|
34 | .msgT { padding:0x; spacing:0x }
|
---|
35 | .msgEvent { background-color:#fff8b4; color:#000000 }
|
---|
36 | .msgControl { background-color:#bbbbbb; color:#000000 }
|
---|
37 | .msgNote { background-color:#ddeeff; color:#000000 }
|
---|
38 | .mrange { background-color:#dfddf3 }
|
---|
39 | .mrange { border-bottom:1px solid #6F9DBE }
|
---|
40 | .PathIndex { font-weight: bold; padding:0px 5px; margin-right:5px; }
|
---|
41 | .PathIndex { -webkit-border-radius:8px }
|
---|
42 | .PathIndex { border-radius:8px }
|
---|
43 | .PathIndexEvent { background-color:#bfba87 }
|
---|
44 | .PathIndexControl { background-color:#8c8c8c }
|
---|
45 | .PathNav a { text-decoration:none; font-size: larger }
|
---|
46 | .CodeInsertionHint { font-weight: bold; background-color: #10dd10 }
|
---|
47 | .CodeRemovalHint { background-color:#de1010 }
|
---|
48 | .CodeRemovalHint { border-bottom:1px solid #6F9DBE }
|
---|
49 | table.simpletable {
|
---|
50 | padding: 5px;
|
---|
51 | font-size:12pt;
|
---|
52 | margin:20px;
|
---|
53 | border-collapse: collapse; border-spacing: 0px;
|
---|
54 | }
|
---|
55 | td.rowname {
|
---|
56 | text-align: right;
|
---|
57 | vertical-align: top;
|
---|
58 | font-weight: bold;
|
---|
59 | color:#444444;
|
---|
60 | padding-right:2ex;
|
---|
61 | }
|
---|
62 | </style>
|
---|
63 | </head>
|
---|
64 | <body>
|
---|
65 | <!-- BUGDESC Use of memory after it is freed -->
|
---|
66 |
|
---|
67 | <!-- BUGTYPE Use-after-free -->
|
---|
68 |
|
---|
69 | <!-- BUGCATEGORY Memory Error -->
|
---|
70 |
|
---|
71 | <!-- BUGFILE /home/haiku/haiku/haiku/src/add-ons/kernel/drivers/bluetooth/h2/h2generic/h2generic.cpp -->
|
---|
72 |
|
---|
73 | <!-- FILENAME h2generic.cpp -->
|
---|
74 |
|
---|
75 | <!-- FUNCTIONNAME spawn_device -->
|
---|
76 |
|
---|
77 | <!-- ISSUEHASHCONTENTOFLINEINCONTEXT a2cf6c784a95825fa35a8a4d7e815e3d -->
|
---|
78 |
|
---|
79 | <!-- BUGLINE 153 -->
|
---|
80 |
|
---|
81 | <!-- BUGCOLUMN 2 -->
|
---|
82 |
|
---|
83 | <!-- BUGPATHLENGTH 11 -->
|
---|
84 |
|
---|
85 | <!-- BUGMETAEND -->
|
---|
86 | <!-- REPORTHEADER -->
|
---|
87 | <h3>Bug Summary</h3>
|
---|
88 | <table class="simpletable">
|
---|
89 | <tr><td class="rowname">File:</td><td>src/add-ons/kernel/drivers/bluetooth/h2/h2generic/h2generic.cpp</td></tr>
|
---|
90 | <tr><td class="rowname">Warning:</td><td><a href="#EndPath">line 153, column 2</a><br />Use of memory after it is freed</td></tr>
|
---|
91 | </table>
|
---|
92 | <!-- REPORTSUMMARYEXTRA -->
|
---|
93 | <h3>Annotated Source Code</h3>
|
---|
94 | <table class="code">
|
---|
95 | <tr><td class="num" id="LN1">1</td><td class="line"><span class='comment'>/*</span></td></tr>
|
---|
96 | <tr><td class="num" id="LN2">2</td><td class="line"> <span class='comment'>* Copyright 2007 Oliver Ruiz Dorantes, oliver.ruiz.dorantes_at_gmail.com</span></td></tr>
|
---|
97 | <tr><td class="num" id="LN3">3</td><td class="line"> <span class='comment'>* Copyright 2008 Mika Lindqvist, monni1995_at_gmail.com</span></td></tr>
|
---|
98 | <tr><td class="num" id="LN4">4</td><td class="line"> <span class='comment'>* All rights reserved. Distributed under the terms of the MIT License.</span></td></tr>
|
---|
99 | <tr><td class="num" id="LN5">5</td><td class="line"> <span class='comment'>*</span></td></tr>
|
---|
100 | <tr><td class="num" id="LN6">6</td><td class="line"> <span class='comment'>*/</span></td></tr>
|
---|
101 | <tr><td class="num" id="LN7">7</td><td class="line"> </td></tr>
|
---|
102 | <tr><td class="num" id="LN8">8</td><td class="line"> </td></tr>
|
---|
103 | <tr><td class="num" id="LN9">9</td><td class="line"><span class='directive'>#include "h2generic.h"</span></td></tr>
|
---|
104 | <tr><td class="num" id="LN10">10</td><td class="line"> </td></tr>
|
---|
105 | <tr><td class="num" id="LN11">11</td><td class="line"><span class='directive'>#include <kernel.h></span></td></tr>
|
---|
106 | <tr><td class="num" id="LN12">12</td><td class="line"><span class='directive'>#include <malloc.h></span></td></tr>
|
---|
107 | <tr><td class="num" id="LN13">13</td><td class="line"><span class='directive'>#include <stdio.h></span></td></tr>
|
---|
108 | <tr><td class="num" id="LN14">14</td><td class="line"><span class='directive'>#include <string.h></span></td></tr>
|
---|
109 | <tr><td class="num" id="LN15">15</td><td class="line"> </td></tr>
|
---|
110 | <tr><td class="num" id="LN16">16</td><td class="line"><span class='directive'>#include <KernelExport.h></span></td></tr>
|
---|
111 | <tr><td class="num" id="LN17">17</td><td class="line"><span class='directive'>#include <ByteOrder.h></span></td></tr>
|
---|
112 | <tr><td class="num" id="LN18">18</td><td class="line"><span class='directive'>#include <Drivers.h></span></td></tr>
|
---|
113 | <tr><td class="num" id="LN19">19</td><td class="line"> </td></tr>
|
---|
114 | <tr><td class="num" id="LN20">20</td><td class="line"><span class='directive'>#include <btModules.h></span></td></tr>
|
---|
115 | <tr><td class="num" id="LN21">21</td><td class="line"> </td></tr>
|
---|
116 | <tr><td class="num" id="LN22">22</td><td class="line"><span class='directive'>#include "snet_buffer.h"</span></td></tr>
|
---|
117 | <tr><td class="num" id="LN23">23</td><td class="line"><span class='directive'>#include "h2cfg.h"</span></td></tr>
|
---|
118 | <tr><td class="num" id="LN24">24</td><td class="line"><span class='directive'>#include "h2debug.h"</span></td></tr>
|
---|
119 | <tr><td class="num" id="LN25">25</td><td class="line"><span class='directive'>#include "h2transactions.h"</span></td></tr>
|
---|
120 | <tr><td class="num" id="LN26">26</td><td class="line"><span class='directive'>#include "h2util.h"</span></td></tr>
|
---|
121 | <tr><td class="num" id="LN27">27</td><td class="line"> </td></tr>
|
---|
122 | <tr><td class="num" id="LN28">28</td><td class="line"> </td></tr>
|
---|
123 | <tr><td class="num" id="LN29">29</td><td class="line">int32 api_version = <span class='macro'>B_CUR_DRIVER_API_VERSION<span class='expansion'>2</span></span>;</td></tr>
|
---|
124 | <tr><td class="num" id="LN30">30</td><td class="line"> </td></tr>
|
---|
125 | <tr><td class="num" id="LN31">31</td><td class="line"><span class='comment'>// Modules</span></td></tr>
|
---|
126 | <tr><td class="num" id="LN32">32</td><td class="line"><span class='keyword'>static</span> <span class='keyword'>const</span> <span class='keyword'>char</span>* usb_name = <span class='macro'>B_USB_MODULE_NAME<span class='expansion'>"bus_managers/usb/v3"</span></span>;</td></tr>
|
---|
127 | <tr><td class="num" id="LN33">33</td><td class="line"><span class='keyword'>static</span> <span class='keyword'>const</span> <span class='keyword'>char</span>* hci_name = <span class='macro'>BT_HCI_MODULE_NAME<span class='expansion'>"bluetooth/hci/v1"</span></span>;</td></tr>
|
---|
128 | <tr><td class="num" id="LN34">34</td><td class="line"><span class='keyword'>static</span> <span class='keyword'>const</span> <span class='keyword'>char</span>* btDevices_name = <span class='macro'>BT_HCI_MODULE_NAME<span class='expansion'>"bluetooth/hci/v1"</span></span>;</td></tr>
|
---|
129 | <tr><td class="num" id="LN35">35</td><td class="line"> </td></tr>
|
---|
130 | <tr><td class="num" id="LN36">36</td><td class="line"> </td></tr>
|
---|
131 | <tr><td class="num" id="LN37">37</td><td class="line">usb_module_info* usb = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
132 | <tr><td class="num" id="LN38">38</td><td class="line">bt_hci_module_info* hci = <span class='macro'>NULL<span class='expansion'>__null</span></span>; <span class='comment'>// TODO remove / clean</span></td></tr>
|
---|
133 | <tr><td class="num" id="LN39">39</td><td class="line"><span class='keyword'>struct</span> bt_hci_module_info* btDevices = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
134 | <tr><td class="num" id="LN40">40</td><td class="line"><span class='keyword'>struct</span> net_buffer_module_info* nb = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
135 | <tr><td class="num" id="LN41">41</td><td class="line"><span class='keyword'>struct</span> bluetooth_core_data_module_info* btCoreData = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
136 | <tr><td class="num" id="LN42">42</td><td class="line"> </td></tr>
|
---|
137 | <tr><td class="num" id="LN43">43</td><td class="line"><span class='comment'>// Driver Global data</span></td></tr>
|
---|
138 | <tr><td class="num" id="LN44">44</td><td class="line"><span class='keyword'>static</span> <span class='keyword'>char</span>* publish_names[<span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span>];</td></tr>
|
---|
139 | <tr><td class="num" id="LN45">45</td><td class="line"> </td></tr>
|
---|
140 | <tr><td class="num" id="LN46">46</td><td class="line">int32 dev_count = 0; <span class='comment'>// number of connected devices</span></td></tr>
|
---|
141 | <tr><td class="num" id="LN47">47</td><td class="line"><span class='keyword'>static</span> bt_usb_dev* bt_usb_devices[<span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span>];</td></tr>
|
---|
142 | <tr><td class="num" id="LN48">48</td><td class="line">sem_id dev_table_sem = -1; <span class='comment'>// sem to synchronize access to device table</span></td></tr>
|
---|
143 | <tr><td class="num" id="LN49">49</td><td class="line"> </td></tr>
|
---|
144 | <tr><td class="num" id="LN50">50</td><td class="line">status_t submit_nbuffer(hci_id hid, net_buffer* nbuf);</td></tr>
|
---|
145 | <tr><td class="num" id="LN51">51</td><td class="line"> </td></tr>
|
---|
146 | <tr><td class="num" id="LN52">52</td><td class="line">usb_support_descriptor supported_devices[] = {</td></tr>
|
---|
147 | <tr><td class="num" id="LN53">53</td><td class="line"> <span class='comment'>// Generic Bluetooth USB device</span></td></tr>
|
---|
148 | <tr><td class="num" id="LN54">54</td><td class="line"> <span class='comment'>// Class, SubClass, and Protocol codes that describe a Bluetooth device</span></td></tr>
|
---|
149 | <tr><td class="num" id="LN55">55</td><td class="line"> { <span class='macro'>UDCLASS_WIRELESS<span class='expansion'>0xe0</span></span>, <span class='macro'>UDSUBCLASS_RF<span class='expansion'>0x01</span></span>, <span class='macro'>UDPROTO_BLUETOOTH<span class='expansion'>0x01</span></span> , 0 , 0 },</td></tr>
|
---|
150 | <tr><td class="num" id="LN56">56</td><td class="line"> </td></tr>
|
---|
151 | <tr><td class="num" id="LN57">57</td><td class="line"> <span class='comment'>// Broadcom BCM2035</span></td></tr>
|
---|
152 | <tr><td class="num" id="LN58">58</td><td class="line"> { 0, 0, 0, 0x0a5c, 0x200a },</td></tr>
|
---|
153 | <tr><td class="num" id="LN59">59</td><td class="line"> { 0, 0, 0, 0x0a5c, 0x2009 },</td></tr>
|
---|
154 | <tr><td class="num" id="LN60">60</td><td class="line"> </td></tr>
|
---|
155 | <tr><td class="num" id="LN61">61</td><td class="line"> <span class='comment'>// Devices taken from the linux Driver</span></td></tr>
|
---|
156 | <tr><td class="num" id="LN62">62</td><td class="line"> <span class='comment'>// AVM BlueFRITZ! USB v2.0</span></td></tr>
|
---|
157 | <tr><td class="num" id="LN63">63</td><td class="line"> { 0, 0, 0, 0x057c, 0x3800 },</td></tr>
|
---|
158 | <tr><td class="num" id="LN64">64</td><td class="line"> <span class='comment'>// Bluetooth Ultraport Module from IBM</span></td></tr>
|
---|
159 | <tr><td class="num" id="LN65">65</td><td class="line"> { 0, 0, 0, 0x04bf, 0x030a },</td></tr>
|
---|
160 | <tr><td class="num" id="LN66">66</td><td class="line"> <span class='comment'>// ALPS Modules with non-standard id</span></td></tr>
|
---|
161 | <tr><td class="num" id="LN67">67</td><td class="line"> { 0, 0, 0, 0x044e, 0x3001 },</td></tr>
|
---|
162 | <tr><td class="num" id="LN68">68</td><td class="line"> { 0, 0, 0, 0x044e, 0x3002 },</td></tr>
|
---|
163 | <tr><td class="num" id="LN69">69</td><td class="line"> <span class='comment'>// Ericsson with non-standard id</span></td></tr>
|
---|
164 | <tr><td class="num" id="LN70">70</td><td class="line"> { 0, 0, 0, 0x0bdb, 0x1002 }</td></tr>
|
---|
165 | <tr><td class="num" id="LN71">71</td><td class="line">};</td></tr>
|
---|
166 | <tr><td class="num" id="LN72">72</td><td class="line"> </td></tr>
|
---|
167 | <tr><td class="num" id="LN73">73</td><td class="line"><span class='comment'>/* add a device to the list of connected devices */</span></td></tr>
|
---|
168 | <tr><td class="num" id="LN74">74</td><td class="line"><span class='directive'>#ifdef <span class='macro'>HAIKU_TARGET_PLATFORM_HAIKU<span class='expansion'>1</span></span></span></td></tr>
|
---|
169 | <tr><td class="num" id="LN75">75</td><td class="line"><span class='keyword'>static</span> bt_usb_dev*</td></tr>
|
---|
170 | <tr><td class="num" id="LN76">76</td><td class="line">spawn_device(usb_device usb_dev)</td></tr>
|
---|
171 | <tr><td class="num" id="LN77">77</td><td class="line"><span class='directive'>#else</span></td></tr>
|
---|
172 | <tr><td class="num" id="LN78">78</td><td class="line"><span class='keyword'>static</span> bt_usb_dev*</td></tr>
|
---|
173 | <tr><td class="num" id="LN79">79</td><td class="line">spawn_device(usb_device* usb_dev)</td></tr>
|
---|
174 | <tr><td class="num" id="LN80">80</td><td class="line"><span class='directive'>#endif</span></td></tr>
|
---|
175 | <tr><td class="num" id="LN81">81</td><td class="line"> </td></tr>
|
---|
176 | <tr><td class="num" id="LN82">82</td><td class="line">{</td></tr>
|
---|
177 | <tr><td class="num" id="LN83">83</td><td class="line"> <span class='macro'>CALLED()<span class='expansion'>dprintf("h2generic: " "h2generic: CALLED %s\n", __PRETTY_FUNCTION__<br>)</span></span>;</td></tr>
|
---|
178 | <tr><td class="num" id="LN84">84</td><td class="line"> </td></tr>
|
---|
179 | <tr><td class="num" id="LN85">85</td><td class="line"> int32 i;</td></tr>
|
---|
180 | <tr><td class="num" id="LN86">86</td><td class="line"> status_t err = <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>;</td></tr>
|
---|
181 | <tr><td class="num" id="LN87">87</td><td class="line"> bt_usb_dev* new_bt_dev = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
182 | <tr><td class="num" id="LN88">88</td><td class="line"> </td></tr>
|
---|
183 | <tr><td class="num" id="LN89">89</td><td class="line"> <span class='comment'>// 16 usb dongles...</span></td></tr>
|
---|
184 | <tr><td class="num" id="LN90">90</td><td class="line"> <span class='keyword'>if</span> (<span class="mrange">dev_count >= <span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span></span>) {</td></tr>
|
---|
185 | <tr><td class="num"></td><td class="line"><div id="Path2" class="msg msgEvent" style="margin-left:13ex"><table class="msgT"><tr><td valign="top"><div class="PathIndex PathIndexEvent">2</div></td><td><div class="PathNav"><a href="#Path1" title="Previous event (1)">←</a></div></td></td><td>Assuming 'dev_count' is < MAX_BT_GENERIC_USB_DEVICES</td><td><div class="PathNav"><a href="#Path3" title="Next event (3)">→</a></div></td></tr></table></div></td></tr>
|
---|
186 | <tr><td class="num"></td><td class="line"><div id="Path3" class="msg msgControl" style="margin-left:9ex"><table class="msgT"><tr><td valign="top"><div class="PathIndex PathIndexControl">3</div></td><td><div class="PathNav"><a href="#Path2" title="Previous event (2)">←</a></div></td></td><td>Taking false branch</td><td><div class="PathNav"><a href="#Path4" title="Next event (4)">→</a></div></td></tr></table></div></td></tr>
|
---|
187 | <tr><td class="num" id="LN91">91</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Device table full\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Device table full\n", __func__)</span></span>;</td></tr>
|
---|
188 | <tr><td class="num" id="LN92">92</td><td class="line"> <span class='keyword'>goto</span> exit;</td></tr>
|
---|
189 | <tr><td class="num" id="LN93">93</td><td class="line"> }</td></tr>
|
---|
190 | <tr><td class="num" id="LN94">94</td><td class="line"> </td></tr>
|
---|
191 | <tr><td class="num" id="LN95">95</td><td class="line"> <span class='comment'>// try the allocation</span></td></tr>
|
---|
192 | <tr><td class="num" id="LN96">96</td><td class="line"> new_bt_dev = (bt_usb_dev*)<span class="mrange">malloc(<span class='keyword'>sizeof</span>(bt_usb_dev))</span>;</td></tr>
|
---|
193 | <tr><td class="num"></td><td class="line"><div id="Path4" class="msg msgEvent" style="margin-left:35ex"><table class="msgT"><tr><td valign="top"><div class="PathIndex PathIndexEvent">4</div></td><td><div class="PathNav"><a href="#Path3" title="Previous event (3)">←</a></div></td></td><td>Memory is allocated</td><td><div class="PathNav"><a href="#Path5" title="Next event (5)">→</a></div></td></tr></table></div></td></tr>
|
---|
194 | <tr><td class="num" id="LN97">97</td><td class="line"> <span class='keyword'>if</span> (<span class="mrange">new_bt_dev == <span class='macro'>NULL<span class='expansion'>__null</span></span></span>) {</td></tr>
|
---|
195 | <tr><td class="num"></td><td class="line"><div id="Path5" class="msg msgEvent" style="margin-left:13ex"><table class="msgT"><tr><td valign="top"><div class="PathIndex PathIndexEvent">5</div></td><td><div class="PathNav"><a href="#Path4" title="Previous event (4)">←</a></div></td></td><td>Assuming 'new_bt_dev' is not equal to NULL</td><td><div class="PathNav"><a href="#Path6" title="Next event (6)">→</a></div></td></tr></table></div></td></tr>
|
---|
196 | <tr><td class="num"></td><td class="line"><div id="Path6" class="msg msgControl" style="margin-left:9ex"><table class="msgT"><tr><td valign="top"><div class="PathIndex PathIndexControl">6</div></td><td><div class="PathNav"><a href="#Path5" title="Previous event (5)">←</a></div></td></td><td>Taking false branch</td><td><div class="PathNav"><a href="#Path7" title="Next event (7)">→</a></div></td></tr></table></div></td></tr>
|
---|
197 | <tr><td class="num" id="LN98">98</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Unable to malloc new bt device\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Unable to malloc new bt device\n",<br> __func__)</span></span>;</td></tr>
|
---|
198 | <tr><td class="num" id="LN99">99</td><td class="line"> <span class='keyword'>goto</span> exit;</td></tr>
|
---|
199 | <tr><td class="num" id="LN100">100</td><td class="line"> }</td></tr>
|
---|
200 | <tr><td class="num" id="LN101">101</td><td class="line"> memset(new_bt_dev, 0, <span class='keyword'>sizeof</span>(bt_usb_dev));</td></tr>
|
---|
201 | <tr><td class="num" id="LN102">102</td><td class="line"> </td></tr>
|
---|
202 | <tr><td class="num" id="LN103">103</td><td class="line"> <span class='comment'>// We will need this sem for some flow control</span></td></tr>
|
---|
203 | <tr><td class="num" id="LN104">104</td><td class="line"> new_bt_dev->cmd_complete = create_sem(1,</td></tr>
|
---|
204 | <tr><td class="num" id="LN105">105</td><td class="line"> <span class='macro'>BLUETOOTH_DEVICE_DEVFS_NAME<span class='expansion'>"h2" "generic"</span></span> <span class='string_literal'>"cmd_complete"</span>);</td></tr>
|
---|
205 | <tr><td class="num" id="LN106">106</td><td class="line"> <span class='keyword'>if</span> (<span class="mrange">new_bt_dev->cmd_complete < 0</span>) {</td></tr>
|
---|
206 | <tr><td class="num"></td><td class="line"><div id="Path7" class="msg msgEvent" style="margin-left:13ex"><table class="msgT"><tr><td valign="top"><div class="PathIndex PathIndexEvent">7</div></td><td><div class="PathNav"><a href="#Path6" title="Previous event (6)">←</a></div></td></td><td>Assuming the condition is true</td><td><div class="PathNav"><a href="#Path8" title="Next event (8)">→</a></div></td></tr></table></div></td></tr>
|
---|
207 | <tr><td class="num"></td><td class="line"><div id="Path8" class="msg msgControl" style="margin-left:9ex"><table class="msgT"><tr><td valign="top"><div class="PathIndex PathIndexControl">8</div></td><td><div class="PathNav"><a href="#Path7" title="Previous event (7)">←</a></div></td></td><td>Taking true branch</td><td><div class="PathNav"><a href="#Path9" title="Next event (9)">→</a></div></td></tr></table></div></td></tr>
|
---|
208 | <tr><td class="num" id="LN107">107</td><td class="line"> err = new_bt_dev->cmd_complete;</td></tr>
|
---|
209 | <tr><td class="num" id="LN108">108</td><td class="line"> <span class='keyword'>goto</span> bail0;</td></tr>
|
---|
210 | <tr><td class="num"></td><td class="line"><div id="Path9" class="msg msgControl" style="margin-left:17ex"><table class="msgT"><tr><td valign="top"><div class="PathIndex PathIndexControl">9</div></td><td><div class="PathNav"><a href="#Path8" title="Previous event (8)">←</a></div></td></td><td>Control jumps to line 151</td><td><div class="PathNav"><a href="#Path10" title="Next event (10)">→</a></div></td></tr></table></div></td></tr>
|
---|
211 | <tr><td class="num" id="LN109">109</td><td class="line"> }</td></tr>
|
---|
212 | <tr><td class="num" id="LN110">110</td><td class="line"> </td></tr>
|
---|
213 | <tr><td class="num" id="LN111">111</td><td class="line"> <span class='comment'>// and this for something else</span></td></tr>
|
---|
214 | <tr><td class="num" id="LN112">112</td><td class="line"> new_bt_dev->lock = create_sem(1, <span class='macro'>BLUETOOTH_DEVICE_DEVFS_NAME<span class='expansion'>"h2" "generic"</span></span> <span class='string_literal'>"lock"</span>);</td></tr>
|
---|
215 | <tr><td class="num" id="LN113">113</td><td class="line"> <span class='keyword'>if</span> (new_bt_dev->lock < 0) {</td></tr>
|
---|
216 | <tr><td class="num" id="LN114">114</td><td class="line"> err = new_bt_dev->lock;</td></tr>
|
---|
217 | <tr><td class="num" id="LN115">115</td><td class="line"> <span class='keyword'>goto</span> bail1;</td></tr>
|
---|
218 | <tr><td class="num" id="LN116">116</td><td class="line"> }</td></tr>
|
---|
219 | <tr><td class="num" id="LN117">117</td><td class="line"> </td></tr>
|
---|
220 | <tr><td class="num" id="LN118">118</td><td class="line"> <span class='comment'>// find a free slot and fill out the name</span></td></tr>
|
---|
221 | <tr><td class="num" id="LN119">119</td><td class="line"> acquire_sem(dev_table_sem);</td></tr>
|
---|
222 | <tr><td class="num" id="LN120">120</td><td class="line"> <span class='keyword'>for</span> (i = 0; i < <span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span>; i++) {</td></tr>
|
---|
223 | <tr><td class="num" id="LN121">121</td><td class="line"> <span class='keyword'>if</span> (bt_usb_devices[i] == <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
224 | <tr><td class="num" id="LN122">122</td><td class="line"> bt_usb_devices[i] = new_bt_dev;</td></tr>
|
---|
225 | <tr><td class="num" id="LN123">123</td><td class="line"> sprintf(new_bt_dev->name, <span class='string_literal'>"%s/%"</span> <span class='macro'>B_PRId32<span class='expansion'>"" "d"</span></span>,</td></tr>
|
---|
226 | <tr><td class="num" id="LN124">124</td><td class="line"> <span class='macro'>BLUETOOTH_DEVICE_PATH<span class='expansion'>"bluetooth/" "h2" "/" "h2" "generic"</span></span>, i);</td></tr>
|
---|
227 | <tr><td class="num" id="LN125">125</td><td class="line"> new_bt_dev->num = i;</td></tr>
|
---|
228 | <tr><td class="num" id="LN126">126</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: added device %p %"</span> B_PRId32 <span class='string_literal'>" %s\n"</span>, <span class='keyword'>__func__</span>,<span class='expansion'>dprintf("h2generic: " "%s: added device %p %" "" "d" " %s\n",<br> __func__, bt_usb_devices[i], new_bt_dev->num, new_bt_dev-><br>name)</span></span></td></tr>
|
---|
229 | <tr><td class="num" id="LN127">127</td><td class="line"> <span class='macro'>bt_usb_devices[i], new_bt_dev->num, new_bt_dev->name)<span class='expansion'>dprintf("h2generic: " "%s: added device %p %" "" "d" " %s\n",<br> __func__, bt_usb_devices[i], new_bt_dev->num, new_bt_dev-><br>name)</span></span>;</td></tr>
|
---|
230 | <tr><td class="num" id="LN128">128</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
231 | <tr><td class="num" id="LN129">129</td><td class="line"> }</td></tr>
|
---|
232 | <tr><td class="num" id="LN130">130</td><td class="line"> }</td></tr>
|
---|
233 | <tr><td class="num" id="LN131">131</td><td class="line"> release_sem_etc(dev_table_sem, 1, B_DO_NOT_RESCHEDULE);</td></tr>
|
---|
234 | <tr><td class="num" id="LN132">132</td><td class="line"> </td></tr>
|
---|
235 | <tr><td class="num" id="LN133">133</td><td class="line"> <span class='comment'>// In the case we cannot us</span></td></tr>
|
---|
236 | <tr><td class="num" id="LN134">134</td><td class="line"> <span class='keyword'>if</span> (bt_usb_devices[i] != new_bt_dev) {</td></tr>
|
---|
237 | <tr><td class="num" id="LN135">135</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Device could not be added\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Device could not be added\n", __func__<br>)</span></span>;</td></tr>
|
---|
238 | <tr><td class="num" id="LN136">136</td><td class="line"> <span class='keyword'>goto</span> bail2;</td></tr>
|
---|
239 | <tr><td class="num" id="LN137">137</td><td class="line"> }</td></tr>
|
---|
240 | <tr><td class="num" id="LN138">138</td><td class="line"> </td></tr>
|
---|
241 | <tr><td class="num" id="LN139">139</td><td class="line"> new_bt_dev->dev = usb_dev;</td></tr>
|
---|
242 | <tr><td class="num" id="LN140">140</td><td class="line"> <span class='comment'>// TODO: currently only server opens</span></td></tr>
|
---|
243 | <tr><td class="num" id="LN141">141</td><td class="line"> new_bt_dev->open_count = 0;</td></tr>
|
---|
244 | <tr><td class="num" id="LN142">142</td><td class="line"> </td></tr>
|
---|
245 | <tr><td class="num" id="LN143">143</td><td class="line"> dev_count++;</td></tr>
|
---|
246 | <tr><td class="num" id="LN144">144</td><td class="line"> <span class='keyword'>return</span> new_bt_dev;</td></tr>
|
---|
247 | <tr><td class="num" id="LN145">145</td><td class="line"> </td></tr>
|
---|
248 | <tr><td class="num" id="LN146">146</td><td class="line">bail2:</td></tr>
|
---|
249 | <tr><td class="num" id="LN147">147</td><td class="line"> delete_sem(new_bt_dev->lock);</td></tr>
|
---|
250 | <tr><td class="num" id="LN148">148</td><td class="line">bail1:</td></tr>
|
---|
251 | <tr><td class="num" id="LN149">149</td><td class="line"> delete_sem(new_bt_dev->cmd_complete);</td></tr>
|
---|
252 | <tr><td class="num" id="LN150">150</td><td class="line">bail0:</td></tr>
|
---|
253 | <tr><td class="num" id="LN151">151</td><td class="line"> <span class="mrange">free(new_bt_dev)</span>;</td></tr>
|
---|
254 | <tr><td class="num"></td><td class="line"><div id="Path10" class="msg msgEvent" style="margin-left:9ex"><table class="msgT"><tr><td valign="top"><div class="PathIndex PathIndexEvent">10</div></td><td><div class="PathNav"><a href="#Path9" title="Previous event (9)">←</a></div></td></td><td>Memory is released</td><td><div class="PathNav"><a href="#EndPath" title="Next event (11)">→</a></div></td></tr></table></div></td></tr>
|
---|
255 | <tr><td class="num" id="LN152">152</td><td class="line">exit:</td></tr>
|
---|
256 | <tr><td class="num" id="LN153">153</td><td class="line"> <span class='keyword'>return</span> <span class="mrange">new_bt_dev</span>;</td></tr>
|
---|
257 | <tr><td class="num"></td><td class="line"><div id="EndPath" class="msg msgEvent" style="margin-left:9ex"><table class="msgT"><tr><td valign="top"><div class="PathIndex PathIndexEvent">11</div></td><td><div class="PathNav"><a href="#Path10" title="Previous event (10)">←</a></div></td></td><td>Use of memory after it is freed</td></tr></table></div></td></tr>
|
---|
258 | <tr><td class="num" id="LN154">154</td><td class="line">}</td></tr>
|
---|
259 | <tr><td class="num" id="LN155">155</td><td class="line"> </td></tr>
|
---|
260 | <tr><td class="num" id="LN156">156</td><td class="line"> </td></tr>
|
---|
261 | <tr><td class="num" id="LN157">157</td><td class="line"><span class='comment'>// remove a device from the list of connected devices</span></td></tr>
|
---|
262 | <tr><td class="num" id="LN158">158</td><td class="line"><span class='keyword'>static</span> <span class='keyword'>void</span></td></tr>
|
---|
263 | <tr><td class="num" id="LN159">159</td><td class="line">kill_device(bt_usb_dev* bdev)</td></tr>
|
---|
264 | <tr><td class="num" id="LN160">160</td><td class="line">{</td></tr>
|
---|
265 | <tr><td class="num" id="LN161">161</td><td class="line"> <span class='keyword'>if</span> (bdev != <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
266 | <tr><td class="num" id="LN162">162</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: (%p)\n"</span>, <span class='keyword'>__func__</span>, bdev)<span class='expansion'>dprintf("h2generic: " "%s: (%p)\n", __func__, bdev)</span></span>;</td></tr>
|
---|
267 | <tr><td class="num" id="LN163">163</td><td class="line"> </td></tr>
|
---|
268 | <tr><td class="num" id="LN164">164</td><td class="line"> delete_sem(bdev->lock);</td></tr>
|
---|
269 | <tr><td class="num" id="LN165">165</td><td class="line"> delete_sem(bdev->cmd_complete);</td></tr>
|
---|
270 | <tr><td class="num" id="LN166">166</td><td class="line"> </td></tr>
|
---|
271 | <tr><td class="num" id="LN167">167</td><td class="line"> <span class='comment'>// mark it free</span></td></tr>
|
---|
272 | <tr><td class="num" id="LN168">168</td><td class="line"> bt_usb_devices[bdev->num] = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
273 | <tr><td class="num" id="LN169">169</td><td class="line"> </td></tr>
|
---|
274 | <tr><td class="num" id="LN170">170</td><td class="line"> free(bdev);</td></tr>
|
---|
275 | <tr><td class="num" id="LN171">171</td><td class="line"> dev_count--;</td></tr>
|
---|
276 | <tr><td class="num" id="LN172">172</td><td class="line"> }</td></tr>
|
---|
277 | <tr><td class="num" id="LN173">173</td><td class="line">}</td></tr>
|
---|
278 | <tr><td class="num" id="LN174">174</td><td class="line"> </td></tr>
|
---|
279 | <tr><td class="num" id="LN175">175</td><td class="line"> </td></tr>
|
---|
280 | <tr><td class="num" id="LN176">176</td><td class="line">bt_usb_dev*</td></tr>
|
---|
281 | <tr><td class="num" id="LN177">177</td><td class="line">fetch_device(bt_usb_dev* dev, hci_id hid)</td></tr>
|
---|
282 | <tr><td class="num" id="LN178">178</td><td class="line">{</td></tr>
|
---|
283 | <tr><td class="num" id="LN179">179</td><td class="line"> <span class='keyword'>int</span> i;</td></tr>
|
---|
284 | <tr><td class="num" id="LN180">180</td><td class="line"> </td></tr>
|
---|
285 | <tr><td class="num" id="LN181">181</td><td class="line"><span class='comment'>// TRACE("%s: (%p) or %d\n", __func__, dev, hid);</span></td></tr>
|
---|
286 | <tr><td class="num" id="LN182">182</td><td class="line"> </td></tr>
|
---|
287 | <tr><td class="num" id="LN183">183</td><td class="line"> acquire_sem(dev_table_sem);</td></tr>
|
---|
288 | <tr><td class="num" id="LN184">184</td><td class="line"> <span class='keyword'>if</span> (dev != <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
289 | <tr><td class="num" id="LN185">185</td><td class="line"> <span class='keyword'>for</span> (i = 0; i < <span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span>; i++) {</td></tr>
|
---|
290 | <tr><td class="num" id="LN186">186</td><td class="line"> <span class='keyword'>if</span> (bt_usb_devices[i] == dev) {</td></tr>
|
---|
291 | <tr><td class="num" id="LN187">187</td><td class="line"> release_sem_etc(dev_table_sem, 1, B_DO_NOT_RESCHEDULE);</td></tr>
|
---|
292 | <tr><td class="num" id="LN188">188</td><td class="line"> <span class='keyword'>return</span> bt_usb_devices[i];</td></tr>
|
---|
293 | <tr><td class="num" id="LN189">189</td><td class="line"> }</td></tr>
|
---|
294 | <tr><td class="num" id="LN190">190</td><td class="line"> }</td></tr>
|
---|
295 | <tr><td class="num" id="LN191">191</td><td class="line"> } <span class='keyword'>else</span> {</td></tr>
|
---|
296 | <tr><td class="num" id="LN192">192</td><td class="line"> <span class='keyword'>for</span> (i = 0; i < <span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span>; i++) {</td></tr>
|
---|
297 | <tr><td class="num" id="LN193">193</td><td class="line"> <span class='keyword'>if</span> (bt_usb_devices[i] != <span class='macro'>NULL<span class='expansion'>__null</span></span> && bt_usb_devices[i]->hdev == hid) {</td></tr>
|
---|
298 | <tr><td class="num" id="LN194">194</td><td class="line"> release_sem_etc(dev_table_sem, 1, B_DO_NOT_RESCHEDULE);</td></tr>
|
---|
299 | <tr><td class="num" id="LN195">195</td><td class="line"> <span class='keyword'>return</span> bt_usb_devices[i];</td></tr>
|
---|
300 | <tr><td class="num" id="LN196">196</td><td class="line"> }</td></tr>
|
---|
301 | <tr><td class="num" id="LN197">197</td><td class="line"> }</td></tr>
|
---|
302 | <tr><td class="num" id="LN198">198</td><td class="line"> }</td></tr>
|
---|
303 | <tr><td class="num" id="LN199">199</td><td class="line"> </td></tr>
|
---|
304 | <tr><td class="num" id="LN200">200</td><td class="line"> release_sem_etc(dev_table_sem, 1, B_DO_NOT_RESCHEDULE);</td></tr>
|
---|
305 | <tr><td class="num" id="LN201">201</td><td class="line"> </td></tr>
|
---|
306 | <tr><td class="num" id="LN202">202</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
307 | <tr><td class="num" id="LN203">203</td><td class="line">}</td></tr>
|
---|
308 | <tr><td class="num" id="LN204">204</td><td class="line"> </td></tr>
|
---|
309 | <tr><td class="num" id="LN205">205</td><td class="line"> </td></tr>
|
---|
310 | <tr><td class="num" id="LN206">206</td><td class="line"><span class='directive'>#if 0</span></td></tr>
|
---|
311 | <tr><td class="num" id="LN207">207</td><td class="line"><span class='directive'>#pragma mark -</span></td></tr>
|
---|
312 | <tr><td class="num" id="LN208">208</td><td class="line"><span class='directive'>#endif</span></td></tr>
|
---|
313 | <tr><td class="num" id="LN209">209</td><td class="line"> </td></tr>
|
---|
314 | <tr><td class="num" id="LN210">210</td><td class="line"><span class='comment'>// called by USB Manager when device is added to the USB</span></td></tr>
|
---|
315 | <tr><td class="num" id="LN211">211</td><td class="line"><span class='directive'>#ifdef <span class='macro'>HAIKU_TARGET_PLATFORM_HAIKU<span class='expansion'>1</span></span></span></td></tr>
|
---|
316 | <tr><td class="num" id="LN212">212</td><td class="line"><span class='keyword'>static</span> status_t</td></tr>
|
---|
317 | <tr><td class="num" id="LN213">213</td><td class="line">device_added(usb_device dev, <span class='keyword'>void</span>** cookie)</td></tr>
|
---|
318 | <tr><td class="num" id="LN214">214</td><td class="line"><span class='directive'>#else</span></td></tr>
|
---|
319 | <tr><td class="num" id="LN215">215</td><td class="line">device_added(usb_device* dev, <span class='keyword'>void</span>** cookie)</td></tr>
|
---|
320 | <tr><td class="num" id="LN216">216</td><td class="line"><span class='directive'>#endif</span></td></tr>
|
---|
321 | <tr><td class="num" id="LN217">217</td><td class="line">{</td></tr>
|
---|
322 | <tr><td class="num" id="LN218">218</td><td class="line"> <span class='keyword'>const</span> usb_interface_info* interface;</td></tr>
|
---|
323 | <tr><td class="num" id="LN219">219</td><td class="line"> <span class='keyword'>const</span> usb_device_descriptor* desc;</td></tr>
|
---|
324 | <tr><td class="num" id="LN220">220</td><td class="line"> <span class='keyword'>const</span> usb_configuration_info* config;</td></tr>
|
---|
325 | <tr><td class="num" id="LN221">221</td><td class="line"> <span class='keyword'>const</span> usb_interface_info* uif;</td></tr>
|
---|
326 | <tr><td class="num" id="LN222">222</td><td class="line"> <span class='keyword'>const</span> usb_endpoint_info* ep;</td></tr>
|
---|
327 | <tr><td class="num" id="LN223">223</td><td class="line"> </td></tr>
|
---|
328 | <tr><td class="num" id="LN224">224</td><td class="line"> status_t err = <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
329 | <tr><td class="num" id="LN225">225</td><td class="line"> bt_usb_dev* new_bt_dev = <span class="mrange">spawn_device(dev)</span>;</td></tr>
|
---|
330 | <tr><td class="num"></td><td class="line"><div id="Path1" class="msg msgEvent" style="margin-left:34ex"><table class="msgT"><tr><td valign="top"><div class="PathIndex PathIndexEvent">1</div></td><td>Calling 'spawn_device'</td><td><div class="PathNav"><a href="#Path2" title="Next event (2)">→</a></div></td></tr></table></div></td></tr>
|
---|
331 | <tr><td class="num" id="LN226">226</td><td class="line"> <span class='keyword'>int</span> e;</td></tr>
|
---|
332 | <tr><td class="num" id="LN227">227</td><td class="line"> </td></tr>
|
---|
333 | <tr><td class="num" id="LN228">228</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: device_added(%p)\n"</span>, <span class='keyword'>__func__</span>, new_bt_dev)<span class='expansion'>dprintf("h2generic: " "%s: device_added(%p)\n", __func__, new_bt_dev<br>)</span></span>;</td></tr>
|
---|
334 | <tr><td class="num" id="LN229">229</td><td class="line"> </td></tr>
|
---|
335 | <tr><td class="num" id="LN230">230</td><td class="line"> <span class='keyword'>if</span> (new_bt_dev == <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
336 | <tr><td class="num" id="LN231">231</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Couldn't allocate device record.\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Couldn't allocate device record.\n"<br>, __func__)</span></span>;</td></tr>
|
---|
337 | <tr><td class="num" id="LN232">232</td><td class="line"> err = <span class='macro'>ENOMEM<span class='expansion'>((-2147483647 - 1) + 0)</span></span>;</td></tr>
|
---|
338 | <tr><td class="num" id="LN233">233</td><td class="line"> <span class='keyword'>goto</span> bail_no_mem;</td></tr>
|
---|
339 | <tr><td class="num" id="LN234">234</td><td class="line"> }</td></tr>
|
---|
340 | <tr><td class="num" id="LN235">235</td><td class="line"> </td></tr>
|
---|
341 | <tr><td class="num" id="LN236">236</td><td class="line"> <span class='comment'>// we only have 1 configuration number 0</span></td></tr>
|
---|
342 | <tr><td class="num" id="LN237">237</td><td class="line"> config = usb->get_nth_configuration(dev, 0);</td></tr>
|
---|
343 | <tr><td class="num" id="LN238">238</td><td class="line"> <span class='comment'>// dump_usb_configuration_info(config);</span></td></tr>
|
---|
344 | <tr><td class="num" id="LN239">239</td><td class="line"> <span class='keyword'>if</span> (config == <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
345 | <tr><td class="num" id="LN240">240</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Couldn't get default USB config.\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Couldn't get default USB config.\n"<br>, __func__)</span></span>;</td></tr>
|
---|
346 | <tr><td class="num" id="LN241">241</td><td class="line"> err = <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
347 | <tr><td class="num" id="LN242">242</td><td class="line"> <span class='keyword'>goto</span> bail;</td></tr>
|
---|
348 | <tr><td class="num" id="LN243">243</td><td class="line"> }</td></tr>
|
---|
349 | <tr><td class="num" id="LN244">244</td><td class="line"> </td></tr>
|
---|
350 | <tr><td class="num" id="LN245">245</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: found %"</span> B_PRIuSIZE <span class='string_literal'>" alt interfaces.\n"</span>, <span class='keyword'>__func__</span>,<span class='expansion'>dprintf("h2generic: " "%s: found %" "l" "u" " alt interfaces.\n"<br>, __func__, config->interface->alt_count)</span></span></td></tr>
|
---|
351 | <tr><td class="num" id="LN246">246</td><td class="line"> <span class='macro'>config->interface->alt_count)<span class='expansion'>dprintf("h2generic: " "%s: found %" "l" "u" " alt interfaces.\n"<br>, __func__, config->interface->alt_count)</span></span>;</td></tr>
|
---|
352 | <tr><td class="num" id="LN247">247</td><td class="line"> </td></tr>
|
---|
353 | <tr><td class="num" id="LN248">248</td><td class="line"> <span class='comment'>// set first interface</span></td></tr>
|
---|
354 | <tr><td class="num" id="LN249">249</td><td class="line"> interface = &config->interface->alt[0];</td></tr>
|
---|
355 | <tr><td class="num" id="LN250">250</td><td class="line"> err = usb->set_alt_interface(new_bt_dev->dev, interface);</td></tr>
|
---|
356 | <tr><td class="num" id="LN251">251</td><td class="line"> </td></tr>
|
---|
357 | <tr><td class="num" id="LN252">252</td><td class="line"> <span class='keyword'>if</span> (err != <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>) {</td></tr>
|
---|
358 | <tr><td class="num" id="LN253">253</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: set_alt_interface() error.\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: set_alt_interface() error.\n", __func__<br>)</span></span>;</td></tr>
|
---|
359 | <tr><td class="num" id="LN254">254</td><td class="line"> <span class='keyword'>goto</span> bail;</td></tr>
|
---|
360 | <tr><td class="num" id="LN255">255</td><td class="line"> }</td></tr>
|
---|
361 | <tr><td class="num" id="LN256">256</td><td class="line"> </td></tr>
|
---|
362 | <tr><td class="num" id="LN257">257</td><td class="line"> <span class='comment'>// call set_configuration() only after calling set_alt_interface()</span></td></tr>
|
---|
363 | <tr><td class="num" id="LN258">258</td><td class="line"> err = usb->set_configuration(dev, config);</td></tr>
|
---|
364 | <tr><td class="num" id="LN259">259</td><td class="line"> <span class='keyword'>if</span> (err != <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>) {</td></tr>
|
---|
365 | <tr><td class="num" id="LN260">260</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: set_configuration() error.\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: set_configuration() error.\n", __func__<br>)</span></span>;</td></tr>
|
---|
366 | <tr><td class="num" id="LN261">261</td><td class="line"> <span class='keyword'>goto</span> bail;</td></tr>
|
---|
367 | <tr><td class="num" id="LN262">262</td><td class="line"> }</td></tr>
|
---|
368 | <tr><td class="num" id="LN263">263</td><td class="line"> </td></tr>
|
---|
369 | <tr><td class="num" id="LN264">264</td><td class="line"> <span class='comment'>// Place to find out whats our concrete device and set up some special</span></td></tr>
|
---|
370 | <tr><td class="num" id="LN265">265</td><td class="line"> <span class='comment'>// info to our driver. If this code increases too much reconsider</span></td></tr>
|
---|
371 | <tr><td class="num" id="LN266">266</td><td class="line"> <span class='comment'>// this implementation</span></td></tr>
|
---|
372 | <tr><td class="num" id="LN267">267</td><td class="line"> desc = usb->get_device_descriptor(dev);</td></tr>
|
---|
373 | <tr><td class="num" id="LN268">268</td><td class="line"> <span class='keyword'>if</span> (desc->vendor_id == 0x0a5c</td></tr>
|
---|
374 | <tr><td class="num" id="LN269">269</td><td class="line"> && (desc->product_id == 0x200a</td></tr>
|
---|
375 | <tr><td class="num" id="LN270">270</td><td class="line"> || desc->product_id == 0x2009</td></tr>
|
---|
376 | <tr><td class="num" id="LN271">271</td><td class="line"> || desc->product_id == 0x2035)) {</td></tr>
|
---|
377 | <tr><td class="num" id="LN272">272</td><td class="line"> </td></tr>
|
---|
378 | <tr><td class="num" id="LN273">273</td><td class="line"> new_bt_dev->driver_info = <span class='macro'>BT_WILL_NEED_A_RESET<span class='expansion'>(1 << 2)</span></span> | <span class='macro'>BT_SCO_NOT_WORKING<span class='expansion'>(1 << 1)</span></span>;</td></tr>
|
---|
379 | <tr><td class="num" id="LN274">274</td><td class="line"> </td></tr>
|
---|
380 | <tr><td class="num" id="LN275">275</td><td class="line"> }</td></tr>
|
---|
381 | <tr><td class="num" id="LN276">276</td><td class="line"> <span class='comment'>/*</span></td></tr>
|
---|
382 | <tr><td class="num" id="LN277">277</td><td class="line"> <span class='comment'>else if ( desc->vendor_id == YOUR_VENDOR_HERE</span></td></tr>
|
---|
383 | <tr><td class="num" id="LN278">278</td><td class="line"> <span class='comment'>&& desc->product_id == YOUR_PRODUCT_HERE ) {</span></td></tr>
|
---|
384 | <tr><td class="num" id="LN279">279</td><td class="line"> <span class='comment'>YOUR_SPECIAL_FLAGS_HERE</span></td></tr>
|
---|
385 | <tr><td class="num" id="LN280">280</td><td class="line"> <span class='comment'>}</span></td></tr>
|
---|
386 | <tr><td class="num" id="LN281">281</td><td class="line"> <span class='comment'>*/</span></td></tr>
|
---|
387 | <tr><td class="num" id="LN282">282</td><td class="line"> </td></tr>
|
---|
388 | <tr><td class="num" id="LN283">283</td><td class="line"> <span class='keyword'>if</span> (new_bt_dev->driver_info & <span class='macro'>BT_IGNORE_THIS_DEVICE<span class='expansion'>(1 << 0)</span></span>) {</td></tr>
|
---|
389 | <tr><td class="num" id="LN284">284</td><td class="line"> err = <span class='macro'>ENODEV<span class='expansion'>(((-2147483647 - 1) + 0x7000) + 7)</span></span>;</td></tr>
|
---|
390 | <tr><td class="num" id="LN285">285</td><td class="line"> <span class='keyword'>goto</span> bail;</td></tr>
|
---|
391 | <tr><td class="num" id="LN286">286</td><td class="line"> }</td></tr>
|
---|
392 | <tr><td class="num" id="LN287">287</td><td class="line"> </td></tr>
|
---|
393 | <tr><td class="num" id="LN288">288</td><td class="line"> <span class='comment'>// security check</span></td></tr>
|
---|
394 | <tr><td class="num" id="LN289">289</td><td class="line"> <span class='keyword'>if</span> (config->interface->active->descr->interface_number > 0) {</td></tr>
|
---|
395 | <tr><td class="num" id="LN290">290</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Strange condition happened %d\n"</span>, <span class='keyword'>__func__</span>,<span class='expansion'>dprintf("h2generic: " "%s: Strange condition happened %d\n", __func__<br>, config->interface->active->descr->interface_number<br>)</span></span></td></tr>
|
---|
396 | <tr><td class="num" id="LN291">291</td><td class="line"> <span class='macro'>config->interface->active->descr->interface_number)<span class='expansion'>dprintf("h2generic: " "%s: Strange condition happened %d\n", __func__<br>, config->interface->active->descr->interface_number<br>)</span></span>;</td></tr>
|
---|
397 | <tr><td class="num" id="LN292">292</td><td class="line"> err = <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
398 | <tr><td class="num" id="LN293">293</td><td class="line"> <span class='keyword'>goto</span> bail;</td></tr>
|
---|
399 | <tr><td class="num" id="LN294">294</td><td class="line"> }</td></tr>
|
---|
400 | <tr><td class="num" id="LN295">295</td><td class="line"> </td></tr>
|
---|
401 | <tr><td class="num" id="LN296">296</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: Found %"</span> B_PRIuSIZE <span class='string_literal'>" interfaces. Expected 3\n"</span>, <span class='keyword'>__func__</span>,<span class='expansion'>dprintf("h2generic: " "%s: Found %" "l" "u" " interfaces. Expected 3\n"<br>, __func__, config->interface_count)</span></span></td></tr>
|
---|
402 | <tr><td class="num" id="LN297">297</td><td class="line"> <span class='macro'>config->interface_count)<span class='expansion'>dprintf("h2generic: " "%s: Found %" "l" "u" " interfaces. Expected 3\n"<br>, __func__, config->interface_count)</span></span>;</td></tr>
|
---|
403 | <tr><td class="num" id="LN298">298</td><td class="line"> </td></tr>
|
---|
404 | <tr><td class="num" id="LN299">299</td><td class="line"> <span class='comment'>// Find endpoints that we need</span></td></tr>
|
---|
405 | <tr><td class="num" id="LN300">300</td><td class="line"> uif = config->interface->active;</td></tr>
|
---|
406 | <tr><td class="num" id="LN301">301</td><td class="line"> <span class='keyword'>for</span> (e = 0; e < uif->descr->num_endpoints; e++) {</td></tr>
|
---|
407 | <tr><td class="num" id="LN302">302</td><td class="line"> </td></tr>
|
---|
408 | <tr><td class="num" id="LN303">303</td><td class="line"> ep = &uif->endpoint[e];</td></tr>
|
---|
409 | <tr><td class="num" id="LN304">304</td><td class="line"> <span class='keyword'>switch</span> (ep->descr->attributes & <span class='macro'>USB_ENDPOINT_ATTR_MASK<span class='expansion'>0x03</span></span>) {</td></tr>
|
---|
410 | <tr><td class="num" id="LN305">305</td><td class="line"> <span class='keyword'>case</span> <span class='macro'>USB_ENDPOINT_ATTR_INTERRUPT<span class='expansion'>0x03</span></span>:</td></tr>
|
---|
411 | <tr><td class="num" id="LN306">306</td><td class="line"> <span class='keyword'>if</span> (ep->descr->endpoint_address & <span class='macro'>USB_ENDPOINT_ADDR_DIR_IN<span class='expansion'>0x80</span></span>)</td></tr>
|
---|
412 | <tr><td class="num" id="LN307">307</td><td class="line"> {</td></tr>
|
---|
413 | <tr><td class="num" id="LN308">308</td><td class="line"> new_bt_dev->intr_in_ep = ep;</td></tr>
|
---|
414 | <tr><td class="num" id="LN309">309</td><td class="line"> new_bt_dev->max_packet_size_intr_in</td></tr>
|
---|
415 | <tr><td class="num" id="LN310">310</td><td class="line"> = ep->descr->max_packet_size;</td></tr>
|
---|
416 | <tr><td class="num" id="LN311">311</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: INT in\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: INT in\n", __func__)</span></span>;</td></tr>
|
---|
417 | <tr><td class="num" id="LN312">312</td><td class="line"> } <span class='keyword'>else</span> {</td></tr>
|
---|
418 | <tr><td class="num" id="LN313">313</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: INT out\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: INT out\n", __func__)</span></span>;</td></tr>
|
---|
419 | <tr><td class="num" id="LN314">314</td><td class="line"> }</td></tr>
|
---|
420 | <tr><td class="num" id="LN315">315</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
421 | <tr><td class="num" id="LN316">316</td><td class="line"> </td></tr>
|
---|
422 | <tr><td class="num" id="LN317">317</td><td class="line"> <span class='keyword'>case</span> <span class='macro'>USB_ENDPOINT_ATTR_BULK<span class='expansion'>0x02</span></span>:</td></tr>
|
---|
423 | <tr><td class="num" id="LN318">318</td><td class="line"> <span class='keyword'>if</span> (ep->descr->endpoint_address & <span class='macro'>USB_ENDPOINT_ADDR_DIR_IN<span class='expansion'>0x80</span></span>) {</td></tr>
|
---|
424 | <tr><td class="num" id="LN319">319</td><td class="line"> new_bt_dev->bulk_in_ep = ep;</td></tr>
|
---|
425 | <tr><td class="num" id="LN320">320</td><td class="line"> new_bt_dev->max_packet_size_bulk_in</td></tr>
|
---|
426 | <tr><td class="num" id="LN321">321</td><td class="line"> = ep->descr->max_packet_size;</td></tr>
|
---|
427 | <tr><td class="num" id="LN322">322</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: BULK int\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: BULK int\n", __func__)</span></span>;</td></tr>
|
---|
428 | <tr><td class="num" id="LN323">323</td><td class="line"> } <span class='keyword'>else</span> {</td></tr>
|
---|
429 | <tr><td class="num" id="LN324">324</td><td class="line"> new_bt_dev->bulk_out_ep = ep;</td></tr>
|
---|
430 | <tr><td class="num" id="LN325">325</td><td class="line"> new_bt_dev->max_packet_size_bulk_out</td></tr>
|
---|
431 | <tr><td class="num" id="LN326">326</td><td class="line"> = ep->descr->max_packet_size;</td></tr>
|
---|
432 | <tr><td class="num" id="LN327">327</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: BULK out\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: BULK out\n", __func__)</span></span>;</td></tr>
|
---|
433 | <tr><td class="num" id="LN328">328</td><td class="line"> }</td></tr>
|
---|
434 | <tr><td class="num" id="LN329">329</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
435 | <tr><td class="num" id="LN330">330</td><td class="line"> }</td></tr>
|
---|
436 | <tr><td class="num" id="LN331">331</td><td class="line"> }</td></tr>
|
---|
437 | <tr><td class="num" id="LN332">332</td><td class="line"> </td></tr>
|
---|
438 | <tr><td class="num" id="LN333">333</td><td class="line"> <span class='keyword'>if</span> (!new_bt_dev->bulk_in_ep || !new_bt_dev->bulk_out_ep</td></tr>
|
---|
439 | <tr><td class="num" id="LN334">334</td><td class="line"> || !new_bt_dev->intr_in_ep) {</td></tr>
|
---|
440 | <tr><td class="num" id="LN335">335</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Minimal # endpoints for BT not found\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Minimal # endpoints for BT not found\n"<br>, __func__)</span></span>;</td></tr>
|
---|
441 | <tr><td class="num" id="LN336">336</td><td class="line"> <span class='keyword'>goto</span> bail;</td></tr>
|
---|
442 | <tr><td class="num" id="LN337">337</td><td class="line"> }</td></tr>
|
---|
443 | <tr><td class="num" id="LN338">338</td><td class="line"> </td></tr>
|
---|
444 | <tr><td class="num" id="LN339">339</td><td class="line"> <span class='comment'>// Look into the devices suported to understand this</span></td></tr>
|
---|
445 | <tr><td class="num" id="LN340">340</td><td class="line"> <span class='keyword'>if</span> (new_bt_dev->driver_info & <span class='macro'>BT_DIGIANSWER<span class='expansion'>(1 << 4)</span></span>)</td></tr>
|
---|
446 | <tr><td class="num" id="LN341">341</td><td class="line"> new_bt_dev->ctrl_req = <span class='macro'>USB_TYPE_VENDOR<span class='expansion'>(0x02 << 5)</span></span>;</td></tr>
|
---|
447 | <tr><td class="num" id="LN342">342</td><td class="line"> <span class='keyword'>else</span></td></tr>
|
---|
448 | <tr><td class="num" id="LN343">343</td><td class="line"> new_bt_dev->ctrl_req = <span class='macro'>USB_TYPE_CLASS<span class='expansion'>(0x01 << 5)</span></span>;</td></tr>
|
---|
449 | <tr><td class="num" id="LN344">344</td><td class="line"> </td></tr>
|
---|
450 | <tr><td class="num" id="LN345">345</td><td class="line"> new_bt_dev->connected = <span class='keyword'>true</span>;</td></tr>
|
---|
451 | <tr><td class="num" id="LN346">346</td><td class="line"> </td></tr>
|
---|
452 | <tr><td class="num" id="LN347">347</td><td class="line"> <span class='comment'>// set the cookie that will be passed to other USB</span></td></tr>
|
---|
453 | <tr><td class="num" id="LN348">348</td><td class="line"> <span class='comment'>// hook functions (currently device_removed() is the only other)</span></td></tr>
|
---|
454 | <tr><td class="num" id="LN349">349</td><td class="line"> *cookie = new_bt_dev;</td></tr>
|
---|
455 | <tr><td class="num" id="LN350">350</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: Ok %p\n"</span>, <span class='keyword'>__func__</span>, new_bt_dev)<span class='expansion'>dprintf("h2generic: " "%s: Ok %p\n", __func__, new_bt_dev)</span></span>;</td></tr>
|
---|
456 | <tr><td class="num" id="LN351">351</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>;</td></tr>
|
---|
457 | <tr><td class="num" id="LN352">352</td><td class="line"> </td></tr>
|
---|
458 | <tr><td class="num" id="LN353">353</td><td class="line">bail:</td></tr>
|
---|
459 | <tr><td class="num" id="LN354">354</td><td class="line"> kill_device(new_bt_dev);</td></tr>
|
---|
460 | <tr><td class="num" id="LN355">355</td><td class="line">bail_no_mem:</td></tr>
|
---|
461 | <tr><td class="num" id="LN356">356</td><td class="line"> *cookie = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
462 | <tr><td class="num" id="LN357">357</td><td class="line"> </td></tr>
|
---|
463 | <tr><td class="num" id="LN358">358</td><td class="line"> <span class='keyword'>return</span> err;</td></tr>
|
---|
464 | <tr><td class="num" id="LN359">359</td><td class="line">}</td></tr>
|
---|
465 | <tr><td class="num" id="LN360">360</td><td class="line"> </td></tr>
|
---|
466 | <tr><td class="num" id="LN361">361</td><td class="line"> </td></tr>
|
---|
467 | <tr><td class="num" id="LN362">362</td><td class="line"><span class='comment'>// Called by USB Manager when device is removed from the USB</span></td></tr>
|
---|
468 | <tr><td class="num" id="LN363">363</td><td class="line"><span class='keyword'>static</span> status_t</td></tr>
|
---|
469 | <tr><td class="num" id="LN364">364</td><td class="line">device_removed(<span class='keyword'>void</span>* cookie)</td></tr>
|
---|
470 | <tr><td class="num" id="LN365">365</td><td class="line">{</td></tr>
|
---|
471 | <tr><td class="num" id="LN366">366</td><td class="line"> bt_usb_dev* bdev = fetch_device((bt_usb_dev*)cookie, 0);</td></tr>
|
---|
472 | <tr><td class="num" id="LN367">367</td><td class="line"> </td></tr>
|
---|
473 | <tr><td class="num" id="LN368">368</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: device_removed(%p)\n"</span>, <span class='keyword'>__func__</span>, bdev)<span class='expansion'>dprintf("h2generic: " "%s: device_removed(%p)\n", __func__, bdev<br>)</span></span>;</td></tr>
|
---|
474 | <tr><td class="num" id="LN369">369</td><td class="line"> </td></tr>
|
---|
475 | <tr><td class="num" id="LN370">370</td><td class="line"> <span class='keyword'>if</span> (bdev == <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
476 | <tr><td class="num" id="LN371">371</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Device not present in driver.\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Device not present in driver.\n", __func__<br>)</span></span>;</td></tr>
|
---|
477 | <tr><td class="num" id="LN372">372</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
478 | <tr><td class="num" id="LN373">373</td><td class="line"> }</td></tr>
|
---|
479 | <tr><td class="num" id="LN374">374</td><td class="line"> </td></tr>
|
---|
480 | <tr><td class="num" id="LN375">375</td><td class="line"> <span class='keyword'>if</span> (!TEST_AND_CLEAR(&bdev->state, RUNNING))</td></tr>
|
---|
481 | <tr><td class="num" id="LN376">376</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: wasnt running?\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: wasnt running?\n", __func__)</span></span>;</td></tr>
|
---|
482 | <tr><td class="num" id="LN377">377</td><td class="line"> </td></tr>
|
---|
483 | <tr><td class="num" id="LN378">378</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: Cancelling queues...\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Cancelling queues...\n", __func__)</span></span>;</td></tr>
|
---|
484 | <tr><td class="num" id="LN379">379</td><td class="line"> <span class='keyword'>if</span> (bdev->intr_in_ep != <span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
485 | <tr><td class="num" id="LN380">380</td><td class="line"> usb->cancel_queued_transfers(bdev->intr_in_ep->handle);</td></tr>
|
---|
486 | <tr><td class="num" id="LN381">381</td><td class="line"> <span class='keyword'>if</span> (bdev->bulk_in_ep != <span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
487 | <tr><td class="num" id="LN382">382</td><td class="line"> usb->cancel_queued_transfers(bdev->bulk_in_ep->handle);</td></tr>
|
---|
488 | <tr><td class="num" id="LN383">383</td><td class="line"> <span class='keyword'>if</span> (bdev->bulk_out_ep != <span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
489 | <tr><td class="num" id="LN384">384</td><td class="line"> usb->cancel_queued_transfers(bdev->bulk_out_ep->handle);</td></tr>
|
---|
490 | <tr><td class="num" id="LN385">385</td><td class="line"> </td></tr>
|
---|
491 | <tr><td class="num" id="LN386">386</td><td class="line"> bdev->connected = <span class='keyword'>false</span>;</td></tr>
|
---|
492 | <tr><td class="num" id="LN387">387</td><td class="line"> </td></tr>
|
---|
493 | <tr><td class="num" id="LN388">388</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>;</td></tr>
|
---|
494 | <tr><td class="num" id="LN389">389</td><td class="line">}</td></tr>
|
---|
495 | <tr><td class="num" id="LN390">390</td><td class="line"> </td></tr>
|
---|
496 | <tr><td class="num" id="LN391">391</td><td class="line"> </td></tr>
|
---|
497 | <tr><td class="num" id="LN392">392</td><td class="line"><span class='keyword'>static</span> bt_hci_transport_hooks bluetooth_hooks = {</td></tr>
|
---|
498 | <tr><td class="num" id="LN393">393</td><td class="line"> <span class='macro'>NULL<span class='expansion'>__null</span></span>,</td></tr>
|
---|
499 | <tr><td class="num" id="LN394">394</td><td class="line"> &submit_nbuffer,</td></tr>
|
---|
500 | <tr><td class="num" id="LN395">395</td><td class="line"> &submit_nbuffer,</td></tr>
|
---|
501 | <tr><td class="num" id="LN396">396</td><td class="line"> <span class='macro'>NULL<span class='expansion'>__null</span></span>,</td></tr>
|
---|
502 | <tr><td class="num" id="LN397">397</td><td class="line"> <span class='macro'>NULL<span class='expansion'>__null</span></span>,</td></tr>
|
---|
503 | <tr><td class="num" id="LN398">398</td><td class="line"> H2</td></tr>
|
---|
504 | <tr><td class="num" id="LN399">399</td><td class="line">};</td></tr>
|
---|
505 | <tr><td class="num" id="LN400">400</td><td class="line"> </td></tr>
|
---|
506 | <tr><td class="num" id="LN401">401</td><td class="line"> </td></tr>
|
---|
507 | <tr><td class="num" id="LN402">402</td><td class="line"><span class='keyword'>static</span> usb_notify_hooks notify_hooks = {</td></tr>
|
---|
508 | <tr><td class="num" id="LN403">403</td><td class="line"> &device_added,</td></tr>
|
---|
509 | <tr><td class="num" id="LN404">404</td><td class="line"> &device_removed</td></tr>
|
---|
510 | <tr><td class="num" id="LN405">405</td><td class="line">};</td></tr>
|
---|
511 | <tr><td class="num" id="LN406">406</td><td class="line"> </td></tr>
|
---|
512 | <tr><td class="num" id="LN407">407</td><td class="line"><span class='directive'>#if 0</span></td></tr>
|
---|
513 | <tr><td class="num" id="LN408">408</td><td class="line"><span class='directive'>#pragma mark -</span></td></tr>
|
---|
514 | <tr><td class="num" id="LN409">409</td><td class="line"><span class='directive'>#endif</span></td></tr>
|
---|
515 | <tr><td class="num" id="LN410">410</td><td class="line"> </td></tr>
|
---|
516 | <tr><td class="num" id="LN411">411</td><td class="line">status_t</td></tr>
|
---|
517 | <tr><td class="num" id="LN412">412</td><td class="line">submit_nbuffer(hci_id hid, net_buffer* nbuf)</td></tr>
|
---|
518 | <tr><td class="num" id="LN413">413</td><td class="line">{</td></tr>
|
---|
519 | <tr><td class="num" id="LN414">414</td><td class="line"> bt_usb_dev* bdev = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
520 | <tr><td class="num" id="LN415">415</td><td class="line"> </td></tr>
|
---|
521 | <tr><td class="num" id="LN416">416</td><td class="line"> bdev = fetch_device(<span class='macro'>NULL<span class='expansion'>__null</span></span>, hid);</td></tr>
|
---|
522 | <tr><td class="num" id="LN417">417</td><td class="line"> </td></tr>
|
---|
523 | <tr><td class="num" id="LN418">418</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: index=%"</span> B_PRId32 <span class='string_literal'>" nbuf=%p bdev=%p\n"</span>, <span class='keyword'>__func__</span>, hid,<span class='expansion'>dprintf("h2generic: " "%s: index=%" "" "d" " nbuf=%p bdev=%p\n"<br>, __func__, hid, nbuf, bdev)</span></span></td></tr>
|
---|
524 | <tr><td class="num" id="LN419">419</td><td class="line"> <span class='macro'>nbuf, bdev)<span class='expansion'>dprintf("h2generic: " "%s: index=%" "" "d" " nbuf=%p bdev=%p\n"<br>, __func__, hid, nbuf, bdev)</span></span>;</td></tr>
|
---|
525 | <tr><td class="num" id="LN420">420</td><td class="line"> </td></tr>
|
---|
526 | <tr><td class="num" id="LN421">421</td><td class="line"> <span class='keyword'>if</span> (bdev != <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
527 | <tr><td class="num" id="LN422">422</td><td class="line"> <span class='keyword'>switch</span> (nbuf->protocol) {</td></tr>
|
---|
528 | <tr><td class="num" id="LN423">423</td><td class="line"> <span class='keyword'>case</span> BT_COMMAND:</td></tr>
|
---|
529 | <tr><td class="num" id="LN424">424</td><td class="line"> <span class='comment'>// not issued this way</span></td></tr>
|
---|
530 | <tr><td class="num" id="LN425">425</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
531 | <tr><td class="num" id="LN426">426</td><td class="line"> </td></tr>
|
---|
532 | <tr><td class="num" id="LN427">427</td><td class="line"> <span class='keyword'>case</span> BT_ACL:</td></tr>
|
---|
533 | <tr><td class="num" id="LN428">428</td><td class="line"> <span class='keyword'>return</span> submit_tx_acl(bdev, nbuf);</td></tr>
|
---|
534 | <tr><td class="num" id="LN429">429</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
535 | <tr><td class="num" id="LN430">430</td><td class="line"> </td></tr>
|
---|
536 | <tr><td class="num" id="LN431">431</td><td class="line"> <span class='keyword'>default</span>:</td></tr>
|
---|
537 | <tr><td class="num" id="LN432">432</td><td class="line"> panic(<span class='string_literal'>"submit_nbuffer: no protocol"</span>);</td></tr>
|
---|
538 | <tr><td class="num" id="LN433">433</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
539 | <tr><td class="num" id="LN434">434</td><td class="line"> </td></tr>
|
---|
540 | <tr><td class="num" id="LN435">435</td><td class="line"> }</td></tr>
|
---|
541 | <tr><td class="num" id="LN436">436</td><td class="line"> }</td></tr>
|
---|
542 | <tr><td class="num" id="LN437">437</td><td class="line"> </td></tr>
|
---|
543 | <tr><td class="num" id="LN438">438</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
544 | <tr><td class="num" id="LN439">439</td><td class="line"> </td></tr>
|
---|
545 | <tr><td class="num" id="LN440">440</td><td class="line">}</td></tr>
|
---|
546 | <tr><td class="num" id="LN441">441</td><td class="line"> </td></tr>
|
---|
547 | <tr><td class="num" id="LN442">442</td><td class="line"> </td></tr>
|
---|
548 | <tr><td class="num" id="LN443">443</td><td class="line"><span class='comment'>// implements the POSIX open()</span></td></tr>
|
---|
549 | <tr><td class="num" id="LN444">444</td><td class="line"><span class='keyword'>static</span> status_t</td></tr>
|
---|
550 | <tr><td class="num" id="LN445">445</td><td class="line">device_open(<span class='keyword'>const</span> <span class='keyword'>char</span>* name, uint32 flags, <span class='keyword'>void</span> **cookie)</td></tr>
|
---|
551 | <tr><td class="num" id="LN446">446</td><td class="line">{</td></tr>
|
---|
552 | <tr><td class="num" id="LN447">447</td><td class="line"> <span class='macro'>CALLED()<span class='expansion'>dprintf("h2generic: " "h2generic: CALLED %s\n", __PRETTY_FUNCTION__<br>)</span></span>;</td></tr>
|
---|
553 | <tr><td class="num" id="LN448">448</td><td class="line"> </td></tr>
|
---|
554 | <tr><td class="num" id="LN449">449</td><td class="line"> status_t err = <span class='macro'>ENODEV<span class='expansion'>(((-2147483647 - 1) + 0x7000) + 7)</span></span>;</td></tr>
|
---|
555 | <tr><td class="num" id="LN450">450</td><td class="line"> bt_usb_dev* bdev = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
556 | <tr><td class="num" id="LN451">451</td><td class="line"> hci_id hdev;</td></tr>
|
---|
557 | <tr><td class="num" id="LN452">452</td><td class="line"> <span class='keyword'>int</span> i;</td></tr>
|
---|
558 | <tr><td class="num" id="LN453">453</td><td class="line"> </td></tr>
|
---|
559 | <tr><td class="num" id="LN454">454</td><td class="line"> acquire_sem(dev_table_sem);</td></tr>
|
---|
560 | <tr><td class="num" id="LN455">455</td><td class="line"> <span class='keyword'>for</span> (i = 0; i < <span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span>; i++) {</td></tr>
|
---|
561 | <tr><td class="num" id="LN456">456</td><td class="line"> <span class='keyword'>if</span> (bt_usb_devices[i] && !strcmp(name, bt_usb_devices[i]->name)) {</td></tr>
|
---|
562 | <tr><td class="num" id="LN457">457</td><td class="line"> bdev = bt_usb_devices[i];</td></tr>
|
---|
563 | <tr><td class="num" id="LN458">458</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
564 | <tr><td class="num" id="LN459">459</td><td class="line"> }</td></tr>
|
---|
565 | <tr><td class="num" id="LN460">460</td><td class="line"> }</td></tr>
|
---|
566 | <tr><td class="num" id="LN461">461</td><td class="line"> release_sem_etc(dev_table_sem, 1, B_DO_NOT_RESCHEDULE);</td></tr>
|
---|
567 | <tr><td class="num" id="LN462">462</td><td class="line"> </td></tr>
|
---|
568 | <tr><td class="num" id="LN463">463</td><td class="line"> <span class='keyword'>if</span> (bdev == <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
569 | <tr><td class="num" id="LN464">464</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Device not found in the open list!"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Device not found in the open list!"<br>, __func__)</span></span>;</td></tr>
|
---|
570 | <tr><td class="num" id="LN465">465</td><td class="line"> *cookie = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
571 | <tr><td class="num" id="LN466">466</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
572 | <tr><td class="num" id="LN467">467</td><td class="line"> }</td></tr>
|
---|
573 | <tr><td class="num" id="LN468">468</td><td class="line"> </td></tr>
|
---|
574 | <tr><td class="num" id="LN469">469</td><td class="line"> <span class='comment'>// Set RUNNING</span></td></tr>
|
---|
575 | <tr><td class="num" id="LN470">470</td><td class="line"> <span class='keyword'>if</span> (TEST_AND_SET(&bdev->state, RUNNING)) {</td></tr>
|
---|
576 | <tr><td class="num" id="LN471">471</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: dev already running! - reOpened device!\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: dev already running! - reOpened device!\n"<br>, __func__)</span></span>;</td></tr>
|
---|
577 | <tr><td class="num" id="LN472">472</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
578 | <tr><td class="num" id="LN473">473</td><td class="line"> }</td></tr>
|
---|
579 | <tr><td class="num" id="LN474">474</td><td class="line"> </td></tr>
|
---|
580 | <tr><td class="num" id="LN475">475</td><td class="line"> acquire_sem(bdev->lock);</td></tr>
|
---|
581 | <tr><td class="num" id="LN476">476</td><td class="line"> <span class='comment'>// TX structures</span></td></tr>
|
---|
582 | <tr><td class="num" id="LN477">477</td><td class="line"> <span class='keyword'>for</span> (i = 0; i < <span class='macro'>BT_DRIVER_TXCOVERAGE<span class='expansion'>(1 + 1 + 0 + 0)</span></span>; i++) {</td></tr>
|
---|
583 | <tr><td class="num" id="LN478">478</td><td class="line"> list_init(&bdev->nbuffersTx[i]);</td></tr>
|
---|
584 | <tr><td class="num" id="LN479">479</td><td class="line"> bdev->nbuffersPendingTx[i] = 0;</td></tr>
|
---|
585 | <tr><td class="num" id="LN480">480</td><td class="line"> }</td></tr>
|
---|
586 | <tr><td class="num" id="LN481">481</td><td class="line"> </td></tr>
|
---|
587 | <tr><td class="num" id="LN482">482</td><td class="line"> <span class='comment'>// RX structures</span></td></tr>
|
---|
588 | <tr><td class="num" id="LN483">483</td><td class="line"> bdev->eventRx = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
589 | <tr><td class="num" id="LN484">484</td><td class="line"> <span class='keyword'>for</span> (i = 0; i < <span class='macro'>BT_DRIVER_RXCOVERAGE<span class='expansion'>(1 + 1 + 0 + 0)</span></span>; i++) {</td></tr>
|
---|
590 | <tr><td class="num" id="LN485">485</td><td class="line"> bdev->nbufferRx[i] = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
591 | <tr><td class="num" id="LN486">486</td><td class="line"> }</td></tr>
|
---|
592 | <tr><td class="num" id="LN487">487</td><td class="line"> </td></tr>
|
---|
593 | <tr><td class="num" id="LN488">488</td><td class="line"> <span class='comment'>// dumping the USB frames</span></td></tr>
|
---|
594 | <tr><td class="num" id="LN489">489</td><td class="line"> init_room(&bdev->eventRoom);</td></tr>
|
---|
595 | <tr><td class="num" id="LN490">490</td><td class="line"> init_room(&bdev->aclRoom);</td></tr>
|
---|
596 | <tr><td class="num" id="LN491">491</td><td class="line"> <span class='comment'>// init_room(new_bt_dev->scoRoom);</span></td></tr>
|
---|
597 | <tr><td class="num" id="LN492">492</td><td class="line"> </td></tr>
|
---|
598 | <tr><td class="num" id="LN493">493</td><td class="line"> list_init(&bdev->snetBufferRecycleTrash);</td></tr>
|
---|
599 | <tr><td class="num" id="LN494">494</td><td class="line"> </td></tr>
|
---|
600 | <tr><td class="num" id="LN495">495</td><td class="line"> <span class='comment'>// Allocate set and register the HCI device</span></td></tr>
|
---|
601 | <tr><td class="num" id="LN496">496</td><td class="line"> <span class='keyword'>if</span> (btDevices != <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
602 | <tr><td class="num" id="LN497">497</td><td class="line"> bluetooth_device* ndev;</td></tr>
|
---|
603 | <tr><td class="num" id="LN498">498</td><td class="line"> <span class='comment'>// TODO: Fill the transport descriptor</span></td></tr>
|
---|
604 | <tr><td class="num" id="LN499">499</td><td class="line"> err = btDevices->RegisterDriver(&bluetooth_hooks, &ndev);</td></tr>
|
---|
605 | <tr><td class="num" id="LN500">500</td><td class="line"> </td></tr>
|
---|
606 | <tr><td class="num" id="LN501">501</td><td class="line"> <span class='keyword'>if</span> (err == <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>) {</td></tr>
|
---|
607 | <tr><td class="num" id="LN502">502</td><td class="line"> bdev->hdev = hdev = ndev->index; <span class='comment'>// Get the index</span></td></tr>
|
---|
608 | <tr><td class="num" id="LN503">503</td><td class="line"> bdev->ndev = ndev; <span class='comment'>// Get the net_device</span></td></tr>
|
---|
609 | <tr><td class="num" id="LN504">504</td><td class="line"> </td></tr>
|
---|
610 | <tr><td class="num" id="LN505">505</td><td class="line"> } <span class='keyword'>else</span> {</td></tr>
|
---|
611 | <tr><td class="num" id="LN506">506</td><td class="line"> hdev = bdev->num; <span class='comment'>// XXX: Lets try to go on</span></td></tr>
|
---|
612 | <tr><td class="num" id="LN507">507</td><td class="line"> }</td></tr>
|
---|
613 | <tr><td class="num" id="LN508">508</td><td class="line"> } <span class='keyword'>else</span> {</td></tr>
|
---|
614 | <tr><td class="num" id="LN509">509</td><td class="line"> hdev = bdev->num; <span class='comment'>// XXX: Lets try to go on</span></td></tr>
|
---|
615 | <tr><td class="num" id="LN510">510</td><td class="line"> }</td></tr>
|
---|
616 | <tr><td class="num" id="LN511">511</td><td class="line"> </td></tr>
|
---|
617 | <tr><td class="num" id="LN512">512</td><td class="line"> bdev->hdev = hdev;</td></tr>
|
---|
618 | <tr><td class="num" id="LN513">513</td><td class="line"> </td></tr>
|
---|
619 | <tr><td class="num" id="LN514">514</td><td class="line"> *cookie = bdev;</td></tr>
|
---|
620 | <tr><td class="num" id="LN515">515</td><td class="line"> release_sem(bdev->lock);</td></tr>
|
---|
621 | <tr><td class="num" id="LN516">516</td><td class="line"> </td></tr>
|
---|
622 | <tr><td class="num" id="LN517">517</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>;</td></tr>
|
---|
623 | <tr><td class="num" id="LN518">518</td><td class="line"> </td></tr>
|
---|
624 | <tr><td class="num" id="LN519">519</td><td class="line">}</td></tr>
|
---|
625 | <tr><td class="num" id="LN520">520</td><td class="line"> </td></tr>
|
---|
626 | <tr><td class="num" id="LN521">521</td><td class="line"> </td></tr>
|
---|
627 | <tr><td class="num" id="LN522">522</td><td class="line"><span class='comment'>/* called when a client calls POSIX close() on the driver, but I/O</span></td></tr>
|
---|
628 | <tr><td class="num" id="LN523">523</td><td class="line"> <span class='comment'>* requests may still be pending</span></td></tr>
|
---|
629 | <tr><td class="num" id="LN524">524</td><td class="line"> <span class='comment'>*/</span></td></tr>
|
---|
630 | <tr><td class="num" id="LN525">525</td><td class="line"><span class='keyword'>static</span> status_t</td></tr>
|
---|
631 | <tr><td class="num" id="LN526">526</td><td class="line">device_close(<span class='keyword'>void</span>* cookie)</td></tr>
|
---|
632 | <tr><td class="num" id="LN527">527</td><td class="line">{</td></tr>
|
---|
633 | <tr><td class="num" id="LN528">528</td><td class="line"> <span class='macro'>CALLED()<span class='expansion'>dprintf("h2generic: " "h2generic: CALLED %s\n", __PRETTY_FUNCTION__<br>)</span></span>;</td></tr>
|
---|
634 | <tr><td class="num" id="LN529">529</td><td class="line"> </td></tr>
|
---|
635 | <tr><td class="num" id="LN530">530</td><td class="line"> int32 i;</td></tr>
|
---|
636 | <tr><td class="num" id="LN531">531</td><td class="line"> <span class='keyword'>void</span>* item;</td></tr>
|
---|
637 | <tr><td class="num" id="LN532">532</td><td class="line"> bt_usb_dev* bdev = (bt_usb_dev*)cookie;</td></tr>
|
---|
638 | <tr><td class="num" id="LN533">533</td><td class="line"> </td></tr>
|
---|
639 | <tr><td class="num" id="LN534">534</td><td class="line"> <span class='keyword'>if</span> (bdev == <span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
640 | <tr><td class="num" id="LN535">535</td><td class="line"> panic(<span class='string_literal'>"bad cookie"</span>);</td></tr>
|
---|
641 | <tr><td class="num" id="LN536">536</td><td class="line"> </td></tr>
|
---|
642 | <tr><td class="num" id="LN537">537</td><td class="line"> <span class='comment'>// Clean queues</span></td></tr>
|
---|
643 | <tr><td class="num" id="LN538">538</td><td class="line"> </td></tr>
|
---|
644 | <tr><td class="num" id="LN539">539</td><td class="line"> <span class='keyword'>if</span> (bdev->connected == <span class='keyword'>true</span>) {</td></tr>
|
---|
645 | <tr><td class="num" id="LN540">540</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: Cancelling queues...\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Cancelling queues...\n", __func__)</span></span>;</td></tr>
|
---|
646 | <tr><td class="num" id="LN541">541</td><td class="line"> </td></tr>
|
---|
647 | <tr><td class="num" id="LN542">542</td><td class="line"> <span class='keyword'>if</span> (bdev->intr_in_ep != <span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
648 | <tr><td class="num" id="LN543">543</td><td class="line"> usb->cancel_queued_transfers(bdev->intr_in_ep->handle);</td></tr>
|
---|
649 | <tr><td class="num" id="LN544">544</td><td class="line"> </td></tr>
|
---|
650 | <tr><td class="num" id="LN545">545</td><td class="line"> <span class='keyword'>if</span> (bdev->bulk_in_ep!=<span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
651 | <tr><td class="num" id="LN546">546</td><td class="line"> usb->cancel_queued_transfers(bdev->bulk_in_ep->handle);</td></tr>
|
---|
652 | <tr><td class="num" id="LN547">547</td><td class="line"> </td></tr>
|
---|
653 | <tr><td class="num" id="LN548">548</td><td class="line"> <span class='keyword'>if</span> (bdev->bulk_out_ep!=<span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
654 | <tr><td class="num" id="LN549">549</td><td class="line"> usb->cancel_queued_transfers(bdev->bulk_out_ep->handle);</td></tr>
|
---|
655 | <tr><td class="num" id="LN550">550</td><td class="line"> }</td></tr>
|
---|
656 | <tr><td class="num" id="LN551">551</td><td class="line"> </td></tr>
|
---|
657 | <tr><td class="num" id="LN552">552</td><td class="line"> <span class='comment'>// TX</span></td></tr>
|
---|
658 | <tr><td class="num" id="LN553">553</td><td class="line"> <span class='keyword'>for</span> (i = 0; i < <span class='macro'>BT_DRIVER_TXCOVERAGE<span class='expansion'>(1 + 1 + 0 + 0)</span></span>; i++) {</td></tr>
|
---|
659 | <tr><td class="num" id="LN554">554</td><td class="line"> <span class='keyword'>if</span> (i == BT_COMMAND) {</td></tr>
|
---|
660 | <tr><td class="num" id="LN555">555</td><td class="line"> <span class='keyword'>while</span> ((item = list_remove_head_item(&bdev->nbuffersTx[i])) != <span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
661 | <tr><td class="num" id="LN556">556</td><td class="line"> snb_free((snet_buffer*)item);</td></tr>
|
---|
662 | <tr><td class="num" id="LN557">557</td><td class="line"> } <span class='keyword'>else</span> {</td></tr>
|
---|
663 | <tr><td class="num" id="LN558">558</td><td class="line"> <span class='keyword'>while</span> ((item = list_remove_head_item(&bdev->nbuffersTx[i])) != <span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
664 | <tr><td class="num" id="LN559">559</td><td class="line"> nb_destroy((net_buffer*)item);</td></tr>
|
---|
665 | <tr><td class="num" id="LN560">560</td><td class="line"> }</td></tr>
|
---|
666 | <tr><td class="num" id="LN561">561</td><td class="line"> }</td></tr>
|
---|
667 | <tr><td class="num" id="LN562">562</td><td class="line"> <span class='comment'>// RX</span></td></tr>
|
---|
668 | <tr><td class="num" id="LN563">563</td><td class="line"> <span class='keyword'>for</span> (i = 0; i < <span class='macro'>BT_DRIVER_RXCOVERAGE<span class='expansion'>(1 + 1 + 0 + 0)</span></span>; i++) {</td></tr>
|
---|
669 | <tr><td class="num" id="LN564">564</td><td class="line"> nb_destroy(bdev->nbufferRx[i]);</td></tr>
|
---|
670 | <tr><td class="num" id="LN565">565</td><td class="line"> }</td></tr>
|
---|
671 | <tr><td class="num" id="LN566">566</td><td class="line"> snb_free(bdev->eventRx);</td></tr>
|
---|
672 | <tr><td class="num" id="LN567">567</td><td class="line"> </td></tr>
|
---|
673 | <tr><td class="num" id="LN568">568</td><td class="line"> purge_room(&bdev->eventRoom);</td></tr>
|
---|
674 | <tr><td class="num" id="LN569">569</td><td class="line"> purge_room(&bdev->aclRoom);</td></tr>
|
---|
675 | <tr><td class="num" id="LN570">570</td><td class="line"> </td></tr>
|
---|
676 | <tr><td class="num" id="LN571">571</td><td class="line"> <span class='comment'>// Device no longer in our Stack</span></td></tr>
|
---|
677 | <tr><td class="num" id="LN572">572</td><td class="line"> <span class='keyword'>if</span> (btDevices != <span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
678 | <tr><td class="num" id="LN573">573</td><td class="line"> btDevices->UnregisterDriver(bdev->hdev);</td></tr>
|
---|
679 | <tr><td class="num" id="LN574">574</td><td class="line"> </td></tr>
|
---|
680 | <tr><td class="num" id="LN575">575</td><td class="line"> <span class='comment'>// unSet RUNNING</span></td></tr>
|
---|
681 | <tr><td class="num" id="LN576">576</td><td class="line"> <span class='keyword'>if</span> (TEST_AND_CLEAR(&bdev->state, RUNNING)) {</td></tr>
|
---|
682 | <tr><td class="num" id="LN577">577</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: %s not running?\n"</span>, <span class='keyword'>__func__</span>, bdev->name)<span class='expansion'>dprintf("h2generic: " "%s: %s not running?\n", __func__, bdev<br>->name)</span></span>;</td></tr>
|
---|
683 | <tr><td class="num" id="LN578">578</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
684 | <tr><td class="num" id="LN579">579</td><td class="line"> }</td></tr>
|
---|
685 | <tr><td class="num" id="LN580">580</td><td class="line"> </td></tr>
|
---|
686 | <tr><td class="num" id="LN581">581</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>;</td></tr>
|
---|
687 | <tr><td class="num" id="LN582">582</td><td class="line">}</td></tr>
|
---|
688 | <tr><td class="num" id="LN583">583</td><td class="line"> </td></tr>
|
---|
689 | <tr><td class="num" id="LN584">584</td><td class="line"> </td></tr>
|
---|
690 | <tr><td class="num" id="LN585">585</td><td class="line"><span class='comment'>// Called after device_close(), when all pending I / O requests have returned</span></td></tr>
|
---|
691 | <tr><td class="num" id="LN586">586</td><td class="line"><span class='keyword'>static</span> status_t</td></tr>
|
---|
692 | <tr><td class="num" id="LN587">587</td><td class="line">device_free(<span class='keyword'>void</span>* cookie)</td></tr>
|
---|
693 | <tr><td class="num" id="LN588">588</td><td class="line">{</td></tr>
|
---|
694 | <tr><td class="num" id="LN589">589</td><td class="line"> <span class='macro'>CALLED()<span class='expansion'>dprintf("h2generic: " "h2generic: CALLED %s\n", __PRETTY_FUNCTION__<br>)</span></span>;</td></tr>
|
---|
695 | <tr><td class="num" id="LN590">590</td><td class="line"> </td></tr>
|
---|
696 | <tr><td class="num" id="LN591">591</td><td class="line"> status_t err = <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>;</td></tr>
|
---|
697 | <tr><td class="num" id="LN592">592</td><td class="line"> bt_usb_dev* bdev = (bt_usb_dev*)cookie;</td></tr>
|
---|
698 | <tr><td class="num" id="LN593">593</td><td class="line"> </td></tr>
|
---|
699 | <tr><td class="num" id="LN594">594</td><td class="line"> <span class='keyword'>if</span> (!bdev->connected)</td></tr>
|
---|
700 | <tr><td class="num" id="LN595">595</td><td class="line"> kill_device(bdev);</td></tr>
|
---|
701 | <tr><td class="num" id="LN596">596</td><td class="line"> </td></tr>
|
---|
702 | <tr><td class="num" id="LN597">597</td><td class="line"> <span class='keyword'>return</span> err;</td></tr>
|
---|
703 | <tr><td class="num" id="LN598">598</td><td class="line">}</td></tr>
|
---|
704 | <tr><td class="num" id="LN599">599</td><td class="line"> </td></tr>
|
---|
705 | <tr><td class="num" id="LN600">600</td><td class="line"> </td></tr>
|
---|
706 | <tr><td class="num" id="LN601">601</td><td class="line"><span class='comment'>// implements the POSIX ioctl()</span></td></tr>
|
---|
707 | <tr><td class="num" id="LN602">602</td><td class="line"><span class='keyword'>static</span> status_t</td></tr>
|
---|
708 | <tr><td class="num" id="LN603">603</td><td class="line">device_control(<span class='keyword'>void</span>* cookie, uint32 msg, <span class='keyword'>void</span>* params, size_t size)</td></tr>
|
---|
709 | <tr><td class="num" id="LN604">604</td><td class="line">{</td></tr>
|
---|
710 | <tr><td class="num" id="LN605">605</td><td class="line"> status_t err = <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
711 | <tr><td class="num" id="LN606">606</td><td class="line"> bt_usb_dev* bdev = (bt_usb_dev*)cookie;</td></tr>
|
---|
712 | <tr><td class="num" id="LN607">607</td><td class="line"> snet_buffer* snbuf;</td></tr>
|
---|
713 | <tr><td class="num" id="LN608">608</td><td class="line"> <span class='directive'>#if <span class='macro'>BT_DRIVER_SUPPORTS_ACL<span class='expansion'>1</span></span> // ACL</span></td></tr>
|
---|
714 | <tr><td class="num" id="LN609">609</td><td class="line"> int32 i;</td></tr>
|
---|
715 | <tr><td class="num" id="LN610">610</td><td class="line"> <span class='directive'>#endif</span></td></tr>
|
---|
716 | <tr><td class="num" id="LN611">611</td><td class="line"> </td></tr>
|
---|
717 | <tr><td class="num" id="LN612">612</td><td class="line"> <span class='macro'>TOUCH(size)<span class='expansion'>((void)(size))</span></span>;</td></tr>
|
---|
718 | <tr><td class="num" id="LN613">613</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: ioctl() opcode %"</span> B_PRId32 <span class='string_literal'>" size %"</span> B_PRIuSIZE <span class='string_literal'>".\n"</span>, <span class='keyword'>__func__</span>,<span class='expansion'>dprintf("h2generic: " "%s: ioctl() opcode %" "" "d" " size %"<br> "l" "u" ".\n", __func__, msg, size)</span></span></td></tr>
|
---|
719 | <tr><td class="num" id="LN614">614</td><td class="line"> <span class='macro'>msg, size)<span class='expansion'>dprintf("h2generic: " "%s: ioctl() opcode %" "" "d" " size %"<br> "l" "u" ".\n", __func__, msg, size)</span></span>;</td></tr>
|
---|
720 | <tr><td class="num" id="LN615">615</td><td class="line"> </td></tr>
|
---|
721 | <tr><td class="num" id="LN616">616</td><td class="line"> <span class='keyword'>if</span> (bdev == <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
722 | <tr><td class="num" id="LN617">617</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: Bad cookie\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Bad cookie\n", __func__)</span></span>;</td></tr>
|
---|
723 | <tr><td class="num" id="LN618">618</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_BAD_VALUE<span class='expansion'>((-2147483647 - 1) + 5)</span></span>;</td></tr>
|
---|
724 | <tr><td class="num" id="LN619">619</td><td class="line"> }</td></tr>
|
---|
725 | <tr><td class="num" id="LN620">620</td><td class="line"> </td></tr>
|
---|
726 | <tr><td class="num" id="LN621">621</td><td class="line"> <span class='keyword'>if</span> (params == <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
727 | <tr><td class="num" id="LN622">622</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: Invalid pointer control\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Invalid pointer control\n", __func__<br>)</span></span>;</td></tr>
|
---|
728 | <tr><td class="num" id="LN623">623</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_BAD_VALUE<span class='expansion'>((-2147483647 - 1) + 5)</span></span>;</td></tr>
|
---|
729 | <tr><td class="num" id="LN624">624</td><td class="line"> }</td></tr>
|
---|
730 | <tr><td class="num" id="LN625">625</td><td class="line"> </td></tr>
|
---|
731 | <tr><td class="num" id="LN626">626</td><td class="line"> acquire_sem(bdev->lock);</td></tr>
|
---|
732 | <tr><td class="num" id="LN627">627</td><td class="line"> </td></tr>
|
---|
733 | <tr><td class="num" id="LN628">628</td><td class="line"> <span class='keyword'>switch</span> (msg) {</td></tr>
|
---|
734 | <tr><td class="num" id="LN629">629</td><td class="line"> <span class='keyword'>case</span> ISSUE_BT_COMMAND:</td></tr>
|
---|
735 | <tr><td class="num" id="LN630">630</td><td class="line"><span class='directive'>#ifdef BT_IOCTLS_PASS_SIZE</span></td></tr>
|
---|
736 | <tr><td class="num" id="LN631">631</td><td class="line"> <span class='keyword'>if</span> (size == 0) {</td></tr>
|
---|
737 | <tr><td class="num" id="LN632">632</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: Invalid size control\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Invalid size control\n", __func__)</span></span>;</td></tr>
|
---|
738 | <tr><td class="num" id="LN633">633</td><td class="line"> err = <span class='macro'>B_BAD_VALUE<span class='expansion'>((-2147483647 - 1) + 5)</span></span>;</td></tr>
|
---|
739 | <tr><td class="num" id="LN634">634</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
740 | <tr><td class="num" id="LN635">635</td><td class="line"> }</td></tr>
|
---|
741 | <tr><td class="num" id="LN636">636</td><td class="line"><span class='directive'>#else</span></td></tr>
|
---|
742 | <tr><td class="num" id="LN637">637</td><td class="line"> size = (*((size_t*)params));</td></tr>
|
---|
743 | <tr><td class="num" id="LN638">638</td><td class="line"> (*(size_t**)&params)++;</td></tr>
|
---|
744 | <tr><td class="num" id="LN639">639</td><td class="line"><span class='directive'>#endif</span></td></tr>
|
---|
745 | <tr><td class="num" id="LN640">640</td><td class="line"> </td></tr>
|
---|
746 | <tr><td class="num" id="LN641">641</td><td class="line"> <span class='comment'>// TODO: Reuse from some TXcompleted queue</span></td></tr>
|
---|
747 | <tr><td class="num" id="LN642">642</td><td class="line"> <span class='comment'>// snbuf = snb_create(size);</span></td></tr>
|
---|
748 | <tr><td class="num" id="LN643">643</td><td class="line"> snbuf = snb_fetch(&bdev->snetBufferRecycleTrash, size);</td></tr>
|
---|
749 | <tr><td class="num" id="LN644">644</td><td class="line"> snb_put(snbuf, params, size);</td></tr>
|
---|
750 | <tr><td class="num" id="LN645">645</td><td class="line"> </td></tr>
|
---|
751 | <tr><td class="num" id="LN646">646</td><td class="line"> err = submit_tx_command(bdev, snbuf);</td></tr>
|
---|
752 | <tr><td class="num" id="LN647">647</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: command launched\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: command launched\n", __func__)</span></span>;</td></tr>
|
---|
753 | <tr><td class="num" id="LN648">648</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
754 | <tr><td class="num" id="LN649">649</td><td class="line"> </td></tr>
|
---|
755 | <tr><td class="num" id="LN650">650</td><td class="line"> <span class='keyword'>case</span> BT_UP:</td></tr>
|
---|
756 | <tr><td class="num" id="LN651">651</td><td class="line"> </td></tr>
|
---|
757 | <tr><td class="num" id="LN652">652</td><td class="line"> <span class='comment'>// EVENTS</span></td></tr>
|
---|
758 | <tr><td class="num" id="LN653">653</td><td class="line"> err = submit_rx_event(bdev);</td></tr>
|
---|
759 | <tr><td class="num" id="LN654">654</td><td class="line"> <span class='keyword'>if</span> (err != <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>) {</td></tr>
|
---|
760 | <tr><td class="num" id="LN655">655</td><td class="line"> bdev->state = <span class='macro'>CLEAR_BIT(bdev->state, ANCILLYANT)<span class='expansion'>((bdev->state) & (~(1 << (ANCILLYANT))))</span></span>;</td></tr>
|
---|
761 | <tr><td class="num" id="LN656">656</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Queuing failed device stops running\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Queuing failed device stops running\n"<br>, __func__)</span></span>;</td></tr>
|
---|
762 | <tr><td class="num" id="LN657">657</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
763 | <tr><td class="num" id="LN658">658</td><td class="line"> }</td></tr>
|
---|
764 | <tr><td class="num" id="LN659">659</td><td class="line"> </td></tr>
|
---|
765 | <tr><td class="num" id="LN660">660</td><td class="line"> <span class='directive'>#if <span class='macro'>BT_DRIVER_SUPPORTS_ACL<span class='expansion'>1</span></span> // ACL</span></td></tr>
|
---|
766 | <tr><td class="num" id="LN661">661</td><td class="line"> <span class='keyword'>for</span> (i = 0; i < <span class='macro'>MAX_ACL_IN_WINDOW<span class='expansion'>1</span></span>; i++) {</td></tr>
|
---|
767 | <tr><td class="num" id="LN662">662</td><td class="line"> err = submit_rx_acl(bdev);</td></tr>
|
---|
768 | <tr><td class="num" id="LN663">663</td><td class="line"> <span class='keyword'>if</span> (err != <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span> && i == 0) {</td></tr>
|
---|
769 | <tr><td class="num" id="LN664">664</td><td class="line"> bdev->state = <span class='macro'>CLEAR_BIT(bdev->state, ANCILLYANT)<span class='expansion'>((bdev->state) & (~(1 << (ANCILLYANT))))</span></span>;</td></tr>
|
---|
770 | <tr><td class="num" id="LN665">665</td><td class="line"> <span class='comment'>// Set the flaq in the HCI world</span></td></tr>
|
---|
771 | <tr><td class="num" id="LN666">666</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Queuing failed device stops running\n"</span>,<span class='expansion'>dprintf("h2generic: " "%s: Queuing failed device stops running\n"<br>, __func__)</span></span></td></tr>
|
---|
772 | <tr><td class="num" id="LN667">667</td><td class="line"> <span class='keyword'><span class='macro'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Queuing failed device stops running\n"<br>, __func__)</span></span>;</td></tr>
|
---|
773 | <tr><td class="num" id="LN668">668</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
774 | <tr><td class="num" id="LN669">669</td><td class="line"> }</td></tr>
|
---|
775 | <tr><td class="num" id="LN670">670</td><td class="line"> }</td></tr>
|
---|
776 | <tr><td class="num" id="LN671">671</td><td class="line"> <span class='directive'>#endif</span></td></tr>
|
---|
777 | <tr><td class="num" id="LN672">672</td><td class="line"> </td></tr>
|
---|
778 | <tr><td class="num" id="LN673">673</td><td class="line"> bdev->state = <span class='macro'>SET_BIT(bdev->state, RUNNING)<span class='expansion'>((bdev->state) | (1 << (RUNNING)))</span></span>;</td></tr>
|
---|
779 | <tr><td class="num" id="LN674">674</td><td class="line"> </td></tr>
|
---|
780 | <tr><td class="num" id="LN675">675</td><td class="line"> <span class='directive'>#if <span class='macro'>BT_DRIVER_SUPPORTS_SCO<span class='expansion'>0</span></span></span></td></tr>
|
---|
781 | <tr><td class="num" id="LN676">676</td><td class="line"> <span class='comment'>// TODO: SCO / eSCO</span></td></tr>
|
---|
782 | <tr><td class="num" id="LN677">677</td><td class="line"> <span class='directive'>#endif</span></td></tr>
|
---|
783 | <tr><td class="num" id="LN678">678</td><td class="line"> </td></tr>
|
---|
784 | <tr><td class="num" id="LN679">679</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Device online\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Device online\n", __func__)</span></span>;</td></tr>
|
---|
785 | <tr><td class="num" id="LN680">680</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
786 | <tr><td class="num" id="LN681">681</td><td class="line"> </td></tr>
|
---|
787 | <tr><td class="num" id="LN682">682</td><td class="line"> <span class='keyword'>case</span> GET_STATS:</td></tr>
|
---|
788 | <tr><td class="num" id="LN683">683</td><td class="line"> memcpy(params, &bdev->stat, <span class='keyword'>sizeof</span>(bt_hci_statistics));</td></tr>
|
---|
789 | <tr><td class="num" id="LN684">684</td><td class="line"> err = <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>;</td></tr>
|
---|
790 | <tr><td class="num" id="LN685">685</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
791 | <tr><td class="num" id="LN686">686</td><td class="line"> </td></tr>
|
---|
792 | <tr><td class="num" id="LN687">687</td><td class="line"> <span class='keyword'>case</span> GET_HCI_ID:</td></tr>
|
---|
793 | <tr><td class="num" id="LN688">688</td><td class="line"> *(hci_id*)params = bdev->hdev;</td></tr>
|
---|
794 | <tr><td class="num" id="LN689">689</td><td class="line"> err = <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>;</td></tr>
|
---|
795 | <tr><td class="num" id="LN690">690</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
796 | <tr><td class="num" id="LN691">691</td><td class="line"> </td></tr>
|
---|
797 | <tr><td class="num" id="LN692">692</td><td class="line"> </td></tr>
|
---|
798 | <tr><td class="num" id="LN693">693</td><td class="line"> <span class='keyword'>default</span>:</td></tr>
|
---|
799 | <tr><td class="num" id="LN694">694</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: Invalid opcode.\n"</span>, <span class='keyword'>__func__</span>)<span class='expansion'>dprintf("h2generic: " "%s: Invalid opcode.\n", __func__)</span></span>;</td></tr>
|
---|
800 | <tr><td class="num" id="LN695">695</td><td class="line"> err = <span class='macro'>B_DEV_INVALID_IOCTL<span class='expansion'>(((-2147483647 - 1) + 0xa000) + 0)</span></span>;</td></tr>
|
---|
801 | <tr><td class="num" id="LN696">696</td><td class="line"> <span class='keyword'>break</span>;</td></tr>
|
---|
802 | <tr><td class="num" id="LN697">697</td><td class="line"> }</td></tr>
|
---|
803 | <tr><td class="num" id="LN698">698</td><td class="line"> </td></tr>
|
---|
804 | <tr><td class="num" id="LN699">699</td><td class="line"> release_sem(bdev->lock);</td></tr>
|
---|
805 | <tr><td class="num" id="LN700">700</td><td class="line"> <span class='keyword'>return</span> err;</td></tr>
|
---|
806 | <tr><td class="num" id="LN701">701</td><td class="line">}</td></tr>
|
---|
807 | <tr><td class="num" id="LN702">702</td><td class="line"> </td></tr>
|
---|
808 | <tr><td class="num" id="LN703">703</td><td class="line"> </td></tr>
|
---|
809 | <tr><td class="num" id="LN704">704</td><td class="line"><span class='comment'>// implements the POSIX read()</span></td></tr>
|
---|
810 | <tr><td class="num" id="LN705">705</td><td class="line"><span class='keyword'>static</span> status_t</td></tr>
|
---|
811 | <tr><td class="num" id="LN706">706</td><td class="line">device_read(<span class='keyword'>void</span>* cookie, off_t pos, <span class='keyword'>void</span>* buffer, size_t* count)</td></tr>
|
---|
812 | <tr><td class="num" id="LN707">707</td><td class="line">{</td></tr>
|
---|
813 | <tr><td class="num" id="LN708">708</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: Reading... count = %"</span> B_PRIuSIZE <span class='string_literal'>"\n"</span>, <span class='keyword'>__func__</span>, *count)<span class='expansion'>dprintf("h2generic: " "%s: Reading... count = %" "l" "u" "\n"<br>, __func__, *count)</span></span>;</td></tr>
|
---|
814 | <tr><td class="num" id="LN709">709</td><td class="line"> </td></tr>
|
---|
815 | <tr><td class="num" id="LN710">710</td><td class="line"> *count = 0;</td></tr>
|
---|
816 | <tr><td class="num" id="LN711">711</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>;</td></tr>
|
---|
817 | <tr><td class="num" id="LN712">712</td><td class="line">}</td></tr>
|
---|
818 | <tr><td class="num" id="LN713">713</td><td class="line"> </td></tr>
|
---|
819 | <tr><td class="num" id="LN714">714</td><td class="line"> </td></tr>
|
---|
820 | <tr><td class="num" id="LN715">715</td><td class="line"><span class='comment'>// implements the POSIX write()</span></td></tr>
|
---|
821 | <tr><td class="num" id="LN716">716</td><td class="line"><span class='keyword'>static</span> status_t</td></tr>
|
---|
822 | <tr><td class="num" id="LN717">717</td><td class="line">device_write(<span class='keyword'>void</span>* cookie, off_t pos, <span class='keyword'>const</span> <span class='keyword'>void</span>* buffer, size_t* count)</td></tr>
|
---|
823 | <tr><td class="num" id="LN718">718</td><td class="line">{</td></tr>
|
---|
824 | <tr><td class="num" id="LN719">719</td><td class="line"> <span class='macro'>CALLED()<span class='expansion'>dprintf("h2generic: " "h2generic: CALLED %s\n", __PRETTY_FUNCTION__<br>)</span></span>;</td></tr>
|
---|
825 | <tr><td class="num" id="LN720">720</td><td class="line"> </td></tr>
|
---|
826 | <tr><td class="num" id="LN721">721</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
827 | <tr><td class="num" id="LN722">722</td><td class="line">}</td></tr>
|
---|
828 | <tr><td class="num" id="LN723">723</td><td class="line"> </td></tr>
|
---|
829 | <tr><td class="num" id="LN724">724</td><td class="line"> </td></tr>
|
---|
830 | <tr><td class="num" id="LN725">725</td><td class="line"><span class='directive'>#if 0</span></td></tr>
|
---|
831 | <tr><td class="num" id="LN726">726</td><td class="line"><span class='directive'>#pragma mark -</span></td></tr>
|
---|
832 | <tr><td class="num" id="LN727">727</td><td class="line"><span class='directive'>#endif</span></td></tr>
|
---|
833 | <tr><td class="num" id="LN728">728</td><td class="line"> </td></tr>
|
---|
834 | <tr><td class="num" id="LN729">729</td><td class="line"> </td></tr>
|
---|
835 | <tr><td class="num" id="LN730">730</td><td class="line"><span class='keyword'>static</span> <span class='keyword'>int</span></td></tr>
|
---|
836 | <tr><td class="num" id="LN731">731</td><td class="line">dump_driver(<span class='keyword'>int</span> argc, <span class='keyword'>char</span>** argv)</td></tr>
|
---|
837 | <tr><td class="num" id="LN732">732</td><td class="line">{</td></tr>
|
---|
838 | <tr><td class="num" id="LN733">733</td><td class="line"> <span class='keyword'>int</span> i;</td></tr>
|
---|
839 | <tr><td class="num" id="LN734">734</td><td class="line"> snet_buffer* item = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
840 | <tr><td class="num" id="LN735">735</td><td class="line"> </td></tr>
|
---|
841 | <tr><td class="num" id="LN736">736</td><td class="line"> <span class='keyword'>for</span> (i = 0; i < <span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span>; i++) {</td></tr>
|
---|
842 | <tr><td class="num" id="LN737">737</td><td class="line"> </td></tr>
|
---|
843 | <tr><td class="num" id="LN738">738</td><td class="line"> <span class='keyword'>if</span> (bt_usb_devices[i] != <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
844 | <tr><td class="num" id="LN739">739</td><td class="line"> kprintf(<span class='string_literal'>"%s : \n"</span>, bt_usb_devices[i]->name);</td></tr>
|
---|
845 | <tr><td class="num" id="LN740">740</td><td class="line"> kprintf(<span class='string_literal'>"\taclroom = %d\teventroom = %d\tcommand & events =%d\n"</span>,</td></tr>
|
---|
846 | <tr><td class="num" id="LN741">741</td><td class="line"> snb_packets(&bt_usb_devices[i]->eventRoom),</td></tr>
|
---|
847 | <tr><td class="num" id="LN742">742</td><td class="line"> snb_packets(&bt_usb_devices[i]->aclRoom),</td></tr>
|
---|
848 | <tr><td class="num" id="LN743">743</td><td class="line"> snb_packets(&bt_usb_devices[i]->snetBufferRecycleTrash));</td></tr>
|
---|
849 | <tr><td class="num" id="LN744">744</td><td class="line"> </td></tr>
|
---|
850 | <tr><td class="num" id="LN745">745</td><td class="line"> <span class='keyword'>while</span> ((item = (snet_buffer*)list_get_next_item(</td></tr>
|
---|
851 | <tr><td class="num" id="LN746">746</td><td class="line"> &bt_usb_devices[i]->snetBufferRecycleTrash, item)) != <span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
852 | <tr><td class="num" id="LN747">747</td><td class="line"> snb_dump(item);</td></tr>
|
---|
853 | <tr><td class="num" id="LN748">748</td><td class="line"> }</td></tr>
|
---|
854 | <tr><td class="num" id="LN749">749</td><td class="line"> }</td></tr>
|
---|
855 | <tr><td class="num" id="LN750">750</td><td class="line"> </td></tr>
|
---|
856 | <tr><td class="num" id="LN751">751</td><td class="line"> <span class='keyword'>return</span> 0;</td></tr>
|
---|
857 | <tr><td class="num" id="LN752">752</td><td class="line">}</td></tr>
|
---|
858 | <tr><td class="num" id="LN753">753</td><td class="line"> </td></tr>
|
---|
859 | <tr><td class="num" id="LN754">754</td><td class="line"> </td></tr>
|
---|
860 | <tr><td class="num" id="LN755">755</td><td class="line"><span class='comment'>// called each time the driver is loaded by the kernel</span></td></tr>
|
---|
861 | <tr><td class="num" id="LN756">756</td><td class="line">status_t</td></tr>
|
---|
862 | <tr><td class="num" id="LN757">757</td><td class="line">init_driver(<span class='keyword'>void</span>)</td></tr>
|
---|
863 | <tr><td class="num" id="LN758">758</td><td class="line">{</td></tr>
|
---|
864 | <tr><td class="num" id="LN759">759</td><td class="line"> <span class='macro'>CALLED()<span class='expansion'>dprintf("h2generic: " "h2generic: CALLED %s\n", __PRETTY_FUNCTION__<br>)</span></span>;</td></tr>
|
---|
865 | <tr><td class="num" id="LN760">760</td><td class="line"> <span class='keyword'>int</span> j;</td></tr>
|
---|
866 | <tr><td class="num" id="LN761">761</td><td class="line"> </td></tr>
|
---|
867 | <tr><td class="num" id="LN762">762</td><td class="line"> <span class='keyword'>if</span> (get_module(<span class='macro'>BT_CORE_DATA_MODULE_NAME<span class='expansion'>"bluetooth/btCoreData/v1"</span></span>,</td></tr>
|
---|
868 | <tr><td class="num" id="LN763">763</td><td class="line"> (module_info**)&btCoreData) != <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>) {</td></tr>
|
---|
869 | <tr><td class="num" id="LN764">764</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: cannot get module '%s'\n"</span>, <span class='keyword'>__func__</span>,<span class='expansion'>dprintf("h2generic: " "%s: cannot get module '%s'\n", __func__<br>, "bluetooth/btCoreData/v1")</span></span></td></tr>
|
---|
870 | <tr><td class="num" id="LN765">765</td><td class="line"> <span class='macro'>BT_CORE_DATA_MODULE_NAME)<span class='expansion'>dprintf("h2generic: " "%s: cannot get module '%s'\n", __func__<br>, "bluetooth/btCoreData/v1")</span></span>;</td></tr>
|
---|
871 | <tr><td class="num" id="LN766">766</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
872 | <tr><td class="num" id="LN767">767</td><td class="line"> }</td></tr>
|
---|
873 | <tr><td class="num" id="LN768">768</td><td class="line"> </td></tr>
|
---|
874 | <tr><td class="num" id="LN769">769</td><td class="line"> <span class='comment'>// BT devices MODULE INITS</span></td></tr>
|
---|
875 | <tr><td class="num" id="LN770">770</td><td class="line"> <span class='keyword'>if</span> (get_module(btDevices_name, (module_info**)&btDevices) != <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>) {</td></tr>
|
---|
876 | <tr><td class="num" id="LN771">771</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: cannot get module '%s'\n"</span>, <span class='keyword'>__func__</span>, btDevices_name)<span class='expansion'>dprintf("h2generic: " "%s: cannot get module '%s'\n", __func__<br>, btDevices_name)</span></span>;</td></tr>
|
---|
877 | <tr><td class="num" id="LN772">772</td><td class="line"> <span class='keyword'>goto</span> err_release3;</td></tr>
|
---|
878 | <tr><td class="num" id="LN773">773</td><td class="line"> }</td></tr>
|
---|
879 | <tr><td class="num" id="LN774">774</td><td class="line"> </td></tr>
|
---|
880 | <tr><td class="num" id="LN775">775</td><td class="line"> <span class='comment'>// HCI MODULE INITS</span></td></tr>
|
---|
881 | <tr><td class="num" id="LN776">776</td><td class="line"> <span class='keyword'>if</span> (get_module(hci_name, (module_info**)&hci) != <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>) {</td></tr>
|
---|
882 | <tr><td class="num" id="LN777">777</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: cannot get module '%s'\n"</span>, <span class='keyword'>__func__</span>, hci_name)<span class='expansion'>dprintf("h2generic: " "%s: cannot get module '%s'\n", __func__<br>, hci_name)</span></span>;</td></tr>
|
---|
883 | <tr><td class="num" id="LN778">778</td><td class="line"><span class='directive'>#ifndef BT_SURVIVE_WITHOUT_HCI</span></td></tr>
|
---|
884 | <tr><td class="num" id="LN779">779</td><td class="line"> <span class='keyword'>goto</span> err_release2;</td></tr>
|
---|
885 | <tr><td class="num" id="LN780">780</td><td class="line"><span class='directive'>#endif</span></td></tr>
|
---|
886 | <tr><td class="num" id="LN781">781</td><td class="line"> }</td></tr>
|
---|
887 | <tr><td class="num" id="LN782">782</td><td class="line"> </td></tr>
|
---|
888 | <tr><td class="num" id="LN783">783</td><td class="line"> <span class='comment'>// USB MODULE INITS</span></td></tr>
|
---|
889 | <tr><td class="num" id="LN784">784</td><td class="line"> <span class='keyword'>if</span> (get_module(usb_name, (module_info**)&usb) != <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>) {</td></tr>
|
---|
890 | <tr><td class="num" id="LN785">785</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: cannot get module '%s'\n"</span>, <span class='keyword'>__func__</span>, usb_name)<span class='expansion'>dprintf("h2generic: " "%s: cannot get module '%s'\n", __func__<br>, usb_name)</span></span>;</td></tr>
|
---|
891 | <tr><td class="num" id="LN786">786</td><td class="line"> <span class='keyword'>goto</span> err_release1;</td></tr>
|
---|
892 | <tr><td class="num" id="LN787">787</td><td class="line"> }</td></tr>
|
---|
893 | <tr><td class="num" id="LN788">788</td><td class="line"> </td></tr>
|
---|
894 | <tr><td class="num" id="LN789">789</td><td class="line"> <span class='keyword'>if</span> (get_module(<span class='macro'>NET_BUFFER_MODULE_NAME<span class='expansion'>"network/stack/buffer/v1"</span></span>, (module_info**)&nb) != <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>) {</td></tr>
|
---|
895 | <tr><td class="num" id="LN790">790</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: cannot get module '%s'\n"</span>, <span class='keyword'>__func__</span>,<span class='expansion'>dprintf("h2generic: " "%s: cannot get module '%s'\n", __func__<br>, "network/stack/buffer/v1")</span></span></td></tr>
|
---|
896 | <tr><td class="num" id="LN791">791</td><td class="line"> <span class='macro'>NET_BUFFER_MODULE_NAME)<span class='expansion'>dprintf("h2generic: " "%s: cannot get module '%s'\n", __func__<br>, "network/stack/buffer/v1")</span></span>;</td></tr>
|
---|
897 | <tr><td class="num" id="LN792">792</td><td class="line"><span class='directive'>#ifndef BT_SURVIVE_WITHOUT_NET_BUFFERS</span></td></tr>
|
---|
898 | <tr><td class="num" id="LN793">793</td><td class="line"> <span class='keyword'>goto</span> err_release;</td></tr>
|
---|
899 | <tr><td class="num" id="LN794">794</td><td class="line"><span class='directive'>#endif</span></td></tr>
|
---|
900 | <tr><td class="num" id="LN795">795</td><td class="line"> }</td></tr>
|
---|
901 | <tr><td class="num" id="LN796">796</td><td class="line"> </td></tr>
|
---|
902 | <tr><td class="num" id="LN797">797</td><td class="line"> <span class='comment'>// GENERAL INITS</span></td></tr>
|
---|
903 | <tr><td class="num" id="LN798">798</td><td class="line"> dev_table_sem = create_sem(1, <span class='macro'>BLUETOOTH_DEVICE_DEVFS_NAME<span class='expansion'>"h2" "generic"</span></span> <span class='string_literal'>"dev_table_lock"</span>);</td></tr>
|
---|
904 | <tr><td class="num" id="LN799">799</td><td class="line"> <span class='keyword'>if</span> (dev_table_sem < 0) {</td></tr>
|
---|
905 | <tr><td class="num" id="LN800">800</td><td class="line"> <span class='keyword'>goto</span> err;</td></tr>
|
---|
906 | <tr><td class="num" id="LN801">801</td><td class="line"> }</td></tr>
|
---|
907 | <tr><td class="num" id="LN802">802</td><td class="line"> </td></tr>
|
---|
908 | <tr><td class="num" id="LN803">803</td><td class="line"> <span class='keyword'>for</span> (j = 0; j < <span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span>; j++) {</td></tr>
|
---|
909 | <tr><td class="num" id="LN804">804</td><td class="line"> bt_usb_devices[j] = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
910 | <tr><td class="num" id="LN805">805</td><td class="line"> }</td></tr>
|
---|
911 | <tr><td class="num" id="LN806">806</td><td class="line"> </td></tr>
|
---|
912 | <tr><td class="num" id="LN807">807</td><td class="line"> <span class='comment'>// Note: After here device_added and publish devices hooks are called</span></td></tr>
|
---|
913 | <tr><td class="num" id="LN808">808</td><td class="line"> usb->register_driver(<span class='macro'>BLUETOOTH_DEVICE_DEVFS_NAME<span class='expansion'>"h2" "generic"</span></span>, supported_devices, 1, <span class='macro'>NULL<span class='expansion'>__null</span></span>);</td></tr>
|
---|
914 | <tr><td class="num" id="LN809">809</td><td class="line"> usb->install_notify(<span class='macro'>BLUETOOTH_DEVICE_DEVFS_NAME<span class='expansion'>"h2" "generic"</span></span>, &notify_hooks);</td></tr>
|
---|
915 | <tr><td class="num" id="LN810">810</td><td class="line"> </td></tr>
|
---|
916 | <tr><td class="num" id="LN811">811</td><td class="line"> add_debugger_command(<span class='string_literal'>"bth2generic"</span>, &dump_driver,</td></tr>
|
---|
917 | <tr><td class="num" id="LN812">812</td><td class="line"> <span class='string_literal'>"Lists H2 Transport device info"</span>);</td></tr>
|
---|
918 | <tr><td class="num" id="LN813">813</td><td class="line"> </td></tr>
|
---|
919 | <tr><td class="num" id="LN814">814</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_OK<span class='expansion'>((int)0)</span></span>;</td></tr>
|
---|
920 | <tr><td class="num" id="LN815">815</td><td class="line"> </td></tr>
|
---|
921 | <tr><td class="num" id="LN816">816</td><td class="line">err: <span class='comment'>// Releasing</span></td></tr>
|
---|
922 | <tr><td class="num" id="LN817">817</td><td class="line"> put_module(<span class='macro'>NET_BUFFER_MODULE_NAME<span class='expansion'>"network/stack/buffer/v1"</span></span>);</td></tr>
|
---|
923 | <tr><td class="num" id="LN818">818</td><td class="line">err_release:</td></tr>
|
---|
924 | <tr><td class="num" id="LN819">819</td><td class="line"> put_module(usb_name);</td></tr>
|
---|
925 | <tr><td class="num" id="LN820">820</td><td class="line">err_release1:</td></tr>
|
---|
926 | <tr><td class="num" id="LN821">821</td><td class="line"> put_module(hci_name);</td></tr>
|
---|
927 | <tr><td class="num" id="LN822">822</td><td class="line"><span class='directive'>#ifndef BT_SURVIVE_WITHOUT_HCI</span></td></tr>
|
---|
928 | <tr><td class="num" id="LN823">823</td><td class="line">err_release2:</td></tr>
|
---|
929 | <tr><td class="num" id="LN824">824</td><td class="line"><span class='directive'>#endif</span></td></tr>
|
---|
930 | <tr><td class="num" id="LN825">825</td><td class="line"> put_module(btDevices_name);</td></tr>
|
---|
931 | <tr><td class="num" id="LN826">826</td><td class="line">err_release3:</td></tr>
|
---|
932 | <tr><td class="num" id="LN827">827</td><td class="line"> put_module(<span class='macro'>BT_CORE_DATA_MODULE_NAME<span class='expansion'>"bluetooth/btCoreData/v1"</span></span>);</td></tr>
|
---|
933 | <tr><td class="num" id="LN828">828</td><td class="line"> </td></tr>
|
---|
934 | <tr><td class="num" id="LN829">829</td><td class="line"> <span class='keyword'>return</span> <span class='macro'>B_ERROR<span class='expansion'>(-1)</span></span>;</td></tr>
|
---|
935 | <tr><td class="num" id="LN830">830</td><td class="line">}</td></tr>
|
---|
936 | <tr><td class="num" id="LN831">831</td><td class="line"> </td></tr>
|
---|
937 | <tr><td class="num" id="LN832">832</td><td class="line"> </td></tr>
|
---|
938 | <tr><td class="num" id="LN833">833</td><td class="line"><span class='comment'>// called just before the kernel unloads the driver</span></td></tr>
|
---|
939 | <tr><td class="num" id="LN834">834</td><td class="line"><span class='keyword'>void</span></td></tr>
|
---|
940 | <tr><td class="num" id="LN835">835</td><td class="line">uninit_driver(<span class='keyword'>void</span>)</td></tr>
|
---|
941 | <tr><td class="num" id="LN836">836</td><td class="line">{</td></tr>
|
---|
942 | <tr><td class="num" id="LN837">837</td><td class="line"> <span class='macro'>CALLED()<span class='expansion'>dprintf("h2generic: " "h2generic: CALLED %s\n", __PRETTY_FUNCTION__<br>)</span></span>;</td></tr>
|
---|
943 | <tr><td class="num" id="LN838">838</td><td class="line"> </td></tr>
|
---|
944 | <tr><td class="num" id="LN839">839</td><td class="line"> int32 j;</td></tr>
|
---|
945 | <tr><td class="num" id="LN840">840</td><td class="line"> </td></tr>
|
---|
946 | <tr><td class="num" id="LN841">841</td><td class="line"> <span class='keyword'>for</span> (j = 0; j < <span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span>; j++) {</td></tr>
|
---|
947 | <tr><td class="num" id="LN842">842</td><td class="line"> </td></tr>
|
---|
948 | <tr><td class="num" id="LN843">843</td><td class="line"> <span class='keyword'>if</span> (publish_names[j] != <span class='macro'>NULL<span class='expansion'>__null</span></span>)</td></tr>
|
---|
949 | <tr><td class="num" id="LN844">844</td><td class="line"> free(publish_names[j]);</td></tr>
|
---|
950 | <tr><td class="num" id="LN845">845</td><td class="line"> </td></tr>
|
---|
951 | <tr><td class="num" id="LN846">846</td><td class="line"> <span class='keyword'>if</span> (bt_usb_devices[j] != <span class='macro'>NULL<span class='expansion'>__null</span></span>) {</td></tr>
|
---|
952 | <tr><td class="num" id="LN847">847</td><td class="line"> <span class='comment'>// if (connected_dev != NULL) {</span></td></tr>
|
---|
953 | <tr><td class="num" id="LN848">848</td><td class="line"> <span class='comment'>// debugf("Device %p still exists.\n", connected_dev);</span></td></tr>
|
---|
954 | <tr><td class="num" id="LN849">849</td><td class="line"> <span class='comment'>// }</span></td></tr>
|
---|
955 | <tr><td class="num" id="LN850">850</td><td class="line"> <span class='macro'>ERROR(<span class='string_literal'>"%s: %s still present?\n"</span>, <span class='keyword'>__func__</span>, bt_usb_devices[j]->name)<span class='expansion'>dprintf("h2generic: " "%s: %s still present?\n", __func__, bt_usb_devices<br>[j]->name)</span></span>;</td></tr>
|
---|
956 | <tr><td class="num" id="LN851">851</td><td class="line"> kill_device(bt_usb_devices[j]);</td></tr>
|
---|
957 | <tr><td class="num" id="LN852">852</td><td class="line"> }</td></tr>
|
---|
958 | <tr><td class="num" id="LN853">853</td><td class="line"> }</td></tr>
|
---|
959 | <tr><td class="num" id="LN854">854</td><td class="line"> </td></tr>
|
---|
960 | <tr><td class="num" id="LN855">855</td><td class="line"> usb->uninstall_notify(<span class='macro'>BLUETOOTH_DEVICE_DEVFS_NAME<span class='expansion'>"h2" "generic"</span></span>);</td></tr>
|
---|
961 | <tr><td class="num" id="LN856">856</td><td class="line"> </td></tr>
|
---|
962 | <tr><td class="num" id="LN857">857</td><td class="line"> remove_debugger_command(<span class='string_literal'>"bth2generic"</span>, &dump_driver);</td></tr>
|
---|
963 | <tr><td class="num" id="LN858">858</td><td class="line"> </td></tr>
|
---|
964 | <tr><td class="num" id="LN859">859</td><td class="line"> <span class='comment'>// Releasing modules</span></td></tr>
|
---|
965 | <tr><td class="num" id="LN860">860</td><td class="line"> put_module(usb_name);</td></tr>
|
---|
966 | <tr><td class="num" id="LN861">861</td><td class="line"> put_module(hci_name);</td></tr>
|
---|
967 | <tr><td class="num" id="LN862">862</td><td class="line"> <span class='comment'>// TODO: netbuffers</span></td></tr>
|
---|
968 | <tr><td class="num" id="LN863">863</td><td class="line"> </td></tr>
|
---|
969 | <tr><td class="num" id="LN864">864</td><td class="line"> delete_sem(dev_table_sem);</td></tr>
|
---|
970 | <tr><td class="num" id="LN865">865</td><td class="line">}</td></tr>
|
---|
971 | <tr><td class="num" id="LN866">866</td><td class="line"> </td></tr>
|
---|
972 | <tr><td class="num" id="LN867">867</td><td class="line"> </td></tr>
|
---|
973 | <tr><td class="num" id="LN868">868</td><td class="line"><span class='keyword'>const</span> <span class='keyword'>char</span>**</td></tr>
|
---|
974 | <tr><td class="num" id="LN869">869</td><td class="line">publish_devices(<span class='keyword'>void</span>)</td></tr>
|
---|
975 | <tr><td class="num" id="LN870">870</td><td class="line">{</td></tr>
|
---|
976 | <tr><td class="num" id="LN871">871</td><td class="line"> <span class='macro'>CALLED()<span class='expansion'>dprintf("h2generic: " "h2generic: CALLED %s\n", __PRETTY_FUNCTION__<br>)</span></span>;</td></tr>
|
---|
977 | <tr><td class="num" id="LN872">872</td><td class="line"> int32 j;</td></tr>
|
---|
978 | <tr><td class="num" id="LN873">873</td><td class="line"> int32 i = 0;</td></tr>
|
---|
979 | <tr><td class="num" id="LN874">874</td><td class="line"> </td></tr>
|
---|
980 | <tr><td class="num" id="LN875">875</td><td class="line"> <span class='keyword'>char</span>* str;</td></tr>
|
---|
981 | <tr><td class="num" id="LN876">876</td><td class="line"> </td></tr>
|
---|
982 | <tr><td class="num" id="LN877">877</td><td class="line"> <span class='keyword'>for</span> (j = 0; j < <span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span>; j++) {</td></tr>
|
---|
983 | <tr><td class="num" id="LN878">878</td><td class="line"> <span class='keyword'>if</span> (publish_names[j]) {</td></tr>
|
---|
984 | <tr><td class="num" id="LN879">879</td><td class="line"> free(publish_names[j]);</td></tr>
|
---|
985 | <tr><td class="num" id="LN880">880</td><td class="line"> publish_names[j] = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
986 | <tr><td class="num" id="LN881">881</td><td class="line"> }</td></tr>
|
---|
987 | <tr><td class="num" id="LN882">882</td><td class="line"> }</td></tr>
|
---|
988 | <tr><td class="num" id="LN883">883</td><td class="line"> </td></tr>
|
---|
989 | <tr><td class="num" id="LN884">884</td><td class="line"> acquire_sem(dev_table_sem);</td></tr>
|
---|
990 | <tr><td class="num" id="LN885">885</td><td class="line"> <span class='keyword'>for</span> (j = 0; j < <span class='macro'>MAX_BT_GENERIC_USB_DEVICES<span class='expansion'>16</span></span>; j++) {</td></tr>
|
---|
991 | <tr><td class="num" id="LN886">886</td><td class="line"> <span class='keyword'>if</span> (bt_usb_devices[j] != <span class='macro'>NULL<span class='expansion'>__null</span></span> && bt_usb_devices[j]->connected) {</td></tr>
|
---|
992 | <tr><td class="num" id="LN887">887</td><td class="line"> str = strdup(bt_usb_devices[j]->name);</td></tr>
|
---|
993 | <tr><td class="num" id="LN888">888</td><td class="line"> <span class='keyword'>if</span> (str) {</td></tr>
|
---|
994 | <tr><td class="num" id="LN889">889</td><td class="line"> publish_names[i++] = str;</td></tr>
|
---|
995 | <tr><td class="num" id="LN890">890</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: publishing %s\n"</span>, <span class='keyword'>__func__</span>, bt_usb_devices[j]->name)<span class='expansion'>dprintf("h2generic: " "%s: publishing %s\n", __func__, bt_usb_devices<br>[j]->name)</span></span>;</td></tr>
|
---|
996 | <tr><td class="num" id="LN891">891</td><td class="line"> }</td></tr>
|
---|
997 | <tr><td class="num" id="LN892">892</td><td class="line"> }</td></tr>
|
---|
998 | <tr><td class="num" id="LN893">893</td><td class="line"> }</td></tr>
|
---|
999 | <tr><td class="num" id="LN894">894</td><td class="line"> release_sem_etc(dev_table_sem, 1, B_DO_NOT_RESCHEDULE);</td></tr>
|
---|
1000 | <tr><td class="num" id="LN895">895</td><td class="line"> </td></tr>
|
---|
1001 | <tr><td class="num" id="LN896">896</td><td class="line"> publish_names[i] = <span class='macro'>NULL<span class='expansion'>__null</span></span>;</td></tr>
|
---|
1002 | <tr><td class="num" id="LN897">897</td><td class="line"> <span class='macro'>TRACE(<span class='string_literal'>"%s: published %"</span> B_PRId32 <span class='string_literal'>" devices\n"</span>, <span class='keyword'>__func__</span>, i)<span class='expansion'>dprintf("h2generic: " "%s: published %" "" "d" " devices\n", __func__<br>, i)</span></span>;</td></tr>
|
---|
1003 | <tr><td class="num" id="LN898">898</td><td class="line"> </td></tr>
|
---|
1004 | <tr><td class="num" id="LN899">899</td><td class="line"> <span class='comment'>// TODO: this method might make better memory use</span></td></tr>
|
---|
1005 | <tr><td class="num" id="LN900">900</td><td class="line"> <span class='comment'>// dev_names = (char**)malloc(sizeof(char*) * (dev_count + 1));</span></td></tr>
|
---|
1006 | <tr><td class="num" id="LN901">901</td><td class="line"> <span class='comment'>// if (dev_names) {</span></td></tr>
|
---|
1007 | <tr><td class="num" id="LN902">902</td><td class="line"> <span class='comment'>// for (i = 0; i < MAX_NUM_DEVS; i++) {</span></td></tr>
|
---|
1008 | <tr><td class="num" id="LN903">903</td><td class="line"> <span class='comment'>// if ((dev != NULL) // dev + \n</span></td></tr>
|
---|
1009 | <tr><td class="num" id="LN904">904</td><td class="line"> <span class='comment'>// && (dev_names[i] = (char*)malloc(strlen(DEVICE_PATH) + 2))) {</span></td></tr>
|
---|
1010 | <tr><td class="num" id="LN905">905</td><td class="line"> <span class='comment'>// sprintf(dev_names[i], "%s%ld", DEVICE_PATH, dev->num);</span></td></tr>
|
---|
1011 | <tr><td class="num" id="LN906">906</td><td class="line"> <span class='comment'>// debugf("publishing \"%s\"\n", dev_names[i]);</span></td></tr>
|
---|
1012 | <tr><td class="num" id="LN907">907</td><td class="line"> <span class='comment'>// }</span></td></tr>
|
---|
1013 | <tr><td class="num" id="LN908">908</td><td class="line"> <span class='comment'>// }</span></td></tr>
|
---|
1014 | <tr><td class="num" id="LN909">909</td><td class="line"> </td></tr>
|
---|
1015 | <tr><td class="num" id="LN910">910</td><td class="line"> <span class='keyword'>return</span> (<span class='keyword'>const</span> <span class='keyword'>char</span>**)publish_names;</td></tr>
|
---|
1016 | <tr><td class="num" id="LN911">911</td><td class="line">}</td></tr>
|
---|
1017 | <tr><td class="num" id="LN912">912</td><td class="line"> </td></tr>
|
---|
1018 | <tr><td class="num" id="LN913">913</td><td class="line"> </td></tr>
|
---|
1019 | <tr><td class="num" id="LN914">914</td><td class="line"><span class='keyword'>static</span> device_hooks hooks = {</td></tr>
|
---|
1020 | <tr><td class="num" id="LN915">915</td><td class="line"> device_open,</td></tr>
|
---|
1021 | <tr><td class="num" id="LN916">916</td><td class="line"> device_close,</td></tr>
|
---|
1022 | <tr><td class="num" id="LN917">917</td><td class="line"> device_free,</td></tr>
|
---|
1023 | <tr><td class="num" id="LN918">918</td><td class="line"> device_control,</td></tr>
|
---|
1024 | <tr><td class="num" id="LN919">919</td><td class="line"> device_read,</td></tr>
|
---|
1025 | <tr><td class="num" id="LN920">920</td><td class="line"> device_write,</td></tr>
|
---|
1026 | <tr><td class="num" id="LN921">921</td><td class="line"> <span class='macro'>NULL<span class='expansion'>__null</span></span>,</td></tr>
|
---|
1027 | <tr><td class="num" id="LN922">922</td><td class="line"> <span class='macro'>NULL<span class='expansion'>__null</span></span>,</td></tr>
|
---|
1028 | <tr><td class="num" id="LN923">923</td><td class="line"> <span class='macro'>NULL<span class='expansion'>__null</span></span>,</td></tr>
|
---|
1029 | <tr><td class="num" id="LN924">924</td><td class="line"> <span class='macro'>NULL<span class='expansion'>__null</span></span></td></tr>
|
---|
1030 | <tr><td class="num" id="LN925">925</td><td class="line">};</td></tr>
|
---|
1031 | <tr><td class="num" id="LN926">926</td><td class="line"> </td></tr>
|
---|
1032 | <tr><td class="num" id="LN927">927</td><td class="line"> </td></tr>
|
---|
1033 | <tr><td class="num" id="LN928">928</td><td class="line">device_hooks*</td></tr>
|
---|
1034 | <tr><td class="num" id="LN929">929</td><td class="line">find_device(<span class='keyword'>const</span> <span class='keyword'>char</span>* name)</td></tr>
|
---|
1035 | <tr><td class="num" id="LN930">930</td><td class="line">{</td></tr>
|
---|
1036 | <tr><td class="num" id="LN931">931</td><td class="line"> <span class='macro'>CALLED()<span class='expansion'>dprintf("h2generic: " "h2generic: CALLED %s\n", __PRETTY_FUNCTION__<br>)</span></span>;</td></tr>
|
---|
1037 | <tr><td class="num" id="LN932">932</td><td class="line"> </td></tr>
|
---|
1038 | <tr><td class="num" id="LN933">933</td><td class="line"> <span class='keyword'>return</span> &hooks;</td></tr>
|
---|
1039 | <tr><td class="num" id="LN934">934</td><td class="line">}</td></tr>
|
---|
1040 | </table></body></html>
|
---|