@@ -892,6 +892,25 @@ static av_always_inline int usePal(enum AVPixelFormat pix_fmt)
}
}
+/*
+ * Identity formats where the data is in the high bits, and the low bits are shifted away.
+ */
+static av_always_inline int isDataInHighBits(enum AVPixelFormat pix_fmt)
+{
+ int i;
+ const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(pix_fmt);
+ av_assert0(desc);
+ if (desc->flags & (AV_PIX_FMT_FLAG_BITSTREAM | AV_PIX_FMT_FLAG_HWACCEL))
+ return 0;
+ for (i = 0; i < desc->nb_components; i++) {
+ if (!desc->comp[i].shift)
+ return 0;
+ if ((desc->comp[i].shift + desc->comp[i].depth) & 0x7)
+ return 0;
+ }
+ return 1;
+}
+
extern const uint64_t ff_dither4[2];
extern const uint64_t ff_dither8[2];
@@ -45,6 +45,7 @@ static const struct {
{"PackedRGB", isPackedRGB},
{"PlanarRGB", isPlanarRGB},
{"usePal", usePal},
+ {"DataInHighBits", isDataInHighBits},
};
static int cmp_str(const void *a, const void *b)
@@ -952,3 +952,15 @@ usePal:
rgb4_byte
rgb8
+DataInHighBits:
+ p010be
+ p010le
+ p210be
+ p210le
+ p410be
+ p410le
+ xyz12be
+ xyz12le
+ y210be
+ y210le
+