From: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
To: ffmpeg-devel@ffmpeg.org
Cc: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
Subject: [FFmpeg-devel] [PATCH 3/5] avutil/pixdesc: Move ff_check_pixfmt_descriptors() to its only user
Date: Mon, 26 Sep 2022 21:58:56 +0200
Message-ID: <GV1P250MB0737560B3F499EFAB9896D0A8F529@GV1P250MB0737.EURP250.PROD.OUTLOOK.COM> (raw)
In-Reply-To: <GV1P250MB073722E20166CCF2883487CF8F529@GV1P250MB0737.EURP250.PROD.OUTLOOK.COM>
Namely to lavu/tests/pixelutils.c. This way, this function will
not be included into actual binaries any more.
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
---
libavutil/internal.h | 2 --
libavutil/pixdesc.c | 48 ---------------------------------
libavutil/tests/pixelutils.c | 52 +++++++++++++++++++++++++++++++++++-
3 files changed, 51 insertions(+), 51 deletions(-)
diff --git a/libavutil/internal.h b/libavutil/internal.h
index c9e30bc5e9..454c59aa50 100644
--- a/libavutil/internal.h
+++ b/libavutil/internal.h
@@ -187,6 +187,4 @@ static av_always_inline av_const int avpriv_mirror(int x, int w)
return x;
}
-void ff_check_pixfmt_descriptors(void);
-
#endif /* AVUTIL_INTERNAL_H */
diff --git a/libavutil/pixdesc.c b/libavutil/pixdesc.c
index f6755f41df..ca3e204a0b 100644
--- a/libavutil/pixdesc.c
+++ b/libavutil/pixdesc.c
@@ -22,12 +22,10 @@
#include <stdio.h>
#include <string.h>
-#include "avassert.h"
#include "avstring.h"
#include "common.h"
#include "pixfmt.h"
#include "pixdesc.h"
-#include "internal.h"
#include "intreadwrite.h"
void av_read_image_line2(void *dst,
@@ -2912,52 +2910,6 @@ int av_pix_fmt_count_planes(enum AVPixelFormat pix_fmt)
return ret;
}
-void ff_check_pixfmt_descriptors(void){
- const AVPixFmtDescriptor *d, *last = NULL;
- int i;
-
- for (i = AV_PIX_FMT_NONE, d = NULL; i++, d = av_pix_fmt_desc_next(d);) {
- uint8_t fill[4][8+6+3] = {{0}};
- uint8_t *data[4] = {fill[0], fill[1], fill[2], fill[3]};
- int linesize[4] = {0,0,0,0};
- uint16_t tmp[2];
-
- av_assert0(d->name && d->name[0]);
- av_log(NULL, AV_LOG_INFO, "Checking: %s\n", d->name);
- av_assert0(d->log2_chroma_w <= 3);
- av_assert0(d->log2_chroma_h <= 3);
- av_assert0(d->nb_components <= 4);
- av_assert2(av_get_pix_fmt(d->name) == av_pix_fmt_desc_get_id(d));
-
- /* The following two checks as well as the one after the loop
- * would need to be changed if we changed the way the descriptors
- * are stored. */
- av_assert0(i == av_pix_fmt_desc_get_id(d));
- av_assert0(!last || last + 1 == d);
-
- for (int j = 0; j < FF_ARRAY_ELEMS(d->comp); j++) {
- const AVComponentDescriptor *c = &d->comp[j];
- if(j>=d->nb_components) {
- av_assert0(!c->plane && !c->step && !c->offset && !c->shift && !c->depth);
- continue;
- }
- if (d->flags & AV_PIX_FMT_FLAG_BITSTREAM) {
- av_assert0(c->step >= c->depth);
- } else {
- av_assert0(8*c->step >= c->depth);
- }
- if (d->flags & AV_PIX_FMT_FLAG_BAYER)
- continue;
- av_read_image_line(tmp, (void*)data, linesize, d, 0, 0, j, 2, 0);
- av_assert0(tmp[0] == 0 && tmp[1] == 0);
- tmp[0] = tmp[1] = (1ULL << c->depth) - 1;
- av_write_image_line(tmp, data, linesize, d, 0, 0, j, 2);
- }
- }
- av_assert0(i == AV_PIX_FMT_NB);
-}
-
-
enum AVPixelFormat av_pix_fmt_swap_endianness(enum AVPixelFormat pix_fmt)
{
const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(pix_fmt);
diff --git a/libavutil/tests/pixelutils.c b/libavutil/tests/pixelutils.c
index 927c8d9217..6e5e8cf738 100644
--- a/libavutil/tests/pixelutils.c
+++ b/libavutil/tests/pixelutils.c
@@ -18,15 +18,65 @@
#include <stdio.h>
+#include "libavutil/avassert.h"
#include "libavutil/internal.h"
+#include "libavutil/log.h"
#include "libavutil/mem.h"
+#include "libavutil/pixdesc.h"
#include "libavutil/pixelutils.c"
+#include "libavutil/pixfmt.h"
#define W1 320
#define H1 240
#define W2 640
#define H2 480
+static void check_pixfmt_descriptors(void)
+{
+ const AVPixFmtDescriptor *d, *last = NULL;
+ int i;
+
+ for (i = AV_PIX_FMT_NONE, d = NULL; i++, d = av_pix_fmt_desc_next(d);) {
+ uint8_t fill[4][8 + 6 + 3] = {{ 0 }};
+ uint8_t *data[4] = { fill[0], fill[1], fill[2], fill[3] };
+ int linesize[4] = { 0, 0, 0, 0 };
+ uint16_t tmp[2];
+
+ av_assert0(d->name && d->name[0]);
+ av_log(NULL, AV_LOG_INFO, "Checking: %s\n", d->name);
+ av_assert0(d->log2_chroma_w <= 3);
+ av_assert0(d->log2_chroma_h <= 3);
+ av_assert0(d->nb_components <= 4);
+ av_assert2(av_get_pix_fmt(d->name) == av_pix_fmt_desc_get_id(d));
+
+ /* The following two checks as well as the one after the loop
+ * would need to be changed if we changed the way the descriptors
+ * are stored. */
+ av_assert0(i == av_pix_fmt_desc_get_id(d));
+ av_assert0(!last || last + 1 == d);
+
+ for (int j = 0; j < FF_ARRAY_ELEMS(d->comp); j++) {
+ const AVComponentDescriptor *c = &d->comp[j];
+ if (j >= d->nb_components) {
+ av_assert0(!c->plane && !c->step && !c->offset && !c->shift && !c->depth);
+ continue;
+ }
+ if (d->flags & AV_PIX_FMT_FLAG_BITSTREAM) {
+ av_assert0(c->step >= c->depth);
+ } else {
+ av_assert0(8*c->step >= c->depth);
+ }
+ if (d->flags & AV_PIX_FMT_FLAG_BAYER)
+ continue;
+ av_read_image_line(tmp, (void*)data, linesize, d, 0, 0, j, 2, 0);
+ av_assert0(tmp[0] == 0 && tmp[1] == 0);
+ tmp[0] = tmp[1] = (1ULL << c->depth) - 1;
+ av_write_image_line(tmp, data, linesize, d, 0, 0, j, 2);
+ }
+ }
+ av_assert0(i == AV_PIX_FMT_NB);
+}
+
static int run_single_test(const char *test,
const uint8_t *block1, ptrdiff_t stride1,
const uint8_t *block2, ptrdiff_t stride2,
@@ -87,7 +137,7 @@ int main(void)
goto end;
}
- ff_check_pixfmt_descriptors();
+ check_pixfmt_descriptors();
#define RANDOM_INIT(buf, size) do { \
int k; \
--
2.34.1
_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
To unsubscribe, visit link above, or email
ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
next prev parent reply other threads:[~2022-09-26 19:59 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-09-26 19:57 [FFmpeg-devel] [PATCH 1/5] avutil/pixdesc: Remove always-false checks Andreas Rheinhardt
2022-09-26 19:58 ` [FFmpeg-devel] [PATCH 2/5] avutil/pixdesc: Avoid direct access to pix fmt desc array Andreas Rheinhardt
2022-09-28 13:43 ` Anton Khirnov
2022-09-28 13:49 ` Andreas Rheinhardt
2022-09-26 19:58 ` Andreas Rheinhardt [this message]
2022-09-26 19:58 ` [FFmpeg-devel] [PATCH 4/5] avutil/tests/pixelutils: Use av_assert0 instead for test tools Andreas Rheinhardt
2022-09-26 19:58 ` [FFmpeg-devel] [PATCH 5/5] avutil/tests/pixelutils: Test that all non-hw pix fmts have components Andreas Rheinhardt
2022-09-29 21:04 ` [FFmpeg-devel] [PATCH 1/5] avutil/pixdesc: Remove always-false checks Andreas Rheinhardt
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=GV1P250MB0737560B3F499EFAB9896D0A8F529@GV1P250MB0737.EURP250.PROD.OUTLOOK.COM \
--to=andreas.rheinhardt@outlook.com \
--cc=ffmpeg-devel@ffmpeg.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
This inbox may be cloned and mirrored by anyone:
git clone --mirror https://master.gitmailbox.com/ffmpegdev/0 ffmpegdev/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 ffmpegdev ffmpegdev/ https://master.gitmailbox.com/ffmpegdev \
ffmpegdev@gitmailbox.com
public-inbox-index ffmpegdev
Example config snippet for mirrors.
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git