[FFmpeg-devel] [PATCH v3 07/18] swscale: add sws_is_noop()
Niklas Haas
ffmpeg at haasn.xyz
Sun Oct 20 23:05:16 EEST 2024
From: Niklas Haas <git at haasn.dev>
Exactly what it says on the tin.
Sponsored-by: Sovereign Tech Fund
Signed-off-by: Niklas Haas <git at haasn.dev>
---
libswscale/swscale.h | 6 ++++++
libswscale/utils.c | 14 ++++++++++++++
2 files changed, 20 insertions(+)
diff --git a/libswscale/swscale.h b/libswscale/swscale.h
index ba944cdc6f..f544387769 100644
--- a/libswscale/swscale.h
+++ b/libswscale/swscale.h
@@ -140,6 +140,12 @@ int sws_test_transfer(enum AVColorTransferCharacteristic trc, int output);
*/
int sws_test_frame(const AVFrame *frame, int output);
+/**
+ * Check if a given conversion is a noop. Returns a positive integer if
+ * no operation needs to be performed, 0 otherwise.
+ */
+int sws_is_noop(const AVFrame *dst, const AVFrame *src);
+
/* values for the flags, the stuff on the command line is different */
#define SWS_FAST_BILINEAR 1
#define SWS_BILINEAR 2
diff --git a/libswscale/utils.c b/libswscale/utils.c
index 5339bbe099..5dff3c5476 100644
--- a/libswscale/utils.c
+++ b/libswscale/utils.c
@@ -2785,3 +2785,17 @@ int sws_test_frame(const AVFrame *frame, int output)
return 1;
}
+
+int sws_is_noop(const AVFrame *dst, const AVFrame *src)
+{
+ for (int field = 0; field < 2; field++) {
+ SwsFormat dst_fmt = ff_fmt_from_frame(dst, field);
+ SwsFormat src_fmt = ff_fmt_from_frame(src, field);
+ if (!ff_fmt_equal(&dst_fmt, &src_fmt))
+ return 0;
+ if (!dst_fmt.interlaced)
+ break;
+ }
+
+ return 1;
+}
--
2.46.1
More information about the ffmpeg-devel
mailing list