Looks OK in general. On Fri, Feb 09, 2018 at 10:51:36AM +0100, Luca Barbato wrote: > --- /dev/null > +++ b/libavcodec/libaom.c > @@ -0,0 +1,90 @@ > + > +#define HIGH_DEPTH(fmt) \ > + case AOM_IMG_FMT_I ## fmt ## 16: switch (depth) { \ > + case 10: return AV_PIX_FMT_YUV ## fmt ## P10; \ > + case 12: return AV_PIX_FMT_YUV ## fmt ## P12; \ > + default: return AV_PIX_FMT_NONE; \
Move the switch statement to the next line for better readability please. > +enum AVPixelFormat ff_aom_imgfmt_to_pixfmt(aom_img_fmt_t img, int depth) > +{ > + switch (img) { > + case AOM_IMG_FMT_RGB24: return AV_PIX_FMT_RGB24; > + case AOM_IMG_FMT_RGB565: return AV_PIX_FMT_RGB565BE; > + case AOM_IMG_FMT_RGB555: return AV_PIX_FMT_RGB555BE; > + case AOM_IMG_FMT_UYVY: return AV_PIX_FMT_UYVY422; > + case AOM_IMG_FMT_YUY2: return AV_PIX_FMT_YUYV422; > + case AOM_IMG_FMT_YVYU: return AV_PIX_FMT_YVYU422; > + case AOM_IMG_FMT_BGR24: return AV_PIX_FMT_BGR24; > + case AOM_IMG_FMT_ARGB: return AV_PIX_FMT_ARGB; > + case AOM_IMG_FMT_ARGB_LE: return AV_PIX_FMT_BGRA; > + case AOM_IMG_FMT_RGB565_LE: return AV_PIX_FMT_RGB565LE; > + case AOM_IMG_FMT_RGB555_LE: return AV_PIX_FMT_RGB555LE; > + case AOM_IMG_FMT_I420: return AV_PIX_FMT_YUV420P; > + case AOM_IMG_FMT_I422: return AV_PIX_FMT_YUV422P; > + case AOM_IMG_FMT_I444: return AV_PIX_FMT_YUV444P; > + case AOM_IMG_FMT_444A: return AV_PIX_FMT_YUVA444P; > + case AOM_IMG_FMT_I440: return AV_PIX_FMT_YUV440P; I'd break those lines. > +/* case AOM_IMG_FMT_I42016: return AV_PIX_FMT_YUV420P16; > + case AOM_IMG_FMT_I42216: return AV_PIX_FMT_YUV422P16; > + case AOM_IMG_FMT_I44416: return AV_PIX_FMT_YUV444P16; */ Why is this commented out? > +aom_img_fmt_t ff_aom_pixfmt_to_imgfmt(enum AVPixelFormat pix) > +{ > + switch (pix) { > + case AV_PIX_FMT_RGB24: return AOM_IMG_FMT_RGB24; > + case AV_PIX_FMT_RGB565BE: return AOM_IMG_FMT_RGB565; > + case AV_PIX_FMT_RGB555BE: return AOM_IMG_FMT_RGB555; > + case AV_PIX_FMT_UYVY422: return AOM_IMG_FMT_UYVY; > + case AV_PIX_FMT_YUYV422: return AOM_IMG_FMT_YUY2; > + case AV_PIX_FMT_YVYU422: return AOM_IMG_FMT_YVYU; > + case AV_PIX_FMT_BGR24: return AOM_IMG_FMT_BGR24; > + case AV_PIX_FMT_ARGB: return AOM_IMG_FMT_ARGB; > + case AV_PIX_FMT_BGRA: return AOM_IMG_FMT_ARGB_LE; > + case AV_PIX_FMT_RGB565LE: return AOM_IMG_FMT_RGB565_LE; > + case AV_PIX_FMT_RGB555LE: return AOM_IMG_FMT_RGB555_LE; > + case AV_PIX_FMT_YUV420P: return AOM_IMG_FMT_I420; > + case AV_PIX_FMT_YUV422P: return AOM_IMG_FMT_I422; > + case AV_PIX_FMT_YUV444P: return AOM_IMG_FMT_I444; > + case AV_PIX_FMT_YUVA444P: return AOM_IMG_FMT_444A; > + case AV_PIX_FMT_YUV440P: return AOM_IMG_FMT_I440; > + case AV_PIX_FMT_YUV420P10: return AOM_IMG_FMT_I42016; > + case AV_PIX_FMT_YUV422P10: return AOM_IMG_FMT_I42216; > + case AV_PIX_FMT_YUV444P10: return AOM_IMG_FMT_I44416; > + case AV_PIX_FMT_YUV420P12: return AOM_IMG_FMT_I42016; > + case AV_PIX_FMT_YUV422P12: return AOM_IMG_FMT_I42216; > + case AV_PIX_FMT_YUV444P12: return AOM_IMG_FMT_I44416; same > --- /dev/null > +++ b/libavcodec/libaom.h > @@ -0,0 +1,31 @@ > + > +#ifndef AVCODEC_LIBAOM_H > +#define AVCODEC_LIBAOM_H > + > +#include <aom/aom_codec.h> > + > +#include "libavutil/pixfmt.h" > + > +enum AVPixelFormat ff_aom_imgfmt_to_pixfmt(aom_img_fmt_t img, int depth); > +aom_img_fmt_t ff_aom_pixfmt_to_imgfmt(enum AVPixelFormat pix); > + > +#endif /* AVCODEC_LIBAOM_H */ Is encoding support planned? Otherwise splitting this into several files is kind of silly. > --- /dev/null > +++ b/libavcodec/libaomdec.c > @@ -0,0 +1,137 @@ > +static av_cold int aom_init(AVCodecContext *avctx, > + const struct aom_codec_iface *iface) > +{ > + if (aom_codec_dec_init(&ctx->decoder, iface, &deccfg, 0) != > AOM_CODEC_OK) { > + const char *error = aom_codec_error(&ctx->decoder); > + av_log(avctx, AV_LOG_ERROR, "Failed to initialize decoder: %s\n", > + error); > + return AVERROR(EINVAL); These don't look like user-supplied values, so I think EINVAL is not the right error code. > +static int aom_decode(AVCodecContext *avctx, void *data, int *got_frame, > + AVPacket *avpkt) > +{ > + *got_frame = 1; odd spacing > +static av_cold int aom_free(AVCodecContext *avctx) Why not aom_close()? > +AVCodec ff_libaom_av1_decoder = { > + .init = av1_init, > + .close = aom_free, > + .decode = aom_decode, Why av1_init and not aom_init? Diego _______________________________________________ libav-devel mailing list libav-devel@libav.org https://lists.libav.org/mailman/listinfo/libav-devel