summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoreunhae1.choi <eunhae1.choi@samsung.com>2014-05-27 14:23:27 +0900
committereunhae1.choi <eunhae1.choi@samsung.com>2014-05-27 14:23:27 +0900
commit7a97ce895b719ae4cf99bb0d6ca1715c1f4c265b (patch)
tree462c8a41125ac92bbd16b19961b60b6ce203e85d
parent712066a6e8c39ebe8a15843edb836214c8703220 (diff)
downloadlibmm-player-accepted/tizen_3.0.2014.q3_common.tar.gz
libmm-player-accepted/tizen_3.0.2014.q3_common.tar.bz2
libmm-player-accepted/tizen_3.0.2014.q3_common.zip
Change-Id: I1412530ec56389d03b2de1cd09e8e5c3d30ec495
-rwxr-xr-x[-rw-r--r--]src/include/mm_player_priv.h11
-rwxr-xr-xsrc/include/mm_player_priv_internal.h1
-rwxr-xr-xsrc/include/mm_player_priv_locl_func.h21
-rwxr-xr-xsrc/mm_player_priv.c84
-rwxr-xr-xsrc/mm_player_priv_internal.c60
5 files changed, 89 insertions, 88 deletions
diff --git a/src/include/mm_player_priv.h b/src/include/mm_player_priv.h
index 132b3e4..3658b33 100644..100755
--- a/src/include/mm_player_priv.h
+++ b/src/include/mm_player_priv.h
@@ -127,7 +127,7 @@ enum MMPlayerUriType {
MM_PLAYER_URI_TYPE_FILE, /**< Player URI type File */
MM_PLAYER_URI_TYPE_URL, /**< Player URI type URL */
MM_PLAYER_URI_TYPE_BUFF, /**< Player URI type Buffer */
- MM_PLAYER_URI_TYPE_HLS, /**< Player URI type http live streaming */
+ MM_PLAYER_URI_TYPE_HLS, /**< Player URI type http live streaming */
MM_PLAYER_URI_TYPE_TEMP, /**< Player URI type Temp */
};
@@ -165,10 +165,10 @@ enum MainElementID
MMPLAYER_M_SRC_2ND_FAKESINK,
/* streaming plugin */
- MMPLAYER_M_S_BUFFER,
- MMPLAYER_M_S_ADEC,
- MMPLAYER_M_S_VDEC,
-
+ MMPLAYER_M_S_BUFFER,
+ MMPLAYER_M_S_ADEC,
+ MMPLAYER_M_S_VDEC,
+
/* FIXIT : if there's really no usage for following IDs. remove it */
MMPLAYER_M_DEC1,
MMPLAYER_M_DEC2,
@@ -661,6 +661,7 @@ int _mmplayer_set_audiostream_cb(MMHandleType hplayer,mm_player_audio_stream_cal
int _mmplayer_set_videoframe_render_error_cb(MMHandleType hplayer, mm_player_video_frame_render_error_callback callback, void *user_param);
int _mmplayer_set_subtitle_silent (MMHandleType hplayer, int silent);
int _mmplayer_get_subtitle_silent (MMHandleType hplayer, int* silent);
+int _mmplayer_get_track_count(MMHandleType hplayer, MMPlayerTrackType track_type, int *count);
int _mmplayer_get_buffer_position(MMHandleType hplayer, int format, unsigned long* start_pos, unsigned long* stop_pos);
/* test API for tuning audio gain. this API should be
* deprecated before the day of final release
diff --git a/src/include/mm_player_priv_internal.h b/src/include/mm_player_priv_internal.h
index 40b9dc4..c6588dc 100755
--- a/src/include/mm_player_priv_internal.h
+++ b/src/include/mm_player_priv_internal.h
@@ -31,6 +31,7 @@
void __mmplayer_release_signal_connection(mm_player_t* player);
gboolean __mmplayer_dump_pipeline_state(mm_player_t* player);
int __mmplayer_gst_set_state (mm_player_t* player, GstElement * element, GstState state, gboolean async, gint timeout);
+void __mmplayer_cancel_delayed_eos(mm_player_t* player);
gboolean __mmplayer_check_subtitle(mm_player_t* player);
int __mmplayer_handle_missed_plugin(mm_player_t* player);
gboolean __mmplayer_link_decoder(mm_player_t* player, GstPad *srcpad);
diff --git a/src/include/mm_player_priv_locl_func.h b/src/include/mm_player_priv_locl_func.h
index c63c0ce..972625d 100755
--- a/src/include/mm_player_priv_locl_func.h
+++ b/src/include/mm_player_priv_locl_func.h
@@ -27,12 +27,27 @@
| LOCAL FUNCTION PROTOTYPES: |
---------------------------------------------------------------------------*/
/* mm_player_priv.c */
-gboolean __mmplayer_eos_timer_cb(gpointer u_data);
+gboolean __mmplayer_set_state(mm_player_t* player, int state);
void __mmplayer_typefind_have_type( GstElement *tf, guint probability, GstCaps *caps, gpointer data);
-GstBusSyncReply __mmplayer_bus_sync_callback (GstBus * bus, GstMessage * message, gpointer data);
+gboolean __mmplayer_try_to_plug(mm_player_t* player, GstPad *pad, const GstCaps *caps);
+void __mmplayer_pipeline_complete(GstElement *decodebin, gpointer data);
gboolean __mmplayer_update_subtitle( GstElement* object, GstBuffer *buffer, GstPad *pad, gpointer data);
-void __mmplayer_videoframe_render_error_cb(GstElement *element, void *error_id, gpointer data);
+void __mmplayer_release_misc(mm_player_t* player);
+gboolean __mmplayer_configure_audio_callback(mm_player_t* player);
+void __mmplayer_set_antishock( mm_player_t* player, gboolean disable_by_force);
+gboolean _mmplayer_update_content_attrs(mm_player_t* player, enum content_attr_flag flag);
void __mmplayer_videostream_cb(GstElement *element, void *stream, int width, int height, gpointer data);
+void __mmplayer_videoframe_render_error_cb(GstElement *element, void *error_id, gpointer data);
+void __mmplayer_handle_buffering_message ( mm_player_t* player );
+int __mmplayer_set_pcm_extraction(mm_player_t* player);
+gboolean __mmplayer_can_extract_pcm( mm_player_t* player );
+void __mmplayer_do_sound_fadedown(mm_player_t* player, unsigned int time);
+void __mmplayer_undo_sound_fadedown(mm_player_t* player);
+const gchar * __get_state_name ( int state );
+GstBusSyncReply __mmplayer_bus_sync_callback (GstBus * bus, GstMessage * message, gpointer data);
+void __mmplayer_post_delayed_eos( mm_player_t* player, int delay_in_ms );
+void __gst_set_async_state_change(mm_player_t* player, gboolean async);
+gboolean __mmplayer_post_message(mm_player_t* player, enum MMMessageType msgtype, MMMessageParamType* param);
/* mm_player_priv_wrapper.c */
gboolean __mmplayer_gst_callback(GstBus *bus, GstMessage *msg, gpointer data);
diff --git a/src/mm_player_priv.c b/src/mm_player_priv.c
index ede7896..0e00372 100755
--- a/src/mm_player_priv.c
+++ b/src/mm_player_priv.c
@@ -111,10 +111,7 @@
/*---------------------------------------------------------------------------
| LOCAL FUNCTION PROTOTYPES: |
---------------------------------------------------------------------------*/
-static gboolean __mmplayer_set_state(mm_player_t* player, int state);
static int __mmplayer_get_state(mm_player_t* player);
-static gboolean __mmplayer_try_to_plug(mm_player_t* player, GstPad *pad, const GstCaps *caps);
-static void __mmplayer_pipeline_complete(GstElement *decodebin, gpointer data);
static gboolean __mmplayer_is_midi_type(gchar* str_caps);
static gboolean __mmplayer_is_amr_type (gchar *str_caps);
static gboolean __mmplayer_is_only_mp3_type (gchar *str_caps);
@@ -126,7 +123,6 @@ static void __mmplayer_add_new_pad(GstElement *element, GstPad *pad, gpointer d
static gboolean __mmplayer_get_stream_service_type( mm_player_t* player );
static void __mmplayer_init_factories(mm_player_t* player);
static void __mmplayer_release_factories(mm_player_t* player);
-static void __mmplayer_release_misc(mm_player_t* player);
static gboolean __mmplayer_gstreamer_init(void);
gboolean __mmplayer_post_message(mm_player_t* player, enum MMMessageType msgtype, MMMessageParamType* param);
@@ -134,22 +130,9 @@ gboolean __mmplayer_post_message(mm_player_t* player, enum MMMessageType msgtype
int __mmplayer_switch_audio_sink (mm_player_t* player);
static int __mmplayer_check_state(mm_player_t* player, enum PlayerCommandState command);
static gboolean __mmplayer_audio_stream_probe (GstPad *pad, GstBuffer *buffer, gpointer u_data);
-static void __mmplayer_post_delayed_eos( mm_player_t* player, int delay_in_ms );
-static void __mmplayer_cancel_delayed_eos( mm_player_t* player );
+static gboolean __mmplayer_eos_timer_cb(gpointer u_data);
static int __mmplayer_check_not_supported_codec(mm_player_t* player, gchar* mime);
-static gboolean __mmplayer_configure_audio_callback(mm_player_t* player);
-static void __mmplayer_set_antishock( mm_player_t* player, gboolean disable_by_force);
static gpointer __mmplayer_repeat_thread(gpointer data);
-int _mmplayer_get_track_count(MMHandleType hplayer, MMPlayerTrackType track_type, int *count);
-static gboolean _mmplayer_update_content_attrs(mm_player_t* player, enum content_attr_flag flag);
-static void __gst_set_async_state_change(mm_player_t* player, gboolean async);
-static int __mmplayer_set_pcm_extraction(mm_player_t* player);
-static gboolean __mmplayer_can_extract_pcm( mm_player_t* player );
-
-/*fadeout */
-static void __mmplayer_do_sound_fadedown(mm_player_t* player, unsigned int time);
-static void __mmplayer_undo_sound_fadedown(mm_player_t* player);
-
static void __mmplayer_add_new_caps(GstPad* pad, GParamSpec* unused, gpointer data);
static void __mmplayer_set_unlinked_mime_type(mm_player_t* player, GstCaps *caps);
@@ -709,7 +692,7 @@ _mmplayer_update_content_attrs(mm_player_t* player, enum content_attr_flag flag)
return TRUE;
}
-gint __mmplayer_get_stream_service_type( mm_player_t* player )
+static gint __mmplayer_get_stream_service_type( mm_player_t* player )
{
gint streaming_type = STREAMING_SERVICE_NONE;
@@ -765,7 +748,7 @@ gint __mmplayer_get_stream_service_type( mm_player_t* player )
/* this function sets the player state and also report
* it to applicaton by calling callback function
*/
-static gboolean
+gboolean
__mmplayer_set_state(mm_player_t* player, int state) // @
{
MMMessageParamType msg = {0, };
@@ -1019,7 +1002,7 @@ __mmplayer_get_state(mm_player_t* player) // @
return state;
}
-static void
+void
__gst_set_async_state_change(mm_player_t* player, gboolean async)
{
//debug_fenter();
@@ -1141,7 +1124,7 @@ static gpointer __mmplayer_repeat_thread(gpointer data)
return NULL;
}
-static void
+void
__mmplayer_handle_buffering_message ( mm_player_t* player )
{
MMPlayerStateType prev_state = MM_PLAYER_STATE_NONE;
@@ -2033,7 +2016,7 @@ __mmplayer_bus_sync_callback (GstBus * bus, GstMessage * message, gpointer data)
return GST_BUS_DROP;
}
-static void __mmplayer_do_sound_fadedown(mm_player_t* player, unsigned int time)
+void __mmplayer_do_sound_fadedown(mm_player_t* player, unsigned int time)
{
debug_fenter();
@@ -2049,7 +2032,7 @@ static void __mmplayer_do_sound_fadedown(mm_player_t* player, unsigned int time)
debug_fleave();
}
-static void __mmplayer_undo_sound_fadedown(mm_player_t* player)
+void __mmplayer_undo_sound_fadedown(mm_player_t* player)
{
debug_fenter();
@@ -3588,7 +3571,7 @@ _mmplayer_activate_section_repeat(MMHandleType hplayer, unsigned long start, uns
return MM_ERROR_NONE;
}
-static int
+int
__mmplayer_set_pcm_extraction(mm_player_t* player)
{
guint64 start_nsec = 0;
@@ -4000,7 +3983,7 @@ __mmplayer_warm_up_video_codec( mm_player_t* player, GstElementFactory *factory
}
/* it will return first created element */
-static gboolean
+gboolean
__mmplayer_try_to_plug(mm_player_t* player, GstPad *pad, const GstCaps *caps) // @
{
MMPlayerGstElement* mainbin = NULL;
@@ -4432,7 +4415,7 @@ DONE:
}
-static void __mmplayer_pipeline_complete(GstElement *decodebin, gpointer data) // @
+void __mmplayer_pipeline_complete(GstElement *decodebin, gpointer data) // @
{
mm_player_t* player = (mm_player_t*)data;
@@ -4465,7 +4448,7 @@ static void __mmplayer_pipeline_complete(GstElement *decodebin, gpointer data)
MMPLAYER_GENERATE_DOT_IF_ENABLED ( player, "pipeline-status-complete" );
}
-static gboolean __mmplayer_configure_audio_callback(mm_player_t* player)
+gboolean __mmplayer_configure_audio_callback(mm_player_t* player)
{
debug_fenter();
@@ -4559,7 +4542,7 @@ __mmplayer_release_factories(mm_player_t* player) // @
debug_fleave();
}
-static void
+void
__mmplayer_release_misc(mm_player_t* player)
{
int i;
@@ -5477,7 +5460,7 @@ _mmplayer_set_volume_tune(MMHandleType hplayer, MMPlayerVolumeType volume)
return error;
}
-static gboolean
+gboolean
__mmplayer_can_extract_pcm( mm_player_t* player )
{
MMHandleType attrs = 0;
@@ -5508,26 +5491,49 @@ __mmplayer_can_extract_pcm( mm_player_t* player )
return TRUE;
}
-static void
-__mmplayer_cancel_delayed_eos( mm_player_t* player )
+void
+__mmplayer_post_delayed_eos( mm_player_t* player, int delay_in_ms )
{
debug_fenter();
return_if_fail( player );
- if ( player->eos_timer )
+ /* cancel if existing */
+ __mmplayer_cancel_delayed_eos( player );
+
+
+ /* post now if delay is zero */
+ if ( delay_in_ms == 0 || player->is_sound_extraction)
{
- g_source_remove( player->eos_timer );
+ debug_log("eos delay is zero. posting EOS now\n");
+ MMPLAYER_POST_MSG( player, MM_MESSAGE_END_OF_STREAM, NULL );
+
+ if ( player->is_sound_extraction )
+ __mmplayer_cancel_delayed_eos(player);
+
+ return;
}
- player->eos_timer = 0;
+ /* init new timeout */
+ /* NOTE : consider give high priority to this timer */
- debug_fleave();
+ debug_log("posting EOS message after [%d] msec\n", delay_in_ms);
+ player->eos_timer = g_timeout_add( delay_in_ms,
+ __mmplayer_eos_timer_cb, player );
- return;
+
+ /* check timer is valid. if not, send EOS now */
+ if ( player->eos_timer == 0 )
+ {
+ debug_warning("creating timer for delayed EOS has failed. sending EOS now\n");
+ MMPLAYER_POST_MSG( player, MM_MESSAGE_END_OF_STREAM, NULL );
+ }
+
+ debug_fleave();
}
-gboolean
+
+static gboolean
__mmplayer_eos_timer_cb(gpointer u_data)
{
mm_player_t* player = NULL;
@@ -5549,7 +5555,7 @@ __mmplayer_eos_timer_cb(gpointer u_data)
return FALSE;
}
-static void __mmplayer_set_antishock( mm_player_t* player, gboolean disable_by_force)
+void __mmplayer_set_antishock( mm_player_t* player, gboolean disable_by_force)
{
gint antishock = FALSE;
MMHandleType attrs = 0;
diff --git a/src/mm_player_priv_internal.c b/src/mm_player_priv_internal.c
index c75b6a9..1d86491 100755
--- a/src/mm_player_priv_internal.c
+++ b/src/mm_player_priv_internal.c
@@ -267,6 +267,25 @@ __mmplayer_gst_set_state (mm_player_t* player, GstElement * element, GstState s
return MM_ERROR_NONE;
}
+void
+__mmplayer_cancel_delayed_eos( mm_player_t* player )
+{
+ debug_fenter();
+
+ return_if_fail( player );
+
+ if ( player->eos_timer )
+ {
+ g_source_remove( player->eos_timer );
+ }
+
+ player->eos_timer = 0;
+
+ debug_fleave();
+
+ return;
+}
+
gboolean
__mmplayer_check_subtitle( mm_player_t* player )
{
@@ -823,47 +842,6 @@ CODEC_NOT_FOUND:
return MM_ERROR_PLAYER_CODEC_NOT_FOUND;
}
-static void
-__mmplayer_post_delayed_eos( mm_player_t* player, int delay_in_ms )
-{
- debug_fenter();
-
- return_if_fail( player );
-
- /* cancel if existing */
- __mmplayer_cancel_delayed_eos( player );
-
-
- /* post now if delay is zero */
- if ( delay_in_ms == 0 || player->is_sound_extraction)
- {
- debug_log("eos delay is zero. posting EOS now\n");
- MMPLAYER_POST_MSG( player, MM_MESSAGE_END_OF_STREAM, NULL );
-
- if ( player->is_sound_extraction )
- __mmplayer_cancel_delayed_eos(player);
-
- return;
- }
-
- /* init new timeout */
- /* NOTE : consider give high priority to this timer */
-
- debug_log("posting EOS message after [%d] msec\n", delay_in_ms);
- player->eos_timer = g_timeout_add( delay_in_ms,
- __mmplayer_eos_timer_cb, player );
-
-
- /* check timer is valid. if not, send EOS now */
- if ( player->eos_timer == 0 )
- {
- debug_warning("creating timer for delayed EOS has failed. sending EOS now\n");
- MMPLAYER_POST_MSG( player, MM_MESSAGE_END_OF_STREAM, NULL );
- }
-
- debug_fleave();
-}
-
gboolean
__mmplayer_handle_gst_error ( mm_player_t* player, GstMessage * message, GError* error )
{