Add support for mute API set
[platform/core/multimedia/libmm-sound.git] / common / mm_sound_utils.c
index 5100556..d33125e 100644 (file)
  */
 
 #include <sys/types.h>
-#include <sys/stat.h>
 #include <fcntl.h>
-#include <stdlib.h>
 #include <stdio.h>
 #include <unistd.h>
 #include <errno.h>
+#include <glib.h>
 
-#include <vconf.h>
-#include <avsys-audio.h>
 #include <mm_types.h>
 #include <mm_error.h>
 #include <mm_debug.h>
 #include "../include/mm_sound_private.h"
-#include "../include/mm_sound.h"
-#include "../include/mm_sound_common.h"
 #include "../include/mm_sound_utils.h"
 
-static mm_sound_route g_valid_route[] = {
-               MM_SOUND_ROUTE_OUT_SPEAKER, MM_SOUND_ROUTE_OUT_WIRED_ACCESSORY, MM_SOUND_ROUTE_OUT_BLUETOOTH,
-               MM_SOUND_ROUTE_OUT_DOCK, MM_SOUND_ROUTE_OUT_HDMI, MM_SOUND_ROUTE_OUT_WFD, MM_SOUND_ROUTE_OUT_USB_AUDIO,
-               MM_SOUND_ROUTE_IN_MIC, MM_SOUND_ROUTE_IN_WIRED_ACCESSORY, MM_SOUND_ROUTE_IN_MIC_OUT_RECEIVER,
-               MM_SOUND_ROUTE_IN_MIC_OUT_SPEAKER, MM_SOUND_ROUTE_IN_MIC_OUT_HEADPHONE,
-               MM_SOUND_ROUTE_INOUT_HEADSET, MM_SOUND_ROUTE_INOUT_BLUETOOTH
-};
-
-#define MM_SOUND_DEFAULT_VOLUME_SYSTEM                 5
-#define MM_SOUND_DEFAULT_VOLUME_NOTIFICATION   7
-#define MM_SOUND_DEFAULT_VOLUME_ALARAM                 6
-#define MM_SOUND_DEFAULT_VOLUME_RINGTONE               13
-#define MM_SOUND_DEFAULT_VOLUME_MEDIA                  7
-#define MM_SOUND_DEFAULT_VOLUME_CALL                   7
-#define MM_SOUND_DEFAULT_VOLUME_VOIP                   7
-#define MM_SOUND_DEFAULT_VOLUME_ANDROID                        0
-#define MM_SOUND_DEFAULT_VOLUME_JAVA                   11
-static int g_default_volume[VOLUME_TYPE_MAX] = {
-       MM_SOUND_DEFAULT_VOLUME_SYSTEM,
-       MM_SOUND_DEFAULT_VOLUME_NOTIFICATION,
-       MM_SOUND_DEFAULT_VOLUME_ALARAM,
-       MM_SOUND_DEFAULT_VOLUME_RINGTONE,
-       MM_SOUND_DEFAULT_VOLUME_MEDIA,
-       MM_SOUND_DEFAULT_VOLUME_CALL,
-       MM_SOUND_DEFAULT_VOLUME_VOIP,
-       MM_SOUND_DEFAULT_VOLUME_ANDROID,
-       MM_SOUND_DEFAULT_VOLUME_JAVA,
-};
-static char *g_volume_vconf[VOLUME_TYPE_MAX] = {
-       VCONF_KEY_VOLUME_TYPE_SYSTEM,           /* VOLUME_TYPE_SYSTEM */
-       VCONF_KEY_VOLUME_TYPE_NOTIFICATION,     /* VOLUME_TYPE_NOTIFICATION */
-       VCONF_KEY_VOLUME_TYPE_ALARM,            /* VOLUME_TYPE_ALARM */
-       VCONF_KEY_VOLUME_TYPE_RINGTONE,         /* VOLUME_TYPE_RINGTONE */
-       VCONF_KEY_VOLUME_TYPE_MEDIA,            /* VOLUME_TYPE_MEDIA */
-       VCONF_KEY_VOLUME_TYPE_CALL,                     /* VOLUME_TYPE_CALL */
-       VCONF_KEY_VOLUME_TYPE_VOIP,                     /* VOLUME_TYPE_VOIP */
-       VCONF_KEY_VOLUME_TYPE_ANDROID,          /* VOLUME_TYPE_FIXED */
-       VCONF_KEY_VOLUME_TYPE_JAVA                      /* VOLUME_TYPE_EXT_JAVA */
-};
-static char *g_volume_str[VOLUME_TYPE_MAX] = {
-       "SYSTEM",
-       "NOTIFICATION",
-       "ALARM",
-       "RINGTONE",
-       "MEDIA",
-       "CALL",
-       "VOIP",
-       "FIXED",
-       "JAVA",
-};
-
-EXPORT_API
-int _mm_sound_get_valid_route_list(mm_sound_route **route_list)
-{
-       *route_list = g_valid_route;
-
-       return (int)(sizeof(g_valid_route) / sizeof(mm_sound_route));
-}
-
 EXPORT_API
-bool _mm_sound_is_route_valid(mm_sound_route route)
+bool mm_sound_util_is_process_alive(pid_t pid)
 {
-       mm_sound_route *route_list = 0;
-       int route_index = 0;
-       int route_list_count = 0;
+       gchar *tmp = NULL;
+       int ret = -1;
 
-       route_list_count = _mm_sound_get_valid_route_list(&route_list);
-       for (route_index = 0; route_index < route_list_count; route_index++) {
-               if (route_list[route_index] == route)
-                       return 1;
-       }
-
-       return 0;
-}
-
-EXPORT_API
-void _mm_sound_get_devices_from_route(mm_sound_route route, mm_sound_device_in *device_in, mm_sound_device_out *device_out)
-{
-       if (device_in && device_out) {
-               *device_in = route & 0x00FF;
-               *device_out = route & 0xFFF00;
-       }
-}
-
-EXPORT_API
-bool _mm_sound_check_hibernation (const char *path)
-{
-       int fd = -1;
-       if (path == NULL) {
-               debug_error ("Path is null\n");
+       if (pid > 999999 || pid < 2)
                return false;
-       }
-
-       fd = open (path, O_RDONLY | O_CREAT, 0644);
-       if (fd != -1) {
-               debug_log ("Open [%s] success!!\n", path);
-       } else {
-               debug_error ("Can't create [%s] with errno [%d]\n", path, errno);
-               return false;
-       }
 
-       close (fd);
-       return true;
-}
-
-EXPORT_API
-int _mm_sound_volume_add_callback(volume_type_t type, void *func, void* user_data)
-{
-       if (vconf_notify_key_changed(g_volume_vconf[type], func, user_data)) {
-               debug_error ("vconf_notify_key_changed failed..\n");
-               return MM_ERROR_SOUND_INTERNAL;
+       if ((tmp = g_strdup_printf("/proc/%d", pid))) {
+               ret = access(tmp, F_OK);
+               g_free(tmp);
        }
 
-       return MM_ERROR_NONE;
-}
-
-EXPORT_API
-int _mm_sound_volume_remove_callback(volume_type_t type, void *func)
-{
-       if (vconf_ignore_key_changed(g_volume_vconf[type], func)) {
-               debug_error ("vconf_ignore_key_changed failed..\n");
-               return MM_ERROR_SOUND_INTERNAL;
-       }
-
-       return MM_ERROR_NONE;
-}
-
-EXPORT_API
-int _mm_sound_volume_get_value_by_type(volume_type_t type, unsigned int *value)
-{
-       int vconf_value = 0;
-
-       /* Get volume value from VCONF */
-       if (vconf_get_int(g_volume_vconf[type], &vconf_value)) {
-               debug_error ("vconf_get_int(%s) failed..\n", g_volume_vconf[type]);
-               return MM_ERROR_SOUND_INTERNAL;
-       }
-
-       *value = vconf_value;
-       debug_log("volume_get_value %s %d",  g_volume_str[type], *value);
-
-       return MM_ERROR_NONE;
-}
-
-EXPORT_API
-int _mm_sound_volume_set_value_by_type(volume_type_t type, unsigned int value)
-{
-       int vconf_value = 0;
-
-       vconf_value = value;
-       debug_log("volume_set_value %s %d",  g_volume_str[type], value);
-
-       /* Set volume value to VCONF */
-       if (vconf_set_int(g_volume_vconf[type], vconf_value)) {
-               debug_error ("vconf_set_int(%s) failed..\n", g_volume_vconf[type]);
-               return MM_ERROR_SOUND_INTERNAL;
-       }
-
-       return MM_ERROR_NONE;
-}
-
-EXPORT_API
-int _mm_sound_volume_get_values_on_bootup(int *values)
-{
-       int i, vconf_value = 0;
-
-       for (i = 0; i < VOLUME_TYPE_MAX; i++) {
-               if (!vconf_get_int(g_volume_vconf[i], &vconf_value)) {
-                       values[i] = vconf_value;
-                       debug_log("volume_get_value %s %d", g_volume_str[i], values[i]);
+       if (ret == -1) {
+               if (errno == ENOENT) {
+                       debug_warning("/proc/%d not exist", pid);
+                       return false;
                } else {
-                       debug_error ("vconf_get_int(%s) failed..\n", g_volume_vconf[i]);
-                       values[i] = g_default_volume[i];
-                       vconf_value = values[i];
-                       if (vconf_set_int(g_volume_vconf[i], vconf_value)) {
-                               debug_error ("vconf_set_int(%s) failed..\n", g_volume_vconf[i]);
-                       }
+                       debug_error("/proc/%d access errno[%d]", pid, errno);
+
+                       /* FIXME: error occured but file exists */
+                       return true;
                }
        }
 
-       return MM_ERROR_NONE;
+       return true;
 }
-