Commit 61365c6
committed
fix(ios): fix thread-safety race in skipDescriptorDiscovery on reconnect (#809)
On reconnect, CoreBluetooth uses cached GATT data and fires
didDiscoverCharacteristicsFor near-instantly on the main queue, before
the bridge thread's write to skipDescriptorDiscovery is visible — causing
the stale false value to be read and the connection to time out.
Fix by dispatching setOnConnected synchronously to the main queue, matching
the queue CoreBluetooth delegates run on. Apply the same fix to
startScanning's scan filter properties for the same reason. Add comments
on stateReceiver where the same issue exists but is too slow to manifest.1 parent cf80aa7 commit 61365c6
2 files changed
+23
-11
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
52 | 52 | | |
53 | 53 | | |
54 | 54 | | |
55 | | - | |
56 | | - | |
57 | | - | |
58 | | - | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
59 | 63 | | |
60 | 64 | | |
61 | 65 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
73 | 73 | | |
74 | 74 | | |
75 | 75 | | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
76 | 79 | | |
77 | 80 | | |
78 | 81 | | |
| |||
99 | 102 | | |
100 | 103 | | |
101 | 104 | | |
102 | | - | |
103 | 105 | | |
104 | 106 | | |
105 | 107 | | |
106 | | - | |
107 | | - | |
108 | | - | |
109 | | - | |
110 | | - | |
111 | | - | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
112 | 120 | | |
113 | 121 | | |
114 | 122 | | |
| |||
0 commit comments