X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=include%2Fbt-internal-types.h;h=95794dc8abb5c67c46161e50740570d052628f23;hb=056495021756aa37041f3e498c79f550d1885a91;hp=d3da33bfe510a9dbc1725d87047785af9225df4f;hpb=aa5b1255572c85a874f49e91975bc9227650be7b;p=platform%2Fcore%2Fconnectivity%2Fbluetooth-frwk.git diff --git a/include/bt-internal-types.h b/include/bt-internal-types.h index d3da33b..95794dc 100644 --- a/include/bt-internal-types.h +++ b/include/bt-internal-types.h @@ -27,10 +27,26 @@ #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; + uint32_t tx_time; + uint32_t rx_time; + uint32_t idle_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, @@ -71,9 +87,12 @@ typedef enum { //#ifndef GATT_DIRECT BT_GATT_SERVER_EVENT, //#endif + BT_GATT_CLIENT_EVENT, BT_TDS_EVENT, BT_OTP_EVENT, BT_HDP_EVENT, + BT_AUDIO_AVC_EVENT, + BT_MESH_EVENT, /* Will be added */ } bt_event_type_t; @@ -138,18 +157,20 @@ typedef enum { #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)) #define BT_FUNC_TDS_BASE ((int)(BT_FUNC_MAP_BASE + 0x0020)) #define BT_FUNC_OTP_BASE ((int)(BT_FUNC_TDS_BASE + 0x0020)) +#define BT_FUNC_MESH_BASE ((int)(BT_FUNC_OTP_BASE + 0x0020)) typedef enum { BT_CHECK_ADAPTER = BT_FUNC_BASE, 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, @@ -171,6 +192,7 @@ typedef enum { BT_GET_RSSI, BT_IS_CONNECTABLE, BT_SET_CONNECTABLE, + BT_GET_CONNECTABLE, BT_GET_BONDED_DEVICES, BT_RESET_ADAPTER, BT_SET_ADVERTISING, @@ -182,6 +204,8 @@ typedef enum { 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, @@ -192,12 +216,11 @@ typedef enum { 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, @@ -218,6 +241,7 @@ typedef enum { 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, @@ -248,9 +272,14 @@ typedef enum { 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, @@ -259,6 +288,7 @@ typedef enum { 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, @@ -295,12 +325,16 @@ typedef enum { 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_RFCOMM_UPDATE_CONNECTION_INFO, BT_PBAP_CONNECT = BT_FUNC_PBAP_BASE, BT_PBAP_DISCONNECT, BT_PBAP_GET_PHONEBOOK_SIZE, @@ -319,6 +353,11 @@ typedef enum { BT_GET_ATT_MTU, BT_GET_DEVICE_IDA, BT_SET_LE_STATIC_RANDOM_ADDRESS, + + BT_GET_GATT_DATA_BATCHING_AVAILABLE_PACKETS, + BT_ENABLE_GATT_DATA_BATCHING, + BT_DISABLE_GATT_DATA_BATCHING, + BT_HDP_CONNECT = BT_FUNC_HDP_BASE, BT_HDP_DISCONNECT, BT_HDP_SEND_DATA, @@ -326,10 +365,20 @@ typedef enum { 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 */ + 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 */ BT_GATT_DISCOVER_CHARACTERISTICS, BT_GATT_SET_PROPERTY_REQUEST, - BT_GATT_READ_CHARACTERISTIC, + BT_GATT_READ_CHARACTERISTIC, /* 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 */ BT_GATT_DISCOVER_CHARACTERISTICS_DESCRIPTOR, #ifndef GATT_NO_RELAY BT_GATT_WATCH_CHARACTERISTIC, @@ -347,6 +396,8 @@ typedef enum { 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, @@ -414,6 +465,47 @@ typedef enum { BT_OTP_WRITE_VALUE, BT_LE_OTC_CONNECT, BT_LE_OTC_DISCONNECT, + /* BT Mesh */ + BT_MESH_INIT = BT_FUNC_MESH_BASE, + BT_MESH_DEINIT, + BT_MESH_NETWORK_CREATE, + BT_MESH_NETWORK_DESTROY, + BT_MESH_NETWORK_LOAD, + BT_MESH_NETWORK_UNLOAD, + BT_MESH_NETWORK_SCAN, + BT_MESH_NETWORK_CANCEL_SCAN, + BT_MESH_NETWORK_SET_CAPABILITIES, + BT_MESH_NETWORK_PROVISION_DEVICE, + BT_MESH_AUTHENTICATION_REPLY, + BT_MESH_NETWORK_SET_NAME, + BT_MESH_NETWORK_ADD_NETKEY, + BT_MESH_NETWORK_DELETE_NETKEY, + BT_MESH_NETWORK_UPDATE_NETKEY, + BT_MESH_NETWORK_ADD_APPKEY, + BT_MESH_NETWORK_DELETE_APPKEY, + BT_MESH_NETWORK_UPDATE_APPKEY, + BT_MESH_NETWORK_GET_NETKEYS, + BT_MESH_NETWORK_GET_APPKEYS, + BT_MESH_NETWORK_GET_NODES, + BT_MESH_ELEMENT_GET_MODELS, + BT_MESH_NODE_BROWSE, + BT_MESH_NODE_GET_VENDOR_FEATURES, + BT_MESH_NODE_CONFIGURE_KEY, + BT_MESH_NODE_TTL_EXECUTE, + BT_MESH_NODE_GET_NETKEYS, + BT_MESH_NODE_GET_APPKEYS, + BT_MESH_NODE_RESET, + BT_MESH_MODEL_CONFIGURE_APPKEY, + BT_MESH_MODEL_GET_APPKEY_LIST, + BT_MESH_MODEL_EXECUTE_MSG, + BT_MESH_MODEL_GET_SUBSCRIPTION_LIST, + BT_MESH_MODEL_SET_PUBLICATION, + BT_MESH_MODEL_GET_PUBLICATION, + BT_MESH_NETWORK_CREATE_GROUP, + BT_MESH_NETWORK_REMOVE_GROUP, + BT_MESH_NETWORK_GET_GROUPS, + BT_MESH_MODEL_CONFIG_GROUP_SUB, + BT_MESH_MODEL_CONFIG_VIRTUAL_GROUP_SUB } bt_function_t; typedef struct { @@ -431,9 +523,7 @@ typedef struct { /* Need to convert the design ID */ #define BT_STR_NOT_SUPPORT "Not support" -#ifdef TIZEN_FEATURE_BT_DPM #define BT_DPM_SYSPOPUP "dpm-syspopup" -#endif #define BT_FILE_VISIBLE_TIME "file/private/libug-setting-bluetooth-efl/visibility_time" @@ -478,8 +568,15 @@ typedef struct { #define BT_GATT_SERVER_PATH "/org/projectx/bt/gatt_server" #endif +#define BT_GATT_CLIENT_PATH "/org/projectx/bt/gatt_client" + +#define BT_AUDIO_AVC_PATH "/org/projectx/bt/avc_mode" + +#define BT_MESH_PATH "/org/projectx/bt/mesh" + #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" @@ -574,18 +671,31 @@ typedef struct { #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" -#define BT_GATT_CONNECTED "GattConnected" -#define BT_GATT_DISCONNECTED "GattDisconnected" + +#define BT_GATT_SERVER_CONNECTED "GattServerConnected" +#define BT_GATT_SERVER_DISCONNECTED "GattServerDisconnected" +#define BT_GATT_CLIENT_CONNECTED "GattClientConnected" +#define BT_GATT_CLIENT_DISCONNECTED "GattClientDisconnected" #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 +#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" + #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" @@ -618,15 +728,40 @@ typedef struct { #define BT_OTP_WRITE_CHAR_VAL "OtpWriteCharVal" #define BT_OTP_INDICATION "OtpIndication" #define BT_OTC_STATE_CHANGED "OtcStateChanged" +#define BT_AUDIO_AVC_MODE_CHANGED "AvcModeChanged" #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_MESH_SCAN_STARTED "MeshScanStarted" +#define BT_MESH_SCAN_FINISHED "MeshScanFinished" +#define BT_MESH_SCAN_RESULT "MeshScanResult" +#define BT_MESH_AUTHENTICATION_REQ "MeshAuthReq" +#define BT_MESH_PROVISIONING_RESULT "MeshProvResult" +#define BT_MESH_NODE_BROWSED "MeshNodeBrowsed" +#define BT_MESH_NODE_VEND_FEATS "MeshNodeVendorFeatures" +#define BT_MESH_NODE_KEY_CONFIGURED "MeshNodeKeyConfigured" +#define BT_MESH_NODE_TTL_CONFIGURED "MeshNodeTTLConfigured" +#define BT_MESH_MODEL_APPKEY_CONFIGURED "MeshModelAppKeyConfigured" +#define BT_MESH_MODEL_MSG_EXECUTED "MeshModelMsgExecuted" +#define BT_MESH_MODEL_APPKEY_LIST "MeshModelAppKeyList" +#define BT_MESH_MODEL_SUB_LIST "MeshModelSubscriptionList" +#define BT_MESH_MODEL_SUB_CONF "MeshModelSubConfiguration" +#define BT_MESH_MODEL_VIR_SUB_CONF "MeshModelVirSubConfiguration" +#define BT_MESH_MODEL_PUB_STATUS "MeshModelPublicationStatus" + +#define BT_FEATURE_COMMON "http://tizen.org/feature/network.bluetooth" +#define BT_FEATURE_OPP "http://tizen.org/feature/network.bluetooth.opp" +#define BT_FEATURE_AUDIO_CALL "http://tizen.org/feature/network.bluetooth.audio.call" +#define BT_FEATURE_HID_DEVICE "http://tizen.org/feature/network.bluetooth.hid_device" +#define BT_FEATURE_PBAP "http://tizen.org/feature/network.bluetooth.phonebook.client" + struct bluetooth_headed_plugin_t { int (*bt_launch_dpmpopup) (char *mode); int (*bt_launch_system_popup)(int event_type, const char *device_name, + const char *remote_address, const unsigned char *auth_info, char *passkey, const char *filename, @@ -649,15 +784,29 @@ typedef enum { _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(); @@ -690,7 +839,12 @@ static inline tizen_profile_t get_tizen_profile() 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; @@ -699,15 +853,66 @@ static inline tizen_profile_t get_tizen_profile() 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_PROFILE_MOBILE (get_tizen_profile() == _PROFILE_MOBILE) +#define TIZEN_PROFILE_IOT (get_tizen_profile() == _PROFILE_IOT) #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) +#define TIZEN_FEATURE_OPP_SUPPORTED (get_tizen_feature_supported(BT_FEATURE_OPP) == true) +#define TIZEN_FEATURE_AUDIO_CALL_SUPPORTED (get_tizen_feature_supported(BT_FEATURE_AUDIO_CALL) == true) +#define TIZEN_FEATURE_HID_DEVICE_SUPPORTED (get_tizen_feature_supported(BT_FEATURE_HID_DEVICE) == true) +#define TIZEN_FEATURE_PBAP_SUPPORTED (get_tizen_feature_supported(BT_FEATURE_PBAP) == true) #ifdef __cplusplus }