mirror of
https://mirror.skon.top/https://github.com/FFmpeg/FFmpeg
synced 2026-04-20 21:00:41 +08:00
The issue is that every le/be pair ends up with a swapped op list:
rgb24 -> rgb48be:
[ u8 XXXX -> +++X] SWS_OP_READ : 3 elem(s) packed >> 0
[ u8 ...X -> +++X] SWS_OP_CONVERT : u8 -> u16 (expand)
- [u16 ...X -> zzzX] SWS_OP_SWAP_BYTES
- [u16 ...X -> zzzX] SWS_OP_WRITE : 3 elem(s) packed >> 0
+ [u16 ...X -> +++X] SWS_OP_WRITE : 3 elem(s) packed >> 0
(X = unused, z = byteswapped, + = exact, 0 = zero)
rgb24 -> rgb48le:
[ u8 XXXX -> +++X] SWS_OP_READ : 3 elem(s) packed >> 0
[ u8 ...X -> +++X] SWS_OP_CONVERT : u8 -> u16 (expand)
- [u16 ...X -> +++X] SWS_OP_WRITE : 3 elem(s) packed >> 0
+ [u16 ...X -> zzzX] SWS_OP_SWAP_BYTES
+ [u16 ...X -> zzzX] SWS_OP_WRITE : 3 elem(s) packed >> 0
(X = unused, z = byteswapped, + = exact, 0 = zero)
I'm not sure of a good work-around that's not needlessly difficult to
implement, so just disable it on BE platforms for now. The actual underlying
conversions should still be covered by the sws-unscaled test.
53 lines
2.7 KiB
Makefile
53 lines
2.7 KiB
Makefile
FATE_LIBSWSCALE += fate-sws-pixdesc-query
|
|
fate-sws-pixdesc-query: libswscale/tests/pixdesc_query$(EXESUF)
|
|
fate-sws-pixdesc-query: CMD = run libswscale/tests/pixdesc_query$(EXESUF)
|
|
|
|
FATE_LIBSWSCALE += fate-sws-floatimg-cmp
|
|
fate-sws-floatimg-cmp: libswscale/tests/floatimg_cmp$(EXESUF)
|
|
fate-sws-floatimg-cmp: CMD = run libswscale/tests/floatimg_cmp$(EXESUF)
|
|
|
|
SWS_SLICE_TEST-$(call DEMDEC, MATROSKA, VP9) += fate-sws-slice-yuv422-12bit-rgb48
|
|
fate-sws-slice-yuv422-12bit-rgb48: CMD = run tools/scale_slice_test$(EXESUF) $(TARGET_SAMPLES)/vp9-test-vectors/vp93-2-20-12bit-yuv422.webm 150 100 rgb48
|
|
|
|
SWS_SLICE_TEST-$(call DEMDEC, IMAGE_BMP_PIPE, BMP) += fate-sws-slice-bgr0-nv12
|
|
fate-sws-slice-bgr0-nv12: CMD = run tools/scale_slice_test$(EXESUF) $(TARGET_SAMPLES)/bmp/test32bf.bmp 32 64 nv12
|
|
|
|
fate-sws-slice: $(SWS_SLICE_TEST-yes)
|
|
$(SWS_SLICE_TEST-yes): tools/scale_slice_test$(EXESUF)
|
|
$(SWS_SLICE_TEST-yes): REF = /dev/null
|
|
FATE_LIBSWSCALE_SAMPLES += $(SWS_SLICE_TEST-yes)
|
|
|
|
FATE_LIBSWSCALE_FFMPEG-$(call FRAMECRC, RAWVIDEO, RAWVIDEO, SCALE_FILTER) += fate-sws-yuv-colorspace \
|
|
fate-sws-yuv-range
|
|
fate-sws-yuv-colorspace: tests/data/vsynth1.yuv
|
|
fate-sws-yuv-colorspace: CMD = framecrc \
|
|
-f rawvideo -s 352x288 -pix_fmt yuv420p -i $(TARGET_PATH)/tests/data/vsynth1.yuv \
|
|
-frames 1 \
|
|
-vf scale=in_color_matrix=bt709:in_range=limited:out_color_matrix=bt601:out_range=full:flags=+accurate_rnd+bitexact
|
|
|
|
fate-sws-yuv-range: tests/data/vsynth1.yuv
|
|
fate-sws-yuv-range: CMD = framecrc \
|
|
-f rawvideo -s 352x288 -pix_fmt yuv420p -i $(TARGET_PATH)/tests/data/vsynth1.yuv \
|
|
-frames 1 \
|
|
-vf scale=in_color_matrix=bt601:in_range=limited:out_color_matrix=bt601:out_range=full:flags=+accurate_rnd+bitexact
|
|
|
|
# This self-check currently fails for legacy swscale, so pass SWS_UNSTABLE to use the new code
|
|
FATE_LIBSWSCALE-$(CONFIG_UNSTABLE) += fate-sws-unscaled
|
|
fate-sws-unscaled: libswscale/tests/swscale$(EXESUF)
|
|
fate-sws-unscaled: CMD = run libswscale/tests/swscale$(EXESUF) -unscaled 1 -flags unstable -v 16
|
|
|
|
ifneq ($(HAVE_BIGENDIAN),yes)
|
|
# Disable on big endian because big endian platforms generate different op
|
|
# lists for le vs be formats; this breaks the checksum otherwise
|
|
FATE_LIBSWSCALE-$(CONFIG_UNSTABLE) += fate-sws-ops-list
|
|
fate-sws-ops-list: libswscale/tests/sws_ops$(EXESUF)
|
|
fate-sws-ops-list: CMD = run libswscale/tests/sws_ops$(EXESUF) | do_md5sum | cut -d" " -f1
|
|
endif
|
|
|
|
FATE_LIBSWSCALE += $(FATE_LIBSWSCALE-yes)
|
|
FATE_LIBSWSCALE_SAMPLES += $(FATE_LIBSWSCALE_SAMPLES-yes)
|
|
FATE-$(CONFIG_SWSCALE) += $(FATE_LIBSWSCALE)
|
|
FATE_FFMPEG += $(FATE_LIBSWSCALE_FFMPEG-yes)
|
|
FATE_EXTERN-$(CONFIG_SWSCALE) += $(FATE_LIBSWSCALE_SAMPLES)
|
|
fate-libswscale: $(FATE_LIBSWSCALE) $(FATE_LIBSWSCALE_SAMPLES) $(FATE_LIBSWSCALE_FFMPEG-yes)
|