summaryrefslogtreecommitdiff
path: root/libavformat/mxf.c
diff options
context:
space:
mode:
authorMarton Balint <cus@passwd.hu>2020-02-28 01:10:45 +0100
committerMarton Balint <cus@passwd.hu>2020-03-14 22:25:25 +0100
commit27a8146990e6e5f798a115b4491d0f67147c1c60 (patch)
treec60f12ece8ad29bd51f15df45d1fdbaf633cf240 /libavformat/mxf.c
parentaef2016bb02fba377481789bf6a84e1176b83c25 (diff)
downloadffmpeg-27a8146990e6e5f798a115b4491d0f67147c1c60.tar.gz
avformat/mxf: get rid of samples per frame array usage
Signed-off-by: Marton Balint <cus@passwd.hu>
Diffstat (limited to 'libavformat/mxf.c')
-rw-r--r--libavformat/mxf.c44
1 files changed, 4 insertions, 40 deletions
diff --git a/libavformat/mxf.c b/libavformat/mxf.c
index 451cbcfb2c..10ccd770e3 100644
--- a/libavformat/mxf.c
+++ b/libavformat/mxf.c
@@ -131,16 +131,6 @@ int ff_mxf_decode_pixel_layout(const char pixel_layout[16], enum AVPixelFormat *
return -1;
}
-static const MXFSamplesPerFrame mxf_spf[] = {
- { { 1001, 24000 }, { 2002, 0, 0, 0, 0, 0 } }, // FILM 23.976
- { { 1, 24}, { 2000, 0, 0, 0, 0, 0 } }, // FILM 24
- { { 1001, 30000 }, { 1602, 1601, 1602, 1601, 1602, 0 } }, // NTSC 29.97
- { { 1001, 60000 }, { 801, 801, 800, 801, 801, 0 } }, // NTSC 59.94
- { { 1, 25 }, { 1920, 0, 0, 0, 0, 0 } }, // PAL 25
- { { 1, 50 }, { 960, 0, 0, 0, 0, 0 } }, // PAL 50
- { { 1, 60 }, { 800, 0, 0, 0, 0, 0 } },
-};
-
static const AVRational mxf_time_base[] = {
{ 1001, 24000 },
{ 1, 24},
@@ -152,40 +142,14 @@ static const AVRational mxf_time_base[] = {
{ 0, 0}
};
-const MXFSamplesPerFrame *ff_mxf_get_samples_per_frame(AVFormatContext *s,
- AVRational time_base)
-{
- int idx = av_find_nearest_q_idx(time_base, mxf_time_base);
- AVRational diff = av_sub_q(time_base, mxf_time_base[idx]);
-
- diff.num = FFABS(diff.num);
-
- if (av_cmp_q(diff, (AVRational){1, 1000}) >= 0)
- return NULL;
-
- if (av_cmp_q(time_base, mxf_time_base[idx]))
- av_log(s, AV_LOG_WARNING,
- "%d/%d input time base matched %d/%d container time base\n",
- time_base.num, time_base.den,
- mxf_spf[idx].time_base.num,
- mxf_spf[idx].time_base.den);
-
- return &mxf_spf[idx];
-}
-
static const int mxf_content_package_rates[] = {
3, 2, 7, 13, 4, 10, 12,
};
int ff_mxf_get_content_package_rate(AVRational time_base)
{
- int idx = av_find_nearest_q_idx(time_base, mxf_time_base);
- AVRational diff = av_sub_q(time_base, mxf_time_base[idx]);
-
- diff.num = FFABS(diff.num);
-
- if (av_cmp_q(diff, (AVRational){1, 1000}) >= 0)
- return -1;
-
- return mxf_content_package_rates[idx];
+ for (int i = 0; mxf_time_base[i].num; i++)
+ if (!av_cmp_q(time_base, mxf_time_base[i]))
+ return mxf_content_package_rates[i];
+ return 0;
}