Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
be0f3d85
Commit
be0f3d85
authored
Dec 14, 2002
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* all: with mpeg4 video I changed the way that some initialisation data
are passed (more logical).
parent
d387c508
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
69 additions
and
35 deletions
+69
-35
modules/codec/ffmpeg/video.c
modules/codec/ffmpeg/video.c
+3
-1
modules/demux/mp4/mp4.c
modules/demux/mp4/mp4.c
+66
-34
No files found.
modules/codec/ffmpeg/video.c
View file @
be0f3d85
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* video.c: video decoder using ffmpeg library
* video.c: video decoder using ffmpeg library
*****************************************************************************
*****************************************************************************
* Copyright (C) 1999-2001 VideoLAN
* Copyright (C) 1999-2001 VideoLAN
* $Id: video.c,v 1.1
2 2002/12/10 10:22:0
4 fenrir Exp $
* $Id: video.c,v 1.1
3 2002/12/14 18:57:3
4 fenrir Exp $
*
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
* Gildas Bazin <gbazin@netcourrier.com>
* Gildas Bazin <gbazin@netcourrier.com>
...
@@ -362,11 +362,13 @@ int E_( InitThread_Video )( vdec_thread_t *p_vdec )
...
@@ -362,11 +362,13 @@ int E_( InitThread_Video )( vdec_thread_t *p_vdec )
switch
(
p_vdec
->
i_codec_id
)
switch
(
p_vdec
->
i_codec_id
)
{
{
case
(
CODEC_ID_MPEG4
):
case
(
CODEC_ID_MPEG4
):
#if 0
avcodec_decode_video( p_vdec->p_context, p_vdec->p_ff_pic,
avcodec_decode_video( p_vdec->p_context, p_vdec->p_ff_pic,
&b_gotpicture,
&b_gotpicture,
(void *)&p_vdec->p_format[1],
(void *)&p_vdec->p_format[1],
p_vdec->p_format->biSize
p_vdec->p_format->biSize
- sizeof(BITMAPINFOHEADER) );
- sizeof(BITMAPINFOHEADER) );
#endif
break
;
break
;
default:
default:
if
(
p_vdec
->
p_fifo
->
i_fourcc
==
FOURCC_MP4S
||
if
(
p_vdec
->
p_fifo
->
i_fourcc
==
FOURCC_MP4S
||
...
...
modules/demux/mp4/mp4.c
View file @
be0f3d85
...
@@ -2,14 +2,14 @@
...
@@ -2,14 +2,14 @@
* mp4.c : MP4 file input module for vlc
* mp4.c : MP4 file input module for vlc
*****************************************************************************
*****************************************************************************
* Copyright (C) 2001 VideoLAN
* Copyright (C) 2001 VideoLAN
* $Id: mp4.c,v 1.
9 2002/12/06 16:34:06 sam
Exp $
* $Id: mp4.c,v 1.
10 2002/12/14 18:57:34 fenrir
Exp $
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
*
* This program is free software; you can redistribute it and/or modify
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
* (at your option) any later version.
*
*
* This program is distributed in the hope that it will be useful,
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
...
@@ -56,7 +56,7 @@ vlc_module_begin();
...
@@ -56,7 +56,7 @@ vlc_module_begin();
vlc_module_end
();
vlc_module_end
();
/*****************************************************************************
/*****************************************************************************
* Declaration of local function
* Declaration of local function
*****************************************************************************/
*****************************************************************************/
static
int
MP4_TrackSynchro
(
input_thread_t
*
p_input
,
track_data_mp4_t
*
p_track
);
static
int
MP4_TrackSynchro
(
input_thread_t
*
p_input
,
track_data_mp4_t
*
p_track
);
...
@@ -87,12 +87,12 @@ static int MP4_DecodeSample();
...
@@ -87,12 +87,12 @@ static int MP4_DecodeSample();
* MP4Init: check file and initializes MP4 structures
* MP4Init: check file and initializes MP4 structures
*****************************************************************************/
*****************************************************************************/
static
int
MP4Init
(
vlc_object_t
*
p_this
)
static
int
MP4Init
(
vlc_object_t
*
p_this
)
{
{
input_thread_t
*
p_input
=
(
input_thread_t
*
)
p_this
;
input_thread_t
*
p_input
=
(
input_thread_t
*
)
p_this
;
uint8_t
*
p_peek
;
uint8_t
*
p_peek
;
demux_sys_t
*
p_demux
;
demux_sys_t
*
p_demux
;
MP4_Box_t
*
p_ftyp
;
MP4_Box_t
*
p_ftyp
;
...
@@ -105,8 +105,8 @@ static int MP4Init( vlc_object_t * p_this )
...
@@ -105,8 +105,8 @@ static int MP4Init( vlc_object_t * p_this )
{
{
msg_Warn
(
p_input
,
"MP4 plugin discarded (unseekable)"
);
msg_Warn
(
p_input
,
"MP4 plugin discarded (unseekable)"
);
return
(
-
1
);
return
(
-
1
);
}
}
/* Initialize access plug-in structures. */
/* Initialize access plug-in structures. */
if
(
p_input
->
i_mtu
==
0
)
if
(
p_input
->
i_mtu
==
0
)
{
{
...
@@ -123,17 +123,17 @@ static int MP4Init( vlc_object_t * p_this )
...
@@ -123,17 +123,17 @@ static int MP4Init( vlc_object_t * p_this )
return
(
-
1
);
return
(
-
1
);
}
}
switch
(
VLC_FOURCC
(
p_peek
[
4
],
p_peek
[
5
],
p_peek
[
6
],
p_peek
[
7
]
)
)
switch
(
VLC_FOURCC
(
p_peek
[
4
],
p_peek
[
5
],
p_peek
[
6
],
p_peek
[
7
]
)
)
{
{
case
(
FOURCC_ftyp
):
case
(
FOURCC_ftyp
):
case
(
FOURCC_moov
):
case
(
FOURCC_moov
):
case
(
FOURCC_moof
):
case
(
FOURCC_moof
):
case
(
FOURCC_mdat
):
case
(
FOURCC_mdat
):
case
(
FOURCC_udta
):
case
(
FOURCC_udta
):
case
(
FOURCC_free
):
case
(
FOURCC_free
):
case
(
FOURCC_skip
):
case
(
FOURCC_skip
):
case
(
FOURCC_wide
):
case
(
FOURCC_wide
):
break
;
break
;
default:
default:
msg_Warn
(
p_input
,
"MP4 plugin discarded (not a valid file)"
);
msg_Warn
(
p_input
,
"MP4 plugin discarded (not a valid file)"
);
...
@@ -141,7 +141,7 @@ static int MP4Init( vlc_object_t * p_this )
...
@@ -141,7 +141,7 @@ static int MP4Init( vlc_object_t * p_this )
}
}
/* create our structure that will contains all data */
/* create our structure that will contains all data */
if
(
!
(
p_input
->
p_demux_data
=
if
(
!
(
p_input
->
p_demux_data
=
p_demux
=
malloc
(
sizeof
(
demux_sys_t
)
)
)
)
p_demux
=
malloc
(
sizeof
(
demux_sys_t
)
)
)
)
{
{
msg_Err
(
p_input
,
"out of memory"
);
msg_Err
(
p_input
,
"out of memory"
);
...
@@ -149,7 +149,7 @@ static int MP4Init( vlc_object_t * p_this )
...
@@ -149,7 +149,7 @@ static int MP4Init( vlc_object_t * p_this )
}
}
memset
(
p_demux
,
0
,
sizeof
(
demux_sys_t
)
);
memset
(
p_demux
,
0
,
sizeof
(
demux_sys_t
)
);
p_input
->
p_demux_data
=
p_demux
;
p_input
->
p_demux_data
=
p_demux
;
/* Now load all boxes ( except raw data ) */
/* Now load all boxes ( except raw data ) */
if
(
!
MP4_BoxGetRoot
(
p_input
,
&
p_demux
->
box_root
)
)
if
(
!
MP4_BoxGetRoot
(
p_input
,
&
p_demux
->
box_root
)
)
...
@@ -205,7 +205,7 @@ static int MP4Init( vlc_object_t * p_this )
...
@@ -205,7 +205,7 @@ static int MP4Init( vlc_object_t * p_this )
p_demux
->
i_timescale
=
p_mvhd
->
data
.
p_mvhd
->
i_timescale
;
p_demux
->
i_timescale
=
p_mvhd
->
data
.
p_mvhd
->
i_timescale
;
p_demux
->
i_duration
=
p_mvhd
->
data
.
p_mvhd
->
i_duration
;
p_demux
->
i_duration
=
p_mvhd
->
data
.
p_mvhd
->
i_duration
;
}
}
if
(
!
(
p_demux
->
i_tracks
=
if
(
!
(
p_demux
->
i_tracks
=
MP4_BoxCount
(
&
p_demux
->
box_root
,
"/moov/trak"
)
)
)
MP4_BoxCount
(
&
p_demux
->
box_root
,
"/moov/trak"
)
)
)
{
{
...
@@ -241,7 +241,7 @@ static int MP4Init( vlc_object_t * p_this )
...
@@ -241,7 +241,7 @@ static int MP4Init( vlc_object_t * p_this )
psz_cat
=
"unknown"
;
psz_cat
=
"unknown"
;
break
;
break
;
}
}
msg_Dbg
(
p_input
,
"adding track[Id 0x%x] %s (%s) language %c%c%c"
,
msg_Dbg
(
p_input
,
"adding track[Id 0x%x] %s (%s) language %c%c%c"
,
p_demux
->
track
[
i
].
i_track_ID
,
p_demux
->
track
[
i
].
i_track_ID
,
psz_cat
,
psz_cat
,
...
@@ -256,7 +256,7 @@ static int MP4Init( vlc_object_t * p_this )
...
@@ -256,7 +256,7 @@ static int MP4Init( vlc_object_t * p_this )
}
}
}
}
/* create one program */
/* create one program */
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
if
(
input_InitStream
(
p_input
,
0
)
==
-
1
)
if
(
input_InitStream
(
p_input
,
0
)
==
-
1
)
...
@@ -277,8 +277,8 @@ static int MP4Init( vlc_object_t * p_this )
...
@@ -277,8 +277,8 @@ static int MP4Init( vlc_object_t * p_this )
/* XXX beurk and beurk, see MP4Demux and MP4Seek */
/* XXX beurk and beurk, see MP4Demux and MP4Seek */
if
(
p_demux
->
i_duration
/
p_demux
->
i_timescale
>
0
)
if
(
p_demux
->
i_duration
/
p_demux
->
i_timescale
>
0
)
{
{
p_input
->
stream
.
i_mux_rate
=
p_input
->
stream
.
i_mux_rate
=
p_input
->
stream
.
p_selected_area
->
i_size
/
50
/
p_input
->
stream
.
p_selected_area
->
i_size
/
50
/
(
p_demux
->
i_duration
/
p_demux
->
i_timescale
);
(
p_demux
->
i_duration
/
p_demux
->
i_timescale
);
}
}
else
else
...
@@ -286,8 +286,8 @@ static int MP4Init( vlc_object_t * p_this )
...
@@ -286,8 +286,8 @@ static int MP4Init( vlc_object_t * p_this )
p_input
->
stream
.
i_mux_rate
=
0
;
p_input
->
stream
.
i_mux_rate
=
0
;
}
}
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
for
(
i
=
0
;
i
<
p_demux
->
i_tracks
;
i
++
)
for
(
i
=
0
;
i
<
p_demux
->
i_tracks
;
i
++
)
{
{
/* start decoder for this track if enable by default*/
/* start decoder for this track if enable by default*/
...
@@ -300,13 +300,13 @@ static int MP4Init( vlc_object_t * p_this )
...
@@ -300,13 +300,13 @@ static int MP4Init( vlc_object_t * p_this )
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
p_input
->
stream
.
p_selected_program
->
b_is_ok
=
1
;
p_input
->
stream
.
p_selected_program
->
b_is_ok
=
1
;
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
return
(
0
);
return
(
0
);
}
}
/*****************************************************************************
/*****************************************************************************
* MP4Demux: read packet and send them to decoders
* MP4Demux: read packet and send them to decoders
*****************************************************************************
*****************************************************************************
* TODO check for newly selected track (ie audio upt to now )
* TODO check for newly selected track (ie audio upt to now )
*****************************************************************************/
*****************************************************************************/
...
@@ -906,19 +906,20 @@ static void MP4_StartDecoder( input_thread_t *p_input,
...
@@ -906,19 +906,20 @@ static void MP4_StartDecoder( input_thread_t *p_input,
unsigned
int
i_decoder_specific_info_len
;
unsigned
int
i_decoder_specific_info_len
;
uint8_t
*
p_decoder_specific_info
;
uint8_t
*
p_decoder_specific_info
;
pes_packet_t
*
p_pes_init
;
uint8_t
*
p_init
;
uint8_t
*
p_init
;
BITMAPINFOHEADER
*
p_bih
;
BITMAPINFOHEADER
*
p_bih
;
WAVEFORMATEX
*
p_wf
;
WAVEFORMATEX
*
p_wf
;
MP4_Box_t
*
p_esds
;
MP4_Box_t
*
p_esds
;
if
(
(
!
p_demux_track
->
b_ok
)
||
(
p_demux_track
->
i_cat
==
UNKNOWN_ES
)
)
if
(
(
!
p_demux_track
->
b_ok
)
||
(
p_demux_track
->
i_cat
==
UNKNOWN_ES
)
)
{
{
return
;
return
;
}
}
msg_Dbg
(
p_input
,
"Starting decoder for track[Id 0x%x]"
,
msg_Dbg
(
p_input
,
"Starting decoder for track[Id 0x%x]"
,
p_demux_track
->
i_track_ID
);
p_demux_track
->
i_track_ID
);
...
@@ -956,7 +957,7 @@ static void MP4_StartDecoder( input_thread_t *p_input,
...
@@ -956,7 +957,7 @@ static void MP4_StartDecoder( input_thread_t *p_input,
p_demux_track
->
p_es
->
psz_desc
[
i
]
=
p_demux_track
->
i_language
[
i
];
p_demux_track
->
p_es
->
psz_desc
[
i
]
=
p_demux_track
->
i_language
[
i
];
}
}
p_demux_track
->
p_es
->
psz_desc
[
3
]
=
'\0'
;
p_demux_track
->
p_es
->
psz_desc
[
3
]
=
'\0'
;
p_demux_track
->
p_es
->
i_stream_id
=
p_demux_track
->
i_track_ID
;
p_demux_track
->
p_es
->
i_stream_id
=
p_demux_track
->
i_track_ID
;
/* It's a little ugly but .. there are special cases */
/* It's a little ugly but .. there are special cases */
...
@@ -970,11 +971,12 @@ static void MP4_StartDecoder( input_thread_t *p_input,
...
@@ -970,11 +971,12 @@ static void MP4_StartDecoder( input_thread_t *p_input,
p_demux_track
->
p_es
->
i_fourcc
=
p_sample
->
i_type
;
p_demux_track
->
p_es
->
i_fourcc
=
p_sample
->
i_type
;
break
;
break
;
}
}
p_demux_track
->
p_es
->
i_cat
=
p_demux_track
->
i_cat
;
p_demux_track
->
p_es
->
i_cat
=
p_demux_track
->
i_cat
;
i_decoder_specific_info_len
=
0
;
i_decoder_specific_info_len
=
0
;
p_decoder_specific_info
=
NULL
;
p_decoder_specific_info
=
NULL
;
p_pes_init
=
NULL
;
/* now see if esds is present and if so create a data packet
/* now see if esds is present and if so create a data packet
with decoder_specific_info */
with decoder_specific_info */
...
@@ -1045,9 +1047,9 @@ static void MP4_StartDecoder( input_thread_t *p_input,
...
@@ -1045,9 +1047,9 @@ static void MP4_StartDecoder( input_thread_t *p_input,
--> bitmapinfoheader_t : width and height
--> bitmapinfoheader_t : width and height
--> waveformatex_t : channels, samplerate, bitspersample
--> waveformatex_t : channels, samplerate, bitspersample
and at the end I add p_decoder_specific_info
and at the end I add p_decoder_specific_info
TODO set more values
TODO set more values
*/
*/
switch
(
p_demux_track
->
i_cat
)
switch
(
p_demux_track
->
i_cat
)
...
@@ -1080,12 +1082,37 @@ static void MP4_StartDecoder( input_thread_t *p_input,
...
@@ -1080,12 +1082,37 @@ static void MP4_StartDecoder( input_thread_t *p_input,
// fall on display size
// fall on display size
p_bih
->
biHeight
=
p_demux_track
->
i_height
;
p_bih
->
biHeight
=
p_demux_track
->
i_height
;
}
}
if
(
i_decoder_specific_info_len
)
if
(
i_decoder_specific_info_len
)
{
{
data_packet_t
*
p_data
;
memcpy
(
p_init
+
sizeof
(
BITMAPINFOHEADER
),
memcpy
(
p_init
+
sizeof
(
BITMAPINFOHEADER
),
p_decoder_specific_info
,
p_decoder_specific_info
,
i_decoder_specific_info_len
);
i_decoder_specific_info_len
);
/* If stream is mpeg4 video we send specific_info,
as it's needed to decode it (vol) */
switch
(
p_demux_track
->
p_es
->
i_fourcc
)
{
case
VLC_FOURCC
(
'm'
,
'p'
,
'4'
,
'v'
):
case
VLC_FOURCC
(
'D'
,
'I'
,
'V'
,
'X'
):
case
VLC_FOURCC
(
'd'
,
'i'
,
'v'
,
'x'
):
p_pes_init
=
input_NewPES
(
p_input
->
p_method_data
);
p_data
=
input_NewPacket
(
p_input
->
p_method_data
,
i_decoder_specific_info_len
);
memcpy
(
p_data
->
p_payload_start
,
p_decoder_specific_info
,
i_decoder_specific_info_len
);
p_pes_init
->
i_dts
=
p_pes_init
->
i_pts
=
0
;
p_pes_init
->
p_first
=
p_pes_init
->
p_last
=
p_data
;
p_pes_init
->
i_nb_data
=
1
;
p_pes_init
->
i_pes_size
=
i_decoder_specific_info_len
;
break
;
default:
break
;
}
}
}
break
;
break
;
...
@@ -1105,10 +1132,11 @@ static void MP4_StartDecoder( input_thread_t *p_input,
...
@@ -1105,10 +1132,11 @@ static void MP4_StartDecoder( input_thread_t *p_input,
if
(
i_decoder_specific_info_len
)
if
(
i_decoder_specific_info_len
)
{
{
memcpy
(
p_init
+
sizeof
(
WAVEFORMATEX
),
memcpy
(
p_init
+
sizeof
(
WAVEFORMATEX
),
p_decoder_specific_info
,
p_decoder_specific_info
,
i_decoder_specific_info_len
);
i_decoder_specific_info_len
);
}
}
break
;
break
;
default:
default:
...
@@ -1121,6 +1149,10 @@ static void MP4_StartDecoder( input_thread_t *p_input,
...
@@ -1121,6 +1149,10 @@ static void MP4_StartDecoder( input_thread_t *p_input,
input_SelectES
(
p_input
,
p_demux_track
->
p_es
);
input_SelectES
(
p_input
,
p_demux_track
->
p_es
);
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
if
(
p_pes_init
!=
NULL
)
{
input_DecodePES
(
p_demux_track
->
p_es
->
p_decoder_fifo
,
p_pes_init
);
}
p_demux_track
->
b_ok
=
1
;
p_demux_track
->
b_ok
=
1
;
p_demux_track
->
b_selected
=
1
;
p_demux_track
->
b_selected
=
1
;
}
}
...
...
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