Skip to content

Commit

Permalink
Add compatibility with FFMPEG 7.0
Browse files Browse the repository at this point in the history
channel_layout has been replace with ch_layout
  • Loading branch information
eclipseo committed May 9, 2024
1 parent bee4233 commit 16e675d
Showing 1 changed file with 49 additions and 9 deletions.
58 changes: 49 additions & 9 deletions src/media.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,8 @@ typedef AVCodec FeAVCodec;
#define FORMAT_CTX_URL m_imp->m_format_ctx->filename
#endif

#define HAVE_CH_LAYOUT (LIBAVUTIL_VERSION_INT >= AV_VERSION_INT(57, 28, 100))

void try_hw_accel( AVCodecContext *&codec_ctx, FeAVCodec *&dec );

std::string g_decoder;
Expand Down Expand Up @@ -321,9 +323,15 @@ FeAudioImp::~FeAudioImp()

bool FeAudioImp::process_frame( AVFrame *frame, sf::SoundStream::Chunk &data, int &offset )
{
#if HAVE_CH_LAYOUT
int nb_channels = codec_ctx->ch_layout.nb_channels;
#else
int nb_channels = codec_ctx->channels;
#endif

int data_size = av_samples_get_buffer_size(
NULL,
codec_ctx->channels,
nb_channels,
frame->nb_samples,
codec_ctx->sample_fmt, 1);

Expand All @@ -349,17 +357,27 @@ bool FeAudioImp::process_frame( AVFrame *frame, sf::SoundStream::Chunk &data, in
return false;
}

#if HAVE_CH_LAYOUT
AVChannelLayout layout;
av_channel_layout_copy(&layout, &frame->ch_layout);
if (!av_channel_layout_check(&layout)) {
av_channel_layout_default(&layout, codec_ctx->ch_layout.nb_channels);
}
av_opt_set_chlayout(resample_ctx, "in_chlayout", &layout, 0);
av_opt_set_chlayout(resample_ctx, "out_chlayout", &layout, 0);
#else
int64_t channel_layout = frame->channel_layout;
if ( !channel_layout )
{
channel_layout = av_get_default_channel_layout(
codec_ctx->channels );
}

av_opt_set_int( resample_ctx, "in_channel_layout", channel_layout, 0 );
av_opt_set_int( resample_ctx, "out_channel_layout", channel_layout, 0 );
#endif

av_opt_set_int( resample_ctx, "in_sample_fmt", frame->format, 0 );
av_opt_set_int( resample_ctx, "in_sample_rate", frame->sample_rate, 0 );
av_opt_set_int( resample_ctx, "out_channel_layout", channel_layout, 0 );
av_opt_set_int( resample_ctx, "out_sample_fmt", AV_SAMPLE_FMT_S16, 0 );
av_opt_set_int( resample_ctx, "out_sample_rate", frame->sample_rate, 0 );

Expand All @@ -382,9 +400,15 @@ bool FeAudioImp::process_frame( AVFrame *frame, sf::SoundStream::Chunk &data, in
if ( resample_ctx )
{
int out_linesize;
#if HAVE_CH_LAYOUT
int nb_channels = codec_ctx->ch_layout.nb_channels;
#else
int nb_channels = codec_ctx->channels;
#endif

av_samples_get_buffer_size(
&out_linesize,
codec_ctx->channels,
nb_channels,
frame->nb_samples,
AV_SAMPLE_FMT_S16, 0 );

Expand All @@ -402,8 +426,9 @@ bool FeAudioImp::process_frame( AVFrame *frame, sf::SoundStream::Chunk &data, in
FeLog() << "Error performing audio conversion." << std::endl;
return false;
}
offset += out_samples * codec_ctx->channels;
data.sampleCount += out_samples * codec_ctx->channels;

offset += out_samples * nb_channels;
data.sampleCount += out_samples * nb_channels;
data.samples = audio_buff;
}
}
Expand Down Expand Up @@ -752,8 +777,17 @@ void FeVideoImp::video_thread()
if ( raw_frame->pts == AV_NOPTS_VALUE )
raw_frame->pts = packet->dts;

// This only works on FFmpeg, exclude libav (it doesn't have pkt_duration
#if (LIBAVUTIL_VERSION_MICRO >= 100 )

#if (LIBAVCODEC_VERSION_INT >= AV_VERSION_INT( 57, 30, 100 ))
// Correct for out of bounds pts
if ( raw_frame->pts < prev_pts )
raw_frame->pts = prev_pts + prev_duration;

// Track pts and duration if we need to correct next frame
prev_pts = raw_frame->pts;
prev_duration = raw_frame->duration;
#elif (LIBAVUTIL_VERSION_MICRO >= 100 )
// This only works on FFmpeg, exclude libav (it doesn't have pkt_duration
// Correct for out of bounds pts
if ( raw_frame->pts < prev_pts )
raw_frame->pts = prev_pts + prev_duration;
Expand Down Expand Up @@ -1065,8 +1099,14 @@ bool FeMedia::open( const std::string &archive,
+ AV_INPUT_BUFFER_PADDING_SIZE
+ codec_ctx->sample_rate );

#if HAVE_CH_LAYOUT
int nb_channels = codec_ctx->ch_layout.nb_channels;
#else
int nb_channels = codec_ctx->channels;
#endif

sf::SoundStream::initialize(
codec_ctx->channels,
nb_channels,
codec_ctx->sample_rate );

sf::SoundStream::setLoop( false );
Expand Down

0 comments on commit 16e675d

Please sign in to comment.