C++程序  |  202行  |  5.9 KB

/*
 *  Copyright (c) 2010 The WebM project authors. All Rights Reserved.
 *
 *  Use of this source code is governed by a BSD-style license
 *  that can be found in the LICENSE file in the root of the source
 *  tree. An additional intellectual property rights grant can be found
 *  in the file PATENTS.  All contributing project authors may
 *  be found in the AUTHORS file in the root of the source tree.
 */


/*!\file vpx_decoder.c
 * \brief Provides the high level interface to wrap decoder algorithms.
 *
 */
#include <stdlib.h>
#include <string.h>
#include "vpx/vpx_decoder.h"
#include "vpx/internal/vpx_codec_internal.h"

#define SAVE_STATUS(ctx,var) (ctx?(ctx->err = var):var)

const char *vpx_dec_iface_name(vpx_dec_iface_t *iface)
{
    return vpx_codec_iface_name((vpx_codec_iface_t *)iface);
}

const char *vpx_dec_err_to_string(vpx_dec_err_t  err)
{
    return vpx_codec_err_to_string(err);
}

const char *vpx_dec_error(vpx_dec_ctx_t  *ctx)
{
    return vpx_codec_error((vpx_codec_ctx_t *)ctx);
}

const char *vpx_dec_error_detail(vpx_dec_ctx_t  *ctx)
{
    return vpx_codec_error_detail((vpx_codec_ctx_t *)ctx);
}


vpx_dec_err_t vpx_dec_init_ver(vpx_dec_ctx_t    *ctx,
                               vpx_dec_iface_t  *iface,
                               int               ver)
{
    return vpx_codec_dec_init_ver((vpx_codec_ctx_t *)ctx,
                                  (vpx_codec_iface_t *)iface,
                                  NULL,
                                  0,
                                  ver);
}


vpx_dec_err_t vpx_dec_destroy(vpx_dec_ctx_t *ctx)
{
    return vpx_codec_destroy((vpx_codec_ctx_t *)ctx);
}


vpx_dec_caps_t vpx_dec_get_caps(vpx_dec_iface_t *iface)
{
    return vpx_codec_get_caps((vpx_codec_iface_t *)iface);
}


vpx_dec_err_t vpx_dec_peek_stream_info(vpx_dec_iface_t       *iface,
                                       const uint8_t         *data,
                                       unsigned int           data_sz,
                                       vpx_dec_stream_info_t *si)
{
    return vpx_codec_peek_stream_info((vpx_codec_iface_t *)iface, data, data_sz,
                                      (vpx_codec_stream_info_t *)si);
}


vpx_dec_err_t vpx_dec_get_stream_info(vpx_dec_ctx_t         *ctx,
                                      vpx_dec_stream_info_t *si)
{
    return vpx_codec_get_stream_info((vpx_codec_ctx_t *)ctx,
                                     (vpx_codec_stream_info_t *)si);
}


vpx_dec_err_t vpx_dec_control(vpx_dec_ctx_t  *ctx,
                              int             ctrl_id,
                              void           *data)
{
    return vpx_codec_control_((vpx_codec_ctx_t *)ctx, ctrl_id, data);
}


vpx_dec_err_t vpx_dec_decode(vpx_dec_ctx_t  *ctx,
                             uint8_t        *data,
                             unsigned int    data_sz,
                             void       *user_priv,
                             int         rel_pts)
{
    (void)rel_pts;
    return vpx_codec_decode((vpx_codec_ctx_t *)ctx, data, data_sz, user_priv,
                            0);
}

vpx_image_t *vpx_dec_get_frame(vpx_dec_ctx_t  *ctx,
                               vpx_dec_iter_t *iter)
{
    return vpx_codec_get_frame((vpx_codec_ctx_t *)ctx, iter);
}


vpx_dec_err_t vpx_dec_register_put_frame_cb(vpx_dec_ctx_t             *ctx,
        vpx_dec_put_frame_cb_fn_t  cb,
        void                      *user_priv)
{
    return vpx_codec_register_put_frame_cb((vpx_codec_ctx_t *)ctx, cb,
                                           user_priv);
}


vpx_dec_err_t vpx_dec_register_put_slice_cb(vpx_dec_ctx_t             *ctx,
        vpx_dec_put_slice_cb_fn_t  cb,
        void                      *user_priv)
{
    return vpx_codec_register_put_slice_cb((vpx_codec_ctx_t *)ctx, cb,
                                           user_priv);
}


vpx_dec_err_t vpx_dec_xma_init_ver(vpx_dec_ctx_t    *ctx,
                                   vpx_dec_iface_t  *iface,
                                   int               ver)
{
    return vpx_codec_dec_init_ver((vpx_codec_ctx_t *)ctx,
                                  (vpx_codec_iface_t *)iface,
                                  NULL,
                                  VPX_CODEC_USE_XMA,
                                  ver);
}

vpx_dec_err_t vpx_dec_get_mem_map(vpx_dec_ctx_t                *ctx_,
                                  vpx_dec_mmap_t               *mmap,
                                  const vpx_dec_stream_info_t  *si,
                                  vpx_dec_iter_t               *iter)
{
    vpx_codec_ctx_t   *ctx = (vpx_codec_ctx_t *)ctx_;
    vpx_dec_err_t      res = VPX_DEC_OK;

    if (!ctx || !mmap || !si || !iter || !ctx->iface)
        res = VPX_DEC_INVALID_PARAM;
    else if (!(ctx->iface->caps & VPX_DEC_CAP_XMA))
        res = VPX_DEC_ERROR;
    else
    {
        if (!ctx->config.dec)
        {
            ctx->config.dec = malloc(sizeof(vpx_codec_dec_cfg_t));
            ctx->config.dec->w = si->w;
            ctx->config.dec->h = si->h;
        }

        res = ctx->iface->get_mmap(ctx, mmap, iter);
    }

    return SAVE_STATUS(ctx, res);
}


vpx_dec_err_t vpx_dec_set_mem_map(vpx_dec_ctx_t   *ctx_,
                                  vpx_dec_mmap_t  *mmap,
                                  unsigned int     num_maps)
{
    vpx_codec_ctx_t   *ctx = (vpx_codec_ctx_t *)ctx_;
    vpx_dec_err_t      res = VPX_DEC_MEM_ERROR;

    if (!ctx || !mmap || !ctx->iface)
        res = VPX_DEC_INVALID_PARAM;
    else if (!(ctx->iface->caps & VPX_DEC_CAP_XMA))
        res = VPX_DEC_ERROR;
    else
    {
        void         *save = (ctx->priv) ? NULL : ctx->config.dec;
        unsigned int i;

        for (i = 0; i < num_maps; i++, mmap++)
        {
            if (!mmap->base)
                break;

            /* Everything look ok, set the mmap in the decoder */
            res = ctx->iface->set_mmap(ctx, mmap);

            if (res)
                break;
        }

        if (save) free(save);
    }

    return SAVE_STATUS(ctx, res);
}