OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef DEVICE_BLUETOOTH_BLUETOOTH_SOCKET_MAC_H_ | 5 #ifndef DEVICE_BLUETOOTH_BLUETOOTH_SOCKET_MAC_H_ |
6 #define DEVICE_BLUETOOTH_BLUETOOTH_SOCKET_MAC_H_ | 6 #define DEVICE_BLUETOOTH_BLUETOOTH_SOCKET_MAC_H_ |
7 | 7 |
8 #include <queue> | 8 #include <queue> |
9 #include <string> | 9 #include <string> |
10 | 10 |
11 #import <IOBluetooth/IOBluetooth.h> | 11 #import <IOBluetooth/IOBluetooth.h> |
12 #import <IOKit/IOReturn.h> | 12 #import <IOKit/IOReturn.h> |
13 | 13 |
14 #include "base/mac/scoped_nsobject.h" | 14 #include "base/mac/scoped_nsobject.h" |
15 #include "base/memory/linked_ptr.h" | 15 #include "base/memory/linked_ptr.h" |
16 #include "base/memory/ref_counted.h" | 16 #include "base/memory/ref_counted.h" |
17 #include "base/memory/scoped_ptr.h" | 17 #include "base/memory/scoped_ptr.h" |
18 #include "base/threading/thread_checker.h" | 18 #include "base/threading/thread_checker.h" |
19 #include "device/bluetooth/bluetooth_socket.h" | 19 #include "device/bluetooth/bluetooth_socket.h" |
20 #include "device/bluetooth/bluetooth_uuid.h" | 20 #include "device/bluetooth/bluetooth_uuid.h" |
21 | 21 |
22 @class BluetoothRfcommChannelDelegate; | |
23 @class BluetoothRfcommConnectionListener; | 22 @class BluetoothRfcommConnectionListener; |
24 | 23 |
25 namespace net { | 24 namespace net { |
26 class IOBuffer; | 25 class IOBuffer; |
27 class IOBufferWithSize; | 26 class IOBufferWithSize; |
28 } | 27 } |
29 | 28 |
30 namespace device { | 29 namespace device { |
31 | 30 |
32 class BluetoothAdapter; | 31 class BluetoothAdapter; |
| 32 class BluetoothChannelMac; |
33 | 33 |
34 // Implements the BluetoothSocket class for the Mac OS X platform. | 34 // Implements the BluetoothSocket class for the Mac OS X platform. |
35 class BluetoothSocketMac : public BluetoothSocket { | 35 class BluetoothSocketMac : public BluetoothSocket { |
36 public: | 36 public: |
37 static scoped_refptr<BluetoothSocketMac> CreateSocket(); | 37 static scoped_refptr<BluetoothSocketMac> CreateSocket(); |
38 | 38 |
39 // Connects this socket to the service on |device| published as UUID |uuid|. | 39 // Connects this socket to the service on |device| published as UUID |uuid|. |
40 // The underlying protocol and PSM or Channel is obtained through service | 40 // The underlying protocol and PSM or Channel is obtained through service |
41 // discovery. On a successful connection, the socket properties will be | 41 // discovery. On a successful connection, the socket properties will be |
42 // updated and |success_callback| called. On failure, |error_callback| will be | 42 // updated and |success_callback| called. On failure, |error_callback| will be |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
86 // |status| is the returned status from the SDP query, |device| is the | 86 // |status| is the returned status from the SDP query, |device| is the |
87 // IOBluetoothDevice for which the query was made. The remaining | 87 // IOBluetoothDevice for which the query was made. The remaining |
88 // parameters are those from |Connect()|. | 88 // parameters are those from |Connect()|. |
89 void OnSDPQueryComplete( | 89 void OnSDPQueryComplete( |
90 IOReturn status, | 90 IOReturn status, |
91 IOBluetoothDevice* device, | 91 IOBluetoothDevice* device, |
92 const base::Closure& success_callback, | 92 const base::Closure& success_callback, |
93 const ErrorCompletionCallback& error_callback); | 93 const ErrorCompletionCallback& error_callback); |
94 | 94 |
95 // Called by BluetoothRfcommConnectionListener. | 95 // Called by BluetoothRfcommConnectionListener. |
96 void OnRfcommChannelOpened(IOBluetoothRFCOMMChannel* rfcomm_channel); | 96 void OnChannelOpened(scoped_ptr<BluetoothChannelMac> channel); |
97 | 97 |
98 // Called by BluetoothRfcommChannelDelegate. | 98 // Called by |channel_|. |
99 void OnRfcommChannelOpenComplete(IOBluetoothRFCOMMChannel* rfcomm_channel, | 99 // Note: OnChannelOpenComplete might be called before the |channel_| is set. |
100 IOReturn status); | 100 void OnChannelOpenComplete(const std::string& device_address, |
101 void OnRfcommChannelClosed(IOBluetoothRFCOMMChannel* rfcomm_channel); | 101 IOReturn status); |
102 void OnRfcommChannelDataReceived(IOBluetoothRFCOMMChannel* rfcomm_channel, | 102 void OnChannelClosed(); |
103 void* data, | 103 void OnChannelDataReceived(void* data, size_t length); |
104 size_t length); | 104 void OnChannelWriteComplete(void* refcon, IOReturn status); |
105 void OnRfcommChannelWriteComplete(IOBluetoothRFCOMMChannel* rfcomm_channel, | |
106 void* refcon, | |
107 IOReturn status); | |
108 | 105 |
109 private: | 106 private: |
110 struct AcceptRequest { | 107 struct AcceptRequest { |
111 AcceptRequest(); | 108 AcceptRequest(); |
112 ~AcceptRequest(); | 109 ~AcceptRequest(); |
113 | 110 |
114 AcceptCompletionCallback success_callback; | 111 AcceptCompletionCallback success_callback; |
115 ErrorCompletionCallback error_callback; | 112 ErrorCompletionCallback error_callback; |
116 }; | 113 }; |
117 | 114 |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
159 scoped_refptr<BluetoothAdapter> adapter_; | 156 scoped_refptr<BluetoothAdapter> adapter_; |
160 | 157 |
161 // UUID of the profile being connected to, or that the socket is listening on. | 158 // UUID of the profile being connected to, or that the socket is listening on. |
162 device::BluetoothUUID uuid_; | 159 device::BluetoothUUID uuid_; |
163 | 160 |
164 // A simple helper that registers for OS notifications and forwards them to | 161 // A simple helper that registers for OS notifications and forwards them to |
165 // |this| profile. | 162 // |this| profile. |
166 base::scoped_nsobject<BluetoothRfcommConnectionListener> | 163 base::scoped_nsobject<BluetoothRfcommConnectionListener> |
167 rfcomm_connection_listener_; | 164 rfcomm_connection_listener_; |
168 | 165 |
169 // A simple delegate that forwards RFCOMM channel methods to |this| socket. | |
170 base::scoped_nsobject<BluetoothRfcommChannelDelegate> | |
171 rfcomm_channel_delegate_; | |
172 | |
173 // A handle to the service record registered in the system SDP server. | 166 // A handle to the service record registered in the system SDP server. |
174 // Used to eventually unregister the service. | 167 // Used to eventually unregister the service. |
175 BluetoothSDPServiceRecordHandle service_record_handle_; | 168 BluetoothSDPServiceRecordHandle service_record_handle_; |
176 | 169 |
177 // The IOBluetooth RFCOMM channel used to issue commands. | 170 // The channel used to issue commands. |
178 base::scoped_nsobject<IOBluetoothRFCOMMChannel> rfcomm_channel_; | 171 scoped_ptr<BluetoothChannelMac> channel_; |
179 | 172 |
180 // Connection callbacks -- when a pending async connection is active. | 173 // Connection callbacks -- when a pending async connection is active. |
181 scoped_ptr<ConnectCallbacks> connect_callbacks_; | 174 scoped_ptr<ConnectCallbacks> connect_callbacks_; |
182 | 175 |
183 // Packets received while there is no pending "receive" callback. | 176 // Packets received while there is no pending "receive" callback. |
184 std::queue<scoped_refptr<net::IOBufferWithSize> > receive_queue_; | 177 std::queue<scoped_refptr<net::IOBufferWithSize> > receive_queue_; |
185 | 178 |
186 // Receive callbacks -- when a receive call is active. | 179 // Receive callbacks -- when a receive call is active. |
187 scoped_ptr<ReceiveCallbacks> receive_callbacks_; | 180 scoped_ptr<ReceiveCallbacks> receive_callbacks_; |
188 | 181 |
189 // Send queue -- one entry per pending send operation. | 182 // Send queue -- one entry per pending send operation. |
190 std::queue<linked_ptr<SendRequest>> send_queue_; | 183 std::queue<linked_ptr<SendRequest>> send_queue_; |
191 | 184 |
192 // The pending request to an Accept() call, or null if there is no pending | 185 // The pending request to an Accept() call, or null if there is no pending |
193 // request. | 186 // request. |
194 scoped_ptr<AcceptRequest> accept_request_; | 187 scoped_ptr<AcceptRequest> accept_request_; |
195 | 188 |
196 // Queue of incoming RFCOMM connections. | 189 // Queue of incoming connections. |
197 std::queue<base::scoped_nsobject<IOBluetoothRFCOMMChannel>> accept_queue_; | 190 std::queue<linked_ptr<BluetoothChannelMac>> accept_queue_; |
198 | 191 |
199 DISALLOW_COPY_AND_ASSIGN(BluetoothSocketMac); | 192 DISALLOW_COPY_AND_ASSIGN(BluetoothSocketMac); |
200 }; | 193 }; |
201 | 194 |
202 } // namespace device | 195 } // namespace device |
203 | 196 |
204 #endif // DEVICE_BLUETOOTH_BLUETOOTH_SOCKET_MAC_H_ | 197 #endif // DEVICE_BLUETOOTH_BLUETOOTH_SOCKET_MAC_H_ |
OLD | NEW |