7 #include "include/mm_sound_proxy.h"
8 #include "include/mm_sound_common.h"
9 #include "include/mm_sound_dbus.h"
10 #include "include/mm_sound_intf.h"
11 #include "include/mm_sound_focus_socket.h"
13 struct callback_data {
16 mm_sound_proxy_userdata_free free_func;
20 #define CB_DATA_NEW(_cb_data, _func, _userdata, _freefunc) \
22 _cb_data = (struct callback_data*) g_malloc0(sizeof(struct callback_data)); \
23 _cb_data->user_cb = _func; \
24 _cb_data->user_data = _userdata; \
25 _cb_data->free_func = _freefunc; \
26 _cb_data->subs_id = 0; \
29 /* subscribe is true when add callback,
30 * false when remove callback */
31 static int _notify_subscription(audio_event_t event, uint32_t subs_id, gboolean subscribe)
33 int ret = MM_ERROR_NONE;
34 GVariant *params = NULL;
35 const char *event_name = NULL;
39 if ((ret = mm_sound_dbus_get_event_name(event, &event_name) != MM_ERROR_NONE)) {
40 debug_error("Failed to get event name");
41 return MM_ERROR_SOUND_INTERNAL;
44 if (!(params = g_variant_new("(sub)", event_name, subs_id, subscribe))) {
45 debug_error("Construct Param failed");
46 return MM_ERROR_SOUND_INTERNAL;
49 if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_CLIENT_SUBSCRIBED, params)))
50 debug_error("dbus send signal for client subscribed failed");
56 static int _notify_signal_handled(audio_event_t event, uint32_t event_id, uint32_t subs_id, GVariant *signal_params)
58 int ret = MM_ERROR_NONE;
59 GVariant *params = NULL;
60 const char *event_name = NULL;
64 if ((ret = mm_sound_dbus_get_event_name(event, &event_name) != MM_ERROR_NONE)) {
65 debug_error("Failed to get event name");
66 return MM_ERROR_SOUND_INTERNAL;
69 if (!(params = g_variant_new("(usuv)", event_id, event_name, subs_id, signal_params))) {
70 debug_error("Construct Param failed");
71 return MM_ERROR_SOUND_INTERNAL;
74 if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_CLIENT_HANDLED, params))) {
75 debug_error("dbus send signal for client handled failed");
82 static int parse_device_variant(GVariant *v, int *device_id, const char **device_type, int *direction, int *state,
83 const char **device_name, int *stream_id, int *stream_num)
87 GVariantIter iter, array_iter;
89 int ret = MM_ERROR_NONE;
92 debug_error("Variant NULL");
96 v_type = g_variant_get_type_string(v);
97 if (g_variant_type_equal(v_type, "(isiisai)") == FALSE) {
98 debug_error("device variant type not matching '%s'", v_type);
102 g_variant_iter_init(&iter, v);
103 g_variant_iter_next(&iter, "i", device_id);
104 g_variant_iter_next(&iter, "&s", device_type);
105 g_variant_iter_next(&iter, "i", direction);
106 g_variant_iter_next(&iter, "i", state);
107 g_variant_iter_next(&iter, "&s", device_name);
109 array_v = g_variant_iter_next_value(&iter);
110 *stream_num = g_variant_iter_init(&array_iter, array_v);
111 if (*stream_num > MAX_STREAM_ON_DEVICE) {
112 debug_error("too many streams on device %d", *stream_num);
113 ret = MM_ERROR_SOUND_INTERNAL;
117 while (g_variant_iter_loop(&array_iter, "i", &stream_id[i++])) ;
119 g_variant_unref(array_v);
124 /* This callback unmarshall general-formed paramters to subject specific parameters,
125 * and call proper callback */
126 static void dbus_callback(audio_event_t event, GVariant *params, void *userdata)
128 struct callback_data *cb_data = (struct callback_data*) userdata;
130 const char *name = NULL, *device_type = NULL;
131 int device_id, direction, state;
135 int stream_id[MAX_STREAM_ON_DEVICE];
138 v_type = g_variant_get_type_string(params);
140 if (event == AUDIO_EVENT_VOLUME_CHANGED) {
141 char *volume_type_str = NULL, *direction = NULL;
142 unsigned volume_level;
144 g_variant_get(params, "(&s&su)", &direction, &volume_type_str, &volume_level);
145 ((mm_sound_volume_changed_wrapper_cb)(cb_data->user_cb))(direction, volume_type_str, volume_level, cb_data->user_data);
146 } else if (event == AUDIO_EVENT_DEVICE_CONNECTED) {
147 gboolean is_connected = FALSE;
149 if (g_variant_type_equal(v_type, "(u(isiisai)b)") == FALSE) {
150 debug_error("Device connection changed signature not matching : %s", v_type);
153 g_variant_iter_init(&iter, params);
154 g_variant_iter_next(&iter, "u", &event_id);
155 device_v = g_variant_iter_next_value(&iter);
156 if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
157 &name, stream_id, &stream_num) < 0) {
158 debug_error("Failed to parse device variant");
161 g_variant_iter_next(&iter, "b", &is_connected);
163 ((mm_sound_device_connected_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
164 state, name, stream_id, stream_num, is_connected, cb_data->user_data);
165 _notify_signal_handled(event, event_id, cb_data->subs_id, g_variant_new("(ib)", device_id, is_connected));
166 } else if (event == AUDIO_EVENT_DEVICE_INFO_CHANGED) {
167 int changed_device_info_type = 0;
169 if (g_variant_type_equal(v_type, "(u(isiisai)i)") == FALSE) {
170 debug_error("Device information changed signature not matching : %s", v_type);
174 g_variant_iter_init(&iter, params);
175 g_variant_iter_next(&iter, "u", &event_id);
176 device_v = g_variant_iter_next_value(&iter);
177 if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
178 &name, stream_id, &stream_num) < 0) {
179 debug_error("Failed to parse device variant");
182 g_variant_iter_next(&iter, "i", &changed_device_info_type);
184 ((mm_sound_device_info_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
185 state, name, stream_id, stream_num, changed_device_info_type, cb_data->user_data);
186 } else if (event == AUDIO_EVENT_DEVICE_STATE_CHANGED) {
188 if (g_variant_type_equal(v_type, "(u(isiisai))") == FALSE) {
189 debug_error("Device state changed signature not matching : %s", v_type);
193 g_variant_iter_init(&iter, params);
194 g_variant_iter_next(&iter, "u", &event_id);
195 device_v = g_variant_iter_next_value(&iter);
196 if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
197 &name, stream_id, &stream_num) < 0) {
198 debug_error("Failed to parse device variant");
202 ((mm_sound_device_state_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
203 state, name, stream_id, stream_num, cb_data->user_data);
204 } else if (event == AUDIO_EVENT_FOCUS_CHANGED) {
205 } else if (event == AUDIO_EVENT_FOCUS_WATCH) {
206 } else if (event == AUDIO_EVENT_TEST) {
208 g_variant_get(params, "(i)", &test_var);
209 ((mm_sound_test_cb)(cb_data->user_cb))(test_var, cb_data->user_data);
210 } else if (event == AUDIO_EVENT_PLAY_FILE_END) {
211 int ended_handle = 0;
212 g_variant_get(params, "(i)", &ended_handle);
213 ((mm_sound_stop_callback_wrapper_func)(cb_data->user_cb))(ended_handle, cb_data->user_data);
217 static void simple_callback_data_free_func(void *data)
219 struct callback_data *cb_data = (struct callback_data*) data;
222 if (cb_data->free_func)
223 cb_data->free_func(cb_data->user_data);
228 int mm_sound_proxy_add_test_callback(mm_sound_test_cb func, void *userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
230 int ret = MM_ERROR_NONE;
231 struct callback_data *cb_data;
235 CB_DATA_NEW(cb_data, func, userdata, freefunc);
237 if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_EVENT_TEST, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE)
238 debug_error("add test callback failed");
240 *subs_id = cb_data->subs_id;
246 int mm_sound_proxy_remove_test_callback(unsigned subs_id)
248 int ret = MM_ERROR_NONE;
251 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
252 debug_error("remove test callback failed");
258 int mm_sound_proxy_test(int a, int b, int *get)
260 int ret = MM_ERROR_NONE;
262 GVariant *params = NULL, *result = NULL;
266 params = g_variant_new("(ii)", a, b);
268 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_TEST, params, &result)) != MM_ERROR_NONE) {
269 debug_error("dbus test call failed");
273 debug_error("Construct Param for method call failed");
274 return MM_ERROR_SOUND_INTERNAL;
278 g_variant_get(result, "(i)", &reply);
279 debug_log("reply : %d", reply);
282 debug_error("reply null");
287 g_variant_unref(result);
293 int mm_sound_proxy_is_stream_on_device(int stream_id, int device_id, bool *is_on)
295 int ret = MM_ERROR_NONE;
296 GVariant *params, *result;
302 debug_error("Invalid Parameter, is_on null");
303 return MM_ERROR_INVALID_ARGUMENT;
306 if ((params = g_variant_new("(ii)", stream_id, device_id)) == NULL) {
307 debug_error("Construct Param for query is stream on device failed");
308 return MM_ERROR_SOUND_INTERNAL;
311 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_METHOD_IS_STREAM_ON_DEVICE, params, &result)) != MM_ERROR_NONE) {
312 debug_error("is stream on device failed");
317 g_variant_get(result, "(b)", &_is_on);
318 debug_log("is_on : %d", _is_on);
319 *is_on = (bool)_is_on;
321 debug_error("reply null");
322 ret = MM_ERROR_SOUND_INTERNAL;
327 g_variant_unref(params);
329 g_variant_unref(result);
335 int mm_sound_proxy_get_current_connected_device_list(int device_flags, GList** device_list)
337 int ret = MM_ERROR_NONE;
338 GVariant *result = NULL, *child = NULL;
339 GVariant *params = NULL;
341 mm_sound_device_t* device_item;
342 const gchar *device_name_tmp = NULL, *device_type_tmp = NULL;
347 debug_error("Invalid Parameter, device_list null");
348 ret = MM_ERROR_INVALID_ARGUMENT;
352 params = g_variant_new("(i)", device_flags);
355 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_METHOD_GET_CONNECTED_DEVICE_LIST, params, &result)) != MM_ERROR_NONE) {
356 debug_error("Get current connected device list failed");
360 debug_error("Construct Param for get current connected device failed");
361 return MM_ERROR_SOUND_INTERNAL;
364 child = g_variant_get_child_value(result, 0);
365 g_variant_iter_init(&iter, child);
367 device_item = g_malloc0(sizeof(mm_sound_device_t));
368 if (device_item && g_variant_iter_loop(&iter, "(i&sii&s)",
369 &device_item->id, &device_type_tmp, &device_item->io_direction, &device_item->state,
371 MMSOUND_STRNCPY(device_item->name, device_name_tmp, MAX_DEVICE_NAME_NUM);
372 MMSOUND_STRNCPY(device_item->type, device_type_tmp, MAX_DEVICE_TYPE_STR_LEN);
373 *device_list = g_list_append(*device_list, device_item);
374 debug_log("Added device id(%d) type(%17s) direction(%d) state(%d) name(%s)",
375 device_item->id, device_item->type,device_item->io_direction, device_item->state,
377 device_item->stream_num = -1;
387 g_variant_unref(result);
393 int mm_sound_proxy_get_device_by_id(int device_id, mm_sound_device_t **device)
395 int ret = MM_ERROR_NONE;
396 GVariant *params = NULL, *result = NULL;
397 mm_sound_device_t* device_item = NULL;
398 const gchar *device_name_tmp = NULL, *device_type_tmp = NULL;
402 if (!device || device_id < 1) {
403 debug_error("Invalid Parameter, device null or improper device id");
404 return MM_ERROR_INVALID_ARGUMENT;
407 if ((params = g_variant_new("(i)", device_id)) == NULL) {
408 debug_error("Construct Param for get device by id failed");
409 return MM_ERROR_SOUND_INTERNAL;
412 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_METHOD_GET_DEVICE_BY_ID, params, &result)) != MM_ERROR_NONE) {
413 debug_error("get device by id failed");
414 ret = MM_ERROR_SOUND_NO_DATA;
419 if ((device_item = g_malloc0(sizeof(mm_sound_device_t))) == NULL) {
420 debug_error("Alloc device handle failed");
421 ret = MM_ERROR_SOUND_INTERNAL;
425 g_variant_get(result, "(i&sii&s)",
426 &device_item->id, &device_type_tmp, &device_item->io_direction,
427 &device_item->state, &device_name_tmp);
428 MMSOUND_STRNCPY(device_item->name, device_name_tmp, MAX_DEVICE_NAME_NUM);
429 MMSOUND_STRNCPY(device_item->type, device_type_tmp, MAX_DEVICE_TYPE_STR_LEN);
430 debug_log("Get device id(%d) type(%17s) direction(%d) state(%d) name(%s)",
431 device_item->id, device_item->type, device_item->io_direction,
432 device_item->state, device_item->name);
433 device_item->stream_num = -1;
434 *device = device_item;
436 debug_error("reply null");
437 ret = MM_ERROR_SOUND_INTERNAL;
442 g_variant_unref(result);
448 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)
450 int ret = MM_ERROR_NONE;
451 struct callback_data *cb_data;
455 CB_DATA_NEW(cb_data, func, userdata, freefunc);
457 if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_EVENT_DEVICE_CONNECTED, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE) {
458 debug_error("add device connected callback failed");
462 if ((ret = _notify_subscription(AUDIO_EVENT_DEVICE_CONNECTED, cb_data->subs_id, TRUE)) != MM_ERROR_NONE) {
463 debug_error("failed to notify subscription of device connected event");
467 *subs_id = cb_data->subs_id;
474 int mm_sound_proxy_remove_device_connected_callback(unsigned subs_id)
476 int ret = MM_ERROR_NONE;
479 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE) {
480 debug_error("remove device connected callback failed");
484 if ((ret = _notify_subscription(AUDIO_EVENT_DEVICE_CONNECTED, subs_id, FALSE)) != MM_ERROR_NONE)
485 debug_error("failed to notify unsubscription of device connected event");
492 int mm_sound_proxy_add_device_info_changed_callback(int device_flags, mm_sound_device_info_changed_wrapper_cb func, void* userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
494 int ret = MM_ERROR_NONE;
495 struct callback_data *cb_data;
499 CB_DATA_NEW(cb_data, func, userdata, freefunc);
501 if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_EVENT_DEVICE_INFO_CHANGED, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE)
502 debug_error("Add device info changed callback failed");
504 *subs_id = cb_data->subs_id;
510 int mm_sound_proxy_remove_device_info_changed_callback(unsigned subs_id)
512 int ret = MM_ERROR_NONE;
515 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
516 debug_error("remove device info changed callback failed");
522 int mm_sound_proxy_add_device_state_changed_callback(int device_flags, mm_sound_device_state_changed_wrapper_cb func, void* userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
524 int ret = MM_ERROR_NONE;
525 struct callback_data *cb_data;
529 CB_DATA_NEW(cb_data, func, userdata, freefunc);
531 if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_EVENT_DEVICE_STATE_CHANGED, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE)
532 debug_error("Add device state changed callback failed");
534 *subs_id = cb_data->subs_id;
540 int mm_sound_proxy_remove_device_state_changed_callback(unsigned subs_id)
542 int ret = MM_ERROR_NONE;
545 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
546 debug_error("remove device state changed callback failed");
552 int mm_sound_proxy_set_volume_by_type(const char *volume_type, const unsigned volume_level)
554 int ret = MM_ERROR_NONE;
555 char *reply = NULL, *direction = "out";
556 GVariant *params = NULL, *result = NULL;
560 params = g_variant_new("(ssu)", direction, volume_type, volume_level);
562 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_SET_VOLUME_LEVEL, params, &result)) != MM_ERROR_NONE) {
563 debug_error("dbus set volume by type failed");
567 debug_error("Construct Param for method call failed");
568 return MM_ERROR_SOUND_INTERNAL;
572 g_variant_get(result, "(&s)", &reply);
573 debug_log("reply : %s", reply);
574 if (!strcmp(reply, "STREAM_MANAGER_RETURN_ERROR"))
575 ret = MM_ERROR_SOUND_INTERNAL;
577 debug_error("reply null");
582 g_variant_unref(result);
588 int mm_sound_proxy_add_volume_changed_callback(mm_sound_volume_changed_wrapper_cb func, void* userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
590 int ret = MM_ERROR_NONE;
591 struct callback_data *cb_data;
595 CB_DATA_NEW(cb_data, func, userdata, freefunc);
597 if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_EVENT_VOLUME_CHANGED, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE)
598 debug_error("Add Volume changed callback failed");
600 *subs_id = cb_data->subs_id;
608 int mm_sound_proxy_remove_volume_changed_callback(unsigned subs_id)
610 int ret = MM_ERROR_NONE;
613 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
614 debug_error("Remove Volume changed callback failed");
620 int mm_sound_proxy_set_filter_by_type(const char *stream_type, const char *filter_name, const char *filter_parameters, const char *filter_group)
622 int ret = MM_ERROR_NONE;
624 GVariant *params = NULL, *result = NULL;
628 params = g_variant_new("(ssss)", filter_name, filter_parameters, filter_group, stream_type);
630 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_SET_FILTER, params, &result)) != MM_ERROR_NONE) {
631 debug_error("dbus set filter by type failed");
635 debug_error("construct param for method call failed");
636 return MM_ERROR_SOUND_INTERNAL;
640 g_variant_get(result, "(&s)", &reply);
641 debug_log("reply : %s", reply);
642 if (!strcmp(reply, "STREAM_MANAGER_RETURN_ERROR"))
643 ret = MM_ERROR_SOUND_INTERNAL;
645 debug_error("reply null");
650 g_variant_unref(result);
656 int mm_sound_proxy_unset_filter_by_type(const char *stream_type)
658 int ret = MM_ERROR_NONE;
660 GVariant *params = NULL, *result = NULL;
664 params = g_variant_new("(s)", stream_type);
666 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_UNSET_FILTER, params, &result)) != MM_ERROR_NONE) {
667 debug_error("dbus unset filter by type failed");
671 debug_error("construct param for method call failed");
672 return MM_ERROR_SOUND_INTERNAL;
676 g_variant_get(result, "(&s)", &reply);
677 debug_log("reply : %s", reply);
678 if (!strcmp(reply, "STREAM_MANAGER_RETURN_ERROR"))
679 ret = MM_ERROR_SOUND_INTERNAL;
681 debug_error("reply null");
686 g_variant_unref(result);
692 int mm_sound_proxy_control_filter_by_type(const char *stream_type, const char *filter_name, const char *filter_controls)
694 int ret = MM_ERROR_NONE;
696 GVariant *params = NULL, *result = NULL;
700 params = g_variant_new("(sss)", filter_name, filter_controls, stream_type);
702 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_CONTROL_FILTER, params, &result)) != MM_ERROR_NONE) {
703 debug_error("dbus control filter by type failed");
707 debug_error("construct param for method call failed");
708 return MM_ERROR_SOUND_INTERNAL;
712 g_variant_get(result, "(&s)", &reply);
713 debug_log("reply : %s", reply);
714 if (!strcmp(reply, "STREAM_MANAGER_RETURN_ERROR"))
715 ret = MM_ERROR_SOUND_INTERNAL;
717 debug_error("reply null");
722 g_variant_unref(result);
728 int mm_sound_proxy_play_tone(int tone, int repeat, int volume, int volume_config,
729 int session_type, int session_options, int client_pid,
730 bool enable_session, int *codechandle, char *stream_type, int stream_index)
732 int ret = MM_ERROR_NONE;
734 GVariant *params = NULL, *result = NULL;
735 gboolean _enable_session = enable_session;
738 debug_error("Param for play is null");
739 return MM_ERROR_INVALID_ARGUMENT;
744 params = g_variant_new("(iiiiiiibsi)", tone, repeat, volume, volume_config, session_type,
745 session_options, client_pid , _enable_session, stream_type, stream_index);
747 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_DTMF, params, &result)) != MM_ERROR_NONE) {
748 debug_error("dbus play tone failed");
752 debug_error("Construct Param for method call failed");
756 g_variant_get(result, "(i)", &handle);
757 debug_log("handle : %d", handle);
758 *codechandle = handle;
760 debug_error("reply null");
765 g_variant_unref(result);
771 int mm_sound_proxy_play_tone_with_stream_info(int client_pid, int tone, char *stream_type, int stream_index, int volume, int repeat, int *codechandle)
773 int ret = MM_ERROR_NONE;
775 GVariant *params = NULL, *result = NULL;
780 debug_error("Param for play is null");
781 return MM_ERROR_INVALID_ARGUMENT;
784 params = g_variant_new("(iiiisi)", tone, repeat, volume, client_pid, stream_type, stream_index);
786 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_DTMF_WITH_STREAM_INFO, params, &result)) != MM_ERROR_NONE) {
787 debug_error("dbus play tone failed");
791 debug_error("Construct Param for method call failed");
795 g_variant_get(result, "(i)", &handle);
796 debug_log("handle : %d", handle);
797 *codechandle = handle;
799 debug_error("reply null");
804 g_variant_unref(result);
810 int mm_sound_proxy_play_sound(const char* filename, int tone, int repeat, int volume, int volume_config,
811 int session_type, int session_options, int client_pid, bool enable_session, int *codechandle,
812 char *stream_type, int stream_index)
814 int ret = MM_ERROR_NONE;
816 GVariant *params = NULL, *result = NULL;
817 gboolean _enable_session = enable_session;
819 if (!filename || !codechandle) {
820 debug_error("Param for play is null");
821 return MM_ERROR_INVALID_ARGUMENT;
826 params = g_variant_new("(siiiiiiibsi)", filename, tone, repeat, volume,
827 volume_config, session_type, session_options, client_pid, _enable_session, stream_type, stream_index);
829 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_FILE_START, params, &result)) != MM_ERROR_NONE) {
830 debug_error("dbus play file failed");
834 debug_error("Construct Param for method call failed");
838 g_variant_get(result, "(i)", &handle);
839 debug_log("handle : %d", handle);
840 *codechandle = handle;
842 debug_error("reply null");
847 g_variant_unref(result);
853 int mm_sound_proxy_play_sound_with_stream_info(const char* filename, int repeat, int volume,
854 int client_pid, int *codechandle, char *stream_type, int stream_index)
856 int ret = MM_ERROR_NONE;
858 GVariant *params = NULL, *result = NULL;
860 if (!filename || !codechandle) {
861 debug_error("Param for play is null");
862 return MM_ERROR_INVALID_ARGUMENT;
867 params = g_variant_new("(siiisi)", filename, repeat, volume, client_pid, stream_type, stream_index);
869 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_FILE_START_WITH_STREAM_INFO, params, &result)) != MM_ERROR_NONE) {
870 debug_error("dbus play file failed");
874 debug_error("Construct Param for method call failed");
878 g_variant_get(result, "(i)", &handle);
879 debug_log("handle : %d", handle);
880 *codechandle = handle;
882 debug_error("reply null");
887 g_variant_unref(result);
895 int mm_sound_proxy_stop_sound(int handle)
897 int ret = MM_ERROR_NONE;
898 GVariant *result = NULL;
902 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_FILE_STOP, g_variant_new("(i)", handle), &result)) != MM_ERROR_NONE) {
903 debug_error("dbus stop file playing failed");
909 g_variant_unref(result);
915 int mm_sound_proxy_clear_focus(int pid)
917 int ret = MM_ERROR_NONE;
918 GVariant *result = NULL;
922 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)
923 debug_error("dbus clear focus failed");
926 g_variant_unref(result);
932 int mm_sound_proxy_add_play_sound_end_callback(mm_sound_stop_callback_wrapper_func func, void* userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
934 int ret = MM_ERROR_NONE;
935 struct callback_data *cb_data;
939 CB_DATA_NEW(cb_data, func, userdata, freefunc);
941 if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_EVENT_PLAY_FILE_END, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE)
942 debug_error("add play sound end callback failed");
944 *subs_id = cb_data->subs_id;
951 int mm_sound_proxy_remove_play_sound_end_callback(unsigned subs_id)
953 int ret = MM_ERROR_NONE;
956 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
957 debug_error("Remove Play File End callback failed");
963 int mm_sound_proxy_emergent_exit(int exit_pid)
965 int ret = MM_ERROR_NONE;
966 GVariant *params = NULL;
970 params = g_variant_new("(i)", exit_pid);
972 if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_EMERGENT_EXIT, params)) != MM_ERROR_NONE) {
973 debug_error("dbus emergent exit failed");
977 debug_error("Construct Param for emergent exit signal failed");
978 ret = MM_ERROR_SOUND_INTERNAL;
987 /*------------------------------------------ FOCUS --------------------------------------------------*/
990 int mm_sound_proxy_get_unique_id(int *id)
992 int ret = MM_ERROR_NONE;
994 GVariant *result = NULL;
998 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_GET_UNIQUE_ID, NULL, &result)) != MM_ERROR_NONE)
999 debug_error("dbus get unique id failed");
1002 g_variant_get(result, "(i)", &res);
1004 debug_msg("got unique id(%d)", *id);
1005 g_variant_unref(result);
1013 int mm_sound_proxy_register_focus(int id, int instance, const char *stream_type, mm_sound_focus_changed_cb callback, bool is_for_session, void* userdata)
1015 int ret = MM_ERROR_NONE;
1016 GVariant *params = NULL, *result = NULL;
1020 params = g_variant_new("(iisb)", instance, id, stream_type, is_for_session);
1022 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_REGISTER_FOCUS, params, &result)) != MM_ERROR_NONE)
1023 debug_error("dbus register focus failed");
1025 debug_error("Construct Param for method call failed");
1028 if (ret != MM_ERROR_NONE)
1029 g_variant_get(result, "(i)", &ret);
1031 g_variant_unref(result);
1039 int mm_sound_proxy_unregister_focus(int instance, int id, bool is_for_session)
1041 int ret = MM_ERROR_NONE;
1042 GVariant *params = NULL, *result = NULL;
1046 params = g_variant_new("(iib)", instance, id, is_for_session);
1048 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_UNREGISTER_FOCUS, params, &result)) != MM_ERROR_NONE)
1049 debug_error("dbus unregister focus failed");
1051 debug_error("Construct Param for method call failed");
1054 if (ret != MM_ERROR_NONE)
1055 g_variant_get(result, "(i)", &ret);
1057 g_variant_unref(result);
1064 int mm_sound_proxy_set_focus_reacquisition(int instance, int id, bool reacquisition, bool is_for_session)
1066 int ret = MM_ERROR_NONE;
1067 GVariant *params = NULL, *result = NULL;
1071 params = g_variant_new("(iibb)", instance, id, reacquisition, is_for_session);
1073 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_SET_FOCUS_REACQUISITION, params, &result)) != MM_ERROR_NONE)
1074 debug_error("dbus set focus reacquisition failed");
1076 debug_error("Construct Param for method call failed");
1079 if (ret != MM_ERROR_NONE)
1080 g_variant_get(result, "(i)", &ret);
1082 g_variant_unref(result);
1088 int mm_sound_proxy_get_acquired_focus_stream_type(int focus_type, char **stream_type, int *option, char **ext_info)
1090 int ret = MM_ERROR_NONE;
1091 GVariant *params = NULL, *result = NULL;
1095 if (!(params = g_variant_new("(i)", focus_type))) {
1096 debug_error("Construct Param for method call failed");
1097 return MM_ERROR_SOUND_INTERNAL;
1100 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_GET_ACQUIRED_FOCUS_STREAM_TYPE, params, &result)) == MM_ERROR_NONE) {
1102 g_variant_get(result, "(sis)", stream_type, option, ext_info);
1103 g_variant_unref(result);
1106 debug_error("dbus get stream type of acquired focus failed");
1113 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)
1115 int ret = MM_ERROR_NONE;
1116 bool is_in_focus_cb_thread = false;
1120 mm_sound_client_is_focus_cb_thread(g_thread_self(), &is_in_focus_cb_thread);
1121 if (is_in_focus_cb_thread) {
1122 if ((ret = mm_sound_focus_socket_acquire(instance, id, type, option, ext_info ? ext_info : "", true, is_for_session)))
1123 debug_error("failed to mm_sound_focus_socket_acquire(), ret[0x%x]", ret);
1125 GVariant *params = NULL, *result = NULL;
1127 params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
1129 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_ACQUIRE_FOCUS, params, &result)) != MM_ERROR_NONE)
1130 debug_error("dbus acquire focus failed");
1132 debug_error("Construct Param for method call failed");
1135 if (ret != MM_ERROR_NONE)
1136 g_variant_get(result, "(i)", &ret);
1138 g_variant_unref(result);
1145 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)
1147 int ret = MM_ERROR_NONE;
1148 bool is_in_focus_cb_thread = false;
1152 mm_sound_client_is_focus_cb_thread(g_thread_self(), &is_in_focus_cb_thread);
1153 if (is_in_focus_cb_thread) {
1154 if ((ret = mm_sound_focus_socket_release(instance, id, type, option, ext_info ? ext_info : "", true, is_for_session)))
1155 debug_error("failed to mm_sound_focus_socket_release(), ret[0x%x]", ret);
1157 GVariant *params = NULL, *result = NULL;
1159 params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
1161 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_RELEASE_FOCUS, params, &result)) != MM_ERROR_NONE)
1162 debug_error("dbus release focus failed");
1164 debug_error("Construct Param for method call failed");
1167 if (ret != MM_ERROR_NONE)
1168 g_variant_get(result, "(i)", &ret);
1170 g_variant_unref(result);
1177 int mm_sound_proxy_update_stream_focus_status(int focus_id, unsigned int status)
1179 int ret = MM_ERROR_NONE;
1181 GVariant *params = NULL, *result = NULL;
1185 params = g_variant_new("(iu)", focus_id, status);
1187 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_UPDATE_STREAM_FOCUS_STATUS, params, &result)) != MM_ERROR_NONE) {
1188 debug_error("dbus set volume by type failed");
1192 debug_error("Construct Param for method call failed");
1193 return MM_ERROR_SOUND_INTERNAL;
1197 g_variant_get(result, "(&s)", &reply);
1198 debug_log("reply : %s", reply);
1199 if (!strcmp(reply, "STREAM_MANAGER_RETURN_ERROR"))
1200 ret = MM_ERROR_SOUND_INTERNAL;
1202 debug_error("reply null");
1207 g_variant_unref(result);
1213 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)
1215 int ret = MM_ERROR_NONE;
1216 GVariant *params = NULL, *result = NULL;
1220 params = g_variant_new("(iiibb)", instance, handle, type, is_for_session, is_for_monitor);
1222 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_WATCH_FOCUS, params, &result)) != MM_ERROR_NONE)
1223 debug_error("dbus set watch focus failed");
1225 debug_error("Construct Param for method call failed");
1228 if (ret != MM_ERROR_NONE)
1229 g_variant_get(result, "(i)", &ret);
1231 g_variant_unref(result);
1238 int mm_sound_proxy_unset_focus_watch_callback(int focus_tid, int handle, bool is_for_session)
1240 int ret = MM_ERROR_NONE;
1241 GVariant *params = NULL, *result = NULL;
1245 params = g_variant_new("(iib)", focus_tid, handle, is_for_session);
1247 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_UNWATCH_FOCUS, params, &result)) != MM_ERROR_NONE)
1248 debug_error("dbus unset watch focus failed");
1250 debug_error("Construct Param for method call failed");
1252 if (ret != MM_ERROR_NONE)
1253 g_variant_get(result, "(i)", &ret);
1255 g_variant_unref(result);
1262 #endif /* USE_FOCUS */
1263 /*------------------------------------------ FOCUS --------------------------------------------------*/
1265 int mm_sound_proxy_initialize(void)
1267 int ret = MM_ERROR_NONE;
1275 int mm_sound_proxy_finalize(void)
1277 int ret = MM_ERROR_NONE;