Merge "[0.6.195] apply the RM policy about audio offload" into tizen
[platform/core/multimedia/libmm-player.git] / src / mm_player_priv.c
index 55da794..42528d6 100644 (file)
@@ -606,6 +606,9 @@ static int __mmplayer_acquire_hw_resource(mmplayer_t *player, mmplayer_resource_
                case MMPLAYER_RESOURCE_TYPE_VIDEO_OVERLAY:
                        rm_res_type = MM_RESOURCE_MANAGER_RES_TYPE_VIDEO_OVERLAY;
                        break;
+               case MMPLAYER_RESOURCE_TYPE_AUDIO_OFFLOAD:
+                       rm_res_type = MM_RESOURCE_MANAGER_RES_TYPE_AUDIO_OFFLOAD;
+                       break;
                default:
                        LOGE("invalid mmplayer resource type %d", type);
                        return MM_ERROR_PLAYER_INTERNAL;
@@ -5145,9 +5148,14 @@ _mmplayer_unrealize(MMHandleType hplayer)
        ret = __mmplayer_gst_unrealize(player);
 
        if (!player->interrupted_by_resource) {
-               if ((__mmplayer_release_hw_resource(player, MMPLAYER_RESOURCE_TYPE_VIDEO_DECODER) != MM_ERROR_NONE) ||
-                       (__mmplayer_release_hw_resource(player, MMPLAYER_RESOURCE_TYPE_VIDEO_OVERLAY) != MM_ERROR_NONE))
-                       LOGE("failed to release video resources");
+               int rm_ret = MM_ERROR_NONE;
+               mmplayer_resource_type_e res_idx = MMPLAYER_RESOURCE_TYPE_MAX;
+
+               for (res_idx = MMPLAYER_RESOURCE_TYPE_VIDEO_DECODER; res_idx < MMPLAYER_RESOURCE_TYPE_MAX; res_idx++) {
+                       rm_ret = __mmplayer_release_hw_resource(player, res_idx);
+                       if (rm_ret != MM_ERROR_NONE)
+                               LOGE("failed to release [%d] resources", res_idx);
+               }
        }
 
        MMPLAYER_FLEAVE();
@@ -6963,6 +6971,12 @@ __mmplayer_can_build_audio_offload_path(mmplayer_t *player)
        }
        gst_object_unref(factory);
 
+       if (__mmplayer_acquire_hw_resource(player,
+                       MMPLAYER_RESOURCE_TYPE_AUDIO_OFFLOAD) != MM_ERROR_NONE) {
+               LOGE("failed to acquire audio offload decoder resource");
+               goto DONE;
+       }
+
        if (!__mmplayer_add_audio_device_connected_cb(player))
                goto DONE;
 
@@ -6973,6 +6987,9 @@ __mmplayer_can_build_audio_offload_path(mmplayer_t *player)
        ret = TRUE;
 
 DONE:
+       if (!ret)
+               __mmplayer_release_hw_resource(player, MMPLAYER_RESOURCE_TYPE_AUDIO_OFFLOAD);
+
        MMPLAYER_FLEAVE();
        return ret;
 }