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");
81 static int parse_device_variant(GVariant *v, int *device_id, const char **device_type, int *direction, int *state,
82 const char **device_name, int *vendor_id, int *product_id, int *stream_id, int *stream_num)
86 GVariantIter iter, array_iter;
88 int ret = MM_ERROR_NONE;
91 debug_error("Variant NULL");
95 v_type = g_variant_get_type_string(v);
96 if (g_variant_type_equal(v_type, "(isiisiiai)") == FALSE) {
97 debug_error("device variant type not matching '%s'", v_type);
101 g_variant_iter_init(&iter, v);
102 g_variant_iter_next(&iter, "i", device_id);
103 g_variant_iter_next(&iter, "&s", device_type);
104 g_variant_iter_next(&iter, "i", direction);
105 g_variant_iter_next(&iter, "i", state);
106 g_variant_iter_next(&iter, "&s", device_name);
107 g_variant_iter_next(&iter, "i", vendor_id);
108 g_variant_iter_next(&iter, "i", product_id);
110 array_v = g_variant_iter_next_value(&iter);
111 *stream_num = g_variant_iter_init(&array_iter, array_v);
112 if (*stream_num > MAX_STREAM_ON_DEVICE) {
113 debug_error("too many streams on device %d", *stream_num);
114 ret = MM_ERROR_SOUND_INTERNAL;
118 while (g_variant_iter_loop(&array_iter, "i", &stream_id[i++])) ;
120 g_variant_unref(array_v);
125 /* This callback unmarshall general-formed paramters to subject specific parameters,
126 * and call proper callback */
127 static void dbus_callback(audio_event_t event, GVariant *params, void *userdata)
129 struct callback_data *cb_data = (struct callback_data*) userdata;
131 const char *name = NULL, *device_type = NULL;
132 int device_id, direction, state;
136 int stream_id[MAX_STREAM_ON_DEVICE];
138 int vendor_id, product_id;
140 v_type = g_variant_get_type_string(params);
142 if (event == AUDIO_EVENT_VOLUME_CHANGED) {
143 char *volume_type_str = NULL, *direction = NULL;
144 unsigned volume_level;
146 g_variant_get(params, "(&s&su)", &direction, &volume_type_str, &volume_level);
147 ((mm_sound_volume_changed_wrapper_cb)(cb_data->user_cb))(direction, volume_type_str, volume_level, cb_data->user_data);
148 } else if (event == AUDIO_EVENT_DEVICE_CONNECTED) {
149 gboolean is_connected = FALSE;
151 if (g_variant_type_equal(v_type, "(u(isiisiiai)b)") == FALSE) {
152 debug_error("Device connection changed signature not matching : %s", v_type);
155 g_variant_iter_init(&iter, params);
156 g_variant_iter_next(&iter, "u", &event_id);
157 device_v = g_variant_iter_next_value(&iter);
158 if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
159 &name, &vendor_id, &product_id, stream_id, &stream_num) < 0) {
160 debug_error("Failed to parse device variant");
163 g_variant_iter_next(&iter, "b", &is_connected);
165 ((mm_sound_device_connected_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
166 state, name, vendor_id, product_id, stream_id, stream_num, is_connected, cb_data->user_data);
167 _notify_signal_handled(event, event_id, cb_data->subs_id, g_variant_new("(ib)", device_id, is_connected));
168 } else if (event == AUDIO_EVENT_DEVICE_INFO_CHANGED) {
169 int changed_device_info_type = 0;
171 if (g_variant_type_equal(v_type, "(u(isiisiiai)i)") == FALSE) {
172 debug_error("Device information changed signature not matching : %s", v_type);
176 g_variant_iter_init(&iter, params);
177 g_variant_iter_next(&iter, "u", &event_id);
178 device_v = g_variant_iter_next_value(&iter);
179 if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
180 &name, &vendor_id, &product_id, stream_id, &stream_num) < 0) {
181 debug_error("Failed to parse device variant");
184 g_variant_iter_next(&iter, "i", &changed_device_info_type);
186 ((mm_sound_device_info_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
187 state, name, vendor_id, product_id, stream_id, stream_num, changed_device_info_type, cb_data->user_data);
188 } else if (event == AUDIO_EVENT_DEVICE_STATE_CHANGED) {
190 if (g_variant_type_equal(v_type, "(u(isiisiiai))") == FALSE) {
191 debug_error("Device state changed signature not matching : %s", v_type);
195 g_variant_iter_init(&iter, params);
196 g_variant_iter_next(&iter, "u", &event_id);
197 device_v = g_variant_iter_next_value(&iter);
198 if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
199 &name, &vendor_id, &product_id, stream_id, &stream_num) < 0) {
200 debug_error("Failed to parse device variant");
204 ((mm_sound_device_state_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
205 state, name, vendor_id, product_id, stream_id, stream_num, cb_data->user_data);
206 } else if (event == AUDIO_EVENT_FOCUS_CHANGED) {
207 } else if (event == AUDIO_EVENT_FOCUS_WATCH) {
208 } else if (event == AUDIO_EVENT_TEST) {
210 g_variant_get(params, "(i)", &test_var);
211 ((mm_sound_test_cb)(cb_data->user_cb))(test_var, cb_data->user_data);
212 } else if (event == AUDIO_EVENT_PLAY_FILE_END) {
213 int ended_handle = 0;
214 g_variant_get(params, "(i)", &ended_handle);
215 ((mm_sound_stop_callback_wrapper_func)(cb_data->user_cb))(ended_handle, cb_data->user_data);
219 static void simple_callback_data_free_func(void *data)
221 struct callback_data *cb_data = (struct callback_data*) data;
224 if (cb_data->free_func)
225 cb_data->free_func(cb_data->user_data);
230 int mm_sound_proxy_add_test_callback(mm_sound_test_cb func, void *userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
232 int ret = MM_ERROR_NONE;
233 struct callback_data *cb_data;
237 CB_DATA_NEW(cb_data, func, userdata, freefunc);
239 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)
240 debug_error("add test callback failed");
242 *subs_id = cb_data->subs_id;
248 int mm_sound_proxy_remove_test_callback(unsigned subs_id)
250 int ret = MM_ERROR_NONE;
253 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
254 debug_error("remove test callback failed");
260 int mm_sound_proxy_test(int a, int b, int *get)
262 int ret = MM_ERROR_NONE;
264 GVariant *params = NULL, *result = NULL;
268 params = g_variant_new("(ii)", a, b);
270 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_TEST, params, &result)) != MM_ERROR_NONE) {
271 debug_error("dbus test call failed");
275 debug_error("Construct Param for method call failed");
276 return MM_ERROR_SOUND_INTERNAL;
280 g_variant_get(result, "(i)", &reply);
281 debug_log("reply : %d", reply);
284 debug_error("reply null");
289 g_variant_unref(result);
295 int mm_sound_proxy_is_stream_on_device(int stream_id, int device_id, bool *is_on)
297 int ret = MM_ERROR_NONE;
298 GVariant *params, *result;
304 debug_error("Invalid Parameter, is_on null");
305 return MM_ERROR_INVALID_ARGUMENT;
308 if ((params = g_variant_new("(ii)", stream_id, device_id)) == NULL) {
309 debug_error("Construct Param for query is stream on device failed");
310 return MM_ERROR_SOUND_INTERNAL;
313 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_METHOD_IS_STREAM_ON_DEVICE, params, &result)) != MM_ERROR_NONE) {
314 debug_error("is stream on device failed");
319 g_variant_get(result, "(b)", &_is_on);
320 debug_log("is_on : %d", _is_on);
321 *is_on = (bool)_is_on;
323 debug_error("reply null");
324 ret = MM_ERROR_SOUND_INTERNAL;
329 g_variant_unref(params);
331 g_variant_unref(result);
337 int mm_sound_proxy_get_current_connected_device_list(int device_flags, GList** device_list)
339 int ret = MM_ERROR_NONE;
340 GVariant *result = NULL, *child = NULL;
341 GVariant *params = NULL;
343 mm_sound_device_t* device_item;
344 const gchar *device_name_tmp = NULL, *device_type_tmp = NULL;
349 debug_error("Invalid Parameter, device_list null");
350 ret = MM_ERROR_INVALID_ARGUMENT;
354 params = g_variant_new("(i)", device_flags);
357 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_METHOD_GET_CONNECTED_DEVICE_LIST, params, &result)) != MM_ERROR_NONE) {
358 debug_error("Get current connected device list failed");
362 debug_error("Construct Param for get current connected device failed");
363 return MM_ERROR_SOUND_INTERNAL;
366 child = g_variant_get_child_value(result, 0);
367 g_variant_iter_init(&iter, child);
369 device_item = g_malloc0(sizeof(mm_sound_device_t));
370 if (device_item && g_variant_iter_loop(&iter, "(i&sii&sii)",
371 &device_item->id, &device_type_tmp, &device_item->io_direction, &device_item->state,
372 &device_name_tmp, &device_item->vendor_id, &device_item->product_id)) {
373 MMSOUND_STRNCPY(device_item->name, device_name_tmp, MAX_DEVICE_NAME_NUM);
374 MMSOUND_STRNCPY(device_item->type, device_type_tmp, MAX_DEVICE_TYPE_STR_LEN);
375 *device_list = g_list_append(*device_list, device_item);
376 debug_log("Added device id(%d) type(%17s) direction(%d) state(%d) name(%s) vendor-id(%04x) product-id(%04x)",
377 device_item->id, device_item->type, device_item->io_direction, device_item->state,
378 device_item->name, device_item->vendor_id, device_item->product_id);
379 device_item->stream_num = -1;
389 g_variant_unref(result);
395 int mm_sound_proxy_get_device_by_id(int device_id, mm_sound_device_t **device)
397 int ret = MM_ERROR_NONE;
398 GVariant *params = NULL, *result = NULL;
399 mm_sound_device_t* device_item = NULL;
400 const gchar *device_name_tmp = NULL, *device_type_tmp = NULL;
404 if (!device || device_id < 1) {
405 debug_error("Invalid Parameter, device null or improper device id");
406 return MM_ERROR_INVALID_ARGUMENT;
409 if ((params = g_variant_new("(i)", device_id)) == NULL) {
410 debug_error("Construct Param for get device by id failed");
411 return MM_ERROR_SOUND_INTERNAL;
414 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_METHOD_GET_DEVICE_BY_ID, params, &result)) != MM_ERROR_NONE) {
415 debug_error("get device by id failed");
416 ret = MM_ERROR_SOUND_NO_DATA;
421 if ((device_item = g_malloc0(sizeof(mm_sound_device_t))) == NULL) {
422 debug_error("Alloc device handle failed");
423 ret = MM_ERROR_SOUND_INTERNAL;
427 g_variant_get(result, "(i&sii&sii)",
428 &device_item->id, &device_type_tmp, &device_item->io_direction,
429 &device_item->state, &device_name_tmp,
430 &device_item->vendor_id, &device_item->product_id);
431 MMSOUND_STRNCPY(device_item->name, device_name_tmp, MAX_DEVICE_NAME_NUM);
432 MMSOUND_STRNCPY(device_item->type, device_type_tmp, MAX_DEVICE_TYPE_STR_LEN);
433 debug_log("Get device id(%d) type(%17s) direction(%d) state(%d) name(%s) vendor-id(%04x) product-id(%04x)",
434 device_item->id, device_item->type, device_item->io_direction,
435 device_item->state, device_item->name,
436 device_item->vendor_id, device_item->product_id);
437 device_item->stream_num = -1;
438 *device = device_item;
440 debug_error("reply null");
441 ret = MM_ERROR_SOUND_INTERNAL;
446 g_variant_unref(result);
452 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)
454 int ret = MM_ERROR_NONE;
455 struct callback_data *cb_data;
459 CB_DATA_NEW(cb_data, func, userdata, freefunc);
461 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) {
462 debug_error("add device connected callback failed");
466 if ((ret = _notify_subscription(AUDIO_EVENT_DEVICE_CONNECTED, cb_data->subs_id, TRUE)) != MM_ERROR_NONE) {
467 debug_error("failed to notify subscription of device connected event");
471 *subs_id = cb_data->subs_id;
478 int mm_sound_proxy_remove_device_connected_callback(unsigned subs_id)
480 int ret = MM_ERROR_NONE;
483 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE) {
484 debug_error("remove device connected callback failed");
488 if ((ret = _notify_subscription(AUDIO_EVENT_DEVICE_CONNECTED, subs_id, FALSE)) != MM_ERROR_NONE)
489 debug_error("failed to notify unsubscription of device connected event");
496 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)
498 int ret = MM_ERROR_NONE;
499 struct callback_data *cb_data;
503 CB_DATA_NEW(cb_data, func, userdata, freefunc);
505 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)
506 debug_error("Add device info changed callback failed");
508 *subs_id = cb_data->subs_id;
514 int mm_sound_proxy_remove_device_info_changed_callback(unsigned subs_id)
516 int ret = MM_ERROR_NONE;
519 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
520 debug_error("remove device info changed callback failed");
526 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)
528 int ret = MM_ERROR_NONE;
529 struct callback_data *cb_data;
533 CB_DATA_NEW(cb_data, func, userdata, freefunc);
535 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)
536 debug_error("Add device state changed callback failed");
538 *subs_id = cb_data->subs_id;
544 int mm_sound_proxy_remove_device_state_changed_callback(unsigned subs_id)
546 int ret = MM_ERROR_NONE;
549 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
550 debug_error("remove device state changed callback failed");
556 int mm_sound_proxy_set_volume_by_type(const char *volume_type, const unsigned volume_level)
558 int ret = MM_ERROR_NONE;
559 char *reply = NULL, *direction = "out";
560 GVariant *params = NULL, *result = NULL;
564 params = g_variant_new("(ssu)", direction, volume_type, volume_level);
566 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_SET_VOLUME_LEVEL, params, &result)) != MM_ERROR_NONE) {
567 debug_error("dbus set volume by type failed");
571 debug_error("Construct Param for method call failed");
572 return MM_ERROR_SOUND_INTERNAL;
576 g_variant_get(result, "(&s)", &reply);
577 debug_log("reply : %s", reply);
578 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
579 ret = MM_ERROR_SOUND_INTERNAL;
581 debug_error("reply null");
586 g_variant_unref(result);
592 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)
594 int ret = MM_ERROR_NONE;
595 struct callback_data *cb_data;
599 CB_DATA_NEW(cb_data, func, userdata, freefunc);
601 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)
602 debug_error("Add Volume changed callback failed");
604 *subs_id = cb_data->subs_id;
612 int mm_sound_proxy_remove_volume_changed_callback(unsigned subs_id)
614 int ret = MM_ERROR_NONE;
617 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
618 debug_error("Remove Volume changed callback failed");
624 int mm_sound_proxy_set_filter_by_type(const char *stream_type, const char *filter_name, const char *filter_parameters, const char *filter_group)
626 int ret = MM_ERROR_NONE;
628 GVariant *params = NULL, *result = NULL;
632 params = g_variant_new("(ssss)", filter_name, filter_parameters, filter_group, stream_type);
634 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_SET_FILTER, params, &result)) != MM_ERROR_NONE) {
635 debug_error("dbus set filter by type failed");
639 debug_error("construct param for method call failed");
640 return MM_ERROR_SOUND_INTERNAL;
644 g_variant_get(result, "(&s)", &reply);
645 debug_log("reply : %s", reply);
646 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
647 ret = MM_ERROR_SOUND_INTERNAL;
649 debug_error("reply null");
654 g_variant_unref(result);
660 int mm_sound_proxy_unset_filter_by_type(const char *stream_type)
662 int ret = MM_ERROR_NONE;
664 GVariant *params = NULL, *result = NULL;
668 params = g_variant_new("(s)", stream_type);
670 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_UNSET_FILTER, params, &result)) != MM_ERROR_NONE) {
671 debug_error("dbus unset filter by type failed");
675 debug_error("construct param for method call failed");
676 return MM_ERROR_SOUND_INTERNAL;
680 g_variant_get(result, "(&s)", &reply);
681 debug_log("reply : %s", reply);
682 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
683 ret = MM_ERROR_SOUND_INTERNAL;
685 debug_error("reply null");
690 g_variant_unref(result);
696 int mm_sound_proxy_control_filter_by_type(const char *stream_type, const char *filter_name, const char *filter_controls)
698 int ret = MM_ERROR_NONE;
700 GVariant *params = NULL, *result = NULL;
704 params = g_variant_new("(sss)", filter_name, filter_controls, stream_type);
706 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_CONTROL_FILTER, params, &result)) != MM_ERROR_NONE) {
707 debug_error("dbus control filter by type failed");
711 debug_error("construct param for method call failed");
712 return MM_ERROR_SOUND_INTERNAL;
716 g_variant_get(result, "(&s)", &reply);
717 debug_log("reply : %s", reply);
718 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
719 ret = MM_ERROR_SOUND_INTERNAL;
721 debug_error("reply null");
726 g_variant_unref(result);
732 int mm_sound_proxy_play_tone(int tone, int repeat, int volume, int volume_config,
733 int session_type, int session_options, int client_pid,
734 bool enable_session, int *codechandle, char *stream_type, int stream_index)
736 int ret = MM_ERROR_NONE;
738 GVariant *params = NULL, *result = NULL;
739 gboolean _enable_session = enable_session;
742 debug_error("Param for play is null");
743 return MM_ERROR_INVALID_ARGUMENT;
748 params = g_variant_new("(iiiiiiibsi)", tone, repeat, volume, volume_config, session_type,
749 session_options, client_pid, _enable_session, stream_type, stream_index);
751 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_DTMF, params, &result)) != MM_ERROR_NONE) {
752 debug_error("dbus play tone failed");
756 debug_error("Construct Param for method call failed");
760 g_variant_get(result, "(i)", &handle);
761 debug_log("handle : %d", handle);
762 *codechandle = handle;
764 debug_error("reply null");
769 g_variant_unref(result);
775 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)
777 int ret = MM_ERROR_NONE;
779 GVariant *params = NULL, *result = NULL;
784 debug_error("Param for play is null");
785 return MM_ERROR_INVALID_ARGUMENT;
788 params = g_variant_new("(iiiisi)", tone, repeat, volume, client_pid, stream_type, stream_index);
790 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_DTMF_WITH_STREAM_INFO, params, &result)) != MM_ERROR_NONE) {
791 debug_error("dbus play tone failed");
795 debug_error("Construct Param for method call failed");
799 g_variant_get(result, "(i)", &handle);
800 debug_log("handle : %d", handle);
801 *codechandle = handle;
803 debug_error("reply null");
808 g_variant_unref(result);
814 int mm_sound_proxy_play_sound(const char* filename, int tone, int repeat, int volume, int volume_config,
815 int session_type, int session_options, int client_pid, bool enable_session, int *codechandle,
816 char *stream_type, int stream_index)
818 int ret = MM_ERROR_NONE;
820 GVariant *params = NULL, *result = NULL;
821 gboolean _enable_session = enable_session;
823 if (!filename || !codechandle) {
824 debug_error("Param for play is null");
825 return MM_ERROR_INVALID_ARGUMENT;
830 params = g_variant_new("(siiiiiiibsi)", filename, tone, repeat, volume,
831 volume_config, session_type, session_options, client_pid, _enable_session, stream_type, stream_index);
833 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_FILE_START, params, &result)) != MM_ERROR_NONE) {
834 debug_error("dbus play file failed");
838 debug_error("Construct Param for method call failed");
842 g_variant_get(result, "(i)", &handle);
843 debug_log("handle : %d", handle);
844 *codechandle = handle;
846 debug_error("reply null");
851 g_variant_unref(result);
857 int mm_sound_proxy_play_sound_with_stream_info(const char* filename, int repeat, int volume,
858 int client_pid, int *codechandle, char *stream_type, int stream_index)
860 int ret = MM_ERROR_NONE;
862 GVariant *params = NULL, *result = NULL;
864 if (!filename || !codechandle) {
865 debug_error("Param for play is null");
866 return MM_ERROR_INVALID_ARGUMENT;
871 params = g_variant_new("(siiisi)", filename, repeat, volume, client_pid, stream_type, stream_index);
873 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) {
874 debug_error("dbus play file failed");
878 debug_error("Construct Param for method call failed");
882 g_variant_get(result, "(i)", &handle);
883 debug_log("handle : %d", handle);
884 *codechandle = handle;
886 debug_error("reply null");
891 g_variant_unref(result);
899 int mm_sound_proxy_stop_sound(int handle)
901 int ret = MM_ERROR_NONE;
902 GVariant *result = NULL;
906 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) {
907 debug_error("dbus stop file playing failed");
913 g_variant_unref(result);
919 int mm_sound_proxy_clear_focus(int pid)
921 int ret = MM_ERROR_NONE;
922 GVariant *result = NULL;
926 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)
927 debug_error("dbus clear focus failed");
930 g_variant_unref(result);
936 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)
938 int ret = MM_ERROR_NONE;
939 struct callback_data *cb_data;
943 CB_DATA_NEW(cb_data, func, userdata, freefunc);
945 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)
946 debug_error("add play sound end callback failed");
948 *subs_id = cb_data->subs_id;
955 int mm_sound_proxy_remove_play_sound_end_callback(unsigned subs_id)
957 int ret = MM_ERROR_NONE;
960 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
961 debug_error("Remove Play File End callback failed");
967 int mm_sound_proxy_emergent_exit(int exit_pid)
969 int ret = MM_ERROR_NONE;
970 GVariant *params = NULL;
974 params = g_variant_new("(i)", exit_pid);
976 if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_EMERGENT_EXIT, params)) != MM_ERROR_NONE) {
977 debug_error("dbus emergent exit failed");
981 debug_error("Construct Param for emergent exit signal failed");
982 ret = MM_ERROR_SOUND_INTERNAL;
991 /*------------------------------------------ FOCUS --------------------------------------------------*/
994 int mm_sound_proxy_get_unique_id(int *id)
996 int ret = MM_ERROR_NONE;
998 GVariant *result = NULL;
1002 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_GET_UNIQUE_ID, NULL, &result)) != MM_ERROR_NONE)
1003 debug_error("dbus get unique id failed");
1006 g_variant_get(result, "(i)", &res);
1008 debug_msg("got unique id(%d)", *id);
1009 g_variant_unref(result);
1017 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)
1019 int ret = MM_ERROR_NONE;
1020 GVariant *params = NULL, *result = NULL;
1024 params = g_variant_new("(iisb)", instance, id, stream_type, is_for_session);
1026 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_REGISTER_FOCUS, params, &result)) != MM_ERROR_NONE)
1027 debug_error("dbus register focus failed");
1029 debug_error("Construct Param for method call failed");
1032 if (ret != MM_ERROR_NONE)
1033 g_variant_get(result, "(i)", &ret);
1035 g_variant_unref(result);
1043 int mm_sound_proxy_unregister_focus(int instance, int id, bool is_for_session)
1045 int ret = MM_ERROR_NONE;
1046 GVariant *params = NULL, *result = NULL;
1050 params = g_variant_new("(iib)", instance, id, is_for_session);
1052 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_UNREGISTER_FOCUS, params, &result)) != MM_ERROR_NONE)
1053 debug_error("dbus unregister focus failed");
1055 debug_error("Construct Param for method call failed");
1058 if (ret != MM_ERROR_NONE)
1059 g_variant_get(result, "(i)", &ret);
1061 g_variant_unref(result);
1068 int mm_sound_proxy_set_focus_reacquisition(int instance, int id, bool reacquisition, bool is_for_session)
1070 int ret = MM_ERROR_NONE;
1071 GVariant *params = NULL, *result = NULL;
1075 params = g_variant_new("(iibb)", instance, id, reacquisition, is_for_session);
1077 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_SET_FOCUS_REACQUISITION, params, &result)) != MM_ERROR_NONE)
1078 debug_error("dbus set focus reacquisition failed");
1080 debug_error("Construct Param for method call failed");
1083 if (ret != MM_ERROR_NONE)
1084 g_variant_get(result, "(i)", &ret);
1086 g_variant_unref(result);
1092 int mm_sound_proxy_get_acquired_focus_stream_type(int focus_type, char **stream_type, int *option, char **ext_info)
1094 int ret = MM_ERROR_NONE;
1095 GVariant *params = NULL, *result = NULL;
1099 if (!(params = g_variant_new("(i)", focus_type))) {
1100 debug_error("Construct Param for method call failed");
1101 return MM_ERROR_SOUND_INTERNAL;
1104 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_GET_ACQUIRED_FOCUS_STREAM_TYPE, params, &result)) == MM_ERROR_NONE) {
1106 g_variant_get(result, "(sis)", stream_type, option, ext_info);
1107 g_variant_unref(result);
1110 debug_error("dbus get stream type of acquired focus failed");
1117 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)
1119 int ret = MM_ERROR_NONE;
1120 bool is_in_focus_cb_thread = false;
1124 mm_sound_client_is_focus_cb_thread(g_thread_self(), &is_in_focus_cb_thread);
1125 if (is_in_focus_cb_thread) {
1126 if ((ret = mm_sound_focus_socket_acquire(instance, id, type, option, ext_info ? ext_info : "", true, is_for_session)))
1127 debug_error("failed to mm_sound_focus_socket_acquire(), ret[0x%x]", ret);
1129 GVariant *params = NULL, *result = NULL;
1131 params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
1133 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_ACQUIRE_FOCUS, params, &result)) != MM_ERROR_NONE)
1134 debug_error("dbus acquire focus failed");
1136 debug_error("Construct Param for method call failed");
1139 if (ret != MM_ERROR_NONE)
1140 g_variant_get(result, "(i)", &ret);
1142 g_variant_unref(result);
1149 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)
1151 int ret = MM_ERROR_NONE;
1152 bool is_in_focus_cb_thread = false;
1156 mm_sound_client_is_focus_cb_thread(g_thread_self(), &is_in_focus_cb_thread);
1157 if (is_in_focus_cb_thread) {
1158 if ((ret = mm_sound_focus_socket_release(instance, id, type, option, ext_info ? ext_info : "", true, is_for_session)))
1159 debug_error("failed to mm_sound_focus_socket_release(), ret[0x%x]", ret);
1161 GVariant *params = NULL, *result = NULL;
1163 params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
1165 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_RELEASE_FOCUS, params, &result)) != MM_ERROR_NONE)
1166 debug_error("dbus release focus failed");
1168 debug_error("Construct Param for method call failed");
1171 if (ret != MM_ERROR_NONE)
1172 g_variant_get(result, "(i)", &ret);
1174 g_variant_unref(result);
1181 int mm_sound_proxy_update_stream_focus_status(int focus_id, unsigned int status)
1183 int ret = MM_ERROR_NONE;
1185 GVariant *params = NULL, *result = NULL;
1189 params = g_variant_new("(iu)", focus_id, status);
1191 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_UPDATE_STREAM_FOCUS_STATUS, params, &result)) != MM_ERROR_NONE) {
1192 debug_error("dbus set volume by type failed");
1194 g_variant_get(result, "(&s)", &reply);
1195 debug_log("reply : %s", reply);
1196 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
1197 ret = MM_ERROR_SOUND_INTERNAL;
1201 debug_error("Construct Param for method call failed");
1202 return MM_ERROR_SOUND_INTERNAL;
1206 g_variant_unref(result);
1212 int mm_sound_proxy_deliver_focus(int pid, int src_id, int dst_id, mm_sound_focus_type_e focus_type)
1214 int ret = MM_ERROR_NONE;
1216 GVariant *params = NULL, *result = NULL;
1220 params = g_variant_new("(iiii)", pid, src_id, dst_id, focus_type);
1222 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_DELIVER_FOCUS, params, &result)) != MM_ERROR_NONE) {
1223 debug_error("dbus deliver focus failed");
1225 g_variant_get(result, "(&s)", &reply);
1226 debug_log("reply : %s", reply);
1227 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
1228 ret = MM_ERROR_SOUND_INTERNAL;
1232 debug_error("Construct Param for method call failed");
1233 return MM_ERROR_SOUND_INTERNAL;
1237 g_variant_unref(result);
1243 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)
1245 int ret = MM_ERROR_NONE;
1246 GVariant *params = NULL, *result = NULL;
1250 params = g_variant_new("(iiibb)", instance, handle, type, is_for_session, is_for_monitor);
1252 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_WATCH_FOCUS, params, &result)) != MM_ERROR_NONE)
1253 debug_error("dbus set watch focus failed");
1255 debug_error("Construct Param for method call failed");
1258 if (ret != MM_ERROR_NONE)
1259 g_variant_get(result, "(i)", &ret);
1261 g_variant_unref(result);
1268 int mm_sound_proxy_unset_focus_watch_callback(int focus_tid, int handle, bool is_for_session)
1270 int ret = MM_ERROR_NONE;
1271 GVariant *params = NULL, *result = NULL;
1275 params = g_variant_new("(iib)", focus_tid, handle, is_for_session);
1277 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_UNWATCH_FOCUS, params, &result)) != MM_ERROR_NONE)
1278 debug_error("dbus unset watch focus failed");
1280 debug_error("Construct Param for method call failed");
1282 if (ret != MM_ERROR_NONE)
1283 g_variant_get(result, "(i)", &ret);
1285 g_variant_unref(result);
1292 #endif /* USE_FOCUS */
1293 /*------------------------------------------ FOCUS --------------------------------------------------*/
1295 int mm_sound_proxy_initialize(void)
1297 int ret = MM_ERROR_NONE;
1305 int mm_sound_proxy_finalize(void)
1307 int ret = MM_ERROR_NONE;