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, bool *is_running, 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, "(isiisiibai)") == 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);
109 g_variant_iter_next(&iter, "b", is_running);
111 array_v = g_variant_iter_next_value(&iter);
112 *stream_num = g_variant_iter_init(&array_iter, array_v);
113 if (*stream_num > MAX_STREAM_ON_DEVICE) {
114 debug_error("too many streams on device %d", *stream_num);
115 ret = MM_ERROR_SOUND_INTERNAL;
119 while (g_variant_iter_loop(&array_iter, "i", &stream_id[i++])) ;
121 g_variant_unref(array_v);
126 /* This callback unmarshall general-formed paramters to subject specific parameters,
127 * and call proper callback */
128 static void dbus_callback(audio_event_t event, GVariant *params, void *userdata)
130 struct callback_data *cb_data = (struct callback_data*) userdata;
132 const char *name = NULL, *device_type = NULL;
133 int device_id, direction, state;
137 int stream_id[MAX_STREAM_ON_DEVICE];
139 int vendor_id, product_id;
140 bool is_running = FALSE;
142 v_type = g_variant_get_type_string(params);
144 if (event == AUDIO_EVENT_VOLUME_CHANGED) {
145 char *volume_type_str = NULL, *direction = NULL;
146 unsigned volume_level;
148 g_variant_get(params, "(&s&su)", &direction, &volume_type_str, &volume_level);
149 ((mm_sound_volume_changed_wrapper_cb)(cb_data->user_cb))(direction, volume_type_str, volume_level, cb_data->user_data);
150 } else if (event == AUDIO_EVENT_DEVICE_CONNECTED) {
151 bool is_connected = false;
153 if (g_variant_type_equal(v_type, "(u(isiisiibai)b)") == FALSE) {
154 debug_error("Device connection changed signature not matching : %s", v_type);
157 g_variant_iter_init(&iter, params);
158 g_variant_iter_next(&iter, "u", &event_id);
159 device_v = g_variant_iter_next_value(&iter);
160 if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
161 &name, &vendor_id, &product_id, &is_running, stream_id, &stream_num) < 0) {
162 debug_error("Failed to parse device variant");
165 g_variant_iter_next(&iter, "b", &is_connected);
167 ((mm_sound_device_connected_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
168 state, name, vendor_id, product_id, is_running, stream_id, stream_num, is_connected, cb_data->user_data);
169 _notify_signal_handled(event, event_id, cb_data->subs_id, g_variant_new("(ib)", device_id, is_connected));
170 } else if (event == AUDIO_EVENT_DEVICE_INFO_CHANGED) {
171 int changed_device_info_type = 0;
173 if (g_variant_type_equal(v_type, "(u(isiisiibai)i)") == FALSE) {
174 debug_error("Device information changed signature not matching : %s", v_type);
178 g_variant_iter_init(&iter, params);
179 g_variant_iter_next(&iter, "u", &event_id);
180 device_v = g_variant_iter_next_value(&iter);
181 if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
182 &name, &vendor_id, &product_id, &is_running, stream_id, &stream_num) < 0) {
183 debug_error("Failed to parse device variant");
186 g_variant_iter_next(&iter, "i", &changed_device_info_type);
188 ((mm_sound_device_info_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
189 state, name, vendor_id, product_id, is_running, stream_id, stream_num, changed_device_info_type, cb_data->user_data);
190 } else if (event == AUDIO_EVENT_DEVICE_STATE_CHANGED) {
192 if (g_variant_type_equal(v_type, "(u(isiisiibai))") == FALSE) {
193 debug_error("Device state changed signature not matching : %s", v_type);
197 g_variant_iter_init(&iter, params);
198 g_variant_iter_next(&iter, "u", &event_id);
199 device_v = g_variant_iter_next_value(&iter);
200 if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
201 &name, &vendor_id, &product_id, &is_running, stream_id, &stream_num) < 0) {
202 debug_error("Failed to parse device variant");
206 ((mm_sound_device_state_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
207 state, name, vendor_id, product_id, is_running, stream_id, stream_num, cb_data->user_data);
208 } else if (event == AUDIO_EVENT_DEVICE_RUNNING_CHANGED) {
210 if (g_variant_type_equal(v_type, "(u(isiisiibai))") == FALSE) {
211 debug_error("Device state changed signature not matching : %s", v_type);
215 g_variant_iter_init(&iter, params);
216 g_variant_iter_next(&iter, "u", &event_id);
217 device_v = g_variant_iter_next_value(&iter);
218 if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
219 &name, &vendor_id, &product_id, &is_running, stream_id, &stream_num) < 0) {
220 debug_error("Failed to parse device variant");
224 ((mm_sound_device_running_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
225 state, name, vendor_id, product_id, is_running, stream_id, stream_num, cb_data->user_data);
226 } else if (event == AUDIO_EVENT_FOCUS_CHANGED) {
227 } else if (event == AUDIO_EVENT_FOCUS_WATCH) {
228 } else if (event == AUDIO_EVENT_TEST) {
230 g_variant_get(params, "(i)", &test_var);
231 ((mm_sound_test_cb)(cb_data->user_cb))(test_var, cb_data->user_data);
232 } else if (event == AUDIO_EVENT_PLAY_FILE_END) {
233 int ended_handle = 0;
234 g_variant_get(params, "(i)", &ended_handle);
235 ((mm_sound_stop_callback_wrapper_func)(cb_data->user_cb))(ended_handle, cb_data->user_data);
239 static void simple_callback_data_free_func(void *data)
241 struct callback_data *cb_data = (struct callback_data*) data;
244 if (cb_data->free_func)
245 cb_data->free_func(cb_data->user_data);
250 int mm_sound_proxy_add_test_callback(mm_sound_test_cb func, void *userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
252 int ret = MM_ERROR_NONE;
253 struct callback_data *cb_data;
257 CB_DATA_NEW(cb_data, func, userdata, freefunc);
259 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)
260 debug_error("add test callback failed");
262 *subs_id = cb_data->subs_id;
268 int mm_sound_proxy_remove_test_callback(unsigned subs_id)
270 int ret = MM_ERROR_NONE;
273 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
274 debug_error("remove test callback failed");
280 int mm_sound_proxy_test(int a, int b, int *get)
282 int ret = MM_ERROR_NONE;
284 GVariant *params = NULL, *result = NULL;
288 params = g_variant_new("(ii)", a, b);
290 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_TEST, params, &result)) != MM_ERROR_NONE) {
291 debug_error("dbus test call failed");
295 debug_error("Construct Param for method call failed");
296 return MM_ERROR_SOUND_INTERNAL;
300 g_variant_get(result, "(i)", &reply);
301 debug_log("reply : %d", reply);
304 debug_error("reply null");
309 g_variant_unref(result);
315 int mm_sound_proxy_is_stream_on_device(int stream_id, int device_id, bool *is_on)
317 int ret = MM_ERROR_NONE;
318 GVariant *params, *result;
324 debug_error("Invalid Parameter, is_on null");
325 return MM_ERROR_INVALID_ARGUMENT;
328 if ((params = g_variant_new("(ii)", stream_id, device_id)) == NULL) {
329 debug_error("Construct Param for query is stream on device failed");
330 return MM_ERROR_SOUND_INTERNAL;
333 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_METHOD_IS_STREAM_ON_DEVICE, params, &result)) != MM_ERROR_NONE) {
334 debug_error("is stream on device failed");
339 g_variant_get(result, "(b)", &_is_on);
340 debug_log("is_on : %d", _is_on);
341 *is_on = (bool)_is_on;
343 debug_error("reply null");
344 ret = MM_ERROR_SOUND_INTERNAL;
349 g_variant_unref(params);
351 g_variant_unref(result);
357 int mm_sound_proxy_get_current_connected_device_list(int device_flags, GList** device_list)
359 int ret = MM_ERROR_NONE;
360 GVariant *result = NULL, *child = NULL;
361 GVariant *params = NULL;
363 mm_sound_device_t* device_item;
364 const gchar *device_name_tmp = NULL, *device_type_tmp = NULL;
369 debug_error("Invalid Parameter, device_list null");
370 ret = MM_ERROR_INVALID_ARGUMENT;
374 params = g_variant_new("(i)", device_flags);
377 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_METHOD_GET_CONNECTED_DEVICE_LIST, params, &result)) != MM_ERROR_NONE) {
378 debug_error("Get current connected device list failed");
382 debug_error("Construct Param for get current connected device failed");
383 return MM_ERROR_SOUND_INTERNAL;
386 child = g_variant_get_child_value(result, 0);
387 g_variant_iter_init(&iter, child);
389 device_item = g_malloc0(sizeof(mm_sound_device_t));
390 if (device_item && g_variant_iter_loop(&iter, "(i&sii&siib)",
391 &device_item->id, &device_type_tmp, &device_item->io_direction, &device_item->state,
392 &device_name_tmp, &device_item->vendor_id, &device_item->product_id, &device_item->is_running)) {
393 MMSOUND_STRNCPY(device_item->name, device_name_tmp, MAX_DEVICE_NAME_NUM);
394 MMSOUND_STRNCPY(device_item->type, device_type_tmp, MAX_DEVICE_TYPE_STR_LEN);
395 *device_list = g_list_append(*device_list, device_item);
396 debug_log("Added device id(%d) type(%17s) direction(%d) state(%d) name(%s) vendor-id(%04x) product-id(%04x) is_running(%d)",
397 device_item->id, device_item->type, device_item->io_direction, device_item->state,
398 device_item->name, device_item->vendor_id, device_item->product_id, device_item->is_running);
399 device_item->stream_num = -1;
409 g_variant_unref(result);
415 int mm_sound_proxy_get_device_by_id(int device_id, mm_sound_device_t **device)
417 int ret = MM_ERROR_NONE;
418 GVariant *params = NULL, *result = NULL;
419 mm_sound_device_t* device_item = NULL;
420 const gchar *device_name_tmp = NULL, *device_type_tmp = NULL;
424 if (!device || device_id < 1) {
425 debug_error("Invalid Parameter, device null or improper device id");
426 return MM_ERROR_INVALID_ARGUMENT;
429 if ((params = g_variant_new("(i)", device_id)) == NULL) {
430 debug_error("Construct Param for get device by id failed");
431 return MM_ERROR_SOUND_INTERNAL;
434 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_METHOD_GET_DEVICE_BY_ID, params, &result)) != MM_ERROR_NONE) {
435 debug_error("get device by id failed");
436 ret = MM_ERROR_SOUND_NO_DATA;
441 if ((device_item = g_malloc0(sizeof(mm_sound_device_t))) == NULL) {
442 debug_error("Alloc device handle failed");
443 ret = MM_ERROR_SOUND_INTERNAL;
447 g_variant_get(result, "(i&sii&sii)",
448 &device_item->id, &device_type_tmp, &device_item->io_direction,
449 &device_item->state, &device_name_tmp,
450 &device_item->vendor_id, &device_item->product_id);
451 MMSOUND_STRNCPY(device_item->name, device_name_tmp, MAX_DEVICE_NAME_NUM);
452 MMSOUND_STRNCPY(device_item->type, device_type_tmp, MAX_DEVICE_TYPE_STR_LEN);
453 debug_log("Get device id(%d) type(%17s) direction(%d) state(%d) name(%s) vendor-id(%04x) product-id(%04x)",
454 device_item->id, device_item->type, device_item->io_direction,
455 device_item->state, device_item->name,
456 device_item->vendor_id, device_item->product_id);
457 device_item->stream_num = -1;
458 *device = device_item;
460 debug_error("reply null");
461 ret = MM_ERROR_SOUND_INTERNAL;
466 g_variant_unref(result);
472 int mm_sound_proxy_add_device_connected_callback(mm_sound_device_connected_wrapper_cb func, void *userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
474 int ret = MM_ERROR_NONE;
475 struct callback_data *cb_data;
479 CB_DATA_NEW(cb_data, func, userdata, freefunc);
481 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) {
482 debug_error("add device connected callback failed");
486 if ((ret = _notify_subscription(AUDIO_EVENT_DEVICE_CONNECTED, cb_data->subs_id, TRUE)) != MM_ERROR_NONE) {
487 debug_error("failed to notify subscription of device connected event");
491 *subs_id = cb_data->subs_id;
498 int mm_sound_proxy_remove_device_connected_callback(unsigned subs_id)
500 int ret = MM_ERROR_NONE;
503 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE) {
504 debug_error("remove device connected callback failed");
508 if ((ret = _notify_subscription(AUDIO_EVENT_DEVICE_CONNECTED, subs_id, FALSE)) != MM_ERROR_NONE)
509 debug_error("failed to notify unsubscription of device connected event");
516 int mm_sound_proxy_add_device_info_changed_callback(mm_sound_device_info_changed_wrapper_cb func, void* userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
518 int ret = MM_ERROR_NONE;
519 struct callback_data *cb_data;
523 CB_DATA_NEW(cb_data, func, userdata, freefunc);
525 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)
526 debug_error("Add device info changed callback failed");
528 *subs_id = cb_data->subs_id;
534 int mm_sound_proxy_remove_device_info_changed_callback(unsigned subs_id)
536 int ret = MM_ERROR_NONE;
539 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
540 debug_error("remove device info changed callback failed");
546 int mm_sound_proxy_add_device_state_changed_callback(mm_sound_device_state_changed_wrapper_cb func, void* userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
548 int ret = MM_ERROR_NONE;
549 struct callback_data *cb_data;
553 CB_DATA_NEW(cb_data, func, userdata, freefunc);
555 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)
556 debug_error("Add device state changed callback failed");
558 *subs_id = cb_data->subs_id;
564 int mm_sound_proxy_remove_device_state_changed_callback(unsigned subs_id)
566 int ret = MM_ERROR_NONE;
569 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
570 debug_error("remove device state changed callback failed");
576 int mm_sound_proxy_add_device_running_changed_callback(mm_sound_device_running_changed_wrapper_cb func, void* userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
578 int ret = MM_ERROR_NONE;
579 struct callback_data *cb_data;
583 CB_DATA_NEW(cb_data, func, userdata, freefunc);
585 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)
586 debug_error("Add device running changed callback failed");
588 *subs_id = cb_data->subs_id;
594 int mm_sound_proxy_remove_device_running_changed_callback(unsigned subs_id)
596 int ret = MM_ERROR_NONE;
599 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
600 debug_error("remove device running changed callback failed");
606 int mm_sound_proxy_set_volume_by_type(const char *volume_type, const unsigned volume_level)
608 int ret = MM_ERROR_NONE;
609 char *reply = NULL, *direction = "out";
610 GVariant *params = NULL, *result = NULL;
614 params = g_variant_new("(ssu)", direction, volume_type, volume_level);
616 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_SET_VOLUME_LEVEL, params, &result)) != MM_ERROR_NONE) {
617 debug_error("dbus set volume by type failed");
621 debug_error("Construct Param for method call failed");
622 return MM_ERROR_SOUND_INTERNAL;
626 g_variant_get(result, "(&s)", &reply);
627 debug_log("reply : %s", reply);
628 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
629 ret = MM_ERROR_SOUND_INTERNAL;
631 debug_error("reply null");
636 g_variant_unref(result);
642 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)
644 int ret = MM_ERROR_NONE;
645 struct callback_data *cb_data;
649 CB_DATA_NEW(cb_data, func, userdata, freefunc);
651 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)
652 debug_error("Add Volume changed callback failed");
654 *subs_id = cb_data->subs_id;
662 int mm_sound_proxy_remove_volume_changed_callback(unsigned subs_id)
664 int ret = MM_ERROR_NONE;
667 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
668 debug_error("Remove Volume changed callback failed");
674 int mm_sound_proxy_set_filter_by_type(const char *stream_type, const char *filter_name, const char *filter_parameters, const char *filter_group)
676 int ret = MM_ERROR_NONE;
678 GVariant *params = NULL, *result = NULL;
682 params = g_variant_new("(ssss)", filter_name, filter_parameters, filter_group, stream_type);
684 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_SET_FILTER, params, &result)) != MM_ERROR_NONE) {
685 debug_error("dbus set filter by type failed");
689 debug_error("construct param for method call failed");
690 return MM_ERROR_SOUND_INTERNAL;
694 g_variant_get(result, "(&s)", &reply);
695 debug_log("reply : %s", reply);
696 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
697 ret = MM_ERROR_SOUND_INTERNAL;
699 debug_error("reply null");
704 g_variant_unref(result);
710 int mm_sound_proxy_unset_filter_by_type(const char *stream_type)
712 int ret = MM_ERROR_NONE;
714 GVariant *params = NULL, *result = NULL;
718 params = g_variant_new("(s)", stream_type);
720 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_UNSET_FILTER, params, &result)) != MM_ERROR_NONE) {
721 debug_error("dbus unset filter by type failed");
725 debug_error("construct param for method call failed");
726 return MM_ERROR_SOUND_INTERNAL;
730 g_variant_get(result, "(&s)", &reply);
731 debug_log("reply : %s", reply);
732 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
733 ret = MM_ERROR_SOUND_INTERNAL;
735 debug_error("reply null");
740 g_variant_unref(result);
746 int mm_sound_proxy_control_filter_by_type(const char *stream_type, const char *filter_name, const char *filter_controls)
748 int ret = MM_ERROR_NONE;
750 GVariant *params = NULL, *result = NULL;
754 params = g_variant_new("(sss)", filter_name, filter_controls, stream_type);
756 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_CONTROL_FILTER, params, &result)) != MM_ERROR_NONE) {
757 debug_error("dbus control filter by type failed");
761 debug_error("construct param for method call failed");
762 return MM_ERROR_SOUND_INTERNAL;
766 g_variant_get(result, "(&s)", &reply);
767 debug_log("reply : %s", reply);
768 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
769 ret = MM_ERROR_SOUND_INTERNAL;
771 debug_error("reply null");
776 g_variant_unref(result);
782 int mm_sound_proxy_play_tone(int tone, int repeat, int volume, int volume_config,
783 int session_type, int session_options, int client_pid,
784 bool enable_session, int *codechandle, char *stream_type, int stream_index)
786 int ret = MM_ERROR_NONE;
788 GVariant *params = NULL, *result = NULL;
789 gboolean _enable_session = enable_session;
792 debug_error("Param for play is null");
793 return MM_ERROR_INVALID_ARGUMENT;
798 params = g_variant_new("(iiiiiiibsi)", tone, repeat, volume, volume_config, session_type,
799 session_options, client_pid, _enable_session, stream_type, stream_index);
801 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_DTMF, params, &result)) != MM_ERROR_NONE) {
802 debug_error("dbus play tone failed");
806 debug_error("Construct Param for method call failed");
810 g_variant_get(result, "(i)", &handle);
811 debug_log("handle : %d", handle);
812 *codechandle = handle;
814 debug_error("reply null");
819 g_variant_unref(result);
825 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)
827 int ret = MM_ERROR_NONE;
829 GVariant *params = NULL, *result = NULL;
834 debug_error("Param for play is null");
835 return MM_ERROR_INVALID_ARGUMENT;
838 params = g_variant_new("(iiiisi)", tone, repeat, volume, client_pid, stream_type, stream_index);
840 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_DTMF_WITH_STREAM_INFO, params, &result)) != MM_ERROR_NONE) {
841 debug_error("dbus play tone failed");
845 debug_error("Construct Param for method call failed");
849 g_variant_get(result, "(i)", &handle);
850 debug_log("handle : %d", handle);
851 *codechandle = handle;
853 debug_error("reply null");
858 g_variant_unref(result);
864 int mm_sound_proxy_play_sound(const char* filename, int tone, int repeat, int volume, int volume_config,
865 int session_type, int session_options, int client_pid, bool enable_session, int *codechandle,
866 char *stream_type, int stream_index)
868 int ret = MM_ERROR_NONE;
870 GVariant *params = NULL, *result = NULL;
871 gboolean _enable_session = enable_session;
873 if (!filename || !codechandle) {
874 debug_error("Param for play is null");
875 return MM_ERROR_INVALID_ARGUMENT;
880 params = g_variant_new("(siiiiiiibsi)", filename, tone, repeat, volume,
881 volume_config, session_type, session_options, client_pid, _enable_session, stream_type, stream_index);
883 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_FILE_START, params, &result)) != MM_ERROR_NONE) {
884 debug_error("dbus play file failed");
888 debug_error("Construct Param for method call failed");
892 g_variant_get(result, "(i)", &handle);
893 debug_log("handle : %d", handle);
894 *codechandle = handle;
896 debug_error("reply null");
901 g_variant_unref(result);
907 int mm_sound_proxy_play_sound_with_stream_info(const char* filename, int repeat, int volume,
908 int client_pid, int *codechandle, char *stream_type, int stream_index)
910 int ret = MM_ERROR_NONE;
912 GVariant *params = NULL, *result = NULL;
914 if (!filename || !codechandle) {
915 debug_error("Param for play is null");
916 return MM_ERROR_INVALID_ARGUMENT;
921 params = g_variant_new("(siiisi)", filename, repeat, volume, client_pid, stream_type, stream_index);
923 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) {
924 debug_error("dbus play file failed");
928 debug_error("Construct Param for method call failed");
932 g_variant_get(result, "(i)", &handle);
933 debug_log("handle : %d", handle);
934 *codechandle = handle;
936 debug_error("reply null");
941 g_variant_unref(result);
949 int mm_sound_proxy_stop_sound(int handle)
951 int ret = MM_ERROR_NONE;
952 GVariant *result = NULL;
956 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) {
957 debug_error("dbus stop file playing failed");
963 g_variant_unref(result);
969 int mm_sound_proxy_clear_focus(int pid)
971 int ret = MM_ERROR_NONE;
972 GVariant *result = NULL;
976 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)
977 debug_error("dbus clear focus failed");
980 g_variant_unref(result);
986 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)
988 int ret = MM_ERROR_NONE;
989 struct callback_data *cb_data;
993 CB_DATA_NEW(cb_data, func, userdata, freefunc);
995 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)
996 debug_error("add play sound end callback failed");
998 *subs_id = cb_data->subs_id;
1005 int mm_sound_proxy_remove_play_sound_end_callback(unsigned subs_id)
1007 int ret = MM_ERROR_NONE;
1010 if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE)
1011 debug_error("Remove Play File End callback failed");
1017 int mm_sound_proxy_emergent_exit(int exit_pid)
1019 int ret = MM_ERROR_NONE;
1020 GVariant *params = NULL;
1024 params = g_variant_new("(i)", exit_pid);
1026 if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_EMERGENT_EXIT, params)) != MM_ERROR_NONE) {
1027 debug_error("dbus emergent exit failed");
1031 debug_error("Construct Param for emergent exit signal failed");
1032 ret = MM_ERROR_SOUND_INTERNAL;
1041 /*------------------------------------------ FOCUS --------------------------------------------------*/
1044 int mm_sound_proxy_get_unique_id(int *id)
1046 int ret = MM_ERROR_NONE;
1048 GVariant *result = NULL;
1052 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_GET_UNIQUE_ID, NULL, &result)) != MM_ERROR_NONE)
1053 debug_error("dbus get unique id failed");
1056 g_variant_get(result, "(i)", &res);
1058 debug_msg("got unique id(%d)", *id);
1059 g_variant_unref(result);
1067 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)
1069 int ret = MM_ERROR_NONE;
1070 GVariant *params = NULL, *result = NULL;
1074 params = g_variant_new("(iisb)", instance, id, stream_type, is_for_session);
1076 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_REGISTER_FOCUS, params, &result)) != MM_ERROR_NONE)
1077 debug_error("dbus register focus failed");
1079 debug_error("Construct Param for method call failed");
1082 if (ret != MM_ERROR_NONE)
1083 g_variant_get(result, "(i)", &ret);
1085 g_variant_unref(result);
1093 int mm_sound_proxy_unregister_focus(int instance, int id, bool is_for_session)
1095 int ret = MM_ERROR_NONE;
1096 GVariant *params = NULL, *result = NULL;
1100 params = g_variant_new("(iib)", instance, id, is_for_session);
1102 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_UNREGISTER_FOCUS, params, &result)) != MM_ERROR_NONE)
1103 debug_error("dbus unregister focus failed");
1105 debug_error("Construct Param for method call failed");
1108 if (ret != MM_ERROR_NONE)
1109 g_variant_get(result, "(i)", &ret);
1111 g_variant_unref(result);
1118 int mm_sound_proxy_set_focus_reacquisition(int instance, int id, bool reacquisition, bool is_for_session)
1120 int ret = MM_ERROR_NONE;
1121 GVariant *params = NULL, *result = NULL;
1125 params = g_variant_new("(iibb)", instance, id, reacquisition, is_for_session);
1127 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_SET_FOCUS_REACQUISITION, params, &result)) != MM_ERROR_NONE)
1128 debug_error("dbus set focus reacquisition failed");
1130 debug_error("Construct Param for method call failed");
1133 if (ret != MM_ERROR_NONE)
1134 g_variant_get(result, "(i)", &ret);
1136 g_variant_unref(result);
1142 int mm_sound_proxy_get_acquired_focus_stream_type(int focus_type, char **stream_type, int *option, char **ext_info)
1144 int ret = MM_ERROR_NONE;
1145 GVariant *params = NULL, *result = NULL;
1149 if (!(params = g_variant_new("(i)", focus_type))) {
1150 debug_error("Construct Param for method call failed");
1151 return MM_ERROR_SOUND_INTERNAL;
1154 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_GET_ACQUIRED_FOCUS_STREAM_TYPE, params, &result)) == MM_ERROR_NONE) {
1156 g_variant_get(result, "(sis)", stream_type, option, ext_info);
1157 g_variant_unref(result);
1160 debug_error("dbus get stream type of acquired focus failed");
1167 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)
1169 int ret = MM_ERROR_NONE;
1170 bool is_in_focus_cb_thread = false;
1174 mm_sound_client_is_focus_cb_thread(g_thread_self(), &is_in_focus_cb_thread);
1175 if (is_in_focus_cb_thread) {
1176 if ((ret = mm_sound_focus_socket_acquire(instance, id, type, option, ext_info ? ext_info : "", true, is_for_session)))
1177 debug_error("failed to mm_sound_focus_socket_acquire(), ret[0x%x]", ret);
1179 GVariant *params = NULL, *result = NULL;
1181 params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
1183 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_ACQUIRE_FOCUS, params, &result)) != MM_ERROR_NONE)
1184 debug_error("dbus acquire focus failed");
1186 debug_error("Construct Param for method call failed");
1189 if (ret != MM_ERROR_NONE)
1190 g_variant_get(result, "(i)", &ret);
1192 g_variant_unref(result);
1199 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)
1201 int ret = MM_ERROR_NONE;
1202 bool is_in_focus_cb_thread = false;
1206 mm_sound_client_is_focus_cb_thread(g_thread_self(), &is_in_focus_cb_thread);
1207 if (is_in_focus_cb_thread) {
1208 if ((ret = mm_sound_focus_socket_release(instance, id, type, option, ext_info ? ext_info : "", true, is_for_session)))
1209 debug_error("failed to mm_sound_focus_socket_release(), ret[0x%x]", ret);
1211 GVariant *params = NULL, *result = NULL;
1213 params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
1215 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_RELEASE_FOCUS, params, &result)) != MM_ERROR_NONE)
1216 debug_error("dbus release focus failed");
1218 debug_error("Construct Param for method call failed");
1221 if (ret != MM_ERROR_NONE)
1222 g_variant_get(result, "(i)", &ret);
1224 g_variant_unref(result);
1231 int mm_sound_proxy_update_stream_focus_status(int focus_id, unsigned int status)
1233 int ret = MM_ERROR_NONE;
1235 GVariant *params = NULL, *result = NULL;
1239 params = g_variant_new("(iu)", focus_id, status);
1241 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_METHOD_UPDATE_STREAM_FOCUS_STATUS, params, &result)) != MM_ERROR_NONE) {
1242 debug_error("dbus set volume by type failed");
1244 g_variant_get(result, "(&s)", &reply);
1245 debug_log("reply : %s", reply);
1246 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
1247 ret = MM_ERROR_SOUND_INTERNAL;
1251 debug_error("Construct Param for method call failed");
1252 return MM_ERROR_SOUND_INTERNAL;
1256 g_variant_unref(result);
1262 int mm_sound_proxy_deliver_focus(int pid, int src_id, int dst_id, mm_sound_focus_type_e focus_type)
1264 int ret = MM_ERROR_NONE;
1266 GVariant *params = NULL, *result = NULL;
1270 params = g_variant_new("(iiii)", pid, src_id, dst_id, focus_type);
1272 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_DELIVER_FOCUS, params, &result)) != MM_ERROR_NONE) {
1273 debug_error("dbus deliver focus failed");
1275 g_variant_get(result, "(&s)", &reply);
1276 debug_log("reply : %s", reply);
1277 if (strcmp(reply, "STREAM_MANAGER_RETURN_OK"))
1278 ret = MM_ERROR_SOUND_INTERNAL;
1282 debug_error("Construct Param for method call failed");
1283 return MM_ERROR_SOUND_INTERNAL;
1287 g_variant_unref(result);
1293 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)
1295 int ret = MM_ERROR_NONE;
1296 GVariant *params = NULL, *result = NULL;
1300 params = g_variant_new("(iiibb)", instance, handle, type, is_for_session, is_for_monitor);
1302 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_WATCH_FOCUS, params, &result)) != MM_ERROR_NONE)
1303 debug_error("dbus set watch focus failed");
1305 debug_error("Construct Param for method call failed");
1308 if (ret != MM_ERROR_NONE)
1309 g_variant_get(result, "(i)", &ret);
1311 g_variant_unref(result);
1318 int mm_sound_proxy_unset_focus_watch_callback(int focus_tid, int handle, bool is_for_session)
1320 int ret = MM_ERROR_NONE;
1321 GVariant *params = NULL, *result = NULL;
1325 params = g_variant_new("(iib)", focus_tid, handle, is_for_session);
1327 if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_UNWATCH_FOCUS, params, &result)) != MM_ERROR_NONE)
1328 debug_error("dbus unset watch focus failed");
1330 debug_error("Construct Param for method call failed");
1332 if (ret != MM_ERROR_NONE)
1333 g_variant_get(result, "(i)", &ret);
1335 g_variant_unref(result);
1342 #endif /* USE_FOCUS */
1343 /*------------------------------------------ FOCUS --------------------------------------------------*/
1345 int mm_sound_proxy_initialize(void)
1347 int ret = MM_ERROR_NONE;
1355 int mm_sound_proxy_finalize(void)
1357 int ret = MM_ERROR_NONE;