X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=include%2Fbt-internal-types.h;h=5fee5c994851705830cdd764185977a77c95457f;hb=058d1c9bffbd8b4be2f16e8d55796afc7f8c4704;hp=9281aa0144c1954da2e331a7b70ed845e4cd2269;hpb=96e67a02816e81a31f8a37e188de0f3bbb13429b;p=platform%2Fcore%2Fconnectivity%2Fbluetooth-frwk.git diff --git a/include/bt-internal-types.h b/include/bt-internal-types.h index 9281aa0..5fee5c9 100644 --- a/include/bt-internal-types.h +++ b/include/bt-internal-types.h @@ -27,10 +27,23 @@ #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, @@ -71,6 +84,9 @@ typedef enum { //#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, @@ -138,7 +154,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)) @@ -150,6 +166,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, @@ -182,6 +199,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 +211,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 +236,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, @@ -251,6 +270,8 @@ typedef enum { 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 +280,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 +317,15 @@ 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_PBAP_CONNECT = BT_FUNC_PBAP_BASE, BT_PBAP_DISCONNECT, BT_PBAP_GET_PHONEBOOK_SIZE, @@ -326,10 +351,24 @@ 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 */ +#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, @@ -341,12 +380,14 @@ typedef enum { //#ifndef GATT_DIRECT BT_GATT_SERVER_REGISTER, BT_GATT_SERVER_ADD_SERVICE, - BT_GATT_SERVER_ADD_CHARACTERISTIC, + 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_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, @@ -478,8 +519,13 @@ typedef struct { #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 + #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" @@ -573,18 +619,37 @@ 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_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" #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" @@ -622,6 +687,8 @@ typedef struct { #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, @@ -648,15 +715,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(); @@ -689,7 +770,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; @@ -698,6 +784,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) @@ -707,6 +837,8 @@ static inline tizen_profile_t get_tizen_profile() #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_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 }