• James Zern's avatar
    vp9_thread: add vp9_worker_execute() · 820201ca
    James Zern authored
    cherry-picked from:
    commit 988b70844e03efcfcc075a9bc25d846670494f36
    Author: Pascal Massimino <pascal.massimino@gmail.com>
    Date:   Fri Aug 2 11:15:16 2013 -0700
    
        add WebPWorkerExecute() for convenient bypass
    
        This is mainly for re-using the worker structs without using the
        thread.
    
        Change-Id: I8e1be29e53874ef425b15c192fb68036b4c0a359
    
    Original source:
     http://git.chromium.org/webm/libwebp.git
     100644 blob c0d318aee628fdf9ba4876451a28aa978f1066b8 src/utils/thread.c
     100644 blob c2b92c9fe353f8e514f78922f3d237204a9cbc66 src/utils/thread.h
    
    Change-Id: I13fe92b1e94062bb99fdeeb7cb0b4b0575d27793
    820201ca
video_reader.c 2.20 KiB
/*
 *  Copyright (c) 2014 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.
 */
#include <stdlib.h>
#include <string.h>
#include "./ivfdec.h"
#include "./video_reader.h"
#include "vpx_ports/mem_ops.h"
static const char *const kIVFSignature = "DKIF";
struct VpxVideoReaderStruct {
  VpxVideoInfo info;
  FILE *file;
  uint8_t *buffer;
  size_t buffer_size;
  size_t frame_size;
VpxVideoReader *vpx_video_reader_open(const char *filename) {
  char header[32];
  VpxVideoReader *reader = NULL;
  FILE *const file = fopen(filename, "rb");
  if (!file)
    return NULL;  // Can't open file
  if (fread(header, 1, 32, file) != 32)
    return NULL;  // Can't read file header
  if (memcmp(kIVFSignature, header, 4) != 0)
    return NULL;  // Wrong IVF signature
  if (mem_get_le16(header + 4) != 0)
    return NULL;  // Wrong IVF version
  reader = calloc(1, sizeof(*reader));
  if (!reader)
    return NULL;  // Can't allocate VpxVideoReader
  reader->file = file;
  reader->info.codec_fourcc = mem_get_le32(header + 8);
  reader->info.frame_width = mem_get_le16(header + 12);
  reader->info.frame_height = mem_get_le16(header + 14);
  reader->info.time_base.numerator = mem_get_le32(header + 16);
  reader->info.time_base.denominator = mem_get_le32(header + 20);
  return reader;
void vpx_video_reader_close(VpxVideoReader *reader) {
  if (reader) {
    fclose(reader->file);
    free(reader->buffer);
    free(reader);
int vpx_video_reader_read_frame(VpxVideoReader *reader) {
  return !ivf_read_frame(reader->file, &reader->buffer, &reader->frame_size,
                         &reader->buffer_size);
7172737475767778798081828384
const uint8_t *vpx_video_reader_get_frame(VpxVideoReader *reader, size_t *size) { if (size) *size = reader->frame_size; return reader->buffer; } const VpxVideoInfo *vpx_video_reader_get_info(VpxVideoReader *reader) { return &reader->info; }