[0.6.219] Fix g_mutex_clear crash when destroying bus msg thread
[platform/core/multimedia/libmm-player.git] / src / mm_player.c
index cbb8778..52feafe 100644 (file)
 #include "mm_player_capture.h"
 #include "mm_player_tracks.h"
 #include "mm_player_es.h"
-#include "mm_player_sound_focus.h"
+#include "mm_player_360.h"
+#include "mm_player_gst.h"
 
 int mm_player_create(MMHandleType *player)
 {
        int result = MM_ERROR_PLAYER_INTERNAL;
-       mm_player_t* new_player = NULL;
+       mmplayer_t *new_player = NULL;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
        /* alloc player structure */
-       new_player = g_malloc(sizeof(mm_player_t));
-       if (!new_player)
-       {
+       new_player = g_try_new0(mmplayer_t, 1);
+       if (!new_player) {
                LOGE("Cannot allocate memory for player\n");
                result = MM_ERROR_PLAYER_RESOURCE_LIMIT;
                goto ERROR;
        }
-       memset(new_player, 0, sizeof(mm_player_t));
 
-       /* create player lock */
+       /* create player lock and cond */
        g_mutex_init(&new_player->cmd_lock);
-
-       /* create player lock */
-       g_mutex_init(&new_player->playback_lock);
+       g_mutex_init(&new_player->reconfigure_lock);
+       g_cond_init(&new_player->reconfigure_cond);
 
        /* load ini files */
-       if (MM_ERROR_NONE != mm_player_ini_load(&new_player->ini))
-       {
+       if (MM_ERROR_NONE != mm_player_ini_load(&new_player->ini)) {
                LOGE("can't load ini");
                goto ERROR;
        }
 
-       if (MM_ERROR_NONE != mm_player_audio_effect_ini_load(&new_player->ini))
-       {
+       if (MM_ERROR_NONE != mm_player_audio_effect_ini_load(&new_player->ini)) {
                LOGE("can't load audio ini");
                goto ERROR;
        }
 
        /* create player */
        result = _mmplayer_create_player((MMHandleType)new_player);
-       if(result != MM_ERROR_NONE)
-       {
+       if (result != MM_ERROR_NONE) {
                LOGE("failed to create player");
                if (result != MM_ERROR_PLAYER_RESOURCE_LIMIT)
                        result = MM_ERROR_PLAYER_INTERNAL;
@@ -89,84 +84,74 @@ int mm_player_create(MMHandleType *player)
 
 ERROR:
 
-       if ( new_player )
-       {
-               _mmplayer_destroy( (MMHandleType)new_player );
+       if (new_player) {
+               _mmplayer_destroy((MMHandleType)new_player);
                g_mutex_clear(&new_player->cmd_lock);
-               g_mutex_clear(&new_player->playback_lock);
-
-               MMPLAYER_FREEIF( new_player );
+               g_mutex_clear(&new_player->reconfigure_lock);
+               g_cond_clear(&new_player->reconfigure_cond);
+               MMPLAYER_FREEIF(new_player);
        }
 
        *player = (MMHandleType)0;
        return result; /* MM_ERROR_PLAYER_INTERNAL or MM_ERROR_PLAYER_RESOURCE_LIMIT */
 }
 
-int  mm_player_destroy(MMHandleType player)
+int mm_player_destroy(MMHandleType player)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       _mmplayer_bus_watcher_remove(player);
+       /* destroy the gst bus msg thread if it is remained.
+          this funct have to be called before getting cmd lock. */
+       _mmplayer_bus_msg_thread_destroy(player);
+
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_destroy(player);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
-       g_mutex_clear(&((mm_player_t*)player)->cmd_lock);
-       g_mutex_clear(&((mm_player_t*)player)->playback_lock);
+       g_mutex_clear(&((mmplayer_t *)player)->cmd_lock);
+       g_mutex_clear(&((mmplayer_t *)player)->reconfigure_lock);
+       g_cond_clear(&((mmplayer_t *)player)->reconfigure_cond);
 
-       memset( (mm_player_t*)player, 0x00, sizeof(mm_player_t) );
+       memset((mmplayer_t *)player, 0x00, sizeof(mmplayer_t));
 
        /* free player */
-       g_free( (void*)player );
+       g_free((void *)player);
 
        return result;
 }
 
-int mm_player_sound_register(MMHandleType player, int pid)
-{
-       int result = MM_ERROR_NONE;
-
-       MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-
-       MMPLAYER_CMD_LOCK( player );
-
-       result = _mmplayer_sound_register_with_pid(player, pid);
-
-       MMPLAYER_CMD_UNLOCK( player );
-
-       return result;
-}
-
-int mm_player_get_client_pid (MMHandleType player, int* pid)
+int mm_player_realize(MMHandleType player)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(pid, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_client_pid(player, pid);
+       result = _mmplayer_realize(player);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_realize(MMHandleType player)
+int mm_player_abort_pause(MMHandleType player)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       _mmplayer_bus_watcher_remove(player);
+       /* destroy the gst bus msg thread not to be blocked in pause(without cmd lock). */
+       _mmplayer_bus_msg_thread_destroy(player);
 
-       result = _mmplayer_realize(player);
-
-       MMPLAYER_CMD_UNLOCK( player );
+       /* abort the pause operation for preparing(without cmd lock). */
+       result = _mmplayer_abort_pause(player);
 
        return result;
 }
@@ -177,11 +162,11 @@ int mm_player_unrealize(MMHandleType player)
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_unrealize(player);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
@@ -192,67 +177,41 @@ int mm_player_set_message_callback(MMHandleType player, MMMessageCallback callba
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_set_message_callback(player, callback, user_param);
 
-       MMPLAYER_CMD_UNLOCK( player );
-
-       return result;
-}
-
-int mm_player_set_pd_message_callback(MMHandleType player, MMMessageCallback callback, void *user_param)
-{
-       int result = MM_ERROR_NONE;
-
-       MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-
-       result = _mm_player_set_pd_downloader_message_cb(player, callback, user_param);
-
-       return result;
-}
-
-int mm_player_set_audio_stream_callback(MMHandleType player, mm_player_audio_stream_callback callback, void *user_param)
-{
-       int result = MM_ERROR_NONE;
-
-       MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-
-       MMPLAYER_CMD_LOCK( player );
-
-       result = _mmplayer_set_audiostream_cb(player, callback, user_param);
-
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_audio_stream_callback_ex(MMHandleType player, bool sync, mm_player_audio_stream_callback_ex callback, void *user_param)
+int mm_player_set_audio_decoded_callback(MMHandleType player, mmplayer_audio_extract_opt_e opt, mm_player_audio_decoded_callback callback, void *user_param)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_audiostream_cb_ex(player, sync, callback, user_param);
+       result = _mmplayer_set_audio_decoded_cb(player, opt, callback, user_param);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_video_stream_callback(MMHandleType player, mm_player_video_stream_callback callback, void *user_param)
+int mm_player_set_video_decoded_callback(MMHandleType player, mm_player_video_decoded_callback callback, void *user_param)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_videostream_cb(player, callback, user_param);
+       result = _mmplayer_set_video_decoded_cb(player, callback, user_param);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
@@ -263,109 +222,78 @@ int mm_player_do_video_capture(MMHandleType player)
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_do_video_capture(player);
 
-       MMPLAYER_CMD_UNLOCK( player );
-
-       return result;
-}
-
-int mm_player_set_prepare_buffering_time(MMHandleType player, int second)
-{
-       int result = MM_ERROR_NONE;
-
-       MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-
-       MMPLAYER_CMD_LOCK( player );
-
-       result = _mmplayer_set_prepare_buffering_time(player, second);
-
-       MMPLAYER_CMD_UNLOCK( player );
-
-       return result;
-}
-
-int mm_player_set_runtime_buffering_mode(MMHandleType player, MMPlayerBufferingMode mode, int second)
-{
-       int result = MM_ERROR_NONE;
-
-       MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-
-       MMPLAYER_CMD_LOCK( player );
-
-       result = _mmplayer_set_runtime_buffering_mode(player, mode, second);
-
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_volume(MMHandleType player, MMPlayerVolumeType *volume)
+int mm_player_set_volume(MMHandleType player, float volume)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(volume, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_volume(player, *volume);
+       result = _mmplayer_set_volume(player, volume);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_volume(MMHandleType player, MMPlayerVolumeType *volume)
+int mm_player_get_volume(MMHandleType player, float *volume)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
        MMPLAYER_RETURN_VAL_IF_FAIL(volume, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_get_volume(player, volume);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_mute(MMHandleType player, int mute)
+int mm_player_set_mute(MMHandleType player, bool mute)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_set_mute(player, mute);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_mute(MMHandleType player, int *mute)
+int mm_player_get_mute(MMHandleType player, bool *mute)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
        MMPLAYER_RETURN_VAL_IF_FAIL(mute, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_get_mute(player, mute);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_state(MMHandleType player, MMPlayerStateType *state)
+int mm_player_get_state(MMHandleType player, mmplayer_state_e *state)
 {
        int result = MM_ERROR_NONE;
 
@@ -374,23 +302,23 @@ int mm_player_get_state(MMHandleType player, MMPlayerStateType *state)
 
        *state = MM_PLAYER_STATE_NULL;
 
-       result = _mmplayer_get_state(player, (int*)state);
+       result = _mmplayer_get_state(player, (int *)state);
 
        return result;
 }
 
 /* NOTE : It does not support some use cases, eg using colorspace converter */
-int mm_player_change_videosink(MMHandleType player, MMDisplaySurfaceType display_surface_type, void *display_overlay)
+int mm_player_change_videosink(MMHandleType player, MMDisplaySurfaceType display_surface_type, int wl_surface_id)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_change_videosink(player, display_surface_type, display_overlay);
+       result = _mmplayer_change_videosink(player, display_surface_type, wl_surface_id);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
@@ -401,11 +329,11 @@ int mm_player_start(MMHandleType player)
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_start(player);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
@@ -416,11 +344,11 @@ int  mm_player_stop(MMHandleType player)
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_stop(player);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
@@ -431,11 +359,11 @@ int mm_player_pause(MMHandleType player)
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_pause(player);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
@@ -446,163 +374,119 @@ int mm_player_resume(MMHandleType player)
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_resume(player);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_activate_section_repeat(MMHandleType player, int start_pos, int end_pos)
+int mm_player_set_play_speed(MMHandleType player, float rate, bool streaming)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_activate_section_repeat(player, start_pos, end_pos);
+       result = _mmplayer_set_playspeed(player, rate, streaming);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_deactivate_section_repeat(MMHandleType player)
+int mm_player_set_position(MMHandleType player, int64_t pos)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_deactivate_section_repeat(player);
+       result = _mmplayer_set_position(player, pos);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_play_speed(MMHandleType player, float rate, bool streaming)
+int mm_player_get_position(MMHandleType player, int64_t *pos)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(pos, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_playspeed(player, rate, streaming);
+       result = _mmplayer_gst_get_position((mmplayer_t *)player, pos);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_position(MMHandleType player, MMPlayerPosFormatType format, int pos)
+int mm_player_get_duration(MMHandleType player, int64_t *dur)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(dur, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       if (format >= MM_PLAYER_POS_FORMAT_NUM)
-       {
-               LOGE("wrong format\n");
-               return MM_ERROR_COMMON_INVALID_ARGUMENT;
-       }
+       MMPLAYER_CMD_LOCK(player);
 
-       MMPLAYER_CMD_LOCK( player );
+       result = _mmplayer_get_duration(player, dur);
 
-       result = _mmplayer_set_position(player, format, pos);
-
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_position(MMHandleType player, MMPlayerPosFormatType format, unsigned long *pos)
-{
-       int result = MM_ERROR_NONE;
-
-       MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(pos, MM_ERROR_COMMON_INVALID_ARGUMENT);
-
-       if (format >= MM_PLAYER_POS_FORMAT_NUM)
-       {
-               LOGE("wrong format\n");
-               return MM_ERROR_COMMON_INVALID_ARGUMENT;
-       }
-
-       MMPLAYER_CMD_LOCK( player );
 
-       result = _mmplayer_get_position(player, (int)format, pos);
-
-       MMPLAYER_CMD_UNLOCK( player );
-
-       return result;
-}
-
-int mm_player_get_buffer_position(MMHandleType player, MMPlayerPosFormatType format, unsigned long *start_pos, unsigned long *stop_pos)
+int mm_player_get_buffer_position(MMHandleType player, int *start_pos, int *end_pos)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(start_pos && stop_pos, MM_ERROR_COMMON_INVALID_ARGUMENT);
+       MMPLAYER_RETURN_VAL_IF_FAIL(start_pos && end_pos, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_buffer_position(player, (int)format, start_pos, stop_pos );
+       result = _mmplayer_get_buffer_position(player, start_pos, end_pos);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_external_subtitle_path(MMHandleType player, const charpath)
+int mm_player_set_external_subtitle_path(MMHandleType player, const char *path)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_set_external_subtitle_path(player, path);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
        return result;
 }
 
-int mm_player_adjust_subtitle_position(MMHandleType player, MMPlayerPosFormatType format, int pos)
+int mm_player_adjust_subtitle_position(MMHandleType player, int pos)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       if (format >= MM_PLAYER_POS_FORMAT_NUM)
-       {
-               LOGE("wrong format(%d) \n", format);
-               return MM_ERROR_INVALID_ARGUMENT;
-       }
-
-       MMPLAYER_CMD_LOCK( player );
-
-       result = _mmplayer_adjust_subtitle_postion(player, format, pos);
+       MMPLAYER_CMD_LOCK(player);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       result = _mmplayer_adjust_subtitle_postion(player, pos);
 
-       return result;
-}
-
-int mm_player_adjust_video_position(MMHandleType player, int offset)
-{
-       int result = MM_ERROR_NONE;
-       MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_CMD_LOCK( player );
-
-       result = _mmplayer_adjust_video_postion(player, offset);
-
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
@@ -613,26 +497,26 @@ int mm_player_set_subtitle_silent(MMHandleType player, int silent)
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_set_subtitle_silent(player, silent);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_subtitle_silent(MMHandleType player, intsilent)
+int mm_player_get_subtitle_silent(MMHandleType player, int *silent)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
        result = _mmplayer_get_subtitle_silent(player, silent);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
@@ -645,9 +529,9 @@ int mm_player_set_attribute(MMHandleType player,  char **err_attr_name, const ch
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
        MMPLAYER_RETURN_VAL_IF_FAIL(first_attribute_name, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       va_start (var_args, first_attribute_name);
+       va_start(var_args, first_attribute_name);
        result = _mmplayer_set_attribute(player, err_attr_name, first_attribute_name, var_args);
-       va_end (var_args);
+       va_end(var_args);
 
        return result;
 }
@@ -660,14 +544,14 @@ int mm_player_get_attribute(MMHandleType player,  char **err_attr_name, const ch
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
        MMPLAYER_RETURN_VAL_IF_FAIL(first_attribute_name, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       va_start (var_args, first_attribute_name);
+       va_start(var_args, first_attribute_name);
        result = _mmplayer_get_attribute(player, err_attr_name, first_attribute_name, var_args);
-       va_end (var_args);
+       va_end(var_args);
 
        return result;
 }
 
-int mm_player_get_attribute_info(MMHandleType player,  const char *attribute_name, MMPlayerAttrsInfo *info)
+int mm_player_get_attribute_info(MMHandleType player,  const char *attribute_name, mmplayer_attrs_info_t *info)
 {
        int result = MM_ERROR_NONE;
 
@@ -681,694 +565,717 @@ int mm_player_get_attribute_info(MMHandleType player,  const char *attribute_nam
        return result;
 }
 
-int mm_player_get_pd_status(MMHandleType player, guint64 *current_pos, guint64 *total_size)
+int mm_player_get_track_count(MMHandleType player, mmplayer_track_type_e type, int *count)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(current_pos, MM_ERROR_COMMON_INVALID_ARGUMENT);
-       MMPLAYER_RETURN_VAL_IF_FAIL(total_size, MM_ERROR_COMMON_INVALID_ARGUMENT);
+       MMPLAYER_RETURN_VAL_IF_FAIL(count, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       result = _mmplayer_get_pd_downloader_status(player, current_pos, total_size);
+       MMPLAYER_CMD_LOCK(player);
+
+       result = _mmplayer_get_track_count(player, type, count);
+
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_track_count(MMHandleType player, MMPlayerTrackType type, int *count)
+int mm_player_select_track(MMHandleType player, mmplayer_track_type_e type, int index)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(count, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_track_count(player, type, count);
+       result = _mmplayer_select_track(player, type, index);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_select_track(MMHandleType player, MMPlayerTrackType type, int index)
+int mm_player_get_current_track(MMHandleType player, mmplayer_track_type_e type, int *index)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(index, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_select_track(player, type, index);
+       result = _mmplayer_get_current_track(player, type, index);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
-#ifdef _MULTI_TRACK
-int mm_player_track_add_subtitle_language(MMHandleType player, int index)
+
+int mm_player_get_track_language_code(MMHandleType player,  mmplayer_track_type_e type, int index, char **code)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_track_add_subtitle_language(player, index);
+       result = _mmplayer_get_track_language_code(player, type, index, code);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_track_remove_subtitle_language(MMHandleType player, int index)
+int mm_player_set_uri(MMHandleType player, const char *uri)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_track_remove_subtitle_language(player, index);
+       result = _mmplayer_set_uri(player, uri);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 
 }
-#endif
-int mm_player_get_current_track(MMHandleType player, MMPlayerTrackType type, int *index)
+
+int mm_player_set_next_uri(MMHandleType player, const char *uri)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(index, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_current_track(player, type, index);
+       result = _mmplayer_set_next_uri(player, uri, FALSE);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
+
 }
 
-int mm_player_get_track_language_code(MMHandleType player,  MMPlayerTrackType type, int index, char **code)
+int mm_player_get_next_uri(MMHandleType player, char **uri)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_track_language_code(player, type, index, code);
+       result = _mmplayer_get_next_uri(player, uri);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
+
 }
 
-int mm_player_set_display_zoom(MMHandleType player, float level, int x, int y)
+int mm_player_has_closed_caption(MMHandleType player, bool *exist)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(exist, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_display_zoom(player, level, x, y);
+       result = _mmplayer_has_closed_caption(player, exist);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_display_zoom(MMHandleType player, float *level, int *x, int *y)
+void mm_player_video_stream_internal_buffer_unref(void *buffer)
+{
+       _mm_player_video_stream_internal_buffer_unref(buffer);
+}
+
+int mm_player_submit_packet(MMHandleType player, media_packet_h packet)
 {
+
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(level, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       /* no lock here, otherwise callback for the "need-data" signal of appsrc will be blocking */
+       //MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_display_zoom(player, level, x, y);
+       result = _mmplayer_submit_packet(player, packet);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       //MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_video_share_master_clock(MMHandleType player,
-                                               long long clock,
-                                               long long clock_delta,
-                                               long long video_time,
-                                               long long media_clock,
-                                               long long audio_time)
+int mm_player_set_video_info(MMHandleType player, media_format_h format)
 {
        int result = MM_ERROR_NONE;
 
+       LOGD("\n");
+
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_video_share_master_clock(player, clock, clock_delta, video_time, media_clock, audio_time);
+       result = _mmplayer_set_video_info(player, format);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
+
 }
 
-int mm_player_get_video_share_master_clock(MMHandleType player,
-                                               long long *video_time,
-                                               long long *media_clock,
-                                               long long *audio_time)
+int mm_player_set_audio_info(MMHandleType player, media_format_h format)
 {
        int result = MM_ERROR_NONE;
 
+       LOGD("\n");
+
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(video_time, MM_ERROR_COMMON_INVALID_ARGUMENT);
-       MMPLAYER_RETURN_VAL_IF_FAIL(media_clock, MM_ERROR_COMMON_INVALID_ARGUMENT);
-       MMPLAYER_RETURN_VAL_IF_FAIL(audio_time, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_video_share_master_clock(player, video_time, media_clock, audio_time);
+       result = _mmplayer_set_audio_info(player, format);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_video_rotate_angle(MMHandleType player, int *angle)
+int mm_player_set_subtitle_info(MMHandleType player, mmplayer_subtitle_stream_info_t *subtitle_stream_info)
 {
        int result = MM_ERROR_NONE;
 
+       LOGD("\n");
+
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(angle, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_video_rotate_angle(player, angle);
+       result = _mmplayer_set_subtitle_info(player, subtitle_stream_info);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_video_hub_download_mode(MMHandleType player, bool mode)
+int mm_player_set_media_stream_buffer_max_size(MMHandleType player, mmplayer_stream_type_e type, unsigned long long max_size)
 {
        int result = MM_ERROR_NONE;
 
+       LOGD("\n");
+
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_video_hub_download_mode(player, mode);
+       result = _mmplayer_set_media_stream_max_size(player, type, max_size);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_enable_sync_handler(MMHandleType player, bool enable)
+int mm_player_get_media_stream_buffer_max_size(MMHandleType player, mmplayer_stream_type_e type, unsigned long long *max_size)
 {
        int result = MM_ERROR_NONE;
+       guint64 _max_size = 0;
+
+       LOGD("\n");
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(max_size, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_enable_sync_handler(player, enable);
+       result = _mmplayer_get_media_stream_max_size(player, type, &_max_size);
+       *max_size = _max_size;
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_uri(MMHandleType player, const char *uri)
+int mm_player_set_media_stream_buffer_min_percent(MMHandleType player, mmplayer_stream_type_e type, unsigned min_percent)
 {
        int result = MM_ERROR_NONE;
 
+       LOGD("\n");
+
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_uri(player, uri);
+       result = _mmplayer_set_media_stream_min_percent(player, type, min_percent);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
-
 }
 
-int mm_player_set_next_uri(MMHandleType player, const char *uri)
+int mm_player_get_media_stream_buffer_min_percent(MMHandleType player, mmplayer_stream_type_e type, unsigned int *min_percent)
 {
        int result = MM_ERROR_NONE;
 
+       LOGD("\n");
+
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(min_percent, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_next_uri(player, uri, FALSE);
+       result = _mmplayer_get_media_stream_min_percent(player, type, min_percent);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
-
 }
 
-int mm_player_get_next_uri(MMHandleType player, char **uri)
+int mm_player_set_audio_stream_changed_callback(MMHandleType player, mm_player_stream_changed_callback callback, void *user_param)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_next_uri(player, uri);
+       result = _mmplayer_set_audiostream_changed_cb(player, callback, user_param);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
-
 }
-#ifdef _MULTI_TRACK
-int mm_player_track_foreach_selected_subtitle_language(MMHandleType player, mm_player_track_selected_subtitle_language_callback callback, void *user_param)
+
+int mm_player_get_timeout(MMHandleType player, int *timeout)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(timeout, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_track_foreach_selected_subtitle_language(player, callback, user_param);
+       result = _mmplayer_get_timeout(player, timeout);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
-#endif
 
-int mm_player_has_closed_caption(MMHandleType player, bool *exist)
+int mm_player_set_media_stream_dynamic_resolution(MMHandleType player, bool drc)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(exist, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_has_closed_caption(player, exist);
+       result = _mmplayer_set_media_stream_dynamic_resolution(player, drc);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-void * mm_player_media_packet_video_stream_internal_buffer_ref(void *buffer)
+int mm_player_release_video_stream_bo(MMHandleType player, void *bo)
 {
-       void * result;
-       result = _mm_player_media_packet_video_stream_internal_buffer_ref(buffer);
+       int result = MM_ERROR_NONE;
+
+       MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(bo, MM_ERROR_COMMON_INVALID_ARGUMENT);
+
+       //MMPLAYER_CMD_LOCK(player);
+
+       result = _mmplayer_video_stream_release_bo(player, bo);
+
+       //MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-void mm_player_media_packet_video_stream_internal_buffer_unref(void *buffer)
+int mm_player_set_sound_stream_info(MMHandleType player, char *stream_type, int stream_index)
 {
-       _mm_player_media_packet_video_stream_internal_buffer_unref(buffer);
+       int result = MM_ERROR_NONE;
+
+       MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL((stream_type && (stream_index >= 0)), MM_ERROR_INVALID_ARGUMENT);
+
+       MMPLAYER_CMD_LOCK(player);
+
+       result = mm_player_set_attribute(player, NULL, "sound_stream_type", stream_type, strlen(stream_type), "sound_stream_index", stream_index, NULL);
+
+       MMPLAYER_CMD_UNLOCK(player);
+
+       return result;
 }
 
-int mm_player_submit_packet(MMHandleType player, media_packet_h packet)
+int mm_player_manage_external_storage_state(MMHandleType player, int id, int state)
 {
-
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       /* no lock here, otherwise callback for the "need-data" signal of appsrc will be blocking */
-       //MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_submit_packet(player, packet);
+       result = _mmplayer_manage_external_storage_state(player, id, state);
 
-       //MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_video_info (MMHandleType player, media_format_h format)
+int mm_player_get_adaptive_variant_info(MMHandleType player, int *num, char **var_info)
 {
        int result = MM_ERROR_NONE;
 
-       LOGD("\n");
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(num && var_info, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_video_info(player, format);
+       result = _mmplayer_get_adaptive_variant_info(player, num, var_info);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
-
 }
 
-int mm_player_set_audio_info (MMHandleType player, media_format_h format)
+int mm_player_set_max_adaptive_variant_limit(MMHandleType player, int bandwidth, int width, int height)
 {
        int result = MM_ERROR_NONE;
 
-       LOGD("\n");
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_audio_info(player, format);
+       result = _mmplayer_set_max_adaptive_variant_limit(player, bandwidth, width, height);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_subtitle_info (MMHandleType player, MMPlayerSubtitleStreamInfo *subtitle_stream_info)
+int mm_player_get_max_adaptive_variant_limit(MMHandleType player, int *bandwidth, int *width, int *height)
 {
        int result = MM_ERROR_NONE;
 
-       LOGD("\n");
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(bandwidth && width && height, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_subtitle_info(player, subtitle_stream_info);
+       result = _mmplayer_get_max_adaptive_variant_limit(player, bandwidth, width, height);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_media_stream_buffer_max_size(MMHandleType player, MMPlayerStreamType type, unsigned long long max_size)
+int mm_player_get_streaming_buffering_time(MMHandleType player, int *prebuffer_ms, int *rebuffer_ms)
 {
        int result = MM_ERROR_NONE;
 
-       LOGD("\n");
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(prebuffer_ms && rebuffer_ms, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_media_stream_max_size(player, type, max_size);
+       result = _mmplayer_get_streaming_buffering_time(player, prebuffer_ms, rebuffer_ms);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_media_stream_buffer_max_size(MMHandleType player, MMPlayerStreamType type, unsigned long long *max_size)
+int mm_player_set_audio_only(MMHandleType player, bool audio_only)
 {
        int result = MM_ERROR_NONE;
-       guint64 _max_size = 0;
-
-       LOGD("\n");
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(max_size, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_media_stream_max_size(player, type, &_max_size);
-       *max_size = _max_size;
+       result = _mmplayer_set_audio_only(player, audio_only);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_media_stream_buffer_min_percent(MMHandleType player, MMPlayerStreamType type, unsigned min_percent)
+int mm_player_get_audio_only(MMHandleType player, bool *audio_only)
 {
        int result = MM_ERROR_NONE;
 
-       LOGD("\n");
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(audio_only, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_media_stream_min_percent(player, type, min_percent);
+       result = _mmplayer_get_audio_only(player, audio_only);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_media_stream_buffer_min_percent(MMHandleType player, MMPlayerStreamType type, unsigned int *min_percent)
+int mm_player_360_is_content_spherical(MMHandleType player, bool *is_spherical)
 {
        int result = MM_ERROR_NONE;
 
-       LOGD("\n");
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(min_percent, MM_ERROR_INVALID_ARGUMENT);
+       MMPLAYER_RETURN_VAL_IF_FAIL(is_spherical, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_media_stream_min_percent(player, type, min_percent);
+       result = _mmplayer_360_is_content_spherical(player, is_spherical);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_media_stream_buffer_status_callback(MMHandleType player, MMPlayerStreamType type, mm_player_media_stream_buffer_status_callback callback, void * user_param)
+int mm_player_360_set_enabled(MMHandleType player, bool enabled)
 {
        int result = MM_ERROR_NONE;
-
-       LOGD("\n");
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_media_stream_buffer_status_cb(player, type, callback, user_param);
+       result = _mmplayer_360_set_enabled(player, enabled);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_media_stream_seek_data_callback(MMHandleType player, MMPlayerStreamType type, mm_player_media_stream_seek_data_callback callback, void * user_param)
+int mm_player_360_is_enabled(MMHandleType player, bool *enabled)
 {
        int result = MM_ERROR_NONE;
 
-       LOGD("\n");
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(enabled, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_media_stream_seek_data_cb(player, type, callback, user_param);
+       result = _mmplayer_360_is_enabled(player, enabled);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_audio_stream_changed_callback(MMHandleType player, mm_player_stream_changed_callback callback, void *user_param)
+int mm_player_360_set_direction_of_view(MMHandleType player, float yaw, float pitch)
 {
        int result = MM_ERROR_NONE;
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_audiostream_changed_cb(player, callback, user_param);
+       result = _mmplayer_360_set_direction_of_view(player, yaw, pitch);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_video_stream_changed_callback(MMHandleType player, mm_player_stream_changed_callback callback, void *user_param)
+int mm_player_360_get_direction_of_view(MMHandleType player, float *yaw, float *pitch)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(yaw && pitch, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_videostream_changed_cb(player, callback, user_param);
+       result = _mmplayer_360_get_direction_of_view(player, yaw, pitch);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_pcm_spec(MMHandleType player, int samplerate, int channel)
+int mm_player_360_set_zoom(MMHandleType player, float level)
 {
        int result = MM_ERROR_NONE;
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_pcm_spec(player, samplerate, channel);
+       result = _mmplayer_360_set_zoom(player, level);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_timeout(MMHandleType player, int *timeout)
+int mm_player_360_get_zoom(MMHandleType player, float *level)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(timeout, MM_ERROR_COMMON_INVALID_ARGUMENT);
+       MMPLAYER_RETURN_VAL_IF_FAIL(level, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_timeout(player, timeout);
+       result = _mmplayer_360_get_zoom(player, level);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_num_of_video_out_buffers(MMHandleType player, int *num, int *extra_num)
+int mm_player_360_set_field_of_view(MMHandleType player, int horizontal_degrees, int vertical_degrees)
 {
        int result = MM_ERROR_NONE;
-
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(num && extra_num, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_num_of_video_out_buffers(player, num, extra_num);
+       result = _mmplayer_360_set_field_of_view(player, horizontal_degrees, vertical_degrees);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_media_stream_dynamic_resolution(MMHandleType player, bool drc)
+int mm_player_360_get_field_of_view(MMHandleType player, int *horizontal_degrees, int *vertical_degrees)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(horizontal_degrees && vertical_degrees, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_media_stream_dynamic_resolution(player, drc);
+       result = _mmplayer_360_get_field_of_view(player, horizontal_degrees, vertical_degrees);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_release_video_stream_bo(MMHandleType player, void* bo)
+int mm_player_set_codec_type(MMHandleType player, mmplayer_stream_type_e stream_type, mmplayer_codec_type_e codec_type)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(bo, MM_ERROR_COMMON_INVALID_ARGUMENT);
-//     MMPLAYER_CMD_LOCK( player );
 
-       result = _mmplayer_video_stream_release_bo(player, bo);
+       MMPLAYER_CMD_LOCK(player);
+
+       result = _mmplayer_set_codec_type(player, stream_type, codec_type);
+
+       MMPLAYER_CMD_UNLOCK(player);
 
-//     MMPLAYER_CMD_UNLOCK( player );
        return result;
 }
 
-int mm_player_set_file_buffering_path(MMHandleType player, const char *file_path)
+int mm_player_set_replaygain_enabled(MMHandleType player, bool enabled)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_file_buffering_path(player, file_path);
+       result = _mmplayer_set_replaygain_enabled(player, enabled);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_sound_stream_info(MMHandleType player, char *stream_type, int stream_index)
+int mm_player_is_replaygain_enabled(MMHandleType player, bool *enabled)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL((stream_type && (stream_index >= 0)), MM_ERROR_INVALID_ARGUMENT);
+       MMPLAYER_RETURN_VAL_IF_FAIL(enabled, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       _mmplayer_sound_unregister(&((mm_player_t*)player)->sound_focus);
-       result = mm_player_set_attribute(player, NULL, "sound_stream_type", stream_type, strlen(stream_type), "sound_stream_index", stream_index, NULL);
+       result = _mmplayer_is_replaygain_enabled(player, enabled);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_manage_external_storage_state(MMHandleType player, int state)
+int mm_player_set_video_roi_area(MMHandleType player, double scale_x, double scale_y, double scale_width, double scale_height)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_manage_external_storage_state(player, state);
+       result = _mmplayer_set_video_roi_area(player, scale_x, scale_y, scale_width, scale_height);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_adaptive_variant_info(MMHandleType player, int *num, char **var_info)
+int mm_player_get_video_roi_area(MMHandleType player, double *scale_x, double *scale_y, double *scale_width, double *scale_height)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(num && var_info, MM_ERROR_COMMON_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_adaptive_variant_info(player, num, var_info);
+       result = _mmplayer_get_video_roi_area(player, scale_x, scale_y, scale_width, scale_height);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_set_max_adaptive_variant_limit(MMHandleType player, int bandwidth, int width, int height)
+int mm_player_set_client_pid(MMHandleType player, int pid)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_set_max_adaptive_variant_limit(player, bandwidth, width, height);
+       result = _mmplayer_set_client_pid(player, pid);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }
 
-int mm_player_get_max_adaptive_variant_limit(MMHandleType player, int *bandwidth, int *width, int *height)
+int mm_player_audio_offload_is_activated(MMHandleType player, bool *activated)
 {
        int result = MM_ERROR_NONE;
 
        MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
-       MMPLAYER_RETURN_VAL_IF_FAIL(bandwidth && width && height, MM_ERROR_COMMON_INVALID_ARGUMENT);
+       MMPLAYER_RETURN_VAL_IF_FAIL(activated, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_LOCK( player );
+       MMPLAYER_CMD_LOCK(player);
 
-       result = _mmplayer_get_max_adaptive_variant_limit(player, bandwidth, width, height);
+       result = _mmplayer_audio_offload_is_activated(player, activated);
+
+       MMPLAYER_CMD_UNLOCK(player);
+
+       return result;
+}
+
+int mm_player_is_audio_control_available(MMHandleType player, mmplayer_audio_control_opt_e opt, bool *available)
+{
+       int result = MM_ERROR_NONE;
+
+       MMPLAYER_RETURN_VAL_IF_FAIL(player, MM_ERROR_PLAYER_NOT_INITIALIZED);
+       MMPLAYER_RETURN_VAL_IF_FAIL(available, MM_ERROR_INVALID_ARGUMENT);
 
-       MMPLAYER_CMD_UNLOCK( player );
+       MMPLAYER_CMD_LOCK(player);
+       result = _mmplayer_is_audio_control_available(player, opt, available);
+       MMPLAYER_CMD_UNLOCK(player);
 
        return result;
 }