X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;ds=sidebyside;f=include%2Fbt-internal-types.h;h=de99945bed0d9c722a823f07af11f65db0766d95;hb=81db5653f444efcea9cdb0b5b640db738511ef13;hp=399214710f05eacb14f97301ec1c50d1b740e3f2;hpb=c5d845104b6ac010cb6d432b6751da3731d51e3e;p=platform%2Fcore%2Fconnectivity%2Fbluetooth-frwk.git diff --git a/include/bt-internal-types.h b/include/bt-internal-types.h index 3992147..de99945 100644 --- a/include/bt-internal-types.h +++ b/include/bt-internal-types.h @@ -21,15 +21,32 @@ #include #include +#include #include #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, @@ -64,9 +81,21 @@ typedef enum { BT_A2DP_SOURCE_EVENT, BT_HID_DEVICE_EVENT, BT_MAP_CLIENT_EVENT, +#ifdef GATT_NO_RELAY BT_GATT_BLUEZ_EVENT, /* GattValueChanged from bluez directly */ +#endif +//#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; @@ -103,6 +132,7 @@ typedef enum { #define BT_SERVER_ACCEPT_TIMEOUT 2000 /* 2 seconds */ #define BT_FILE_PATH_MAX 256 #define BT_META_DATA_MAX_LEN 512 + 1 +#define BT_MAX_HANDLE_LENGTH 50 #define BT_HFP_AUDIO_GATEWAY_UUID "0000111f-0000-1000-8000-00805f9b34fb" #define BT_HSP_AUDIO_GATEWAY_UUID "00001112-0000-1000-8000-00805f9b34fb" @@ -130,7 +160,7 @@ 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)) @@ -142,6 +172,7 @@ typedef enum { 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, @@ -163,6 +194,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, @@ -174,6 +206,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, @@ -184,12 +218,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, @@ -210,8 +243,7 @@ typedef enum { BT_UPDATE_LE_CONNECTION_MODE, BT_SET_PROFILE_TRUSTED, BT_GET_PROFILE_TRUSTED, - BT_SET_PROFILE_RESTRICTED, - BT_GET_PROFILE_RESTRICTED, + BT_DISCONNECT_DEVICE, BT_HID_CONNECT = BT_FUNC_HID_BASE, BT_HID_DISCONNECT, BT_HID_DEVICE_ACTIVATE, @@ -242,9 +274,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, @@ -253,9 +290,11 @@ 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, + BT_AVRCP_TRANSPORT_SET_PROPERTY, BT_OPP_PUSH_FILES = BT_FUNC_OPP_BASE, BT_OPP_CANCEL_PUSH, BT_OPP_IS_PUSHING_FILES, @@ -288,12 +327,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_SERVER_UPDATE_CONNECTION_INFO, BT_PBAP_CONNECT = BT_FUNC_PBAP_BASE, BT_PBAP_DISCONNECT, BT_PBAP_GET_PHONEBOOK_SIZE, @@ -312,19 +355,59 @@ 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, BT_HDP_REGISTER_SINK_APP, BT_HDP_UNREGISTER_SINK_APP, - BT_GATT_GET_PRIMARY_SERVICES = BT_FUNC_GATT_BASE, + BT_HDP_GET_FD, + + 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_UNWATCH_CHARACTERISTIC, +#endif BT_GATT_REGISTER_APPLICATION, BT_GATT_REGISTER_SERVICE, BT_GATT_SEND_RESPONSE, +//#ifndef GATT_DIRECT + BT_GATT_SERVER_REGISTER, + BT_GATT_SERVER_ADD_SERVICE, + BT_GATT_SERVER_ADD_CHARACTERISTIC, + BT_GATT_SERVER_ADD_DESCRIPTOR, + BT_GATT_SERVER_START_SERVICE, + 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, +//#endif BT_LE_IPSP_INIT = BT_FUNC_IPSP_BASE, BT_LE_IPSP_DEINIT, BT_LE_IPSP_CONNECT, @@ -383,6 +466,11 @@ typedef enum { BT_TDS_ACTIVATE_CONTROL_POINT, BT_OTP_SERVER_INIT = BT_FUNC_OTP_BASE, BT_OTP_SERVER_DEINIT, + BT_OTP_READ_VALUE, + BT_OTP_ENABLE_NOTIFICATION, + BT_OTP_WRITE_VALUE, + BT_LE_OTC_CONNECT, + BT_LE_OTC_DISCONNECT, } bt_function_t; typedef struct { @@ -416,7 +504,9 @@ typedef struct { #define BT_HF_SERVICE_INTERFACE "org.tizen.HfApp" #define BT_CORE_EVENT_INTERFACE "org.projectx.bt_core_event" #define BT_HF_LOCAL_TERM_EVENT_INTERFACE "org.projectx.bt_hf_local_term" +#ifdef GATT_NO_RELAY #define BT_GATT_CHARACTERISTIC_INTERFACE "org.bluez.GattCharacteristic1" +#endif #define BT_ADAPTER_PATH "/org/projectx/bt/adapter" #define BT_LE_ADAPTER_PATH "/org/projectx/bt/le/adapter" @@ -439,9 +529,23 @@ typedef struct { #define BT_HID_DEVICE_PATH "/org/projectx/bt/hid_device" #define BT_TDS_PATH "/org/projectx/bt/tds" #define BT_OTP_PATH "/org/projectx/bt/otp" +#define BT_HDP_DEVICE_PATH "/org/projectx/bt/hdp_device" + +#ifndef GATT_DIRECT +#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" @@ -535,12 +639,43 @@ typedef struct { #define BT_MEDIA_PLAY_STATUS "MediaPlayStatus" #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" +#endif #define BT_HARDWARE_ERROR "HardwareError" #define BT_TX_TIMEOUT_ERROR "TxTimeoutError" #define BT_HF_LOCAL_TERM "HandsfreeLocalTermination" @@ -550,6 +685,9 @@ typedef struct { #define BT_IPSP_CONNECTED "IpspConnected" #define BT_IPSP_DISCONNECTED "IpspDisconnected" #define BT_LE_DATA_LENGTH_CHANGED "LEDataLengthChanged" +#define BT_HDP_CONNECTED "HDPConnected" +#define BT_HDP_DISCONNECTED "HDPDisconnected" +#define BT_IBEACON_DEVICE_FOUND "iBeaconDeviceFound" #define BT_PXP_PROPERTY_CHANGED "PxpValueChanged" /* TDS */ @@ -561,6 +699,41 @@ typedef struct { /* OTP */ #define BT_OTP_SERVER_STATE_CHANGED "OtpServerStateChanged" +#define BT_OTP_READ_CHAR_VAL "OtpReadCharVal" +#define BT_OTP_NOTIFICATION_ENABLED "OtpNotificationEnabled" +#define BT_OTP_WRITE_CHAR_VAL "OtpWriteCharVal" +#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, + const char *device_name, + const unsigned char *auth_info, + char *passkey, + const char *filename, + const char *agent_path); + void (*bt_destroy_popup_all)(void); + bool (*bt_launch_unable_to_pairing_syspopup)(int result); + bool (*bt_is_tethering_enabled)(void); + int (*bt_get_mime_type)(char *file_name, char **mime_type); +}; + +typedef struct { + gboolean plugin_headed_enabled; + void *handle_headed; + struct bluetooth_headed_plugin_t *headed_plugin; +} bt_plugin_info_t; typedef enum { _PROFILE_UNKNOWN = 0, @@ -568,14 +741,32 @@ 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(); static inline tizen_profile_t get_tizen_profile() { @@ -605,7 +796,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; @@ -614,6 +810,50 @@ 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) @@ -622,7 +862,9 @@ static inline tizen_profile_t get_tizen_profile() #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 }