av_assert1(width && height);
if (f->colorspace == 0) {
- const int chroma_width = -((-width) >> f->chroma_h_shift);
- const int chroma_height = -((-height) >> f->chroma_v_shift);
+ const int chroma_width = AV_CEIL_RSHIFT(width, f->chroma_h_shift);
+ const int chroma_height = AV_CEIL_RSHIFT(height, f->chroma_v_shift);
const int cx = x >> f->chroma_h_shift;
const int cy = y >> f->chroma_v_shift;
decode_plane(fs, p->data[0] + ps * x + y * p->linesize[0], width,
}
if (f->colorspace == 0) {
+ if (f->transparency && f->avctx->bits_per_raw_sample > 8) {
+ av_log(f->avctx, AV_LOG_ERROR,
+ "Transparency not supported for bit depth %d\n",
+ f->avctx->bits_per_raw_sample);
+ return AVERROR(ENOSYS);
+ }
if (!f->transparency && !f->chroma_planes) {
if (f->avctx->bits_per_raw_sample <= 8)
f->avctx->pix_fmt = AV_PIX_FMT_GRAY8;
"chroma subsampling not supported in this colorspace\n");
return AVERROR(ENOSYS);
}
+ if (f->transparency) {
+ av_log(f->avctx, AV_LOG_ERROR,
+ "Transparency not supported in this colorspace\n");
+ return AVERROR(ENOSYS);
+ }
switch (f->avctx->bits_per_raw_sample) {
case 0:
case 8: