1 /*
2  * Copyright (C) 2012 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #pragma once
18 
19 #include <bluetooth/log.h>
20 #include <raw_address.h>
21 
22 #define BTPAN_ROLE_NONE 0
23 #define BTPAN_ROLE_PANNAP 1
24 #define BTPAN_ROLE_PANU 2
25 
26 typedef enum {
27   BTPAN_STATE_CONNECTED = 0,
28   BTPAN_STATE_CONNECTING = 1,
29   BTPAN_STATE_DISCONNECTED = 2,
30   BTPAN_STATE_DISCONNECTING = 3
31 } btpan_connection_state_t;
32 
33 typedef enum {
34   BTPAN_STATE_ENABLED = 0,
35   BTPAN_STATE_DISABLED = 1
36 } btpan_control_state_t;
37 
38 /**
39  * Callback for pan connection state
40  */
41 typedef void (*btpan_connection_state_callback)(btpan_connection_state_t state,
42                                                 bt_status_t error,
43                                                 const RawAddress* bd_addr,
44                                                 int local_role,
45                                                 int remote_role);
46 typedef void (*btpan_control_state_callback)(btpan_control_state_t state,
47                                              int local_role, bt_status_t error,
48                                              const char* ifname);
49 
50 typedef struct {
51   size_t size;
52   btpan_control_state_callback control_state_cb;
53   btpan_connection_state_callback connection_state_cb;
54 } btpan_callbacks_t;
55 typedef struct {
56   /** set to size of this struct*/
57   size_t size;
58   /**
59    * Initialize the pan interface and register the btpan callbacks
60    */
61   bt_status_t (*init)(const btpan_callbacks_t* callbacks);
62   /*
63    * enable the pan service by specified role. The result state of
64    * enabl will be returned by btpan_control_state_callback. when pan-nap is
65    * enabled, the state of connecting panu device will be notified by
66    * btpan_connection_state_callback
67    */
68   bt_status_t (*enable)(int local_role);
69   /*
70    * get current pan local role
71    */
72   int (*get_local_role)(void);
73   /**
74    * start bluetooth pan connection to the remote device by specified pan role.
75    * The result state will be returned by btpan_connection_state_callback
76    */
77   bt_status_t (*connect)(const RawAddress* bd_addr, int local_role,
78                          int remote_role);
79   /**
80    * stop bluetooth pan connection. The result state will be returned by
81    * btpan_connection_state_callback
82    */
83   bt_status_t (*disconnect)(const RawAddress* bd_addr);
84 
85   /**
86    * Cleanup the pan interface
87    */
88   void (*cleanup)(void);
89 
90 } btpan_interface_t;
91 
92 namespace fmt {
93 template <>
94 struct formatter<btpan_connection_state_t>
95     : enum_formatter<btpan_connection_state_t> {};
96 
97 template <>
98 struct formatter<btpan_control_state_t>
99     : enum_formatter<btpan_control_state_t> {};
100 }  // namespace fmt
101