4 * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
6 * Contact: Seungbae Shin <seungbae.shin@samsung.com>
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
33 #include "include/mm_sound_private.h"
34 #include "include/mm_sound_utils.h"
35 #include "include/mm_sound_client.h"
36 #include "include/mm_sound_pa_client.h"
37 #include "include/mm_sound_common.h"
39 #define MASTER_VOLUME_MAX 100
40 #define MASTER_VOLUME_MIN 0
44 #define MM_SOUND_DBUS_BUS_NAME_PREPIX "org.tizen.MMSound"
45 #define MM_SOUND_DBUS_OBJECT_PATH "/org/tizen/MMSound"
46 #define MM_SOUND_DBUS_INTERFACE "org.tizen.mmsound"
48 static const char* _get_volume_str(volume_type_t type)
50 static const char *volume_type_str[VOLUME_TYPE_MAX] = {
51 "SYSTEM", "NOTIFICATION", "ALARM", "RINGTONE", "MEDIA", "CALL", "VOIP", "VOICE", "FIXED"
54 return (type < VOLUME_TYPE_MAX) ? volume_type_str[type] : "Unknown";
57 static const char* _get_volume_str_internal(volume_type_internal_t type)
59 static const char *volume_type_str[] = {
63 return (type < (VOLUME_TYPE_BIXBY + 1)) ? volume_type_str[type] : "Unknown";
67 int mm_sound_add_volume_changed_callback(mm_sound_volume_changed_cb func, void* user_data, unsigned int *subs_id)
69 int ret = MM_ERROR_NONE;
71 if (func == NULL || subs_id == NULL) {
72 debug_error("argument is not valid");
73 return MM_ERROR_INVALID_ARGUMENT;
76 ret = mm_sound_client_add_volume_changed_callback(func, user_data, subs_id);
78 debug_error("Can not add volume changed callback, ret = %x", ret);
85 int mm_sound_remove_volume_changed_callback(unsigned int subs_id)
87 int ret = MM_ERROR_NONE;
89 ret = mm_sound_client_remove_volume_changed_callback(subs_id);
91 debug_error("Can not remove volume changed callback, ret = %x", ret);
98 int mm_sound_volume_set_value(volume_type_t type, const unsigned int value)
100 int ret = MM_ERROR_NONE;
102 /* request daemon to set volume */
103 ret = mm_sound_client_set_volume_by_type(type, value);
105 debug_error("can not set volume, type(%s), value(%d), ret=0x%x", _get_volume_str(type), value, ret);
107 debug_msg("set (%s) volume to (%d)", _get_volume_str(type), value);
113 int mm_sound_volume_get_value(volume_type_t type, unsigned int *value)
115 int ret = MM_ERROR_NONE;
117 ret = mm_sound_client_get_volume_by_type(type, value);
119 debug_error("can not get volume, type(%s), ret=0x%x", _get_volume_str(type), ret);
121 debug_msg("(%s) volume : %d", _get_volume_str(type), *value);
127 int mm_sound_add_volume_changed_callback_internal(mm_sound_volume_changed_cb_internal func, void* user_data, unsigned int *subs_id)
129 int ret = MM_ERROR_NONE;
131 if (func == NULL || subs_id == NULL) {
132 debug_error("argument is not valid");
133 return MM_ERROR_INVALID_ARGUMENT;
136 ret = mm_sound_client_add_volume_changed_callback_internal(func, user_data, subs_id);
138 debug_error("Can not add internal volume changed callback, ret = %x", ret);
144 int mm_sound_remove_volume_changed_callback_internal(unsigned int subs_id)
146 int ret = MM_ERROR_NONE;
148 ret = mm_sound_client_remove_volume_changed_callback(subs_id);
150 debug_error("Can not remove internal volume changed callback, ret = %x", ret);
156 int mm_sound_volume_set_value_internal(volume_type_internal_t type, const unsigned int value)
158 int ret = MM_ERROR_NONE;
160 /* request daemon to set volume */
161 ret = mm_sound_client_set_volume_by_internal_type(type, value);
163 debug_error("can not set internal volume, type(%s), value(%d), ret=0x%x", _get_volume_str_internal(type), value, ret);
165 debug_msg("set (%s) volume to (%d)", _get_volume_str_internal(type), value);
171 int mm_sound_volume_get_value_internal(volume_type_internal_t type, unsigned int *value)
173 int ret = MM_ERROR_NONE;
175 ret = mm_sound_client_get_volume_by_internal_type(type, value);
177 debug_error("can not get internal volume, type(%s), ret=0x%x", _get_volume_str_internal(type), ret);
179 debug_msg("(%s) volume : %d", _get_volume_str_internal(type), *value);
185 int mm_sound_set_mute(volume_type_t type, bool mute)
187 int ret = MM_ERROR_NONE;
189 ret = mm_sound_client_set_mute_by_type(type, mute);
191 debug_error("can not set mute, type(%s), mute(%d), ret=0x%x", _get_volume_str(type), mute, ret);
193 debug_msg("set (%s) mute to (%d)", _get_volume_str(type), mute);
199 int mm_sound_get_mute(volume_type_t type, bool *muted)
201 int ret = MM_ERROR_NONE;
203 /* Check input param */
205 debug_error("invalid argument");
206 return MM_ERROR_INVALID_ARGUMENT;
208 if (type > VOLUME_TYPE_VOICE) {
209 debug_error("invalid volume type value %d", type);
210 return MM_ERROR_INVALID_ARGUMENT;
213 ret = mm_sound_client_get_mute_by_type(type, muted);
215 debug_error("can not get mute, type(%s), ret=0x%x", _get_volume_str(type), ret);
217 debug_msg("(%s) mute state : %d", _get_volume_str(type), *muted);
223 int mm_sound_set_filter(const char *stream_type, const char *filter_name, const char *filter_parameters, const char *filter_group)
225 /* Check input param */
226 if (!stream_type || !filter_name) {
227 debug_error("invalid argument");
228 return MM_ERROR_INVALID_ARGUMENT;
230 if (!filter_parameters)
231 filter_parameters = "";
233 filter_group = "default";
235 debug_msg("stream_type(%s), filter_name(%s), filter_parameters(%s), filter_group(%s)", stream_type, filter_name, filter_parameters, filter_group);
237 return mm_sound_client_set_filter_by_type(stream_type, filter_name, filter_parameters, filter_group);
241 int mm_sound_unset_filter(const char *stream_type)
243 /* Check input param */
245 debug_error("invalid argument");
246 return MM_ERROR_INVALID_ARGUMENT;
249 debug_msg("stream_type(%s)", stream_type);
251 return mm_sound_client_unset_filter_by_type(stream_type);
255 int mm_sound_control_filter(const char *stream_type, const char *filter_name, const char *filter_controls)
257 /* Check input param */
258 if (!stream_type || !filter_name || !filter_controls) {
259 debug_error("invalid argument");
260 return MM_ERROR_INVALID_ARGUMENT;
263 debug_msg("stream_type(%s), filter_name(%s), filter_controls(%s)", stream_type, filter_name, filter_controls);
265 return mm_sound_client_control_filter_by_type(stream_type, filter_name, filter_controls);
268 ///////////////////////////////////
269 //// MMSOUND PLAY APIs
270 ///////////////////////////////////
272 int mm_sound_play_sound_with_stream_info(const char *filename, char *stream_type, int stream_id, unsigned int loop, mm_sound_stop_callback_func callback, void *data, int *handle)
274 MMSoundPlayParam param = { 0, };
277 param.filename = filename;
278 param.volume = 0; //volume value dose not effect anymore
279 param.callback = callback;
287 err = mm_sound_client_play_sound_with_stream_info(¶m, handle, stream_type, stream_id);
289 debug_error("Failed to play sound");
293 debug_warning("success : handle=[%p]", handle);
295 return MM_ERROR_NONE;
301 int mm_sound_stop_sound(int handle)
305 debug_warning("enter : handle=[%d]", handle);
307 err = mm_sound_client_stop_sound(handle);
309 debug_error("Fail to stop sound");
312 debug_warning("success : handle=[%d]", handle);
314 return MM_ERROR_NONE;
318 int mm_sound_stop_tone(int handle)
322 debug_warning("enter : handle=[%d]", handle);
324 err = mm_sound_client_stop_tone(handle);
326 debug_error("Fail to stop tone. err=0x%x", err);
329 debug_msg("success : handle=[%d]", handle);
331 return MM_ERROR_NONE;
334 ///////////////////////////////////
335 //// MMSOUND TONE APIs
336 ///////////////////////////////////
338 int mm_sound_play_tone_with_stream_info(MMSoundTone_t tone, char *stream_type, int stream_id, const double volume, const int duration, int *handle)
341 int err = MM_ERROR_NONE;
343 err = mm_sound_client_play_tone_with_stream_info(tone, stream_type, stream_id, volume, duration, handle);
345 debug_error("Failed to play sound");
353 ///////////////////////////////////
354 //// MMSOUND ROUTING APIs
355 ///////////////////////////////////
358 int mm_sound_test(int a, int b, int* getv)
360 int ret = MM_ERROR_NONE;
362 debug_log("mm_sound_test enter");
364 debug_error("argu null");
365 return MM_ERROR_INVALID_ARGUMENT;
367 ret = mm_sound_client_test(a, b, getv);
369 debug_error("Can not mm sound test, ret = %x", ret);
371 debug_log("mm_sound_test leave");
377 int mm_sound_add_test_callback(mm_sound_test_cb func, void *user_data, unsigned int *subs_id)
379 int ret = MM_ERROR_NONE;
382 if (!func || !subs_id) {
383 debug_error("argument is not valid");
384 return MM_ERROR_INVALID_ARGUMENT;
387 ret = mm_sound_client_add_test_callback(func, user_data, subs_id);
389 debug_error("Can not add test callback, ret = %x", ret);
397 int mm_sound_remove_test_callback(unsigned int subs_id)
399 int ret = MM_ERROR_NONE;
402 ret = mm_sound_client_remove_test_callback(subs_id);
404 debug_error("Can not remove test callback, ret = %x", ret);
412 int mm_sound_add_ducking_state_changed_callback(mm_sound_ducking_state_changed_cb func, void *user_data, unsigned int *subs_id)
414 int ret = MM_ERROR_NONE;
416 if (func == NULL || subs_id == NULL) {
417 debug_error("argument is not valid");
418 return MM_ERROR_INVALID_ARGUMENT;
421 ret = mm_sound_client_add_ducking_state_changed_callback(func, user_data, subs_id);
423 debug_error("Can not add ducking state changed callback, ret = %x", ret);
430 int mm_sound_remove_ducking_state_changed_callback(unsigned int subs_id)
432 int ret = MM_ERROR_NONE;
434 ret = mm_sound_client_remove_ducking_state_changed_callback(subs_id);
436 debug_error("Can not remove ducking state changed callback, ret = %x", ret);
444 void mm_sound_dotnet_cleanup(int signo)
449 __attribute__ ((constructor))
450 static void _mm_sound_initialize(void)
452 mm_sound_client_initialize();
456 __attribute__ ((destructor))
457 static void _mm_sound_finalize(void)
459 mm_sound_client_finalize();