Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
2657f00d
Commit
2657f00d
authored
Nov 11, 2014
by
Lukasz Marek
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ffmpeg_opt: use codec private context in ffserver streams
Signed-off-by:
Lukasz Marek
<
lukasz.m.luki2@gmail.com
>
parent
6690d4c3
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
33 additions
and
15 deletions
+33
-15
ffmpeg_opt.c
ffmpeg_opt.c
+33
-15
No files found.
ffmpeg_opt.c
View file @
2657f00d
...
@@ -1617,6 +1617,31 @@ static int copy_chapters(InputFile *ifile, OutputFile *ofile, int copy_metadata)
...
@@ -1617,6 +1617,31 @@ static int copy_chapters(InputFile *ifile, OutputFile *ofile, int copy_metadata)
return
0
;
return
0
;
}
}
static
int
ffserver_streams_copy_context
(
AVCodecContext
*
dest
,
const
AVCodecContext
*
src
,
const
char
*
configuration
)
{
int
ret
;
if
((
ret
=
avcodec_copy_context
(
dest
,
src
))
<
0
)
return
ret
;
dest
->
codec
=
avcodec_find_encoder
(
src
->
codec_id
);
if
(
!
dest
->
codec
)
return
AVERROR
(
EINVAL
);
if
(
!
dest
->
codec
->
priv_class
||
!
dest
->
codec
->
priv_data_size
)
return
0
;
if
(
!
dest
->
priv_data
)
{
dest
->
priv_data
=
av_mallocz
(
dest
->
codec
->
priv_data_size
);
if
(
!
dest
->
priv_data
)
return
AVERROR
(
ENOMEM
);
*
(
const
AVClass
**
)
dest
->
priv_data
=
dest
->
codec
->
priv_class
;
}
av_opt_set_defaults
(
dest
->
priv_data
);
if
(
av_set_options_string
(
dest
->
priv_data
,
configuration
,
"="
,
","
)
<
0
)
{
av_log
(
dest
,
AV_LOG_WARNING
,
"Cannot copy private codec options. Using defaults.
\n
"
);
av_opt_set_defaults
(
dest
->
priv_data
);
}
return
0
;
}
static
int
read_ffserver_streams
(
OptionsContext
*
o
,
AVFormatContext
*
s
,
const
char
*
filename
)
static
int
read_ffserver_streams
(
OptionsContext
*
o
,
AVFormatContext
*
s
,
const
char
*
filename
)
{
{
int
i
,
err
;
int
i
,
err
;
...
@@ -1631,35 +1656,28 @@ static int read_ffserver_streams(OptionsContext *o, AVFormatContext *s, const ch
...
@@ -1631,35 +1656,28 @@ static int read_ffserver_streams(OptionsContext *o, AVFormatContext *s, const ch
AVStream
*
st
;
AVStream
*
st
;
OutputStream
*
ost
;
OutputStream
*
ost
;
AVCodec
*
codec
;
AVCodec
*
codec
;
AVCodecContext
*
avctx
;
codec
=
avcodec_find_encoder
(
ic
->
streams
[
i
]
->
codec
->
codec_id
);
codec
=
avcodec_find_encoder
(
ic
->
streams
[
i
]
->
codec
->
codec_id
);
if
(
!
codec
)
{
if
(
!
codec
)
{
av_log
(
s
,
AV_LOG_ERROR
,
"no encoder found for codec id %i
\n
"
,
ic
->
streams
[
i
]
->
codec
->
codec_id
);
av_log
(
s
,
AV_LOG_ERROR
,
"no encoder found for codec id %i
\n
"
,
ic
->
streams
[
i
]
->
codec
->
codec_id
);
return
AVERROR
(
EINVAL
);
return
AVERROR
(
EINVAL
);
}
}
if
(
codec
->
type
==
AVMEDIA_TYPE_AUDIO
)
opt_audio_codec
(
o
,
"c:a"
,
codec
->
name
);
else
if
(
codec
->
type
==
AVMEDIA_TYPE_VIDEO
)
opt_video_codec
(
o
,
"c:v"
,
codec
->
name
);
ost
=
new_output_stream
(
o
,
s
,
codec
->
type
,
-
1
);
ost
=
new_output_stream
(
o
,
s
,
codec
->
type
,
-
1
);
st
=
ost
->
st
;
st
=
ost
->
st
;
avctx
=
st
->
codec
;
ost
->
enc
=
codec
;
// FIXME: a more elegant solution is needed
ffserver_streams_copy_context
(
st
->
codec
,
ic
->
streams
[
i
]
->
codec
,
memcpy
(
st
,
ic
->
streams
[
i
],
sizeof
(
AVStream
));
av_stream_get_recommended_encoder_configuration
(
ic
->
streams
[
i
]));
st
->
cur_dts
=
0
;
st
->
info
=
av_malloc
(
sizeof
(
*
st
->
info
));
memcpy
(
st
->
info
,
ic
->
streams
[
i
]
->
info
,
sizeof
(
*
st
->
info
));
st
->
codec
=
avctx
;
avcodec_copy_context
(
st
->
codec
,
ic
->
streams
[
i
]
->
codec
);
if
(
st
->
codec
->
codec_type
==
AVMEDIA_TYPE_AUDIO
&&
!
ost
->
stream_copy
)
if
(
st
->
codec
->
codec_type
==
AVMEDIA_TYPE_AUDIO
&&
!
ost
->
stream_copy
)
choose_sample_fmt
(
st
,
codec
);
choose_sample_fmt
(
st
,
codec
);
else
if
(
st
->
codec
->
codec_type
==
AVMEDIA_TYPE_VIDEO
&&
!
ost
->
stream_copy
)
else
if
(
st
->
codec
->
codec_type
==
AVMEDIA_TYPE_VIDEO
&&
!
ost
->
stream_copy
)
choose_pixel_fmt
(
st
,
st
->
codec
,
codec
,
st
->
codec
->
pix_fmt
);
choose_pixel_fmt
(
st
,
st
->
codec
,
codec
,
st
->
codec
->
pix_fmt
);
avcodec_copy_context
(
ost
->
enc_ctx
,
st
->
codec
);
ffserver_streams_copy_context
(
ost
->
enc_ctx
,
st
->
codec
,
if
(
ost
->
enc_ctx
->
priv_data
)
{
av_stream_get_recommended_encoder_configuration
(
ic
->
streams
[
i
]));
av_opt_free
(
ost
->
enc_ctx
->
priv_data
);
av_freep
(
&
ost
->
enc_ctx
->
priv_data
);
}
}
}
avformat_close_input
(
&
ic
);
avformat_close_input
(
&
ic
);
...
...
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