Add support for device running changed callback
[platform/core/multimedia/libmm-sound.git] / mm_sound_proxy.c
index 552614a..699949b 100644 (file)
@@ -8,6 +8,7 @@
 #include "include/mm_sound_common.h"
 #include "include/mm_sound_dbus.h"
 #include "include/mm_sound_intf.h"
+#include "include/mm_sound_focus_socket.h"
 
 struct callback_data {
        void *user_cb;
@@ -45,9 +46,8 @@ static int _notify_subscription(audio_event_t event, uint32_t subs_id, gboolean
                return MM_ERROR_SOUND_INTERNAL;
        }
 
-       if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_CLIENT_SUBSCRIBED, params))) {
+       if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_CLIENT_SUBSCRIBED, params)))
                debug_error("dbus send signal for client subscribed failed");
-       }
 
        debug_fleave();
        return ret;
@@ -71,16 +71,15 @@ static int _notify_signal_handled(audio_event_t event, uint32_t event_id, uint32
                return MM_ERROR_SOUND_INTERNAL;
        }
 
-       if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_CLIENT_HANDLED, params))) {
+       if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_CLIENT_HANDLED, params)))
                debug_error("dbus send signal for client handled failed");
-       }
 
        debug_fleave();
        return ret;
 }
 
 static int parse_device_variant(GVariant *v, int *device_id, const char **device_type, int *direction, int *state,
-                                                               const char **device_name, int *stream_id, int *stream_num)
+                                               const char **device_name, int *vendor_id, int *product_id, bool *is_running, int *stream_id, int *stream_num)
 {
        const char *v_type;
        GVariant *array_v;
@@ -94,7 +93,7 @@ static int parse_device_variant(GVariant *v, int *device_id, const char **device
        }
 
        v_type = g_variant_get_type_string(v);
-       if (g_variant_type_equal(v_type, "(isiisai)") == FALSE) {
+       if (g_variant_type_equal(v_type, "(isiisiibai)") == FALSE) {
                debug_error("device variant type not matching '%s'", v_type);
                return MM_ERROR_NONE;
        }
@@ -105,6 +104,9 @@ static int parse_device_variant(GVariant *v, int *device_id, const char **device
        g_variant_iter_next(&iter, "i", direction);
        g_variant_iter_next(&iter, "i", state);
        g_variant_iter_next(&iter, "&s", device_name);
+       g_variant_iter_next(&iter, "i", vendor_id);
+       g_variant_iter_next(&iter, "i", product_id);
+       g_variant_iter_next(&iter, "b", is_running);
 
        array_v = g_variant_iter_next_value(&iter);
        *stream_num = g_variant_iter_init(&array_iter, array_v);
@@ -134,6 +136,8 @@ static void dbus_callback(audio_event_t event, GVariant *params, void *userdata)
        GVariant *device_v;
        int stream_id[MAX_STREAM_ON_DEVICE];
        int stream_num;
+       int vendor_id, product_id;
+       bool is_running = FALSE;
 
        v_type = g_variant_get_type_string(params);
 
@@ -144,9 +148,9 @@ static void dbus_callback(audio_event_t event, GVariant *params, void *userdata)
                g_variant_get(params, "(&s&su)", &direction, &volume_type_str, &volume_level);
                ((mm_sound_volume_changed_wrapper_cb)(cb_data->user_cb))(direction, volume_type_str, volume_level, cb_data->user_data);
        } else if (event == AUDIO_EVENT_DEVICE_CONNECTED) {
-               gboolean is_connected = FALSE;
+               bool is_connected = false;
 
-               if (g_variant_type_equal(v_type, "(u(isiisai)b)") == FALSE) {
+               if (g_variant_type_equal(v_type, "(u(isiisiibai)b)") == FALSE) {
                        debug_error("Device connection changed signature not matching : %s", v_type);
                        return ;
                }
@@ -154,19 +158,19 @@ static void dbus_callback(audio_event_t event, GVariant *params, void *userdata)
                g_variant_iter_next(&iter, "u", &event_id);
                device_v = g_variant_iter_next_value(&iter);
                if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
-                                                       &name, stream_id, &stream_num) < 0) {
+                                                       &name, &vendor_id, &product_id, &is_running, stream_id, &stream_num) < 0) {
                        debug_error("Failed to parse device variant");
                        return ;
                }
                g_variant_iter_next(&iter, "b", &is_connected);
 
                ((mm_sound_device_connected_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
-                       state, name, stream_id, stream_num, is_connected, cb_data->user_data);
+                       state, name, vendor_id, product_id, is_running, stream_id, stream_num, is_connected, cb_data->user_data);
                _notify_signal_handled(event, event_id, cb_data->subs_id, g_variant_new("(ib)", device_id, is_connected));
        } else if (event == AUDIO_EVENT_DEVICE_INFO_CHANGED) {
                int changed_device_info_type = 0;
 
-               if (g_variant_type_equal(v_type, "(u(isiisai)i)") == FALSE) {
+               if (g_variant_type_equal(v_type, "(u(isiisiibai)i)") == FALSE) {
                        debug_error("Device information changed signature not matching : %s", v_type);
                        return ;
                }
@@ -175,17 +179,17 @@ static void dbus_callback(audio_event_t event, GVariant *params, void *userdata)
                g_variant_iter_next(&iter, "u", &event_id);
                device_v = g_variant_iter_next_value(&iter);
                if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
-                                                       &name, stream_id, &stream_num) < 0) {
+                                                       &name, &vendor_id, &product_id, &is_running, stream_id, &stream_num) < 0) {
                        debug_error("Failed to parse device variant");
                        return ;
                }
                g_variant_iter_next(&iter, "i", &changed_device_info_type);
 
                ((mm_sound_device_info_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
-                       state, name, stream_id, stream_num, changed_device_info_type, cb_data->user_data);
+                       state, name, vendor_id, product_id, is_running, stream_id, stream_num, changed_device_info_type, cb_data->user_data);
        } else if (event == AUDIO_EVENT_DEVICE_STATE_CHANGED) {
 
-               if (g_variant_type_equal(v_type, "(u(isiisai))") == FALSE) {
+               if (g_variant_type_equal(v_type, "(u(isiisiibai))") == FALSE) {
                        debug_error("Device state changed signature not matching : %s", v_type);
                        return ;
                }
@@ -194,13 +198,31 @@ static void dbus_callback(audio_event_t event, GVariant *params, void *userdata)
                g_variant_iter_next(&iter, "u", &event_id);
                device_v = g_variant_iter_next_value(&iter);
                if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
-                                                       &name, stream_id, &stream_num) < 0) {
+                                                       &name, &vendor_id, &product_id, &is_running, stream_id, &stream_num) < 0) {
                        debug_error("Failed to parse device variant");
                        return ;
                }
 
                ((mm_sound_device_state_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
-                       state, name, stream_id, stream_num, cb_data->user_data);
+                       state, name, vendor_id, product_id, is_running, stream_id, stream_num, cb_data->user_data);
+       } else if (event == AUDIO_EVENT_DEVICE_RUNNING_CHANGED) {
+
+               if (g_variant_type_equal(v_type, "(u(isiisiibai))") == FALSE) {
+                       debug_error("Device state changed signature not matching : %s", v_type);
+                       return ;
+               }
+
+               g_variant_iter_init(&iter, params);
+               g_variant_iter_next(&iter, "u", &event_id);
+               device_v = g_variant_iter_next_value(&iter);
+               if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
+                                                       &name, &vendor_id, &product_id, &is_running, stream_id, &stream_num) < 0) {
+                       debug_error("Failed to parse device variant");
+                       return ;
+               }
+
+               ((mm_sound_device_running_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
+                       state, name, vendor_id, product_id, is_running, stream_id, stream_num, cb_data->user_data);
        } else if (event == AUDIO_EVENT_FOCUS_CHANGED) {
        } else if (event == AUDIO_EVENT_FOCUS_WATCH) {
        } else if (event == AUDIO_EVENT_TEST) {
@@ -248,9 +270,8 @@ int mm_sound_proxy_remove_test_callback(unsigned subs_id)
        int ret = MM_ERROR_NONE;
        debug_fenter();
 
-       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
                debug_error("remove test callback failed");
-       }
 
        debug_fleave();
        return ret;
@@ -366,15 +387,15 @@ int mm_sound_proxy_get_current_connected_device_list(int device_flags, GList** d
        g_variant_iter_init(&iter, child);
        while (1) {
                device_item = g_malloc0(sizeof(mm_sound_device_t));
-               if (device_item && g_variant_iter_loop(&iter, "(i&sii&s)",
+               if (device_item && g_variant_iter_loop(&iter, "(i&sii&siib)",
                                        &device_item->id, &device_type_tmp, &device_item->io_direction, &device_item->state,
-                                       &device_name_tmp)) {
+                                       &device_name_tmp, &device_item->vendor_id, &device_item->product_id, &device_item->is_running)) {
                        MMSOUND_STRNCPY(device_item->name, device_name_tmp, MAX_DEVICE_NAME_NUM);
                        MMSOUND_STRNCPY(device_item->type, device_type_tmp, MAX_DEVICE_TYPE_STR_LEN);
                        *device_list = g_list_append(*device_list, device_item);
-                       debug_log("Added device id(%d) type(%17s) direction(%d) state(%d) name(%s)",
-                                       device_item->id, device_item->type,device_item->io_direction, device_item->state,
-                                       device_item->name);
+                       debug_log("Added device id(%d) type(%17s) direction(%d) state(%d) name(%s) vendor-id(%04x) product-id(%04x) is_running(%d)",
+                                       device_item->id, device_item->type, device_item->io_direction, device_item->state,
+                                       device_item->name, device_item->vendor_id, device_item->product_id, device_item->is_running);
                        device_item->stream_num = -1;
                } else {
                        if (device_item)
@@ -391,6 +412,63 @@ cleanup:
        return ret;
 }
 
+int mm_sound_proxy_get_device_by_id(int device_id, mm_sound_device_t **device)
+{
+       int ret = MM_ERROR_NONE;
+       GVariant *params = NULL, *result = NULL;
+       mm_sound_device_t* device_item = NULL;
+       const gchar *device_name_tmp = NULL, *device_type_tmp = NULL;
+
+       debug_fenter();
+
+       if (!device || device_id < 1) {
+               debug_error("Invalid Parameter, device null or improper device id");
+               return MM_ERROR_INVALID_ARGUMENT;
+       }
+
+       if ((params = g_variant_new("(i)", device_id)) == NULL) {
+               debug_error("Construct Param for get device by id failed");
+               return MM_ERROR_SOUND_INTERNAL;
+       }
+
+       if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_METHOD_GET_DEVICE_BY_ID, params, &result)) != MM_ERROR_NONE) {
+               debug_error("get device by id failed");
+               ret = MM_ERROR_SOUND_NO_DATA;
+               goto cleanup;
+       }
+
+       if (result) {
+               if ((device_item = g_malloc0(sizeof(mm_sound_device_t))) == NULL) {
+                       debug_error("Alloc device handle failed");
+                       ret = MM_ERROR_SOUND_INTERNAL;
+                       goto cleanup;
+               }
+
+               g_variant_get(result, "(i&sii&sii)",
+                               &device_item->id, &device_type_tmp, &device_item->io_direction,
+                               &device_item->state, &device_name_tmp,
+                               &device_item->vendor_id, &device_item->product_id);
+               MMSOUND_STRNCPY(device_item->name, device_name_tmp, MAX_DEVICE_NAME_NUM);
+               MMSOUND_STRNCPY(device_item->type, device_type_tmp, MAX_DEVICE_TYPE_STR_LEN);
+               debug_log("Get device id(%d) type(%17s) direction(%d) state(%d) name(%s) vendor-id(%04x) product-id(%04x)",
+                               device_item->id, device_item->type, device_item->io_direction,
+                               device_item->state, device_item->name,
+                               device_item->vendor_id, device_item->product_id);
+               device_item->stream_num = -1;
+               *device = device_item;
+       } else {
+               debug_error("reply null");
+               ret = MM_ERROR_SOUND_INTERNAL;
+       }
+
+cleanup:
+       if (result)
+               g_variant_unref(result);
+
+       debug_fleave();
+       return ret;
+}
+
 int mm_sound_proxy_add_device_connected_callback(int device_flags, mm_sound_device_connected_wrapper_cb func, void *userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
 {
        int ret = MM_ERROR_NONE;
@@ -458,9 +536,8 @@ int mm_sound_proxy_remove_device_info_changed_callback(unsigned subs_id)
        int ret = MM_ERROR_NONE;
        debug_fenter();
 
-       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
                debug_error("remove device info changed callback failed");
-       }
 
        debug_fleave();
        return ret;
@@ -489,9 +566,38 @@ int mm_sound_proxy_remove_device_state_changed_callback(unsigned subs_id)
        int ret = MM_ERROR_NONE;
        debug_fenter();
 
-       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
                debug_error("remove device state changed callback failed");
-       }
+
+       debug_fleave();
+       return ret;
+}
+
+int mm_sound_proxy_add_device_running_changed_callback(int device_flags, mm_sound_device_running_changed_wrapper_cb func, void* userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
+{
+       int ret = MM_ERROR_NONE;
+       struct callback_data *cb_data;
+
+       debug_fenter();
+
+       CB_DATA_NEW(cb_data, func, userdata, freefunc);
+
+       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_EVENT_DEVICE_RUNNING_CHANGED, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE)
+               debug_error("Add device running changed callback failed");
+       else
+               *subs_id = cb_data->subs_id;
+
+       debug_fleave();
+       return ret;
+}
+
+int mm_sound_proxy_remove_device_running_changed_callback(unsigned subs_id)
+{
+       int ret = MM_ERROR_NONE;
+       debug_fenter();
+
+       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
+               debug_error("remove device running changed callback failed");
 
        debug_fleave();
        return ret;
@@ -519,7 +625,7 @@ int mm_sound_proxy_set_volume_by_type(const char *volume_type, const unsigned vo
        if (result) {
                g_variant_get(result, "(&s)",  &reply);
                debug_log("reply : %s", reply);
-               if (!strcmp(reply, "STREAM_MANAGER_RETURN_ERROR"))
+               if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
                        ret = MM_ERROR_SOUND_INTERNAL;
        } else {
                debug_error("reply null");
@@ -558,10 +664,117 @@ int mm_sound_proxy_remove_volume_changed_callback(unsigned subs_id)
        int ret = MM_ERROR_NONE;
        debug_fenter();
 
-       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
                debug_error("Remove Volume changed callback failed");
+
+       debug_fleave();
+       return ret;
+}
+
+int mm_sound_proxy_set_filter_by_type(const char *stream_type, const char *filter_name, const char *filter_parameters, const char *filter_group)
+{
+       int ret = MM_ERROR_NONE;
+       char *reply = NULL;
+       GVariant *params = NULL, *result = NULL;
+
+       debug_fenter();
+
+       params = g_variant_new("(ssss)", filter_name, filter_parameters, filter_group, stream_type);
+       if (params) {
+               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_SET_FILTER, params, &result)) != MM_ERROR_NONE) {
+                       debug_error("dbus set filter by type failed");
+                       goto cleanup;
+               }
+       } else {
+               debug_error("construct param for method call failed");
+               return MM_ERROR_SOUND_INTERNAL;
        }
 
+       if (result) {
+               g_variant_get(result, "(&s)", &reply);
+               debug_log("reply : %s", reply);
+               if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
+                       ret = MM_ERROR_SOUND_INTERNAL;
+       } else {
+               debug_error("reply null");
+       }
+
+cleanup:
+       if (result)
+               g_variant_unref(result);
+
+       debug_fleave();
+       return ret;
+}
+
+int mm_sound_proxy_unset_filter_by_type(const char *stream_type)
+{
+       int ret = MM_ERROR_NONE;
+       char *reply = NULL;
+       GVariant *params = NULL, *result = NULL;
+
+       debug_fenter();
+
+       params = g_variant_new("(s)", stream_type);
+       if (params) {
+               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_UNSET_FILTER, params, &result)) != MM_ERROR_NONE) {
+                       debug_error("dbus unset filter by type failed");
+                       goto cleanup;
+               }
+       } else {
+               debug_error("construct param for method call failed");
+               return MM_ERROR_SOUND_INTERNAL;
+       }
+
+       if (result) {
+               g_variant_get(result, "(&s)", &reply);
+               debug_log("reply : %s", reply);
+               if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
+                       ret = MM_ERROR_SOUND_INTERNAL;
+       } else {
+               debug_error("reply null");
+       }
+
+cleanup:
+       if (result)
+               g_variant_unref(result);
+
+       debug_fleave();
+       return ret;
+}
+
+int mm_sound_proxy_control_filter_by_type(const char *stream_type, const char *filter_name, const char *filter_controls)
+{
+       int ret = MM_ERROR_NONE;
+       char *reply = NULL;
+       GVariant *params = NULL, *result = NULL;
+
+       debug_fenter();
+
+       params = g_variant_new("(sss)", filter_name, filter_controls, stream_type);
+       if (params) {
+               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_CONTROL_FILTER, params, &result)) != MM_ERROR_NONE) {
+                       debug_error("dbus control filter by type failed");
+                       goto cleanup;
+               }
+       } else {
+               debug_error("construct param for method call failed");
+               return MM_ERROR_SOUND_INTERNAL;
+       }
+
+       if (result) {
+               g_variant_get(result, "(&s)", &reply);
+               debug_log("reply : %s", reply);
+               if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
+                       ret = MM_ERROR_SOUND_INTERNAL;
+       } else {
+               debug_error("reply null");
+       }
+
+cleanup:
+       if (result)
+               g_variant_unref(result);
+
        debug_fleave();
        return ret;
 }
@@ -583,7 +796,7 @@ int mm_sound_proxy_play_tone(int tone, int repeat, int volume, int volume_config
        debug_fenter();
 
        params = g_variant_new("(iiiiiiibsi)", tone, repeat, volume, volume_config, session_type,
-                     session_options, client_pid , _enable_session, stream_type, stream_index);
+                                               session_options, client_pid, _enable_session, stream_type, stream_index);
        if (params) {
                if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_DTMF, params, &result)) != MM_ERROR_NONE) {
                        debug_error("dbus play tone failed");
@@ -665,7 +878,7 @@ int mm_sound_proxy_play_sound(const char* filename, int tone, int repeat, int vo
        debug_fenter();
 
        params = g_variant_new("(siiiiiiibsi)", filename, tone, repeat, volume,
-                     volume_config, session_type, session_options, client_pid, _enable_session, stream_type, stream_index);
+                               volume_config, session_type, session_options, client_pid, _enable_session, stream_type, stream_index);
        if (params) {
                if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_FILE_START, params, &result)) != MM_ERROR_NONE) {
                        debug_error("dbus play file failed");
@@ -760,9 +973,8 @@ int mm_sound_proxy_clear_focus(int pid)
 
        debug_fenter();
 
-       if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_CLEAR_FOCUS, g_variant_new("(i)", pid), &result)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_CLEAR_FOCUS, g_variant_new("(i)", pid), &result)) != MM_ERROR_NONE)
                debug_error("dbus clear focus failed");
-       }
 
        if (result)
                g_variant_unref(result);
@@ -795,9 +1007,8 @@ int mm_sound_proxy_remove_play_sound_end_callback(unsigned subs_id)
        int ret = MM_ERROR_NONE;
        debug_fenter();
 
-       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
                debug_error("Remove Play File End callback failed");
-       }
 
        debug_fleave();
        return ret;
@@ -838,9 +1049,8 @@ int mm_sound_proxy_get_unique_id(int *id)
 
        debug_fenter();
 
-       if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_GET_UNIQUE_ID, NULL, &result)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_GET_UNIQUE_ID, NULL, &result)) != MM_ERROR_NONE)
                debug_error("dbus get unique id failed");
-       }
 
        if (result) {
                g_variant_get(result, "(i)", &res);
@@ -863,9 +1073,8 @@ int mm_sound_proxy_register_focus(int id, int instance, const char *stream_type,
 
        params = g_variant_new("(iisb)", instance, id, stream_type, is_for_session);
        if (params) {
-               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_REGISTER_FOCUS, params, &result)) != MM_ERROR_NONE) {
+               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_REGISTER_FOCUS, params, &result)) != MM_ERROR_NONE)
                        debug_error("dbus register focus failed");
-               }
        } else {
                debug_error("Construct Param for method call failed");
        }
@@ -890,9 +1099,8 @@ int mm_sound_proxy_unregister_focus(int instance, int id, bool is_for_session)
 
        params = g_variant_new("(iib)", instance, id, is_for_session);
        if (params) {
-               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_UNREGISTER_FOCUS, params, &result)) != MM_ERROR_NONE) {
+               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_UNREGISTER_FOCUS, params, &result)) != MM_ERROR_NONE)
                        debug_error("dbus unregister focus failed");
-               }
        } else {
                debug_error("Construct Param for method call failed");
        }
@@ -907,18 +1115,17 @@ int mm_sound_proxy_unregister_focus(int instance, int id, bool is_for_session)
        return ret;
 }
 
-int mm_sound_proxy_set_foucs_reacquisition(int instance, int id, bool reacquisition)
+int mm_sound_proxy_set_focus_reacquisition(int instance, int id, bool reacquisition, bool is_for_session)
 {
        int ret = MM_ERROR_NONE;
        GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
 
-       params = g_variant_new("(iib)", instance, id, reacquisition);
+       params = g_variant_new("(iibb)", instance, id, reacquisition, is_for_session);
        if (params) {
-               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_SET_FOCUS_REACQUISITION, params, &result)) != MM_ERROR_NONE) {
+               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_SET_FOCUS_REACQUISITION, params, &result)) != MM_ERROR_NONE)
                        debug_error("dbus set focus reacquisition failed");
-               }
        } else {
                debug_error("Construct Param for method call failed");
        }
@@ -960,21 +1167,91 @@ int mm_sound_proxy_get_acquired_focus_stream_type(int focus_type, char **stream_
 int mm_sound_proxy_acquire_focus(int instance, int id, mm_sound_focus_type_e type, int option, const char *ext_info, bool is_for_session)
 {
        int ret = MM_ERROR_NONE;
+       bool is_in_focus_cb_thread = false;
+
+       debug_fenter();
+
+       mm_sound_client_is_focus_cb_thread(g_thread_self(), &is_in_focus_cb_thread);
+       if (is_in_focus_cb_thread) {
+               if ((ret = mm_sound_focus_socket_acquire(instance, id, type, option, ext_info ? ext_info : "", true, is_for_session)))
+                       debug_error("failed to mm_sound_focus_socket_acquire(), ret[0x%x]", ret);
+       } else {
+               GVariant *params = NULL, *result = NULL;
+
+               params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
+               if (params) {
+                       if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_ACQUIRE_FOCUS, params, &result)) != MM_ERROR_NONE)
+                               debug_error("dbus acquire focus failed");
+               } else {
+                       debug_error("Construct Param for method call failed");
+               }
+
+               if (ret != MM_ERROR_NONE)
+                       g_variant_get(result, "(i)",  &ret);
+               if (result)
+                       g_variant_unref(result);
+       }
+
+       debug_fleave();
+       return ret;
+}
+
+int mm_sound_proxy_release_focus(int instance, int id, mm_sound_focus_type_e type, int option, const char *ext_info, bool is_for_session)
+{
+       int ret = MM_ERROR_NONE;
+       bool is_in_focus_cb_thread = false;
+
+       debug_fenter();
+
+       mm_sound_client_is_focus_cb_thread(g_thread_self(), &is_in_focus_cb_thread);
+       if (is_in_focus_cb_thread) {
+               if ((ret = mm_sound_focus_socket_release(instance, id, type, option, ext_info ? ext_info : "", true, is_for_session)))
+                       debug_error("failed to mm_sound_focus_socket_release(), ret[0x%x]", ret);
+       } else {
+               GVariant *params = NULL, *result = NULL;
+
+               params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
+               if (params) {
+                       if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_RELEASE_FOCUS, params, &result)) != MM_ERROR_NONE)
+                               debug_error("dbus release focus failed");
+               } else {
+                       debug_error("Construct Param for method call failed");
+               }
+
+               if (ret != MM_ERROR_NONE)
+                       g_variant_get(result, "(i)",  &ret);
+               if (result)
+                       g_variant_unref(result);
+       }
+
+       debug_fleave();
+       return ret;
+}
+
+int mm_sound_proxy_update_stream_focus_status(int focus_id, unsigned int status)
+{
+       int ret = MM_ERROR_NONE;
+       char *reply = NULL;
        GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
 
-       params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
+       params = g_variant_new("(iu)", focus_id, status);
        if (params) {
-               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_ACQUIRE_FOCUS, params, &result)) != MM_ERROR_NONE) {
-                       debug_error("dbus acquire focus failed");
+               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_UPDATE_STREAM_FOCUS_STATUS, params, &result)) != MM_ERROR_NONE) {
+                       debug_error("dbus set volume by type failed");
+                       if (result) {
+                               g_variant_get(result, "(&s)",  &reply);
+                               debug_log("reply : %s", reply);
+                               if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
+                                       ret = MM_ERROR_SOUND_INTERNAL;
+                       }
                }
        } else {
                debug_error("Construct Param for method call failed");
+               return MM_ERROR_SOUND_INTERNAL;
        }
 
-       if (ret != MM_ERROR_NONE)
-               g_variant_get(result, "(i)",  &ret);
        if (result)
                g_variant_unref(result);
 
@@ -982,24 +1259,30 @@ int mm_sound_proxy_acquire_focus(int instance, int id, mm_sound_focus_type_e typ
        return ret;
 }
 
-int mm_sound_proxy_release_focus(int instance, int id, mm_sound_focus_type_e type, int option, const char *ext_info, bool is_for_session)
+int mm_sound_proxy_deliver_focus(int pid, int src_id, int dst_id, mm_sound_focus_type_e focus_type)
 {
        int ret = MM_ERROR_NONE;
+       char *reply = NULL;
        GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
 
-       params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
+       params = g_variant_new("(iiii)", pid, src_id, dst_id, focus_type);
        if (params) {
-               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_RELEASE_FOCUS, params, &result)) != MM_ERROR_NONE) {
-                       debug_error("dbus release focus failed");
+               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_DELIVER_FOCUS, params, &result)) != MM_ERROR_NONE) {
+                       debug_error("dbus deliver focus failed");
+                       if (result) {
+                               g_variant_get(result, "(&s)", &reply);
+                               debug_log("reply : %s", reply);
+                               if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
+                                       ret = MM_ERROR_SOUND_INTERNAL;
+                       }
                }
        } else {
                debug_error("Construct Param for method call failed");
+               return MM_ERROR_SOUND_INTERNAL;
        }
 
-       if (ret != MM_ERROR_NONE)
-               g_variant_get(result, "(i)",  &ret);
        if (result)
                g_variant_unref(result);
 
@@ -1007,18 +1290,17 @@ int mm_sound_proxy_release_focus(int instance, int id, mm_sound_focus_type_e typ
        return ret;
 }
 
-int mm_sound_proxy_set_focus_watch_callback(int instance, int handle, mm_sound_focus_type_e type, mm_sound_focus_changed_watch_cb callback, bool is_for_session, void* userdata)
+int mm_sound_proxy_set_focus_watch_callback(int instance, int handle, mm_sound_focus_type_e type, bool is_for_session, bool is_for_monitor, mm_sound_focus_changed_watch_cb callback, void* userdata)
 {
        int ret = MM_ERROR_NONE;
        GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
 
-       params = g_variant_new("(iiib)", instance, handle, type, is_for_session);
+       params = g_variant_new("(iiibb)", instance, handle, type, is_for_session, is_for_monitor);
        if (params) {
-               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_WATCH_FOCUS, params, &result)) != MM_ERROR_NONE) {
+               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_WATCH_FOCUS, params, &result)) != MM_ERROR_NONE)
                        debug_error("dbus set watch focus failed");
-               }
        } else {
                debug_error("Construct Param for method call failed");
        }
@@ -1042,9 +1324,8 @@ int mm_sound_proxy_unset_focus_watch_callback(int focus_tid, int handle, bool is
 
        params = g_variant_new("(iib)", focus_tid, handle, is_for_session);
        if (params) {
-               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_UNWATCH_FOCUS, params, &result)) != MM_ERROR_NONE) {
+               if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_UNWATCH_FOCUS, params, &result)) != MM_ERROR_NONE)
                        debug_error("dbus unset watch focus failed");
-               }
        } else {
                debug_error("Construct Param for method call failed");
        }