Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-1.1
Commits
b04e87d0
Commit
b04e87d0
authored
Apr 02, 2004
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* m4v: demux -> demux2.
parent
0b4ff2a3
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
53 additions
and
51 deletions
+53
-51
modules/demux/demux2.c
modules/demux/demux2.c
+2
-0
modules/demux/mpeg/m4v.c
modules/demux/mpeg/m4v.c
+51
-51
No files found.
modules/demux/demux2.c
View file @
b04e87d0
...
...
@@ -60,6 +60,8 @@ vlc_module_begin();
add_shortcut
(
"flac"
);
add_shortcut
(
"m3u"
);
add_shortcut
(
"playlist"
);
add_shortcut
(
"m4v"
);
add_shortcut
(
"mp4v"
);
vlc_module_end
();
/*****************************************************************************
...
...
modules/demux/mpeg/m4v.c
View file @
b04e87d0
/*****************************************************************************
* m4v.c : MPEG-4 Video demuxer
*****************************************************************************
* Copyright (C) 2002-200
3
VideoLAN
* $Id
: m4v.c,v 1.12 2004/03/03 20:39:52 gbazin Exp
$
* Copyright (C) 2002-200
4
VideoLAN
* $Id$
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
...
...
@@ -33,12 +33,12 @@
/*****************************************************************************
* Module descriptor
*****************************************************************************/
static
int
Open
(
vlc_object_t
*
);
static
void
Close
(
vlc_object_t
*
);
static
int
Open
(
vlc_object_t
*
);
static
void
Close
(
vlc_object_t
*
);
vlc_module_begin
();
set_description
(
_
(
"MPEG-4 video demuxer"
)
);
set_capability
(
"demux"
,
0
);
set_capability
(
"demux
2
"
,
0
);
set_callbacks
(
Open
,
Close
);
add_shortcut
(
"m4v"
);
add_shortcut
(
"mp4v"
);
...
...
@@ -47,8 +47,6 @@ vlc_module_end();
/*****************************************************************************
* Local prototypes
*****************************************************************************/
static
int
Demux
(
input_thread_t
*
);
struct
demux_sys_t
{
mtime_t
i_dts
;
...
...
@@ -57,6 +55,9 @@ struct demux_sys_t
decoder_t
*
p_packetizer
;
};
static
int
Demux
(
demux_t
*
);
static
int
Control
(
demux_t
*
,
int
,
va_list
);
#define M4V_PACKET_SIZE 4096
/*****************************************************************************
...
...
@@ -64,23 +65,22 @@ struct demux_sys_t
*****************************************************************************/
static
int
Open
(
vlc_object_t
*
p_this
)
{
input_thread_t
*
p_input
=
(
input_thread_t
*
)
p_this
;
demux_sys_t
*
p_sys
;
vlc_bool_t
b_forced
=
VLC_FALSE
;
demux_t
*
p_demux
=
(
demux_t
*
)
p_this
;
demux_sys_t
*
p_sys
;
vlc_bool_t
b_forced
=
VLC_FALSE
;
uint8_t
*
p_peek
;
uint8_t
*
p_peek
;
es_format_t
fmt
;
es_format_t
fmt
;
if
(
stream_Peek
(
p_
input
->
s
,
&
p_peek
,
4
)
<
4
)
if
(
stream_Peek
(
p_
demux
->
s
,
&
p_peek
,
4
)
<
4
)
{
msg_Err
(
p_
input
,
"cannot peek"
);
msg_Err
(
p_
demux
,
"cannot peek"
);
return
VLC_EGENERIC
;
}
if
(
p_input
->
psz_demux
&&
(
!
strncmp
(
p_input
->
psz_demux
,
"mp4v"
,
4
)
||
!
strncmp
(
p_input
->
psz_demux
,
"m4v"
,
4
)
)
)
if
(
!
strncmp
(
p_demux
->
psz_demux
,
"mp4v"
,
4
)
||
!
strncmp
(
p_demux
->
psz_demux
,
"m4v"
,
4
)
)
{
b_forced
=
VLC_TRUE
;
}
...
...
@@ -89,35 +89,23 @@ static int Open( vlc_object_t * p_this )
{
if
(
!
b_forced
)
{
msg_Warn
(
p_
input
,
"m4v module discarded (no startcode)"
);
msg_Warn
(
p_
demux
,
"m4v module discarded (no startcode)"
);
return
VLC_EGENERIC
;
}
msg_Err
(
p_
input
,
"this doesn't look like an MPEG-4 ES stream, continuing"
);
msg_Err
(
p_
demux
,
"this doesn't look like an MPEG-4 ES stream, continuing"
);
}
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
if
(
input_InitStream
(
p_input
,
0
)
==
-
1
)
{
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
msg_Err
(
p_input
,
"cannot init stream"
);
return
VLC_EGENERIC
;
}
p_input
->
stream
.
i_mux_rate
=
0
/
50
;
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
p_input
->
pf_demux
=
Demux
;
p_input
->
pf_rewind
=
NULL
;
p_input
->
pf_demux_control
=
demux_vaControlDefault
;
p_input
->
p_demux_data
=
p_sys
=
malloc
(
sizeof
(
demux_sys_t
)
);
p_sys
->
p_es
=
NULL
;
p_sys
->
i_dts
=
0
;
p_demux
->
pf_demux
=
Demux
;
p_demux
->
pf_control
=
Control
;
p_demux
->
p_sys
=
p_sys
=
malloc
(
sizeof
(
demux_sys_t
)
);
p_sys
->
p_es
=
NULL
;
p_sys
->
i_dts
=
0
;
/*
* Load the mpegvideo packetizer
*/
p_sys
->
p_packetizer
=
vlc_object_create
(
p_
input
,
VLC_OBJECT_PACKETIZER
);
p_sys
->
p_packetizer
=
vlc_object_create
(
p_
demux
,
VLC_OBJECT_PACKETIZER
);
p_sys
->
p_packetizer
->
pf_decode_audio
=
NULL
;
p_sys
->
p_packetizer
->
pf_decode_video
=
NULL
;
p_sys
->
p_packetizer
->
pf_decode_sub
=
NULL
;
...
...
@@ -131,7 +119,7 @@ static int Open( vlc_object_t * p_this )
if
(
p_sys
->
p_packetizer
->
p_module
==
NULL
)
{
vlc_object_destroy
(
p_sys
->
p_packetizer
);
msg_Err
(
p_
input
,
"cannot find mp4v packetizer"
);
msg_Err
(
p_
demux
,
"cannot find mp4v packetizer"
);
free
(
p_sys
);
return
VLC_EGENERIC
;
}
...
...
@@ -140,7 +128,7 @@ static int Open( vlc_object_t * p_this )
* create the output
*/
es_format_Init
(
&
fmt
,
VIDEO_ES
,
VLC_FOURCC
(
'm'
,
'p'
,
'4'
,
'v'
)
);
p_sys
->
p_es
=
es_out_Add
(
p_
input
->
p_es_
out
,
&
fmt
);
p_sys
->
p_es
=
es_out_Add
(
p_
demux
->
out
,
&
fmt
);
return
VLC_SUCCESS
;
}
...
...
@@ -150,8 +138,8 @@ static int Open( vlc_object_t * p_this )
*****************************************************************************/
static
void
Close
(
vlc_object_t
*
p_this
)
{
input_thread_t
*
p_input
=
(
input_thread
_t
*
)
p_this
;
demux_sys_t
*
p_sys
=
p_input
->
p_demux_data
;
demux_t
*
p_demux
=
(
demux
_t
*
)
p_this
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
module_Unneed
(
p_sys
->
p_packetizer
,
p_sys
->
p_packetizer
->
p_module
);
vlc_object_destroy
(
p_sys
->
p_packetizer
);
...
...
@@ -164,12 +152,12 @@ static void Close( vlc_object_t * p_this )
*****************************************************************************
* Returns -1 in case of error, 0 in case of EOF, 1 otherwise
*****************************************************************************/
static
int
Demux
(
input_thread_t
*
p_input
)
static
int
Demux
(
demux_t
*
p_demux
)
{
demux_sys_t
*
p_sys
=
p_input
->
p_demux_data
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
block_t
*
p_block_in
,
*
p_block_out
;
if
(
(
p_block_in
=
stream_Block
(
p_
input
->
s
,
M4V_PACKET_SIZE
)
)
==
NULL
)
if
(
(
p_block_in
=
stream_Block
(
p_
demux
->
s
,
M4V_PACKET_SIZE
)
)
==
NULL
)
{
return
0
;
}
...
...
@@ -184,16 +172,13 @@ static int Demux( input_thread_t * p_input )
{
block_t
*
p_next
=
p_block_out
->
p_next
;
input_ClockManageRef
(
p_input
,
p_input
->
stream
.
p_selected_program
,
p_sys
->
i_dts
);
p_block_out
->
i_dts
=
input_ClockGetTS
(
p_input
,
p_input
->
stream
.
p_selected_program
,
p_sys
->
i_dts
);
es_out_Control
(
p_demux
->
out
,
ES_OUT_SET_PCR
,
p_sys
->
i_dts
);
p_block_out
->
i_dts
=
p_sys
->
i_dts
;
p_block_out
->
i_pts
=
0
;
p_block_out
->
p_next
=
NULL
;
es_out_Send
(
p_
input
->
p_es_
out
,
p_sys
->
p_es
,
p_block_out
);
es_out_Send
(
p_
demux
->
out
,
p_sys
->
p_es
,
p_block_out
);
p_block_out
=
p_next
;
...
...
@@ -205,3 +190,18 @@ static int Demux( input_thread_t * p_input )
return
1
;
}
/*****************************************************************************
* Control:
*****************************************************************************/
static
int
Control
(
demux_t
*
p_demux
,
int
i_query
,
va_list
args
)
{
/* demux_sys_t *p_sys = p_demux->p_sys; */
/* FIXME calculate the bitrate */
if
(
i_query
==
DEMUX_SET_TIME
)
return
VLC_EGENERIC
;
else
return
demux2_vaControlHelper
(
p_demux
->
s
,
0
,
-
1
,
0
,
1
,
i_query
,
args
);
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment