From patchwork Tue Oct 8 22:50:11 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: James Almer X-Patchwork-Id: 52144 Delivered-To: ffmpegpatchwork2@gmail.com Received: by 2002:a59:8b47:0:b0:48e:c0f8:d0de with SMTP id x7csp594897vql; Tue, 8 Oct 2024 16:16:12 -0700 (PDT) X-Forwarded-Encrypted: i=2; AJvYcCVRDUNP7Qrj1vohj/KcinNYxqChCNMxFluWlWQs1fDnuElI5K97ArgXHiJ0MMGywg9+Zt0ztmAYunuj0t1wgZBJ@gmail.com X-Google-Smtp-Source: AGHT+IGbwkxVH9N9bpO+sefv4hQ5/mhUNYNbzd74zaq4AlbmbyzaGpu6FJyw1blABHDyh+OZGZlN X-Received: by 2002:a5d:4851:0:b0:374:c287:929b with SMTP id ffacd0b85a97d-37d3a9b5345mr273555f8f.4.1728429372528; Tue, 08 Oct 2024 16:16:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1728429372; cv=none; d=google.com; s=arc-20240605; b=b9ZYSjCm/KbjO/GdubzzUmMAqAW80atveFpt2RSl8PT17XPekwjyPo/AIJUz9uq02h Q9cSgllBH7Y7MEdIsBSQcsvr4CJeITCU39qYd2e1t5zPAoWnFI6oh2jVkBIsvyejeG0J YQoNJz4oU+KcYq1ev9ZMZqzpAVbCG22tE/e+M+aNYw/wCs9LFq3bJVIYPQLE37scwnuW XN5CJ7ate32IGwJiEUjKlUwuhF8U2dSP13e/oPW7HyCcIJihc2ekIZ2aF59drO5vidKB XS9Yn4ihBaunewIQeaVFZeM8HgpeCoTXwUH0g8ybhREJp4scx5CFtWx7KlIi4Cq4oGkC UCCQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20240605; h=sender:errors-to:content-transfer-encoding:reply-to:list-subscribe :list-help:list-post:list-archive:list-unsubscribe:list-id :precedence:subject:mime-version:references:in-reply-to:message-id :date:to:from:dkim-signature:delivered-to; bh=VKP4vaOLJgS+SIgTuebxAQtaCVrwNzA4imLtCo+8kqs=; fh=YOA8vD9MJZuwZ71F/05pj6KdCjf6jQRmzLS+CATXUQk=; b=bRGP7XnnBDv686ugL8vSLgI1/WXY9VZoOh9/FZE8mKtjNl6KrYMoU/ggcRAmxxYQje Wu77HKrDNU71CogKw99WpESCNnVf/GbePvBED5lZ7/gUsk15jFQE7Cf9jVoVUdfXgmEM CyXfYNKekpkpkhVlW5A5V4TycL5R97cJVZ9HXAVr+FsT8L8jb24RCfEV22xTJjbC9lCd /WLiwSaNsHj/ijX/FMLr3w5xkyBGS8ngE/pS8rT/afgEBM59P+PaZcioHmDHHNA9nRiS kUJm7ZXqwtiKk5CicT+AeKTrgWZNfkQKepPIhFeqzrtkL/045/Y8BmBk4bcKMXxKapLP KTvA==; dara=google.com ARC-Authentication-Results: i=1; mx.google.com; dkim=neutral (body hash did not verify) header.i=@gmail.com header.s=20230601 header.b=XgiCTrsQ; spf=pass (google.com: domain of ffmpeg-devel-bounces@ffmpeg.org designates 79.124.17.100 as permitted sender) smtp.mailfrom=ffmpeg-devel-bounces@ffmpeg.org; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com; dara=fail header.i=@gmail.com Return-Path: Received: from ffbox0-bg.mplayerhq.hu (ffbox0-bg.ffmpeg.org. [79.124.17.100]) by mx.google.com with ESMTP id 4fb4d7f45d1cf-5c8e05fcf16si179100a12.511.2024.10.08.16.16.11; Tue, 08 Oct 2024 16:16:12 -0700 (PDT) Received-SPF: pass (google.com: domain of ffmpeg-devel-bounces@ffmpeg.org designates 79.124.17.100 as permitted sender) client-ip=79.124.17.100; Authentication-Results: mx.google.com; dkim=neutral (body hash did not verify) header.i=@gmail.com header.s=20230601 header.b=XgiCTrsQ; spf=pass (google.com: domain of ffmpeg-devel-bounces@ffmpeg.org designates 79.124.17.100 as permitted sender) smtp.mailfrom=ffmpeg-devel-bounces@ffmpeg.org; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com; dara=fail header.i=@gmail.com Received: from [127.0.1.1] (localhost [127.0.0.1]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTP id 55E4968DDB1; Wed, 9 Oct 2024 01:50:52 +0300 (EEST) X-Original-To: ffmpeg-devel@ffmpeg.org Delivered-To: ffmpeg-devel@ffmpeg.org Received: from mail-pl1-f174.google.com (mail-pl1-f174.google.com [209.85.214.174]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTPS id 78FE768DD9A for ; Wed, 9 Oct 2024 01:50:45 +0300 (EEST) Received: by mail-pl1-f174.google.com with SMTP id d9443c01a7336-20bb39d97d1so53774555ad.2 for ; Tue, 08 Oct 2024 15:50:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1728427843; x=1729032643; darn=ffmpeg.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=ztQHvHfCS8YpEZVtnSqRSQ8Sr12f5rhE/AovgiNiJss=; b=XgiCTrsQpY53UpZRQ+W4k7Q8kaxWvohESko0ZvM2n6ss8GdQd5AMbyfuWBi9pbSiUu el6mhfeuMUfW2BrR7R3D/gDmFUFXppNrMHZOXcbtIxymyTUNRGFGGid44+5rcKdAaGpa 44RHVu2YvkrFZcjLbqaOktAW9bd8nrBcFmgDeNy7Ny7q/PkDgHx+UUHZziHj+VeRq0HZ aejRGIsWgd3mEepH2Aw+HGBR6gANP5pC/bsbpqlubh29HDh26i7+4ROTVVjBk9DE4Fpu Ure0uoWcpMS1tKAEMxa2AxnrPpOCPlYmnZZqIuHmDZoTcPPGQK/ho/XrB53y3yWEo5yF GKfg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1728427843; x=1729032643; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=ztQHvHfCS8YpEZVtnSqRSQ8Sr12f5rhE/AovgiNiJss=; b=S2WjUvjA0WFD58Zb3Gml8c/TbJrhpQqkFvO3tvuk76CW+WWU5PE0+5G6zunVN/jVau rvg6njvafvIOmPVGnEFzzMsenP0j/LwWiEm8NF/ZwLbCzJL6l9ePWVgB4ofBrmACN8Av r5BLkk4e1gu/u2zzptByBvv+BiWeMJxxgtL1ldXF3i92gSFGSvq+vSw8Xq0dK7TWbEa6 c0wrnTXoGD5F4lbA/r0+0Eqt9ClgaoAFl1fEk90oWnn2x21UMGCPgYnYXLimDad6Gel9 gG1/po9KEd7HQToRXjgGYXmZf0xDj18CTGXio/Dy9E7aFRPp42jps49ZoHrwzMTCc+KX vC+w== X-Gm-Message-State: AOJu0YwgWUC/KfvHE1b0vx6H0OKA00i2LjUog5v88AjDxFEzNTL+4ZEw M07bmf5+5KjMj5bk2FQT6LK3icVLllRwfm6I827XaEHBBysNgnDsHzSKPw== X-Received: by 2002:a17:902:d54a:b0:20b:c026:6a0d with SMTP id d9443c01a7336-20c637d2b3bmr10633855ad.38.1728427842839; Tue, 08 Oct 2024 15:50:42 -0700 (PDT) Received: from localhost.localdomain ([181.92.233.116]) by smtp.gmail.com with ESMTPSA id d9443c01a7336-20c138afaa0sm60373855ad.4.2024.10.08.15.50.41 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 08 Oct 2024 15:50:42 -0700 (PDT) From: James Almer To: ffmpeg-devel@ffmpeg.org Date: Tue, 8 Oct 2024 19:50:11 -0300 Message-ID: <20241008225027.12209-6-jamrial@gmail.com> X-Mailer: git-send-email 2.46.2 In-Reply-To: <20241008225027.12209-1-jamrial@gmail.com> References: <20241008225027.12209-1-jamrial@gmail.com> MIME-Version: 1.0 Subject: [FFmpeg-devel] [PATCH 06/21] swscale/output: add AYUV output support X-BeenThere: ffmpeg-devel@ffmpeg.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: FFmpeg development discussions and patches List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-To: FFmpeg development discussions and patches Errors-To: ffmpeg-devel-bounces@ffmpeg.org Sender: "ffmpeg-devel" X-TUID: ftIIAbDwwZDh Signed-off-by: James Almer --- libswscale/output.c | 323 ++++++++++++----------- libswscale/utils.c | 2 +- tests/ref/fate/filter-pixdesc-ayuv | 1 + tests/ref/fate/filter-pixfmts-copy | 1 + tests/ref/fate/filter-pixfmts-crop | 1 + tests/ref/fate/filter-pixfmts-field | 1 + tests/ref/fate/filter-pixfmts-fieldorder | 1 + tests/ref/fate/filter-pixfmts-hflip | 1 + tests/ref/fate/filter-pixfmts-il | 1 + tests/ref/fate/filter-pixfmts-null | 1 + tests/ref/fate/filter-pixfmts-pad | 1 + tests/ref/fate/filter-pixfmts-scale | 1 + tests/ref/fate/filter-pixfmts-transpose | 1 + tests/ref/fate/filter-pixfmts-vflip | 1 + 14 files changed, 183 insertions(+), 154 deletions(-) create mode 100644 tests/ref/fate/filter-pixdesc-ayuv diff --git a/libswscale/output.c b/libswscale/output.c index c9dfd6f60a..328b108089 100644 --- a/libswscale/output.c +++ b/libswscale/output.c @@ -2668,165 +2668,177 @@ yuv2xv36le_X_c(SwsContext *c, const int16_t *lumFilter, } } -static void -yuv2vuyX_1_c(SwsContext *c, const int16_t *buf0, - const int16_t *ubuf[2], const int16_t *vbuf[2], - const int16_t *abuf0, uint8_t *dest, int dstW, - int uvalpha, int y) -{ - int hasAlpha = !!abuf0; - int i; - - if (uvalpha < 2048) { - for (i = 0; i < dstW; i++) { - int Y = (buf0[i] + 64) >> 7; - int U = (ubuf[0][i] + 64) >> 7; - int V = (vbuf[0][i] + 64) >> 7; - int A = 255; - - if (Y & 0x100) - Y = av_clip_uint8(Y); - if (U & 0x100) - U = av_clip_uint8(U); - if (V & 0x100) - V = av_clip_uint8(V); - - if (hasAlpha) { - A = (abuf0[i] + 64) >> 7; - if (A & 0x100) - A = av_clip_uint8(A); - } - - dest[4 * i ] = V; - dest[4 * i + 1] = U; - dest[4 * i + 2] = Y; - dest[4 * i + 3] = A; - } - } else { - for (i = 0; i < dstW; i++) { - int Y = (buf0[i] + 64) >> 7; - int U = (ubuf[0][i] + ubuf[1][i] + 128) >> 8; - int V = (vbuf[0][i] + vbuf[1][i] + 128) >> 8; - int A = 255; - - if (Y & 0x100) - Y = av_clip_uint8(Y); - if (U & 0x100) - U = av_clip_uint8(U); - if (V & 0x100) - V = av_clip_uint8(V); - - if (hasAlpha) { - A = (abuf0[i] + 64) >> 7; - if (A & 0x100) - A = av_clip_uint8(A); - } - - dest[4 * i ] = V; - dest[4 * i + 1] = U; - dest[4 * i + 2] = Y; - dest[4 * i + 3] = A; - } - } +#define AYUV_1_WRAPPER(fmt, C0, C1, C2, C3) \ +static void \ +yuv2 ## fmt ##_1_c(SwsContext *c, const int16_t *buf0, \ + const int16_t *ubuf[2], const int16_t *vbuf[2], \ + const int16_t *abuf0, uint8_t *dest, int dstW, \ + int uvalpha, int y) \ +{ \ + int hasAlpha = !!abuf0; \ + int i; \ + \ + if (uvalpha < 2048) { \ + for (i = 0; i < dstW; i++) { \ + int Y = (buf0[i] + 64) >> 7; \ + int U = (ubuf[0][i] + 64) >> 7; \ + int V = (vbuf[0][i] + 64) >> 7; \ + int A = 255; \ + \ + if (Y & 0x100) \ + Y = av_clip_uint8(Y); \ + if (U & 0x100) \ + U = av_clip_uint8(U); \ + if (V & 0x100) \ + V = av_clip_uint8(V); \ + \ + if (hasAlpha) { \ + A = (abuf0[i] + 64) >> 7; \ + if (A & 0x100) \ + A = av_clip_uint8(A); \ + } \ + \ + dest[4 * i ] = (C0); \ + dest[4 * i + 1] = (C1); \ + dest[4 * i + 2] = (C2); \ + dest[4 * i + 3] = (C3); \ + } \ + } else { \ + for (i = 0; i < dstW; i++) { \ + int Y = (buf0[i] + 64) >> 7; \ + int U = (ubuf[0][i] + ubuf[1][i] + 128) >> 8; \ + int V = (vbuf[0][i] + vbuf[1][i] + 128) >> 8; \ + int A = 255; \ + \ + if (Y & 0x100) \ + Y = av_clip_uint8(Y); \ + if (U & 0x100) \ + U = av_clip_uint8(U); \ + if (V & 0x100) \ + V = av_clip_uint8(V); \ + \ + if (hasAlpha) { \ + A = (abuf0[i] + 64) >> 7; \ + if (A & 0x100) \ + A = av_clip_uint8(A); \ + } \ + \ + dest[4 * i ] = (C0); \ + dest[4 * i + 1] = (C1); \ + dest[4 * i + 2] = (C2); \ + dest[4 * i + 3] = (C3); \ + } \ + } \ } -static void -yuv2vuyX_2_c(SwsContext *c, const int16_t *buf[2], - const int16_t *ubuf[2], const int16_t *vbuf[2], - const int16_t *abuf[2], uint8_t *dest, int dstW, - int yalpha, int uvalpha, int y) -{ - int hasAlpha = abuf && abuf[0] && abuf[1]; - const int16_t *buf0 = buf[0], *buf1 = buf[1], - *ubuf0 = ubuf[0], *ubuf1 = ubuf[1], - *vbuf0 = vbuf[0], *vbuf1 = vbuf[1], - *abuf0 = hasAlpha ? abuf[0] : NULL, - *abuf1 = hasAlpha ? abuf[1] : NULL; - int yalpha1 = 4096 - yalpha; - int uvalpha1 = 4096 - uvalpha; - int i; - - av_assert2(yalpha <= 4096U); - av_assert2(uvalpha <= 4096U); - - for (i = 0; i < dstW; i++) { - int Y = (buf0[i] * yalpha1 + buf1[i] * yalpha) >> 19; - int U = (ubuf0[i] * uvalpha1 + ubuf1[i] * uvalpha) >> 19; - int V = (vbuf0[i] * uvalpha1 + vbuf1[i] * uvalpha) >> 19; - int A = 255; - - if (Y & 0x100) - Y = av_clip_uint8(Y); - if (U & 0x100) - U = av_clip_uint8(U); - if (V & 0x100) - V = av_clip_uint8(V); - - if (hasAlpha) { - A = (abuf0[i] * yalpha1 + abuf1[i] * yalpha) >> 19; - A = av_clip_uint8(A); - } - - dest[4 * i ] = V; - dest[4 * i + 1] = U; - dest[4 * i + 2] = Y; - dest[4 * i + 3] = A; - } +AYUV_1_WRAPPER(vuyX, V, U, Y, A) +AYUV_1_WRAPPER(ayuv, A, Y, U, V) + +#define AYUV_2_WRAPPER(fmt, C0, C1, C2, C3) \ +static void \ +yuv2 ## fmt ##_2_c(SwsContext *c, const int16_t *buf[2], \ + const int16_t *ubuf[2], const int16_t *vbuf[2], \ + const int16_t *abuf[2], uint8_t *dest, int dstW, \ + int yalpha, int uvalpha, int y) \ +{ \ + int hasAlpha = abuf && abuf[0] && abuf[1]; \ + const int16_t *buf0 = buf[0], *buf1 = buf[1], \ + *ubuf0 = ubuf[0], *ubuf1 = ubuf[1], \ + *vbuf0 = vbuf[0], *vbuf1 = vbuf[1], \ + *abuf0 = hasAlpha ? abuf[0] : NULL, \ + *abuf1 = hasAlpha ? abuf[1] : NULL; \ + int yalpha1 = 4096 - yalpha; \ + int uvalpha1 = 4096 - uvalpha; \ + int i; \ + \ + av_assert2(yalpha <= 4096U); \ + av_assert2(uvalpha <= 4096U); \ + \ + for (i = 0; i < dstW; i++) { \ + int Y = (buf0[i] * yalpha1 + buf1[i] * yalpha) >> 19; \ + int U = (ubuf0[i] * uvalpha1 + ubuf1[i] * uvalpha) >> 19; \ + int V = (vbuf0[i] * uvalpha1 + vbuf1[i] * uvalpha) >> 19; \ + int A = 255; \ + \ + if (Y & 0x100) \ + Y = av_clip_uint8(Y); \ + if (U & 0x100) \ + U = av_clip_uint8(U); \ + if (V & 0x100) \ + V = av_clip_uint8(V); \ + \ + if (hasAlpha) { \ + A = (abuf0[i] * yalpha1 + abuf1[i] * yalpha) >> 19; \ + A = av_clip_uint8(A); \ + } \ + \ + dest[4 * i ] = (C0); \ + dest[4 * i + 1] = (C1); \ + dest[4 * i + 2] = (C2); \ + dest[4 * i + 3] = (C3); \ + } \ } -static void -yuv2vuyX_X_c(SwsContext *c, const int16_t *lumFilter, - const int16_t **lumSrc, int lumFilterSize, - const int16_t *chrFilter, const int16_t **chrUSrc, - const int16_t **chrVSrc, int chrFilterSize, - const int16_t **alpSrc, uint8_t *dest, int dstW, int y) -{ - int i; - - for (i = 0; i < dstW; i++) { - int j; - int Y = 1 << 18, U = 1 << 18; - int V = 1 << 18, A = 255; - - for (j = 0; j < lumFilterSize; j++) - Y += lumSrc[j][i] * lumFilter[j]; - - for (j = 0; j < chrFilterSize; j++) - U += chrUSrc[j][i] * chrFilter[j]; - - for (j = 0; j < chrFilterSize; j++) - V += chrVSrc[j][i] * chrFilter[j]; - - Y >>= 19; - U >>= 19; - V >>= 19; - - if (Y & 0x100) - Y = av_clip_uint8(Y); - if (U & 0x100) - U = av_clip_uint8(U); - if (V & 0x100) - V = av_clip_uint8(V); - - if (alpSrc) { - A = 1 << 18; - - for (j = 0; j < lumFilterSize; j++) - A += alpSrc[j][i] * lumFilter[j]; - - A >>= 19; - - if (A & 0x100) - A = av_clip_uint8(A); - } - - dest[4 * i ] = V; - dest[4 * i + 1] = U; - dest[4 * i + 2] = Y; - dest[4 * i + 3] = A; - } +AYUV_2_WRAPPER(vuyX, V, U, Y, A) +AYUV_2_WRAPPER(ayuv, A, Y, U, V) + +#define AYUV_X_WRAPPER(fmt, C0, C1, C2, C3) \ +static void \ +yuv2 ## fmt ##_X_c(SwsContext *c, const int16_t *lumFilter, \ + const int16_t **lumSrc, int lumFilterSize, \ + const int16_t *chrFilter, const int16_t **chrUSrc, \ + const int16_t **chrVSrc, int chrFilterSize, \ + const int16_t **alpSrc, uint8_t *dest, int dstW, int y) \ +{ \ + int i; \ + \ + for (i = 0; i < dstW; i++) { \ + int j; \ + int Y = 1 << 18, U = 1 << 18; \ + int V = 1 << 18, A = 255; \ + \ + for (j = 0; j < lumFilterSize; j++) \ + Y += lumSrc[j][i] * lumFilter[j]; \ + \ + for (j = 0; j < chrFilterSize; j++) \ + U += chrUSrc[j][i] * chrFilter[j]; \ + \ + for (j = 0; j < chrFilterSize; j++) \ + V += chrVSrc[j][i] * chrFilter[j]; \ + \ + Y >>= 19; \ + U >>= 19; \ + V >>= 19; \ + \ + if (Y & 0x100) \ + Y = av_clip_uint8(Y); \ + if (U & 0x100) \ + U = av_clip_uint8(U); \ + if (V & 0x100) \ + V = av_clip_uint8(V); \ + \ + if (alpSrc) { \ + A = 1 << 18; \ + \ + for (j = 0; j < lumFilterSize; j++) \ + A += alpSrc[j][i] * lumFilter[j]; \ + \ + A >>= 19; \ + \ + if (A & 0x100) \ + A = av_clip_uint8(A); \ + } \ + \ + dest[4 * i ] = (C0); \ + dest[4 * i + 1] = (C1); \ + dest[4 * i + 2] = (C2); \ + dest[4 * i + 3] = (C3); \ + } \ } +AYUV_X_WRAPPER(vuyX, V, U, Y, A) +AYUV_X_WRAPPER(ayuv, A, Y, U, V) + #define output_pixel(pos, val, bits) \ AV_WL16(pos, av_clip_uintp2(val >> shift, bits) << output_shift); @@ -3379,6 +3391,11 @@ av_cold void ff_sws_init_output_funcs(SwsContext *c, case AV_PIX_FMT_AYUV64LE: *yuv2packedX = yuv2ayuv64le_X_c; break; + case AV_PIX_FMT_AYUV: + *yuv2packed1 = yuv2ayuv_1_c; + *yuv2packed2 = yuv2ayuv_2_c; + *yuv2packedX = yuv2ayuv_X_c; + break; case AV_PIX_FMT_VUYA: case AV_PIX_FMT_VUYX: *yuv2packed1 = yuv2vuyX_1_c; diff --git a/libswscale/utils.c b/libswscale/utils.c index e2ad71a38d..84d23c3ff2 100644 --- a/libswscale/utils.c +++ b/libswscale/utils.c @@ -268,7 +268,7 @@ static const FormatEntry format_entries[] = { [AV_PIX_FMT_RGBAF16LE] = { 1, 0 }, [AV_PIX_FMT_XV30LE] = { 1, 1 }, [AV_PIX_FMT_XV36LE] = { 1, 1 }, - [AV_PIX_FMT_AYUV] = { 1, 0 }, + [AV_PIX_FMT_AYUV] = { 1, 1 }, [AV_PIX_FMT_UYVA] = { 1, 0 }, [AV_PIX_FMT_VYU444] = { 1, 0 }, [AV_PIX_FMT_V30XLE] = { 1, 0 }, diff --git a/tests/ref/fate/filter-pixdesc-ayuv b/tests/ref/fate/filter-pixdesc-ayuv new file mode 100644 index 0000000000..178e847222 --- /dev/null +++ b/tests/ref/fate/filter-pixdesc-ayuv @@ -0,0 +1 @@ +pixdesc-ayuv a21ac760efdec0065bcf605f4ed75f7f diff --git a/tests/ref/fate/filter-pixfmts-copy b/tests/ref/fate/filter-pixfmts-copy index 120129dc1e..dc165b5ec5 100644 --- a/tests/ref/fate/filter-pixfmts-copy +++ b/tests/ref/fate/filter-pixfmts-copy @@ -2,6 +2,7 @@ 0rgb 527ef3d164c8fd0700493733959689c2 abgr 023ecf6396d324edb113e4a483b79ba2 argb f003b555ef429222005d33844cca9325 +ayuv eb7e43cfbb961d1e369311d0f58b9f52 ayuv64le 07b9c969dfbe4add4c0626773b151d4f bgr0 6fcd67c8e6cec723dab21c70cf53dc16 bgr24 4cff3814819f02ecf5824edfd768d2b1 diff --git a/tests/ref/fate/filter-pixfmts-crop b/tests/ref/fate/filter-pixfmts-crop index 4731e96fc0..07ded708bc 100644 --- a/tests/ref/fate/filter-pixfmts-crop +++ b/tests/ref/fate/filter-pixfmts-crop @@ -2,6 +2,7 @@ 0rgb 974833c777e6abe6d84dc59af2ca5625 abgr 1d21f5b8a20186ac9dd54459c986a2a7 argb 8b822972049a1e207000763f2564d6e0 +ayuv f2846cdd8fc01820e561fe4d3855938c ayuv64le ab2f7bc8f150af47c42c778e3ea28bce bgr0 38a84849a9198667c348c686802e3b52 bgr24 1dacd8e04bf0eff163e82250d01a9cc7 diff --git a/tests/ref/fate/filter-pixfmts-field b/tests/ref/fate/filter-pixfmts-field index 0727d733f2..9e1e06bd80 100644 --- a/tests/ref/fate/filter-pixfmts-field +++ b/tests/ref/fate/filter-pixfmts-field @@ -2,6 +2,7 @@ 0rgb e2c35753a2271d1f9455b1809bc0e907 abgr c0eb95959edf5d40ff8af315e62d0f8a argb 6dca4f2987b49b7d63f702d17bace630 +ayuv 6aeadbc3ec2a6ff2bfab9495e7285fed ayuv64le d9836decca6323ba88b3b3d02257c0b6 bgr0 1da3fdbac616b3b410d081e39ed7a1f6 bgr24 573c76d77b1cbe6534ea7c0267dc1b13 diff --git a/tests/ref/fate/filter-pixfmts-fieldorder b/tests/ref/fate/filter-pixfmts-fieldorder index 1d7a98ce11..8f1febf4ad 100644 --- a/tests/ref/fate/filter-pixfmts-fieldorder +++ b/tests/ref/fate/filter-pixfmts-fieldorder @@ -2,6 +2,7 @@ 0rgb 2b0f066cfa0bef378a492875d541de8f abgr 832924b5351361db68dbdbb96c60ae55 argb 80d08e68cb91bc8f2f817516e65f0bd0 +ayuv 61b23fc754d8ca0d6740fa08a0a6ebf2 ayuv64le 84ef6260fe02427da946d4a2207fb54c bgr0 d2c676224ea80ac3ce01afde325ea1a0 bgr24 b7fdbcd10f20e6ea2d40aae0f329f80d diff --git a/tests/ref/fate/filter-pixfmts-hflip b/tests/ref/fate/filter-pixfmts-hflip index 43404db154..a49abba15b 100644 --- a/tests/ref/fate/filter-pixfmts-hflip +++ b/tests/ref/fate/filter-pixfmts-hflip @@ -2,6 +2,7 @@ 0rgb ada57572ee2b35f86edac9b911ce8523 abgr d2da6c3ee72e4a89a7cd011dd08566b2 argb 36cf791c52c5463bfc52a070de54337e +ayuv 122f591eac5669b658c22b09355e4263 ayuv64le 4cedbc38b3d4dcb26cdab170ce6d667b bgr0 66e9fda4e658d73bfe4fc9d792542271 bgr24 db074979bd684ca4547e28681ad3f6ab diff --git a/tests/ref/fate/filter-pixfmts-il b/tests/ref/fate/filter-pixfmts-il index 4a6f15f074..1ac9cf3bd2 100644 --- a/tests/ref/fate/filter-pixfmts-il +++ b/tests/ref/fate/filter-pixfmts-il @@ -2,6 +2,7 @@ 0rgb 53efe0182723cd1dedfdbf56357c76f5 abgr 97603869e6248a8e5d8501563a11b114 argb 9e50e6ef02c83f28e97865a1f46ddfcd +ayuv 3dfdbbbf605d83629f3ef4c96210b074 ayuv64le 6f45f683e99ddf4180c7c7f47719efcc bgr0 590dcd1297d1dd4541eea217381db604 bgr24 73afe7b447b083a7c2d682abe8dd451a diff --git a/tests/ref/fate/filter-pixfmts-null b/tests/ref/fate/filter-pixfmts-null index 120129dc1e..dc165b5ec5 100644 --- a/tests/ref/fate/filter-pixfmts-null +++ b/tests/ref/fate/filter-pixfmts-null @@ -2,6 +2,7 @@ 0rgb 527ef3d164c8fd0700493733959689c2 abgr 023ecf6396d324edb113e4a483b79ba2 argb f003b555ef429222005d33844cca9325 +ayuv eb7e43cfbb961d1e369311d0f58b9f52 ayuv64le 07b9c969dfbe4add4c0626773b151d4f bgr0 6fcd67c8e6cec723dab21c70cf53dc16 bgr24 4cff3814819f02ecf5824edfd768d2b1 diff --git a/tests/ref/fate/filter-pixfmts-pad b/tests/ref/fate/filter-pixfmts-pad index abf4fceb46..5d8111b623 100644 --- a/tests/ref/fate/filter-pixfmts-pad +++ b/tests/ref/fate/filter-pixfmts-pad @@ -2,6 +2,7 @@ 0rgb 8e076dd0f8a9f4652595dffe3544f0f0 abgr 52738042432893de555e6a3833172806 argb 2a10108ac524b422b8a2393c064b3eab +ayuv ddb44f03af05b0cb01dced60641a4160 bgr0 025d4d5e5691801ba39bc9de70e39df0 bgr24 f8b65ad845905c7d0c93ca28dfbb826f bgr48le 4564b56dd1f2a9761b8a7a5244ac4c49 diff --git a/tests/ref/fate/filter-pixfmts-scale b/tests/ref/fate/filter-pixfmts-scale index 2052d3f2f0..41a6fe76e7 100644 --- a/tests/ref/fate/filter-pixfmts-scale +++ b/tests/ref/fate/filter-pixfmts-scale @@ -2,6 +2,7 @@ 0rgb 80a58af8c639743307207ab4b69ca863 abgr 63f2eaa8712ea6108985f4a0b83587c9 argb f0e17c71a40643c33a5bcfb481f6d8f8 +ayuv 9992b829065e2ea4a44de3a25766ca9b ayuv64le 59fb016f9874062d0be77cb3920ffed2 bgr0 243d58ca64f97b2f415b4c63cb79f0e1 bgr24 18744aaab4b8bce065a7144dc0ccf921 diff --git a/tests/ref/fate/filter-pixfmts-transpose b/tests/ref/fate/filter-pixfmts-transpose index 0a395f7e71..bcda0e6460 100644 --- a/tests/ref/fate/filter-pixfmts-transpose +++ b/tests/ref/fate/filter-pixfmts-transpose @@ -2,6 +2,7 @@ 0rgb cf1bedd0784a3efd3ab00c4e44005c37 abgr 6d6f896f853a6c6f93ee70dba9af3d17 argb 87bbd23debb94d486ac3a6b6c0b005f9 +ayuv fe3d4a2d4d37deb94e6f447edc77f199 ayuv64le e4c07e0d5b333b3bc9eb4f3ce6af3a2c bgr0 df3a6eedd4939ce09a357b655ac2962a bgr24 f9a08135e5d58c0b2a5509c369a88414 diff --git a/tests/ref/fate/filter-pixfmts-vflip b/tests/ref/fate/filter-pixfmts-vflip index 5ba28917a7..bb8ad46704 100644 --- a/tests/ref/fate/filter-pixfmts-vflip +++ b/tests/ref/fate/filter-pixfmts-vflip @@ -2,6 +2,7 @@ 0rgb 76b792f8ce8a72925e04294dc2f25b36 abgr 8b94f489e68802d76f1e2844688a4911 argb 3fd6af7ef2364d8aa845d45db289a04a +ayuv 928ac9b09b90dec1d8bc3ecd13b75a60 ayuv64le 558671dd31d0754cfa6344eaf441df78 bgr0 7117438cf000254610f23625265769b5 bgr24 52b2c21cbc166978a38a646c354b6858