Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
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-2-2
Commits
9a1b736f
Commit
9a1b736f
authored
Mar 11, 2003
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* ffmpeg support mace 3/6 audio codec. (quicktime)
parent
ebc06c09
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
45 additions
and
35 deletions
+45
-35
modules/codec/ffmpeg/ffmpeg.c
modules/codec/ffmpeg/ffmpeg.c
+45
-35
No files found.
modules/codec/ffmpeg/ffmpeg.c
View file @
9a1b736f
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* ffmpeg.c: video decoder using ffmpeg library
* ffmpeg.c: video decoder using ffmpeg library
*****************************************************************************
*****************************************************************************
* Copyright (C) 1999-2001 VideoLAN
* Copyright (C) 1999-2001 VideoLAN
* $Id: ffmpeg.c,v 1.2
5 2003/02/20 01:52:46 sigmunau
Exp $
* $Id: ffmpeg.c,v 1.2
6 2003/03/11 05:52:37 fenrir
Exp $
*
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
*
...
@@ -10,7 +10,7 @@
...
@@ -10,7 +10,7 @@
* 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
...
@@ -79,7 +79,7 @@ static int ffmpeg_GetFfmpegCodec( vlc_fourcc_t, int *, int *, char ** );
...
@@ -79,7 +79,7 @@ static int ffmpeg_GetFfmpegCodec( vlc_fourcc_t, int *, int *, char ** );
"Quality of post processing\n"\
"Quality of post processing\n"\
"Valid range is 0 to 6\n" \
"Valid range is 0 to 6\n" \
"(Overridden by others setting)"
"(Overridden by others setting)"
#define POSTPROCESSING_AQ_LONGTEXT \
#define POSTPROCESSING_AQ_LONGTEXT \
"Post processing quality is selected upon time left " \
"Post processing quality is selected upon time left " \
"but no more than requested quality\n" \
"but no more than requested quality\n" \
...
@@ -99,34 +99,34 @@ vlc_module_begin();
...
@@ -99,34 +99,34 @@ vlc_module_begin();
add_category_hint
(
N_
(
"ffmpeg"
),
NULL
,
VLC_FALSE
);
add_category_hint
(
N_
(
"ffmpeg"
),
NULL
,
VLC_FALSE
);
#if LIBAVCODEC_BUILD >= 4615
#if LIBAVCODEC_BUILD >= 4615
add_bool
(
"ffmpeg-dr"
,
0
,
NULL
,
add_bool
(
"ffmpeg-dr"
,
0
,
NULL
,
"direct rendering"
,
"direct rendering"
,
"direct rendering"
,
VLC_TRUE
);
"direct rendering"
,
VLC_TRUE
);
#endif
#endif
#if LIBAVCODEC_BUILD >= 4611
#if LIBAVCODEC_BUILD >= 4611
add_integer
(
"ffmpeg-error-resilience"
,
-
1
,
NULL
,
add_integer
(
"ffmpeg-error-resilience"
,
-
1
,
NULL
,
"error resilience"
,
ERROR_RESILIENCE_LONGTEXT
,
VLC_TRUE
);
"error resilience"
,
ERROR_RESILIENCE_LONGTEXT
,
VLC_TRUE
);
add_integer
(
"ffmpeg-workaround-bugs"
,
1
,
NULL
,
add_integer
(
"ffmpeg-workaround-bugs"
,
1
,
NULL
,
"workaround bugs"
,
WORKAROUND_BUGS_LONGTEXT
,
VLC_FALSE
);
"workaround bugs"
,
WORKAROUND_BUGS_LONGTEXT
,
VLC_FALSE
);
#endif
#endif
add_bool
(
"ffmpeg-hurry-up"
,
0
,
NULL
,
"hurry up"
,
HURRY_UP_LONGTEXT
,
VLC_FALSE
);
add_bool
(
"ffmpeg-hurry-up"
,
0
,
NULL
,
"hurry up"
,
HURRY_UP_LONGTEXT
,
VLC_FALSE
);
add_category_hint
(
N_
(
"Post processing"
),
NULL
,
VLC_FALSE
);
add_category_hint
(
N_
(
"Post processing"
),
NULL
,
VLC_FALSE
);
add_module
(
"ffmpeg-pp"
,
"postprocessing"
,
NULL
,
NULL
,
add_module
(
"ffmpeg-pp"
,
"postprocessing"
,
NULL
,
NULL
,
N_
(
"ffmpeg postprocessing module"
),
NULL
,
VLC_FALSE
);
N_
(
"ffmpeg postprocessing module"
),
NULL
,
VLC_FALSE
);
add_integer
(
"ffmpeg-pp-q"
,
0
,
NULL
,
add_integer
(
"ffmpeg-pp-q"
,
0
,
NULL
,
"post processing quality"
,
POSTPROCESSING_Q_LONGTEXT
,
VLC_FALSE
);
"post processing quality"
,
POSTPROCESSING_Q_LONGTEXT
,
VLC_FALSE
);
add_bool
(
"ffmpeg-pp-auto"
,
0
,
NULL
,
add_bool
(
"ffmpeg-pp-auto"
,
0
,
NULL
,
"auto-level Post processing quality"
,
POSTPROCESSING_AQ_LONGTEXT
,
VLC_FALSE
);
"auto-level Post processing quality"
,
POSTPROCESSING_AQ_LONGTEXT
,
VLC_FALSE
);
add_bool
(
"ffmpeg-db-yv"
,
0
,
NULL
,
add_bool
(
"ffmpeg-db-yv"
,
0
,
NULL
,
"force vertical luminance deblocking"
,
"force vertical luminance deblocking"
,
"force vertical luminance deblocking (override other settings)"
,
VLC_TRUE
);
"force vertical luminance deblocking (override other settings)"
,
VLC_TRUE
);
add_bool
(
"ffmpeg-db-yh"
,
0
,
NULL
,
add_bool
(
"ffmpeg-db-yh"
,
0
,
NULL
,
"force horizontal luminance deblocking"
,
"force horizontal luminance deblocking"
,
"force horizontal luminance deblocking (override other settings)"
,
VLC_TRUE
);
"force horizontal luminance deblocking (override other settings)"
,
VLC_TRUE
);
add_bool
(
"ffmpeg-db-cv"
,
0
,
NULL
,
add_bool
(
"ffmpeg-db-cv"
,
0
,
NULL
,
"force vertical chrominance deblocking"
,
"force vertical chrominance deblocking"
,
"force vertical chrominance deblocking (override other settings)"
,
VLC_TRUE
);
"force vertical chrominance deblocking (override other settings)"
,
VLC_TRUE
);
add_bool
(
"ffmpeg-db-ch"
,
0
,
NULL
,
add_bool
(
"ffmpeg-db-ch"
,
0
,
NULL
,
"force horizontal chrominance deblocking"
,
"force horizontal chrominance deblocking"
,
"force horizontal chrominance deblocking (override other settings) "
,
VLC_TRUE
);
"force horizontal chrominance deblocking (override other settings) "
,
VLC_TRUE
);
add_bool
(
"ffmpeg-dr-y"
,
0
,
NULL
,
add_bool
(
"ffmpeg-dr-y"
,
0
,
NULL
,
...
@@ -135,7 +135,7 @@ vlc_module_begin();
...
@@ -135,7 +135,7 @@ vlc_module_begin();
add_bool
(
"ffmpeg-dr-c"
,
0
,
NULL
,
add_bool
(
"ffmpeg-dr-c"
,
0
,
NULL
,
"force chrominance deringing"
,
"force chrominance deringing"
,
"force chrominance deringing (override other settings)"
,
VLC_TRUE
);
"force chrominance deringing (override other settings)"
,
VLC_TRUE
);
set_description
(
_
(
"ffmpeg audio/video decoder((MS)MPEG4,SVQ1,H263,WMV,WMA)"
)
);
set_description
(
_
(
"ffmpeg audio/video decoder((MS)MPEG4,SVQ1,H263,WMV,WMA)"
)
);
set_capability
(
"decoder"
,
70
);
set_capability
(
"decoder"
,
70
);
set_callbacks
(
OpenDecoder
,
NULL
);
set_callbacks
(
OpenDecoder
,
NULL
);
...
@@ -144,7 +144,7 @@ vlc_module_end();
...
@@ -144,7 +144,7 @@ vlc_module_end();
/*****************************************************************************
/*****************************************************************************
* OpenDecoder: probe the decoder and return score
* OpenDecoder: probe the decoder and return score
*****************************************************************************
*****************************************************************************
* Tries to launch a decoder and return score so that the interface is able
* Tries to launch a decoder and return score so that the interface is able
* to chose.
* to chose.
*****************************************************************************/
*****************************************************************************/
static
int
OpenDecoder
(
vlc_object_t
*
p_this
)
static
int
OpenDecoder
(
vlc_object_t
*
p_this
)
...
@@ -193,7 +193,7 @@ static int RunDecoder( decoder_fifo_t *p_fifo )
...
@@ -193,7 +193,7 @@ static int RunDecoder( decoder_fifo_t *p_fifo )
DecoderError
(
p_fifo
);
DecoderError
(
p_fifo
);
return
(
-
1
);
return
(
-
1
);
}
}
while
(
(
!
p_decoder
->
p_fifo
->
b_die
)
&&
(
!
p_decoder
->
p_fifo
->
b_error
)
)
while
(
(
!
p_decoder
->
p_fifo
->
b_die
)
&&
(
!
p_decoder
->
p_fifo
->
b_error
)
)
{
{
switch
(
p_decoder
->
i_cat
)
switch
(
p_decoder
->
i_cat
)
...
@@ -218,9 +218,9 @@ static int RunDecoder( decoder_fifo_t *p_fifo )
...
@@ -218,9 +218,9 @@ static int RunDecoder( decoder_fifo_t *p_fifo )
{
{
return
(
-
1
);
return
(
-
1
);
}
}
return
(
0
);
return
(
0
);
}
}
/*****************************************************************************
/*****************************************************************************
*
*
...
@@ -231,8 +231,8 @@ static int RunDecoder( decoder_fifo_t *p_fifo )
...
@@ -231,8 +231,8 @@ static int RunDecoder( decoder_fifo_t *p_fifo )
/*****************************************************************************
/*****************************************************************************
* InitThread: initialize vdec output thread
* InitThread: initialize vdec output thread
*****************************************************************************
*****************************************************************************
* This function is called from decoder_Run and performs the second step
* This function is called from decoder_Run and performs the second step
* of the initialization. It returns 0 on success. Note that the thread's
* of the initialization. It returns 0 on success. Note that the thread's
* flag are not modified inside this function.
* flag are not modified inside this function.
*
*
* ffmpeg codec will be open, some memory allocated. But Vout is not yet
* ffmpeg codec will be open, some memory allocated. But Vout is not yet
...
@@ -242,7 +242,7 @@ static int RunDecoder( decoder_fifo_t *p_fifo )
...
@@ -242,7 +242,7 @@ static int RunDecoder( decoder_fifo_t *p_fifo )
static
int
InitThread
(
generic_thread_t
*
p_decoder
)
static
int
InitThread
(
generic_thread_t
*
p_decoder
)
{
{
int
i_result
;
int
i_result
;
/* *** init ffmpeg library (libavcodec) *** */
/* *** init ffmpeg library (libavcodec) *** */
if
(
!
b_ffmpeginit
)
if
(
!
b_ffmpeginit
)
{
{
...
@@ -263,12 +263,12 @@ static int InitThread( generic_thread_t *p_decoder )
...
@@ -263,12 +263,12 @@ static int InitThread( generic_thread_t *p_decoder )
&
p_decoder
->
i_cat
,
&
p_decoder
->
i_cat
,
&
p_decoder
->
i_codec_id
,
&
p_decoder
->
i_codec_id
,
&
p_decoder
->
psz_namecodec
);
&
p_decoder
->
psz_namecodec
);
/* *** ask ffmpeg for a decoder *** */
/* *** ask ffmpeg for a decoder *** */
if
(
!
(
p_decoder
->
p_codec
=
if
(
!
(
p_decoder
->
p_codec
=
avcodec_find_decoder
(
p_decoder
->
i_codec_id
)
)
)
avcodec_find_decoder
(
p_decoder
->
i_codec_id
)
)
)
{
{
msg_Err
(
p_decoder
->
p_fifo
,
msg_Err
(
p_decoder
->
p_fifo
,
"codec not found (%s)"
,
"codec not found (%s)"
,
p_decoder
->
psz_namecodec
);
p_decoder
->
psz_namecodec
);
return
(
-
1
);
return
(
-
1
);
...
@@ -281,7 +281,7 @@ static int InitThread( generic_thread_t *p_decoder )
...
@@ -281,7 +281,7 @@ static int InitThread( generic_thread_t *p_decoder )
p_decoder
->
p_context
=
malloc
(
sizeof
(
AVCodecContext
)
);
p_decoder
->
p_context
=
malloc
(
sizeof
(
AVCodecContext
)
);
memset
(
p_decoder
->
p_context
,
0
,
sizeof
(
AVCodecContext
)
);
memset
(
p_decoder
->
p_context
,
0
,
sizeof
(
AVCodecContext
)
);
#endif
#endif
switch
(
p_decoder
->
i_cat
)
switch
(
p_decoder
->
i_cat
)
{
{
case
VIDEO_ES
:
case
VIDEO_ES
:
...
@@ -293,7 +293,7 @@ static int InitThread( generic_thread_t *p_decoder )
...
@@ -293,7 +293,7 @@ static int InitThread( generic_thread_t *p_decoder )
default:
default:
i_result
=
-
1
;
i_result
=
-
1
;
}
}
p_decoder
->
pts
=
0
;
p_decoder
->
pts
=
0
;
p_decoder
->
p_buffer
=
NULL
;
p_decoder
->
p_buffer
=
NULL
;
p_decoder
->
i_buffer
=
0
;
p_decoder
->
i_buffer
=
0
;
...
@@ -310,17 +310,17 @@ static int InitThread( generic_thread_t *p_decoder )
...
@@ -310,17 +310,17 @@ static int InitThread( generic_thread_t *p_decoder )
*****************************************************************************/
*****************************************************************************/
static
void
EndThread
(
generic_thread_t
*
p_decoder
)
static
void
EndThread
(
generic_thread_t
*
p_decoder
)
{
{
if
(
!
p_decoder
)
if
(
!
p_decoder
)
{
{
return
;
return
;
}
}
if
(
p_decoder
->
p_context
!=
NULL
)
if
(
p_decoder
->
p_context
!=
NULL
)
{
{
FREE
(
p_decoder
->
p_context
->
extradata
);
FREE
(
p_decoder
->
p_context
->
extradata
);
avcodec_close
(
p_decoder
->
p_context
);
avcodec_close
(
p_decoder
->
p_context
);
msg_Dbg
(
p_decoder
->
p_fifo
,
msg_Dbg
(
p_decoder
->
p_fifo
,
"ffmpeg codec (%s) stopped"
,
"ffmpeg codec (%s) stopped"
,
p_decoder
->
psz_namecodec
);
p_decoder
->
psz_namecodec
);
free
(
p_decoder
->
p_context
);
free
(
p_decoder
->
p_context
);
...
@@ -337,7 +337,7 @@ static void EndThread( generic_thread_t *p_decoder )
...
@@ -337,7 +337,7 @@ static void EndThread( generic_thread_t *p_decoder )
E_
(
EndThread_Video
)(
(
vdec_thread_t
*
)
p_decoder
);
E_
(
EndThread_Video
)(
(
vdec_thread_t
*
)
p_decoder
);
break
;
break
;
}
}
free
(
p_decoder
);
free
(
p_decoder
);
}
}
...
@@ -346,8 +346,8 @@ static void EndThread( generic_thread_t *p_decoder )
...
@@ -346,8 +346,8 @@ static void EndThread( generic_thread_t *p_decoder )
*****************************************************************************/
*****************************************************************************/
int
E_
(
GetPESData
)(
u8
*
p_buf
,
int
i_max
,
pes_packet_t
*
p_pes
)
int
E_
(
GetPESData
)(
u8
*
p_buf
,
int
i_max
,
pes_packet_t
*
p_pes
)
{
{
int
i_copy
;
int
i_copy
;
int
i_count
;
int
i_count
;
data_packet_t
*
p_data
;
data_packet_t
*
p_data
;
...
@@ -357,7 +357,7 @@ int E_( GetPESData )( u8 *p_buf, int i_max, pes_packet_t *p_pes )
...
@@ -357,7 +357,7 @@ int E_( GetPESData )( u8 *p_buf, int i_max, pes_packet_t *p_pes )
while
(
p_data
!=
NULL
&&
i_count
<
i_max
)
while
(
p_data
!=
NULL
&&
i_count
<
i_max
)
{
{
i_copy
=
__MIN
(
p_data
->
p_payload_end
-
p_data
->
p_payload_start
,
i_copy
=
__MIN
(
p_data
->
p_payload_end
-
p_data
->
p_payload_start
,
i_max
-
i_count
);
i_max
-
i_count
);
if
(
i_copy
>
0
)
if
(
i_copy
>
0
)
...
@@ -399,7 +399,7 @@ static int ffmpeg_GetFfmpegCodec( vlc_fourcc_t i_fourcc,
...
@@ -399,7 +399,7 @@ static int ffmpeg_GetFfmpegCodec( vlc_fourcc_t i_fourcc,
psz_name = "MPEG-1/2 Video";
psz_name = "MPEG-1/2 Video";
break;
break;
#endif
#endif
#if LIBAVCODEC_BUILD >= 4608
#if LIBAVCODEC_BUILD >= 4608
case
FOURCC_DIV1
:
case
FOURCC_DIV1
:
case
FOURCC_div1
:
case
FOURCC_div1
:
case
FOURCC_MPG4
:
case
FOURCC_MPG4
:
...
@@ -434,7 +434,7 @@ static int ffmpeg_GetFfmpegCodec( vlc_fourcc_t i_fourcc,
...
@@ -434,7 +434,7 @@ static int ffmpeg_GetFfmpegCodec( vlc_fourcc_t i_fourcc,
case
FOURCC_AP41
:
case
FOURCC_AP41
:
case
FOURCC_3IV1
:
case
FOURCC_3IV1
:
i_cat
=
VIDEO_ES
;
i_cat
=
VIDEO_ES
;
#if LIBAVCODEC_BUILD >= 4608
#if LIBAVCODEC_BUILD >= 4608
i_codec
=
CODEC_ID_MSMPEG4V3
;
i_codec
=
CODEC_ID_MSMPEG4V3
;
#else
#else
i_codec
=
CODEC_ID_MSMPEG4
;
i_codec
=
CODEC_ID_MSMPEG4
;
...
@@ -521,6 +521,16 @@ static int ffmpeg_GetFfmpegCodec( vlc_fourcc_t i_fourcc,
...
@@ -521,6 +521,16 @@ static int ffmpeg_GetFfmpegCodec( vlc_fourcc_t i_fourcc,
break
;
break
;
#if LIBAVCODEC_BUILD >= 4655
#if LIBAVCODEC_BUILD >= 4655
case
FOURCC_MAC3
:
i_cat
=
AUDIO_ES
;
i_codec
=
CODEC_ID_MACE3
;
psz_name
=
"MACE-3 audio"
;
break
;
case
FOURCC_MAC6
:
i_cat
=
AUDIO_ES
;
i_codec
=
CODEC_ID_MACE6
;
psz_name
=
"MACE-6 audio"
;
break
;
case
FOURCC_dvau
:
case
FOURCC_dvau
:
i_cat
=
AUDIO_ES
;
i_cat
=
AUDIO_ES
;
i_codec
=
CODEC_ID_DVAUDIO
;
i_codec
=
CODEC_ID_DVAUDIO
;
...
...
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