#include "bluetooth-api.h"
+#define NUM_APP_MAX 30
+
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
+typedef struct {
+ time_t session_start_time;
+ time_t session_end_time;
+ uint16_t session_connected_time;
+ uint16_t session_scan_time;
+ int num_app;
+ bt_battery_app_data app_data[NUM_APP_MAX];
+} bt_battery_dbus_data_t;
+
+typedef void (*bt_adapter_disable_bm_data_cb)(bt_battery_data *data);
+
typedef enum {
BT_NO_SERVER,
BT_NATIVE_SERVER,
//#ifndef GATT_DIRECT
BT_GATT_SERVER_EVENT,
//#endif
+#ifdef TIZEN_GATT_CLIENT
+ BT_GATT_CLIENT_EVENT,
+#endif
BT_TDS_EVENT,
BT_OTP_EVENT,
BT_HDP_EVENT,
+#ifdef TIZEN_FEATURE_BT_AVC_TARGET
+ BT_AUDIO_AVC_EVENT,
+#endif
/* Will be added */
} bt_event_type_t;
#define BT_FUNC_PBAP_BASE ((int)(BT_FUNC_RFCOMM_BASE + 0x0020))
#define BT_FUNC_HDP_BASE ((int)(BT_FUNC_PBAP_BASE + 0x0020))
#define BT_FUNC_GATT_BASE ((int)(BT_FUNC_HDP_BASE + 0x0020))
-#define BT_FUNC_IPSP_BASE ((int)(BT_FUNC_GATT_BASE + 0x0020))
+#define BT_FUNC_IPSP_BASE ((int)(BT_FUNC_GATT_BASE + 0x0040))
#define BT_FUNC_DPM_BASE ((int)(BT_FUNC_IPSP_BASE + 0x0020))
#define BT_FUNC_PXP_BASE ((int)(BT_FUNC_DPM_BASE + 0x0030)) /* Adding 0x0030 to base, as DPM has more use case */
#define BT_FUNC_MAP_BASE ((int)(BT_FUNC_PXP_BASE + 0x0020))
BT_ENABLE_ADAPTER,
BT_DISABLE_ADAPTER,
BT_RECOVER_ADAPTER,
+ BT_BATTERY_READ_DATA,
BT_SET_DISCOVERABLE_TIME,
BT_GET_DISCOVERABLE_TIME,
BT_IGNORE_AUTO_PAIRING,
BT_GET_RSSI,
BT_IS_CONNECTABLE,
BT_SET_CONNECTABLE,
+ BT_GET_CONNECTABLE,
BT_GET_BONDED_DEVICES,
BT_RESET_ADAPTER,
BT_SET_ADVERTISING,
BT_GET_SCAN_RESPONSE_DATA,
BT_SET_SCAN_RESPONSE_DATA,
BT_IS_ADVERTISING,
+ BT_IS_LE_2M_PHY_SUPPORTED,
+ BT_IS_LE_CODED_PHY_SUPPORTED,
BT_SET_MANUFACTURER_DATA,
BT_LE_CONN_UPDATE,
BT_LE_READ_MAXIMUM_DATA_LENGTH,
BT_REMOVE_WHITE_LIST,
BT_CLEAR_WHITE_LIST,
BT_REGISTER_SCAN_FILTER,
- BT_UNREGISTER_SCAN_FILTER,
- BT_UNREGISTER_ALL_SCAN_FILTERS,
BT_IS_SCAN_FILTER_SUPPORTED,
BT_GET_PROFILE_CONNECTED_DEVICES,
BT_ENABLE_FORCE_HCI_DUMP,
BT_SET_PASSKEY_NOTIFICATION,
+ BT_SET_SCAN_TYPE,
BT_BOND_DEVICE = BT_FUNC_DEVICE_BASE,
BT_BOND_DEVICE_BY_TYPE,
BT_CANCEL_BONDING,
BT_UPDATE_LE_CONNECTION_MODE,
BT_SET_PROFILE_TRUSTED,
BT_GET_PROFILE_TRUSTED,
+ BT_DISCONNECT_DEVICE,
BT_HID_CONNECT = BT_FUNC_HID_BASE,
BT_HID_DISCONNECT,
BT_HID_DEVICE_ACTIVATE,
BT_SET_SPEAKER_GAIN,
BT_SET_CONTENT_PROTECT,
BT_AUDIO_SELECT_ROLE,
+ BT_AUDIO_SET_ABSOLUTE_VOLUME,
+ BT_AUDIO_GET_ABSOLUTE_VOLUME,
+ BT_AUDIO_IS_AVC_ACTIVATED,
BT_OOB_READ_LOCAL_DATA = BT_FUNC_OOB_BASE,
BT_OOB_ADD_REMOTE_DATA,
BT_OOB_REMOVE_REMOTE_DATA,
+ BT_LE_OOB_READ_LOCAL_DATA,
+ BT_LE_OOB_ADD_REMOTE_DATA,
BT_AVRCP_SET_TRACK_INFO = BT_FUNC_AVRCP_BASE,
BT_AVRCP_SET_PROPERTY,
BT_AVRCP_SET_PROPERTIES,
BT_AVRCP_TARGET_CONNECT,
BT_AVRCP_TARGET_DISCONNECT,
BT_AVRCP_HANDLE_CONTROL,
+ BT_AVRCP_HANDLE_CONTROL_TO_DEST,
BT_AVRCP_CONTROL_SET_PROPERTY,
BT_AVRCP_CONTROL_GET_PROPERTY,
BT_AVRCP_GET_TRACK_INFO,
BT_RFCOMM_SOCKET_WRITE,
BT_RFCOMM_CREATE_SOCKET,
BT_RFCOMM_REMOVE_SOCKET,
+ BT_RFCOMM_LISTEN_AND_ACCEPT,
BT_RFCOMM_LISTEN,
BT_RFCOMM_IS_UUID_AVAILABLE,
BT_RFCOMM_ACCEPT_CONNECTION,
BT_RFCOMM_REJECT_CONNECTION,
BT_RFCOMM_CREATE_SOCKET_EX,
BT_RFCOMM_REMOVE_SOCKET_EX,
+ BT_RFCOMM_SEND_RX_DETAILS,
+ BT_RFCOMM_SEND_TX_DETAILS,
BT_PBAP_CONNECT = BT_FUNC_PBAP_BASE,
BT_PBAP_DISCONNECT,
BT_PBAP_GET_PHONEBOOK_SIZE,
BT_HDP_UNREGISTER_SINK_APP,
BT_HDP_GET_FD,
- BT_GATT_GET_PRIMARY_SERVICES = BT_FUNC_GATT_BASE,
+ BT_GATT_GET_PRIMARY_SERVICES = BT_FUNC_GATT_BASE, /* GATT Client */
+#ifdef TIZEN_GATT_CLIENT
+ BT_GATT_CLIENT_REGISTER, /* GATT Client */
+ BT_GATT_CLIENT_UNREGISTER, /* GATT Client */
+ BT_GATT_GET_SERVICE_PROPERTIES, /* GATT Client */
+ BT_GATT_GET_CHARACTERISTIC_PROPERTIES, /* GATT Client */
+ BT_GATT_GET_INCLUDED_SERVICES, /* GATT Client */
+#endif
BT_GATT_DISCOVER_CHARACTERISTICS,
BT_GATT_SET_PROPERTY_REQUEST,
- BT_GATT_READ_CHARACTERISTIC,
+ BT_GATT_READ_CHARACTERISTIC, /* GATT Client*/
+#ifdef TIZEN_GATT_CLIENT
+ BT_GATT_READ_DESCRIPTOR_VALUE, /* GATT Client */
+ BT_GATT_WRITE_CHARACTERISTIC_VALUE_BY_TYPE, /* GATT Client */
+ BT_GATT_WRITE_DESCRIPTOR_VALUE, /* GATT Client */
+ BT_GATT_WATCH_SERVICE_CHANGED_INDICATION, /* GATT Client */
+ BT_GATT_ACQUIRE_WRITE, /* GATT Client */
+#endif
BT_GATT_DISCOVER_CHARACTERISTICS_DESCRIPTOR,
#ifndef GATT_NO_RELAY
BT_GATT_WATCH_CHARACTERISTIC,
BT_GATT_SERVER_STOP_SERVICE,
BT_GATT_SERVER_DELETE_SERVICE,
BT_GATT_SERVER_SEND_RESPONSE,
+ BT_GATT_SERVER_ACQURE_WRITE_RESPONSE,
+ BT_GATT_SERVER_ACQUIRE_NOTIFY_RESPONSE,
BT_GATT_SERVER_SEND_INDICATION,
BT_GATT_SERVER_UPDATE_VALUE,
BT_GATT_SERVER_DEREGISTER,
#define BT_GATT_SERVER_PATH "/org/projectx/bt/gatt_server"
#endif
+#ifdef TIZEN_GATT_CLIENT
+#define BT_GATT_CLIENT_PATH "/org/projectx/bt/gatt_client"
+#endif
+
+#ifdef TIZEN_FEATURE_BT_AVC_TARGET
+#define BT_AUDIO_AVC_PATH "/org/projectx/bt/avc_mode"
+#endif
+
#define BT_ENABLED "Enabled"
#define BT_DISABLED "Disabled"
+#define BT_DISABLED_BATTERY_DATA "AdapterDisabledBatteryData"
#define BT_LE_ENABLED "LeEnabled"
#define BT_LE_DISABLED "LeDisabled"
#define BT_DISCOVERABLE_MODE_CHANGED "DiscoverableModeChanged"
#define BT_MEDIA_POSITION_STATUS "MediaPositionStatus"
#define BT_MEDIA_TRACK_CHANGE "MediaTrackStatus"
#define BT_MEDIA_DELAY_CHANGE "MediaDelayStatus"
+#define BT_MEDIA_VOLUME_CHANGE "MediaVolumeStatus"
#define BT_NAME_OWNER_CHANGED "NameOwnerChanged"
+
+#ifdef TIZEN_GATT_CLIENT
+#define BT_GATT_SERVER_CONNECTED "GattServerConnected"
+#define BT_GATT_SERVER_DISCONNECTED "GattServerDisconnected"
+#define BT_GATT_CLIENT_CONNECTED "GattClientConnected"
+#define BT_GATT_CLIENT_DISCONNECTED "GattClientDisconnected"
+#else
#define BT_GATT_CONNECTED "GattConnected"
#define BT_GATT_DISCONNECTED "GattDisconnected"
+#endif
#ifndef GATT_DIRECT
#define BT_GATT_VALUE_CHANGED "GattValueChanged"
#define BT_GATT_SERVER_READ_REQ "GattServerReadReq"
#define BT_GATT_SERVER_NOTIFICATION_COMPLETED "GattServerNotification"
#define BT_GATT_SERVER_NOTIFICATION_CHANGED "GattServerNotifChanged"
+#define BT_GATT_SERVER_ACQUIRE_WRITE "GattServerACquireWrite"
+#define BT_GATT_SERVER_ACQUIRE_NOTIFICATION "GattServerAcquireNotify"
+#endif
+
+#ifdef TIZEN_GATT_CLIENT
+#define BT_GATT_CLIENT_READ_CHAR "GattReadCharValue"
+#define BT_GATT_CLIENT_WRITE_CHAR "GattWriteCharValue"
+#define BT_GATT_CLIENT_READ_DESC "GattReadDescriptor"
+#define BT_GATT_CLIENT_WRITE_DESC "GattWriteDescriptor"
+#define BT_GATT_CLIENT_SERVICE_CHANGED "GattServiceChanged"
#endif
#define BT_GATT_REQ_ATT_MTU_CHANGED "GattReqAttMtuChanged"
+#define BT_GATT_SERVER_ATT_MTU_CHANGED "GattServerAttMtuChanged"
#define BT_GATT_CHAR_VAL_CHANGED "GattCharValueChanged"
#ifdef GATT_NO_RELAY
#define BT_GATT_BLUEZ_CHAR_VAL_CHANGED "GattValueChanged"
#define BT_OTP_INDICATION "OtpIndication"
#define BT_OTC_STATE_CHANGED "OtcStateChanged"
+#ifdef TIZEN_FEATURE_BT_AVC_TARGET
+#define BT_AUDIO_AVC_MODE_CHANGED "AvcModeChanged"
+#endif
+
#define HEADED_PLUGIN_FILEPATH "/usr/lib/bt-plugin-headed.so"
#define HEADED_PLUGIN_FILEPATH64 "/usr/lib64/bt-plugin-headed.so"
#define FILEPATH_ARCH_64 "/usr/lib64"
+#define BT_FEATURE_COMMON "http://tizen.org/feature/network.bluetooth"
+
struct bluetooth_headed_plugin_t {
int (*bt_launch_dpmpopup) (char *mode);
int (*bt_launch_system_popup)(int event_type,
_PROFILE_WEARABLE = 0x2,
_PROFILE_TV = 0x4,
_PROFILE_IVI = 0x8,
- _PROFILE_COMMON = 0x10,
+ _PROFILE_IOT = 0x10,
+ _PROFILE_COMMON = 0x20,
} tizen_profile_t;
+typedef enum {
+ _MODEL_UNKNOWN = 0,
+ _MODEL_COMMON = 0x1,
+ _MODEL_TM1 = 0x2,
+ _MODEL_TM2 = 0x4,
+ _MODEL_TW1 = 0x8,
+ _MODEL_TW2 = 0x10,
+ _MODEL_TW3 = 0x20,
+ _MODEL_RPI3 = 0x40,
+} tizen_model_t;
+
/* For optimization, make this extern and define in a shared C file */
extern tizen_profile_t profile;
+static tizen_model_t model = _MODEL_UNKNOWN;
extern bt_plugin_info_t *headed_plugin_info;
/* Accessing system info */
int system_info_get_platform_string(const char *key, char **value);
+bool system_info_get_platform_bool(const char *key, bool *value);
void bluetooth_plugin_init();
void bluetooth_plugin_deinit();
break;
case 'i':
case 'I':
- profile = _PROFILE_IVI;
+ if (!strncasecmp(profileName, "ivi", 3))
+ profile = _PROFILE_IVI;
+ else if (!strncasecmp(profileName, "iot", 3))
+ profile = _PROFILE_IOT;
+ else
+ profile = _PROFILE_COMMON;
break;
default: // common or unknown ==> ALL ARE COMMON.
profile = _PROFILE_COMMON;
return profile;
}
+
+static inline tizen_model_t get_tizen_model(void)
+{
+ char *model_name = NULL;
+
+ if (__builtin_expect(model != _MODEL_UNKNOWN, 1))
+ return model;
+
+ system_info_get_platform_string("http://tizen.org/system/model_name", &model_name);
+
+ if (model_name == NULL) {
+ model = _MODEL_COMMON;
+ return model;
+ }
+
+ if (!strcasecmp(model_name, "TM1"))
+ model = _MODEL_TM1;
+ else if (!strcasecmp(model_name, "TM2"))
+ model = _MODEL_TM2;
+ else if (!strcasecmp(model_name, "TW1"))
+ model = _MODEL_TW1;
+ else if (!strcasecmp(model_name, "TW2"))
+ model = _MODEL_TW2;
+ else if (!strcasecmp(model_name, "TW3"))
+ model = _MODEL_TW3;
+ else if (!strcasecmp(model_name, "rpi3"))
+ model = _MODEL_RPI3;
+ else
+ model = _MODEL_COMMON;
+
+ free(model_name);
+
+ return model;
+}
+
+static inline bool get_tizen_feature_supported(char *feature)
+{
+ bool is_supported = false;
+
+ system_info_get_platform_bool(feature, &is_supported);
+
+ return is_supported ? true : false;
+}
+
#define TIZEN_PROFILE_WEARABLE (get_tizen_profile() == _PROFILE_WEARABLE)
#define TIZEN_PROFILE_IVI (get_tizen_profile() == _PROFILE_IVI)
#define TIZEN_PROFILE_TV (get_tizen_profile() == _PROFILE_TV)
#define TIZEN_FEATURE_NETWORK_TETHERING_ENABLE (get_tizen_profile() & (_PROFILE_MOBILE))
#define TIZEN_FEATURE_TELEPHONY_ENABLED (get_tizen_profile() & (_PROFILE_MOBILE))
#define TIZEN_FEATURE_FLIGHTMODE_ENABLED (get_tizen_profile() & (_PROFILE_MOBILE | _PROFILE_WEARABLE))
-#define TIZEN_FEATURE_BT_USB_DONGLE (get_tizen_profile() & (_PROFILE_TV))
+#define TIZEN_FEATURE_BT_USB_DONGLE ((get_tizen_model()) == _MODEL_COMMON && (get_tizen_profile()) == _PROFILE_TV)
+#define TIZEN_FEATURE_BLUEZ_SPEAKER_REFERENCE ((get_tizen_model()) == _MODEL_RPI3 && (get_tizen_profile()) == _PROFILE_COMMON)
+#define TIZEN_FEATURE_BT_SUPPORTED (get_tizen_feature_supported(BT_FEATURE_COMMON) == true)
#ifdef __cplusplus
}