ref: f3e79702fa8f102089633a9ac8b39c9b485415b4
parent: dbdd0f664f37a11b8e06e07905d12527509e2723
author: menno <menno>
date: Fri Nov 21 10:08:48 EST 2003
Almost completely new mp4 file library nice and small
--- a/common/mp4ff/Makefile.am
+++ b/common/mp4ff/Makefile.am
@@ -2,12 +2,7 @@
include_HEADERS = mp4ff.h
-libmp4ff_la_SOURCES = atom.c ctts.c dinf.c dref.c edts.c \
- elst.c esds.c hdlr.c iods.c matrix.c mdat.c mdhd.c \
- mdia.c minf.c moov.c mp4ff.c mvhd.c smhd.c stbl.c \
- stco.c stsc.c stsd.c stsdtable.c stss.c stsz.c stts.c \
- tkhd.c trak.c udta.c util.c vmhd.c \
- funcprotos.h mp4ff.h private.h
+libmp4ff_la_SOURCES = mp4ff.c mp4atom.c mp4sample.c mp4util.c mp4ff.h
AM_CFLAGS = -O2 -g
LIBTOOL_DEPS =
--- a/common/mp4ff/README_ORIGINAL
+++ /dev/null
@@ -1,42 +1,0 @@
-Quicktime for Linux
-
-Author: Adam Williams [email protected]
-Homepage: heroinewarrior.com/quicktime
-Requires: libpthread
-------------------------------------------------------------------------
-
-*****
-
-This is a Quicktime library for UNIX in a freely redistributable,
-statically linkable library. You can statically link it in a program
-and charge money for the program. The only condition is that if you
-use it in a program, you must put the author's name and email
-somewhere. If you improve the library itself or add a free codec to
-it, you should release your improvements. If you redistribute the
-code, you must also redistribute the author information and
-documentation. At this time it's very popular to license stuff under
-the GPL. You are free to include this library in a derived work and
-license the derived work under GPL.
-
-*****
-
-Building:
-type "make" in the quicktime/quicktime directory.
-type "make util" to get some Small Utilities.
-
-Configuration:
-
-The file "config.h" defines the size of a 16 bit word and what the
-maximum file size is.
-
-/*******************************************************
- * References:
- *********************************/
-
-Apple's quicktime file format information:
-
-http://developer.apple.com/techpubs/quicktime/qtdevdocs/REF/refQTFileFormat.htm
-
-Color space conversions:
-
-http://www.neuro.sfc.keio.ac.jp/~aly/polygon/info/color-space-faq.html
--- a/common/mp4ff/atom.c
+++ /dev/null
@@ -1,140 +1,0 @@
-#include "mp4ff.h"
-
-
-int mp4ff_atom_reset(mp4ff_atom_t *atom)
-{
- atom->end = 0;
- atom->type[0] = atom->type[1] = atom->type[2] = atom->type[3] = 0;
- return 0;
-}
-
-int mp4ff_atom_read_header(mp4ff_t *file, mp4ff_atom_t *atom)
-{
- char header[10];
- int result;
-
- atom->start = mp4ff_position(file);
-
- mp4ff_atom_reset(atom);
-
- if(!mp4ff_read_data(file, header, HEADER_LENGTH)) return 1;
- result = mp4ff_atom_read_type(header, atom->type);
- atom->size = mp4ff_atom_read_size(header);
- if (atom->size == 0) {
- atom->size = file->total_length - atom->start;
- }
- atom->end = atom->start + atom->size;
-
-/* Skip placeholder atom */
- if(mp4ff_match_32(atom->type, "wide"))
- {
- atom->start = mp4ff_position(file);
- mp4ff_atom_reset(atom);
- if(!mp4ff_read_data(file, header, HEADER_LENGTH))
- return 1;
- result = mp4ff_atom_read_type(header, atom->type);
- atom->size -= 8;
- if(!atom->size)
- {
-/* Wrapper ended. Get new atom size */
- atom->size = mp4ff_atom_read_size(header);
- if (atom->size == 0) {
- atom->size = file->total_length - atom->start;
- }
- }
- atom->end = atom->start + atom->size;
- }
- else
-/* Get extended size */
- if(atom->size == 1)
- {
- if(!mp4ff_read_data(file, header, HEADER_LENGTH)) return 1;
- atom->size = mp4ff_atom_read_size64(header);
- }
-
-
-#ifdef DEBUG
- printf("Reading atom %.4s length %u\n", atom->type, atom->size);
-#endif
- return result;
-}
-
-int mp4ff_atom_write_header(mp4ff_t *file, mp4ff_atom_t *atom, char *text)
-{
- atom->start = mp4ff_position(file);
- mp4ff_write_int32(file, 0);
- mp4ff_write_char32(file, text);
-}
-
-int mp4ff_atom_write_footer(mp4ff_t *file, mp4ff_atom_t *atom)
-{
- atom->end = mp4ff_position(file);
- mp4ff_set_position(file, atom->start);
- mp4ff_write_int32(file, atom->end - atom->start);
- mp4ff_set_position(file, atom->end);
-}
-
-int mp4ff_atom_is(mp4ff_atom_t *atom, char *type)
-{
- if(atom->type[0] == type[0] &&
- atom->type[1] == type[1] &&
- atom->type[2] == type[2] &&
- atom->type[3] == type[3])
- return 1;
- else
- return 0;
-}
-
-long mp4ff_atom_read_size(char *data)
-{
- unsigned long result;
- unsigned long a, b, c, d;
-
- a = (unsigned char)data[0];
- b = (unsigned char)data[1];
- c = (unsigned char)data[2];
- d = (unsigned char)data[3];
-
- result = (a<<24) | (b<<16) | (c<<8) | d;
- if(result > 0 && result < HEADER_LENGTH) result = HEADER_LENGTH;
- return (long)result;
-}
-
-uint64_t mp4ff_atom_read_size64(char *data)
-{
- uint64_t result = 0;
- int i;
-
- for (i = 0; i < 8; i++) {
- result |= data[i];
- if (i < 7) {
- result <<= 8;
- }
- }
-
- if(result < HEADER_LENGTH)
- result = HEADER_LENGTH;
- return result;
-}
-
-int mp4ff_atom_read_type(char *data, char *type)
-{
- type[0] = data[4];
- type[1] = data[5];
- type[2] = data[6];
- type[3] = data[7];
-
-/*printf("%c%c%c%c ", type[0], type[1], type[2], type[3]); */
-/* need this for mp4ff_check_sig */
- if(isalpha(type[0]) && isalpha(type[1]) && isalpha(type[2]) && isalpha(type[3]))
- return 0;
- else
- return 1;
-}
-
-int mp4ff_atom_skip(mp4ff_t *file, mp4ff_atom_t *atom)
-{
- /* printf("skipping atom %.4s, size %u\n", atom->type, atom->size); */
- return mp4ff_set_position(file, atom->end);
-}
-
--- a/common/mp4ff/ctts.c
+++ /dev/null
@@ -1,130 +1,0 @@
-/*
- * The contents of this file are subject to the Mozilla Public
- * License Version 1.1 (the "License"); you may not use this file
- * except in compliance with the License. You may obtain a copy of
- * the License at http://www.mozilla.org/MPL/
- *
- * Software distributed under the License is distributed on an "AS
- * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * rights and limitations under the License.
- *
- * The Original Code is MPEG4IP.
- *
- * The Initial Developer of the Original Code is Cisco Systems Inc.
- * Portions created by Cisco Systems Inc. are
- * Copyright (C) Cisco Systems Inc. 2000, 2001. All Rights Reserved.
- *
- * Contributor(s):
- * Dave Mackie [email protected]
- */
-
-#include "mp4ff.h"
-
-
-int mp4ff_ctts_init(mp4ff_ctts_t *ctts)
-{
- ctts->version = 0;
- ctts->flags = 0;
- ctts->total_entries = 0;
- ctts->entries_allocated = 0;
-}
-
-int mp4ff_ctts_init_table(mp4ff_ctts_t *ctts)
-{
- if (!ctts->entries_allocated) {
- ctts->entries_allocated = 1;
- ctts->table = (mp4ff_ctts_table_t*)
- malloc(sizeof(mp4ff_ctts_table_t) * ctts->entries_allocated);
- ctts->total_entries = 1;
- }
-}
-
-int mp4ff_ctts_init_common(mp4ff_t *file, mp4ff_ctts_t *ctts)
-{
- mp4ff_ctts_table_t *table;
- mp4ff_ctts_init_table(ctts);
- table = &(ctts->table[0]);
-
- table->sample_count = 0; /* need to set this when closing */
- table->sample_offset = 0;
-}
-
-int mp4ff_ctts_delete(mp4ff_ctts_t *ctts)
-{
- if (ctts->total_entries) {
- free(ctts->table);
- }
- ctts->total_entries = 0;
-}
-
-int mp4ff_ctts_dump(mp4ff_ctts_t *ctts)
-{
- int i;
- printf(" composition time to sample\n");
- printf(" version %d\n", ctts->version);
- printf(" flags %d\n", ctts->flags);
- printf(" total_entries %d\n", ctts->total_entries);
- for(i = 0; i < ctts->total_entries; i++) {
- printf(" count %ld offset %ld\n",
- ctts->table[i].sample_count,
- ctts->table[i].sample_offset);
- }
-}
-
-int mp4ff_read_ctts(mp4ff_t *file, mp4ff_ctts_t *ctts)
-{
- int i;
- ctts->version = mp4ff_read_char(file);
- ctts->flags = mp4ff_read_int24(file);
- ctts->total_entries = mp4ff_read_int32(file);
-
- ctts->table = (mp4ff_ctts_table_t*)
- malloc(sizeof(mp4ff_ctts_table_t) * ctts->total_entries);
-
- for (i = 0; i < ctts->total_entries; i++) {
- ctts->table[i].sample_count = mp4ff_read_int32(file);
- ctts->table[i].sample_offset = mp4ff_read_int32(file);
- }
-}
-
-int mp4ff_write_ctts(mp4ff_t *file, mp4ff_ctts_t *ctts)
-{
- int i;
- mp4ff_atom_t atom;
-
- if (ctts->total_entries == 1 && ctts->table[0].sample_offset == 0) {
- return;
- }
-
- mp4ff_atom_write_header(file, &atom, "ctts");
-
- mp4ff_write_char(file, ctts->version);
- mp4ff_write_int24(file, ctts->flags);
- mp4ff_write_int32(file, ctts->total_entries);
- for(i = 0; i < ctts->total_entries; i++) {
- mp4ff_write_int32(file, ctts->table[i].sample_count);
- mp4ff_write_int32(file, ctts->table[i].sample_offset);
- }
- mp4ff_atom_write_footer(file, &atom);
-}
-
-int mp4ff_update_ctts(mp4ff_ctts_t *ctts, long sample_offset)
-{
- if (sample_offset == ctts->table[ctts->total_entries-1].sample_offset) {
- ctts->table[ctts->total_entries-1].sample_count++;
- } else {
- /* need a new entry in the table */
-
- /* allocate more entries if necessary */
- if (ctts->total_entries >= ctts->entries_allocated) {
- ctts->entries_allocated *= 2;
- ctts->table = (mp4ff_ctts_table_t*)realloc(ctts->table,
- sizeof(mp4ff_ctts_table_t) * ctts->entries_allocated);
- }
-
- ctts->table[ctts->total_entries].sample_count = 1;
- ctts->table[ctts->total_entries].sample_offset = sample_offset;
- ctts->total_entries++;
- }
-}
--- a/common/mp4ff/dinf.c
+++ /dev/null
@@ -1,44 +1,0 @@
-#include "mp4ff.h"
-
-int mp4ff_dinf_init(mp4ff_dinf_t *dinf)
-{
- mp4ff_dref_init(&(dinf->dref));
-}
-
-int mp4ff_dinf_delete(mp4ff_dinf_t *dinf)
-{
- mp4ff_dref_delete(&(dinf->dref));
-}
-
-int mp4ff_dinf_init_all(mp4ff_dinf_t *dinf)
-{
- mp4ff_dref_init_all(&(dinf->dref));
-}
-
-int mp4ff_dinf_dump(mp4ff_dinf_t *dinf)
-{
- printf(" data information (dinf)\n");
- mp4ff_dref_dump(&(dinf->dref));
-}
-
-int mp4ff_read_dinf(mp4ff_t *file, mp4ff_dinf_t *dinf, mp4ff_atom_t *dinf_atom)
-{
- mp4ff_atom_t leaf_atom;
-
- do
- {
- mp4ff_atom_read_header(file, &leaf_atom);
- if(mp4ff_atom_is(&leaf_atom, "dref"))
- { mp4ff_read_dref(file, &(dinf->dref)); }
- else
- mp4ff_atom_skip(file, &leaf_atom);
- }while(mp4ff_position(file) < dinf_atom->end);
-}
-
-int mp4ff_write_dinf(mp4ff_t *file, mp4ff_dinf_t *dinf)
-{
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "dinf");
- mp4ff_write_dref(file, &(dinf->dref));
- mp4ff_atom_write_footer(file, &atom);
-}
--- a/common/mp4ff/dref.c
+++ /dev/null
@@ -1,130 +1,0 @@
-#include "mp4ff.h"
-
-int mp4ff_dref_table_init(mp4ff_dref_table_t *table)
-{
- table->size = 0;
- table->type[0] = 'a';
- table->type[1] = 'l';
- table->type[2] = 'i';
- table->type[3] = 's';
- table->version = 0;
- table->flags = 0x0001;
- table->data_reference = malloc(256);
- table->data_reference[0] = 0;
-}
-
-int mp4ff_dref_table_delete(mp4ff_dref_table_t *table)
-{
- if(table->data_reference) free(table->data_reference);
- table->data_reference = 0;
-}
-
-int mp4ff_read_dref_table(mp4ff_t *file, mp4ff_dref_table_t *table)
-{
- table->size = mp4ff_read_int32(file);
- mp4ff_read_char32(file, table->type);
- table->version = mp4ff_read_char(file);
- table->flags = mp4ff_read_int24(file);
- if(table->data_reference) free(table->data_reference);
-
- table->data_reference = malloc(table->size);
- if(table->size > 12)
- mp4ff_read_data(file, table->data_reference, table->size - 12);
- table->data_reference[table->size - 12] = 0;
-}
-
-int mp4ff_write_dref_table(mp4ff_t *file, mp4ff_dref_table_t *table)
-{
- int len = strlen(table->data_reference);
- mp4ff_write_int32(file, 12 + len);
- mp4ff_write_char32(file, table->type);
- mp4ff_write_char(file, table->version);
- mp4ff_write_int24(file, table->flags);
- if(len)
- mp4ff_write_data(file, table->data_reference, len);
-}
-
-int mp4ff_dref_table_dump(mp4ff_dref_table_t *table)
-{
- printf(" data reference table (dref)\n");
- printf(" type %c%c%c%c\n", table->type[0], table->type[1], table->type[2], table->type[3]);
- printf(" version %d\n", table->version);
- printf(" flags %d\n", table->flags);
- printf(" data %s\n", table->data_reference);
-}
-
-
-int mp4ff_dref_init(mp4ff_dref_t *dref)
-{
- dref->version = 0;
- dref->flags = 0;
- dref->total_entries = 0;
- dref->table = 0;
-}
-
-int mp4ff_dref_init_all(mp4ff_dref_t *dref)
-{
- if(!dref->total_entries)
- {
- dref->total_entries = 1;
- dref->table = (mp4ff_dref_table_t *)malloc(sizeof(mp4ff_dref_table_t) * dref->total_entries);
- mp4ff_dref_table_init(&(dref->table[0]));
- }
-}
-
-int mp4ff_dref_delete(mp4ff_dref_t *dref)
-{
- if(dref->table)
- {
- int i;
- for(i = 0; i < dref->total_entries; i++)
- mp4ff_dref_table_delete(&(dref->table[i]));
- free(dref->table);
- }
- dref->total_entries = 0;
-}
-
-int mp4ff_dref_dump(mp4ff_dref_t *dref)
-{
- int i;
-
- printf(" data reference (dref)\n");
- printf(" version %d\n", dref->version);
- printf(" flags %d\n", dref->flags);
- for(i = 0; i < dref->total_entries; i++)
- {
- mp4ff_dref_table_dump(&(dref->table[i]));
- }
-}
-
-int mp4ff_read_dref(mp4ff_t *file, mp4ff_dref_t *dref)
-{
- int i;
-
- dref->version = mp4ff_read_char(file);
- dref->flags = mp4ff_read_int24(file);
- dref->total_entries = mp4ff_read_int32(file);
- dref->table = (mp4ff_dref_table_t*)malloc(sizeof(mp4ff_dref_table_t) * dref->total_entries);
- for(i = 0; i < dref->total_entries; i++)
- {
- mp4ff_dref_table_init(&(dref->table[i]));
- mp4ff_read_dref_table(file, &(dref->table[i]));
- }
-}
-
-int mp4ff_write_dref(mp4ff_t *file, mp4ff_dref_t *dref)
-{
- int i;
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "dref");
-
- mp4ff_write_char(file, dref->version);
- mp4ff_write_int24(file, dref->flags);
- mp4ff_write_int32(file, dref->total_entries);
-
- for(i = 0; i < dref->total_entries; i++)
- {
- mp4ff_write_dref_table(file, &(dref->table[i]));
- }
- mp4ff_atom_write_footer(file, &atom);
-}
--- a/common/mp4ff/edts.c
+++ /dev/null
@@ -1,44 +1,0 @@
-#include "mp4ff.h"
-
-int mp4ff_edts_init(mp4ff_edts_t *edts)
-{
- mp4ff_elst_init(&(edts->elst));
-}
-
-int mp4ff_edts_delete(mp4ff_edts_t *edts)
-{
- mp4ff_elst_delete(&(edts->elst));
-}
-
-int mp4ff_edts_init_table(mp4ff_edts_t *edts)
-{
- mp4ff_elst_init_all(&(edts->elst));
-}
-
-int mp4ff_read_edts(mp4ff_t *file, mp4ff_edts_t *edts, mp4ff_atom_t *edts_atom)
-{
- mp4ff_atom_t leaf_atom;
-
- do
- {
- mp4ff_atom_read_header(file, &leaf_atom);
- if(mp4ff_atom_is(&leaf_atom, "elst"))
- { mp4ff_read_elst(file, &(edts->elst)); }
- else
- mp4ff_atom_skip(file, &leaf_atom);
- }while(mp4ff_position(file) < edts_atom->end);
-}
-
-int mp4ff_edts_dump(mp4ff_edts_t *edts)
-{
- printf(" edit atom (edts)\n");
- mp4ff_elst_dump(&(edts->elst));
-}
-
-int mp4ff_write_edts(mp4ff_t *file, mp4ff_edts_t *edts, long duration)
-{
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "edts");
- mp4ff_write_elst(file, &(edts->elst), duration);
- mp4ff_atom_write_footer(file, &atom);
-}
--- a/common/mp4ff/elst.c
+++ /dev/null
@@ -1,112 +1,0 @@
-#include "mp4ff.h"
-
-
-int mp4ff_elst_table_init(mp4ff_elst_table_t *table)
-{
- table->duration = 0;
- table->time = 0;
- table->rate = 1;
-}
-
-int mp4ff_elst_table_delete(mp4ff_elst_table_t *table)
-{
-}
-
-int mp4ff_read_elst_table(mp4ff_t *file, mp4ff_elst_table_t *table)
-{
- table->duration = mp4ff_read_int32(file);
- table->time = mp4ff_read_int32(file);
- table->rate = mp4ff_read_fixed32(file);
-}
-
-int mp4ff_write_elst_table(mp4ff_t *file, mp4ff_elst_table_t *table, long duration)
-{
- table->duration = duration;
- mp4ff_write_int32(file, table->duration);
- mp4ff_write_int32(file, table->time);
- mp4ff_write_fixed32(file, table->rate);
-}
-
-int mp4ff_elst_table_dump(mp4ff_elst_table_t *table)
-{
- printf(" edit list table\n");
- printf(" duration %ld\n", table->duration);
- printf(" time %ld\n", table->time);
- printf(" rate %f\n", table->rate);
-}
-
-int mp4ff_elst_init(mp4ff_elst_t *elst)
-{
- elst->version = 0;
- elst->flags = 0;
- elst->total_entries = 0;
- elst->table = 0;
-}
-
-int mp4ff_elst_init_all(mp4ff_elst_t *elst)
-{
- if(!elst->total_entries)
- {
- elst->total_entries = 1;
- elst->table = (mp4ff_elst_table_t*)malloc(sizeof(mp4ff_elst_table_t) * elst->total_entries);
- mp4ff_elst_table_init(&(elst->table[0]));
- }
-}
-
-int mp4ff_elst_delete(mp4ff_elst_t *elst)
-{
- int i;
- if(elst->total_entries)
- {
- for(i = 0; i < elst->total_entries; i++)
- mp4ff_elst_table_delete(&(elst->table[i]));
- free(elst->table);
- }
- elst->total_entries = 0;
-}
-
-int mp4ff_elst_dump(mp4ff_elst_t *elst)
-{
- int i;
- printf(" edit list (elst)\n");
- printf(" version %d\n", elst->version);
- printf(" flags %d\n", elst->flags);
- printf(" total_entries %d\n", elst->total_entries);
-
- for(i = 0; i < elst->total_entries; i++)
- {
- mp4ff_elst_table_dump(&(elst->table[i]));
- }
-}
-
-int mp4ff_read_elst(mp4ff_t *file, mp4ff_elst_t *elst)
-{
- int i;
-
- elst->version = mp4ff_read_char(file);
- elst->flags = mp4ff_read_int24(file);
- elst->total_entries = mp4ff_read_int32(file);
- elst->table = (mp4ff_elst_table_t*)malloc(sizeof(mp4ff_elst_table_t) * elst->total_entries);
- for(i = 0; i < elst->total_entries; i++)
- {
- mp4ff_elst_table_init(&(elst->table[i]));
- mp4ff_read_elst_table(file, &(elst->table[i]));
- }
-}
-
-int mp4ff_write_elst(mp4ff_t *file, mp4ff_elst_t *elst, long duration)
-{
- mp4ff_atom_t atom;
- int i;
- mp4ff_atom_write_header(file, &atom, "elst");
-
- mp4ff_write_char(file, elst->version);
- mp4ff_write_int24(file, elst->flags);
- mp4ff_write_int32(file, elst->total_entries);
- for(i = 0; i < elst->total_entries; i++)
- {
- mp4ff_write_elst_table(file, elst->table, duration);
- }
-
- mp4ff_atom_write_footer(file, &atom);
-}
--- a/common/mp4ff/esds.c
+++ /dev/null
@@ -1,194 +1,0 @@
-/*
- * The contents of this file are subject to the Mozilla Public
- * License Version 1.1 (the "License"); you may not use this file
- * except in compliance with the License. You may obtain a copy of
- * the License at http://www.mozilla.org/MPL/
- *
- * Software distributed under the License is distributed on an "AS
- * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * rights and limitations under the License.
- *
- * The Original Code is MPEG4IP.
- *
- * The Initial Developer of the Original Code is Cisco Systems Inc.
- * Portions created by Cisco Systems Inc. are
- * Copyright (C) Cisco Systems Inc. 2000, 2001. All Rights Reserved.
- *
- * Contributor(s):
- * Dave Mackie [email protected]
- */
-
-#include "mp4ff.h"
-
-
-int mp4ff_esds_init(mp4ff_esds_t *esds)
-{
- esds->version = 0;
- esds->flags = 0;
- esds->decoderConfigLen = 0;
- esds->decoderConfig = NULL;
- return 0;
-}
-
-int mp4ff_esds_get_decoder_config(mp4ff_esds_t* esds, unsigned char** ppBuf, int* pBufSize)
-{
- if (esds->decoderConfig == NULL || esds->decoderConfigLen == 0) {
- *ppBuf = NULL;
- *pBufSize = 0;
- } else {
- *ppBuf = malloc(esds->decoderConfigLen);
- if (*ppBuf == NULL) {
- *pBufSize = 0;
- return 1;
- }
- memcpy(*ppBuf, esds->decoderConfig, esds->decoderConfigLen);
- *pBufSize = esds->decoderConfigLen;
- }
- return 0;
-}
-
-int mp4ff_esds_set_decoder_config(mp4ff_esds_t* esds, unsigned char* pBuf, int bufSize)
-{
- free(esds->decoderConfig);
- esds->decoderConfig = malloc(bufSize);
- if (esds->decoderConfig) {
- memcpy(esds->decoderConfig, pBuf, bufSize);
- esds->decoderConfigLen = bufSize;
- return 0;
- }
- return 1;
-}
-
-int mp4ff_esds_delete(mp4ff_esds_t *esds)
-{
- free(esds->decoderConfig);
- return 0;
-}
-
-int mp4ff_esds_dump(mp4ff_esds_t *esds)
-{
- int i;
-
- printf(" elementary stream descriptor\n");
- printf(" version %d\n", esds->version);
- printf(" flags %ld\n", esds->flags);
- printf(" decoder config ");
- for (i = 0; i < esds->decoderConfigLen; i++) {
- printf("%02x ", esds->decoderConfig[i]);
- }
- printf("\n");
-}
-
-int mp4ff_read_esds(mp4ff_t *file, mp4ff_esds_t *esds)
-{
- uint8_t tag;
-
- esds->version = mp4ff_read_char(file);
- esds->flags = mp4ff_read_int24(file);
-
- /* get and verify ES_DescrTag */
- tag = mp4ff_read_char(file);
- if (tag == 0x03) {
- /* read length */
- if (mp4ff_read_mp4_descr_length(file) < 5 + 15) {
- return 1;
- }
- /* skip 3 bytes */
- mp4ff_set_position(file, mp4ff_position(file) + 3);
- } else {
- /* skip 2 bytes */
- mp4ff_set_position(file, mp4ff_position(file) + 2);
- }
-
- /* get and verify DecoderConfigDescrTab */
- if (mp4ff_read_char(file) != 0x04) {
- return 1;
- }
-
- /* read length */
- if (mp4ff_read_mp4_descr_length(file) < 15) {
- return 1;
- }
-
- /* skip 13 bytes */
- mp4ff_set_position(file, mp4ff_position(file) + 13);
-
- /* get and verify DecSpecificInfoTag */
- if (mp4ff_read_char(file) != 0x05) {
- return 1;
- }
-
- /* read length */
- esds->decoderConfigLen = mp4ff_read_mp4_descr_length(file);
-
- free(esds->decoderConfig);
- esds->decoderConfig = malloc(esds->decoderConfigLen);
- if (esds->decoderConfig) {
- mp4ff_read_data(file, esds->decoderConfig, esds->decoderConfigLen);
- } else {
- esds->decoderConfigLen = 0;
- }
-
- /* will skip the remainder of the atom */
- return 0;
-}
-
-int mp4ff_write_esds_common(mp4ff_t *file, mp4ff_esds_t *esds, int esid, unsigned int objectType, unsigned int streamType)
-{
- mp4ff_atom_t atom;
-
- mp4ff_atom_write_header(file, &atom, "esds");
-
- mp4ff_write_char(file, esds->version);
- mp4ff_write_int24(file, esds->flags);
-
- mp4ff_write_char(file, 0x03); /* ES_DescrTag */
- mp4ff_write_mp4_descr_length(file,
- 3 + (5 + (13 + (5 + esds->decoderConfigLen))) + 3, /*FALSE*/0);
-
- mp4ff_write_int16(file, esid);
- mp4ff_write_char(file, 0x10); /* streamPriorty = 16 (0-31) */
-
- /* DecoderConfigDescriptor */
- mp4ff_write_char(file, 0x04); /* DecoderConfigDescrTag */
- mp4ff_write_mp4_descr_length(file,
- 13 + (5 + esds->decoderConfigLen), 0 /*FALSE*/);
-
- mp4ff_write_char(file, objectType); /* objectTypeIndication */
- mp4ff_write_char(file, streamType); /* streamType */
-
- mp4ff_write_int24(file, 0); /* buffer size */
- mp4ff_write_int32(file, 0); /* max bitrate */
- mp4ff_write_int32(file, 0); /* average bitrate */
-
- mp4ff_write_char(file, 0x05); /* DecSpecificInfoTag */
- mp4ff_write_mp4_descr_length(file, esds->decoderConfigLen, 0 /*FALSE*/);
- mp4ff_write_data(file, esds->decoderConfig, esds->decoderConfigLen);
-
- /* SLConfigDescriptor */
- mp4ff_write_char(file, 0x06); /* SLConfigDescrTag */
- mp4ff_write_char(file, 0x01); /* length */
- mp4ff_write_char(file, 0x02); /* constant in mp4 files */
-
- /* no IPI_DescrPointer */
- /* no IP_IdentificationDataSet */
- /* no IPMP_DescriptorPointer */
- /* no LanguageDescriptor */
- /* no QoS_Descriptor */
- /* no RegistrationDescriptor */
- /* no ExtensionDescriptor */
-
- mp4ff_atom_write_footer(file, &atom);
-}
-
-int mp4ff_write_esds_audio(mp4ff_t *file, mp4ff_esds_t *esds, int esid)
-{
- return mp4ff_write_esds_common(file, esds, esid, (unsigned int)0x40, (unsigned int)0x05);
-}
-
-int mp4ff_write_esds_video(mp4ff_t *file, mp4ff_esds_t *esds, int esid)
-{
- return mp4ff_write_esds_common(file, esds, esid, (unsigned int)0x20, (unsigned int)0x04);
-}
-
--- a/common/mp4ff/funcprotos.h
+++ /dev/null
@@ -1,156 +1,0 @@
-#ifndef FUNCPROTOS_H
-#define FUNCPROTOS_H
-
-/* atom handling routines */
-long mp4ff_atom_read_size(char *data);
-uint64_t mp4ff_atom_read_size64(char *data);
-int mp4ff_atom_write_header(mp4ff_t *file, mp4ff_atom_t *atom, char *text);
-int mp4ff_atom_read_header(mp4ff_t *file, mp4ff_atom_t *atom);
-int mp4ff_atom_write_footer(mp4ff_t *file, mp4ff_atom_t *atom);
-
-mp4ff_trak_t* mp4ff_add_track(mp4ff_moov_t *moov);
-mp4ff_trak_t* mp4ff_find_track_by_id(mp4ff_moov_t *moov, int trackId);
-
-
-/* initializers for every atom */
-int mp4ff_matrix_init(mp4ff_matrix_t *matrix);
-int mp4ff_edts_init_table(mp4ff_edts_t *edts);
-int mp4ff_edts_init(mp4ff_edts_t *edts);
-int mp4ff_elst_init(mp4ff_elst_t *elst);
-int mp4ff_elst_init_all(mp4ff_elst_t *elst);
-int mp4ff_elst_table_init(mp4ff_elst_table_t *table); /* initialize a table */
-int mp4ff_tkhd_init(mp4ff_tkhd_t *tkhd);
-int mp4ff_tkhd_init_video(mp4ff_t *file, mp4ff_tkhd_t *tkhd, int frame_w, int frame_h);
-int mp4ff_stsd_table_init(mp4ff_stsd_table_t *table);
-int mp4ff_stsd_init(mp4ff_stsd_t *stsd);
-int mp4ff_stsd_init_table(mp4ff_stsd_t *stsd);
-int mp4ff_stsd_init_video(mp4ff_t *file, mp4ff_stsd_t *stsd, int frame_w, int frame_h, float frame_rate, char *compression);
-int mp4ff_stsd_init_audio(mp4ff_t *file, mp4ff_stsd_t *stsd, int channels, int sample_rate, int bits, char *compressor);
-int mp4ff_stts_init(mp4ff_stts_t *stts);
-int mp4ff_stts_init_table(mp4ff_stts_t *stts);
-int mp4ff_stts_init_video(mp4ff_t *file, mp4ff_stts_t *stts, int time_scale, float frame_rate);
-int mp4ff_stts_init_audio(mp4ff_t *file, mp4ff_stts_t *stts, int time_scale, int sample_duration);
-int mp4ff_stss_init(mp4ff_stss_t *stss);
-int mp4ff_stss_init_common(mp4ff_t *file, mp4ff_stss_t *stss);
-int mp4ff_stsc_init(mp4ff_stsc_t *stsc);
-int mp4ff_stsc_init_video(mp4ff_t *file, mp4ff_stsc_t *stsc);
-int mp4ff_stsc_init_audio(mp4ff_t *file, mp4ff_stsc_t *stsc);
-int mp4ff_stsz_init(mp4ff_stsz_t *stsz);
-int mp4ff_stsz_init_video(mp4ff_t *file, mp4ff_stsz_t *stsz);
-int mp4ff_stsz_init_audio(mp4ff_t *file, mp4ff_stsz_t *stsz, int sample_size);
-int mp4ff_stco_init(mp4ff_stco_t *stco);
-int mp4ff_stco_init_common(mp4ff_t *file, mp4ff_stco_t *stco);
-int mp4ff_stbl_init(mp4ff_stbl_t *tkhd);
-int mp4ff_stbl_init_video(mp4ff_t *file, mp4ff_stbl_t *stbl, int frame_w, int frame_h, int time_scale, float frame_rate, char *compressor);
-int mp4ff_stbl_init_audio(mp4ff_t *file, mp4ff_stbl_t *stbl, int channels, int sample_rate, int bits, int sample_size, int time_scale, int sample_duration, char *compressor);
-int mp4ff_vmhd_init(mp4ff_vmhd_t *vmhd);
-int mp4ff_vmhd_init_video(mp4ff_t *file, mp4ff_vmhd_t *vmhd, int frame_w, int frame_h, float frame_rate);
-int mp4ff_smhd_init(mp4ff_smhd_t *smhd);
-int mp4ff_dref_table_init(mp4ff_dref_table_t *table);
-int mp4ff_dref_init_all(mp4ff_dref_t *dref);
-int mp4ff_dref_init(mp4ff_dref_t *dref);
-int mp4ff_dinf_init_all(mp4ff_dinf_t *dinf);
-int mp4ff_dinf_init(mp4ff_dinf_t *dinf);
-int mp4ff_minf_init(mp4ff_minf_t *minf);
-int mp4ff_minf_init_video(mp4ff_t *file, mp4ff_minf_t *minf, int frame_w, int frame_h, int time_scale, float frame_rate, char *compressor);
-int mp4ff_minf_init_audio(mp4ff_t *file, mp4ff_minf_t *minf, int channels, int sample_rate, int bits, int sample_size, int time_scale, int sample_duration, char *compressor);
-int mp4ff_mdhd_init(mp4ff_mdhd_t *mdhd);
-int mp4ff_mdhd_init_video(mp4ff_t *file, mp4ff_mdhd_t *mdhd, int time_scale);
-int mp4ff_mdhd_init_audio(mp4ff_t *file, mp4ff_mdhd_t *mdhd, int time_scale);
-int mp4ff_mdia_init(mp4ff_mdia_t *mdia);
-int mp4ff_mdia_init_video(mp4ff_t *file, mp4ff_mdia_t *mdia, int frame_w, int frame_h, float frame_rate, int time_scale, char *compressor);
-int mp4ff_mdia_init_audio(mp4ff_t *file, mp4ff_mdia_t *mdia, int channels, int sample_rate, int bits, int sample_size, int time_scale, int sample_duration, char *compressor);
-int mp4ff_trak_init(mp4ff_trak_t *trak);
-int mp4ff_trak_init_video(mp4ff_t *file, mp4ff_trak_t *trak, int frame_w, int frame_h, float frame_rate, int time_scale, char *compressor);
-int mp4ff_trak_init_audio(mp4ff_t *file, mp4ff_trak_t *trak, int channels, int sample_rate, int bits, int sample_size, int time_scale, int sample_duration, char *compressor);
-int mp4ff_udta_init(mp4ff_udta_t *udta);
-int mp4ff_mvhd_init(mp4ff_mvhd_t *mvhd);
-int mp4ff_moov_init(mp4ff_moov_t *moov);
-int mp4ff_mdat_init(mp4ff_mdat_t *mdat);
-int mp4ff_init(mp4ff_t *file);
-int mp4ff_hdlr_init(mp4ff_hdlr_t *hdlr);
-int mp4ff_hdlr_init_video(mp4ff_hdlr_t *hdlr);
-int mp4ff_hdlr_init_audio(mp4ff_hdlr_t *hdlr);
-int mp4ff_hdlr_init_data(mp4ff_hdlr_t *hdlr);
-
-/* utilities for reading data types */
-int mp4ff_read_data(mp4ff_t *file, char *data, int size);
-int mp4ff_write_data(mp4ff_t *file, char *data, int size);
-int mp4ff_read_pascal(mp4ff_t *file, char *data);
-int mp4ff_write_pascal(mp4ff_t *file, char *data);
-float mp4ff_read_fixed32(mp4ff_t *file);
-int mp4ff_write_fixed32(mp4ff_t *file, float number);
-float mp4ff_read_fixed16(mp4ff_t *file);
-int mp4ff_write_fixed16(mp4ff_t *file, float number);
-uint64_t mp4ff_read_int64(mp4ff_t *file);
-int mp4ff_write_int64(mp4ff_t *file, uint64_t number);
-long mp4ff_read_int32(mp4ff_t *file);
-int mp4ff_write_int32(mp4ff_t *file, long number);
-long mp4ff_read_int24(mp4ff_t *file);
-int mp4ff_write_int24(mp4ff_t *file, long number);
-int mp4ff_read_int16(mp4ff_t *file);
-int mp4ff_write_int16(mp4ff_t *file, int number);
-int mp4ff_read_char(mp4ff_t *file);
-int mp4ff_write_char(mp4ff_t *file, char x);
-int mp4ff_read_char32(mp4ff_t *file, char *string);
-int mp4ff_write_char32(mp4ff_t *file, char *string);
-int mp4ff_copy_char32(char *output, char *input);
-long mp4ff_position(mp4ff_t *file);
-int mp4ff_read_mp4_descr_length(mp4ff_t *file);
-int mp4ff_write_mp4_descr_length(mp4ff_t *file, int length, unsigned char compact);
-
-/* Most codecs don't specify the actual number of bits on disk in the stbl. */
-/* Convert the samples to the number of bytes for reading depending on the codec. */
-long mp4ff_samples_to_bytes(mp4ff_trak_t *track, long samples);
-
-
-/* chunks always start on 1 */
-/* samples start on 0 */
-
-/* queries for every atom */
-/* the starting sample in the given chunk */
-long mp4ff_sample_of_chunk(mp4ff_trak_t *trak, long chunk);
-
-/* number of samples in the chunk */
-long mp4ff_chunk_samples(mp4ff_trak_t *trak, long chunk);
-
-/* the byte offset from mdat start of the chunk */
-long mp4ff_chunk_to_offset(mp4ff_trak_t *trak, long chunk);
-
-/* the chunk of any offset from mdat start */
-long mp4ff_offset_to_chunk(long *chunk_offset, mp4ff_trak_t *trak, long offset);
-
-/* the total number of samples in the track depending on the access mode */
-long mp4ff_track_samples(mp4ff_t *file, mp4ff_trak_t *trak);
-
-/* total bytes between the two samples */
-long mp4ff_sample_range_size(mp4ff_trak_t *trak, long chunk_sample, long sample);
-
-/* update the position pointers in all the tracks after a set_position */
-int mp4ff_update_positions(mp4ff_t *file);
-
-/* converting between mdat offsets to samples */
-long mp4ff_sample_to_offset(mp4ff_trak_t *trak, long sample);
-long mp4ff_offset_to_sample(mp4ff_trak_t *trak, long offset);
-
-mp4ff_trak_t* mp4ff_add_trak(mp4ff_moov_t *moov);
-int mp4ff_delete_trak(mp4ff_moov_t *moov, mp4ff_trak_t *trak);
-int mp4ff_get_timescale(float frame_rate);
-
-/* update all the tables after writing a buffer */
-/* set sample_size to 0 if no sample size should be set */
-int mp4ff_update_tables(mp4ff_t *file,
- mp4ff_trak_t *trak,
- long offset,
- long chunk,
- long sample,
- long samples,
- long sample_size,
- long sample_duration,
- unsigned char isSyncSample,
- long renderingOffset);
-unsigned long mp4ff_current_time();
-
-void mp4ff_print_chars(char *desc, char *input, int len);
-
-#endif
--- a/common/mp4ff/hdlr.c
+++ /dev/null
@@ -1,98 +1,0 @@
-#include "mp4ff.h"
-
-
-
-int mp4ff_hdlr_init(mp4ff_hdlr_t *hdlr)
-{
- hdlr->version = 0;
- hdlr->flags = 0;
- hdlr->component_type[0] = 'm';
- hdlr->component_type[1] = 'h';
- hdlr->component_type[2] = 'l';
- hdlr->component_type[3] = 'r';
- hdlr->component_subtype[0] = 'v';
- hdlr->component_subtype[1] = 'i';
- hdlr->component_subtype[2] = 'd';
- hdlr->component_subtype[3] = 'e';
- hdlr->component_manufacturer = 0;
- hdlr->component_flags = 0;
- hdlr->component_flag_mask = 0;
- strcpy(hdlr->component_name, "Linux Media Handler");
-}
-
-int mp4ff_hdlr_init_video(mp4ff_hdlr_t *hdlr)
-{
- hdlr->component_subtype[0] = 'v';
- hdlr->component_subtype[1] = 'i';
- hdlr->component_subtype[2] = 'd';
- hdlr->component_subtype[3] = 'e';
- strcpy(hdlr->component_name, "Linux Video Media Handler");
-}
-
-int mp4ff_hdlr_init_audio(mp4ff_hdlr_t *hdlr)
-{
- hdlr->component_subtype[0] = 's';
- hdlr->component_subtype[1] = 'o';
- hdlr->component_subtype[2] = 'u';
- hdlr->component_subtype[3] = 'n';
- strcpy(hdlr->component_name, "Linux Sound Media Handler");
-}
-
-int mp4ff_hdlr_init_data(mp4ff_hdlr_t *hdlr)
-{
- hdlr->component_type[0] = 'd';
- hdlr->component_type[1] = 'h';
- hdlr->component_type[2] = 'l';
- hdlr->component_type[3] = 'r';
- hdlr->component_subtype[0] = 'a';
- hdlr->component_subtype[1] = 'l';
- hdlr->component_subtype[2] = 'i';
- hdlr->component_subtype[3] = 's';
- strcpy(hdlr->component_name, "Linux Alias Data Handler");
-}
-
-int mp4ff_hdlr_delete(mp4ff_hdlr_t *hdlr)
-{
-}
-
-int mp4ff_hdlr_dump(mp4ff_hdlr_t *hdlr)
-{
- printf(" handler reference (hdlr)\n");
- printf(" version %d\n", hdlr->version);
- printf(" flags %d\n", hdlr->flags);
- printf(" component_type %c%c%c%c\n", hdlr->component_type[0], hdlr->component_type[1], hdlr->component_type[2], hdlr->component_type[3]);
- printf(" component_subtype %c%c%c%c\n", hdlr->component_subtype[0], hdlr->component_subtype[1], hdlr->component_subtype[2], hdlr->component_subtype[3]);
- printf(" component_name %s\n", hdlr->component_name);
-}
-
-int mp4ff_read_hdlr(mp4ff_t *file, mp4ff_hdlr_t *hdlr)
-{
- hdlr->version = mp4ff_read_char(file);
- hdlr->flags = mp4ff_read_int24(file);
- mp4ff_read_char32(file, hdlr->component_type);
- mp4ff_read_char32(file, hdlr->component_subtype);
- hdlr->component_manufacturer = mp4ff_read_int32(file);
- hdlr->component_flags = mp4ff_read_int32(file);
- hdlr->component_flag_mask = mp4ff_read_int32(file);
- // TBD read null terminated string
-}
-
-int mp4ff_write_hdlr(mp4ff_t *file, mp4ff_hdlr_t *hdlr)
-{
- int i;
-
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "hdlr");
-
- mp4ff_write_char(file, hdlr->version);
- mp4ff_write_int24(file, hdlr->flags);
-
- mp4ff_write_int32(file, 0x00000000);
- mp4ff_write_char32(file, hdlr->component_subtype);
- for (i = 0; i < 3; i++) {
- mp4ff_write_int32(file, 0x00000000);
- }
- mp4ff_write_data(file, hdlr->component_name, strlen(hdlr->component_name) + 1);
-
- mp4ff_atom_write_footer(file, &atom);
-}
--- a/common/mp4ff/iods.c
+++ /dev/null
@@ -1,102 +1,0 @@
-/*
- * The contents of this file are subject to the Mozilla Public
- * License Version 1.1 (the "License"); you may not use this file
- * except in compliance with the License. You may obtain a copy of
- * the License at http://www.mozilla.org/MPL/
- *
- * Software distributed under the License is distributed on an "AS
- * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
- * implied. See the License for the specific language governing
- * rights and limitations under the License.
- *
- * The Original Code is MPEG4IP.
- *
- * The Initial Developer of the Original Code is Cisco Systems Inc.
- * Portions created by Cisco Systems Inc. are
- * Copyright (C) Cisco Systems Inc. 2000, 2001. All Rights Reserved.
- *
- * Contributor(s):
- * Dave Mackie [email protected]
- */
-
-#include "mp4ff.h"
-
-
-int mp4ff_iods_init(mp4ff_iods_t *iods)
-{
- iods->version = 0;
- iods->flags = 0;
- iods->audioProfileId = 0xFF;
- iods->videoProfileId = 0xFF;
- return 0;
-}
-
-int mp4ff_iods_set_audio_profile(mp4ff_iods_t* iods, int id)
-{
- iods->audioProfileId = id;
-}
-
-int mp4ff_iods_set_video_profile(mp4ff_iods_t* iods, int id)
-{
- iods->videoProfileId = id;
-}
-
-int mp4ff_iods_delete(mp4ff_iods_t *iods)
-{
- return 0;
-}
-
-int mp4ff_iods_dump(mp4ff_iods_t *iods)
-{
- printf(" initial object descriptor\n");
- printf(" version %d\n", iods->version);
- printf(" flags %ld\n", iods->flags);
- printf(" audioProfileId %u\n", iods->audioProfileId);
- printf(" videoProfileId %u\n", iods->videoProfileId);
-}
-
-int mp4ff_read_iods(mp4ff_t *file, mp4ff_iods_t *iods)
-{
- iods->version = mp4ff_read_char(file);
- iods->flags = mp4ff_read_int24(file);
- mp4ff_read_char(file); /* skip tag */
- mp4ff_read_mp4_descr_length(file); /* skip length */
- /* skip ODID, ODProfile, sceneProfile */
- mp4ff_set_position(file, mp4ff_position(file) + 4);
- iods->audioProfileId = mp4ff_read_char(file);
- iods->videoProfileId = mp4ff_read_char(file);
- /* will skip the remainder of the atom */
-}
-
-int mp4ff_write_iods(mp4ff_t *file, mp4ff_iods_t *iods)
-{
- mp4ff_atom_t atom;
- int i;
-
- mp4ff_atom_write_header(file, &atom, "iods");
-
- mp4ff_write_char(file, iods->version);
- mp4ff_write_int24(file, iods->flags);
-
- mp4ff_write_char(file, 0x10); /* MP4_IOD_Tag */
- mp4ff_write_char(file, 7 + (file->moov.total_tracks * (1+1+4))); /* length */
- mp4ff_write_int16(file, 0x004F); /* ObjectDescriptorID = 1 */
- mp4ff_write_char(file, 0xFF); /* ODProfileLevel */
- mp4ff_write_char(file, 0xFF); /* sceneProfileLevel */
- mp4ff_write_char(file, iods->audioProfileId); /* audioProfileLevel */
- mp4ff_write_char(file, iods->videoProfileId); /* videoProfileLevel */
- mp4ff_write_char(file, 0xFF); /* graphicsProfileLevel */
-
- for (i = 0; i < file->moov.total_tracks; i++) {
- mp4ff_write_char(file, 0x0E); /* ES_ID_IncTag */
- mp4ff_write_char(file, 0x04); /* length */
- mp4ff_write_int32(file, file->moov.trak[i]->tkhd.track_id);
- }
-
- /* no OCI_Descriptors */
- /* no IPMP_DescriptorPointers */
- /* no Extenstion_Descriptors */
-
- mp4ff_atom_write_footer(file, &atom);
-}
-
--- a/common/mp4ff/matrix.c
+++ /dev/null
@@ -1,42 +1,0 @@
-#include "mp4ff.h"
-
-
-
-
-int mp4ff_matrix_init(mp4ff_matrix_t *matrix)
-{
- int i;
- for(i = 0; i < 9; i++) matrix->values[i] = 0;
- matrix->values[0] = matrix->values[4] = 1;
- matrix->values[8] = 16384;
-}
-
-int mp4ff_matrix_delete(mp4ff_matrix_t *matrix)
-{
-}
-
-int mp4ff_read_matrix(mp4ff_t *file, mp4ff_matrix_t *matrix)
-{
- int i = 0;
- for(i = 0; i < 9; i++)
- {
- matrix->values[i] = mp4ff_read_fixed32(file);
- }
-}
-
-int mp4ff_matrix_dump(mp4ff_matrix_t *matrix)
-{
- int i;
- printf(" matrix");
- for(i = 0; i < 9; i++) printf(" %f", matrix->values[i]);
- printf("\n");
-}
-
-int mp4ff_write_matrix(mp4ff_t *file, mp4ff_matrix_t *matrix)
-{
- int i;
- for(i = 0; i < 9; i++)
- {
- mp4ff_write_fixed32(file, matrix->values[i]);
- }
-}
--- a/common/mp4ff/mdat.c
+++ /dev/null
@@ -1,43 +1,0 @@
-#include "mp4ff.h"
-
-int mp4ff_mdat_init(mp4ff_mdat_t *mdat)
-{
- mdat->size = 8;
- mdat->start = 0;
-}
-
-int mp4ff_mdat_delete(mp4ff_mdat_t *mdat)
-{
-}
-
-int mp4ff_read_mdat(mp4ff_t *file, mp4ff_mdat_t *mdat, mp4ff_atom_t *parent_atom)
-{
- mdat->size = parent_atom->size;
- mdat->start = parent_atom->start;
- mp4ff_atom_skip(file, parent_atom);
-}
-
-int mp4ff_write_mdat(mp4ff_t *file, mp4ff_mdat_t *mdat)
-{
- long position, size = 0, new_size = 0;
- int i, j;
-
- for(i = 0; i < file->total_atracks; i++)
- {
- new_size = mp4ff_track_end(file->atracks[i].track);
- if(new_size > size)
- size = new_size;
- }
-
- for(i = 0; i < file->total_vtracks; i++)
- {
- new_size = mp4ff_track_end(file->vtracks[i].track);
- if(new_size > size)
- size = new_size;
- }
-
- mdat->size = size;
- mp4ff_set_position(file, mdat->start);
- mp4ff_write_int32(file, mdat->size);
- mp4ff_set_position(file, mdat->start + mdat->size);
-}
--- a/common/mp4ff/mdhd.c
+++ /dev/null
@@ -1,76 +1,0 @@
-#include "mp4ff.h"
-
-int mp4ff_mdhd_init(mp4ff_mdhd_t *mdhd)
-{
- mdhd->version = 0;
- mdhd->flags = 0;
- mdhd->creation_time = mp4ff_current_time();
- mdhd->modification_time = mp4ff_current_time();
- mdhd->time_scale = 0;
- mdhd->duration = 0;
- mdhd->language = 0;
- mdhd->quality = 0;
-}
-
-int mp4ff_mdhd_init_video(mp4ff_t *file,
- mp4ff_mdhd_t *mdhd,
- int time_scale)
-{
- mdhd->time_scale = time_scale;
- mdhd->duration = 0; /* set this when closing */
-}
-
-int mp4ff_mdhd_init_audio(mp4ff_t *file,
- mp4ff_mdhd_t *mdhd,
- int time_scale)
-{
- mdhd->time_scale = time_scale;
- mdhd->duration = 0; /* set this when closing */
-}
-
-mp4ff_mdhd_delete(mp4ff_mdhd_t *mdhd)
-{
-}
-
-int mp4ff_read_mdhd(mp4ff_t *file, mp4ff_mdhd_t *mdhd)
-{
- mdhd->version = mp4ff_read_char(file);
- mdhd->flags = mp4ff_read_int24(file);
- mdhd->creation_time = mp4ff_read_int32(file);
- mdhd->modification_time = mp4ff_read_int32(file);
- mdhd->time_scale = mp4ff_read_int32(file);
- mdhd->duration = mp4ff_read_int32(file);
- mdhd->language = mp4ff_read_int16(file);
- mdhd->quality = mp4ff_read_int16(file);
-}
-
-int mp4ff_mdhd_dump(mp4ff_mdhd_t *mdhd)
-{
- printf(" media header\n");
- printf(" version %d\n", mdhd->version);
- printf(" flags %d\n", mdhd->flags);
- printf(" creation_time %u\n", mdhd->creation_time);
- printf(" modification_time %u\n", mdhd->modification_time);
- printf(" time_scale %d\n", mdhd->time_scale);
- printf(" duration %d\n", mdhd->duration);
- printf(" language %d\n", mdhd->language);
- printf(" quality %d\n", mdhd->quality);
-}
-
-int mp4ff_write_mdhd(mp4ff_t *file, mp4ff_mdhd_t *mdhd)
-{
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "mdhd");
-
- mp4ff_write_char(file, mdhd->version);
- mp4ff_write_int24(file, mdhd->flags);
- mp4ff_write_int32(file, mdhd->creation_time);
- mp4ff_write_int32(file, mdhd->modification_time);
- mp4ff_write_int32(file, mdhd->time_scale);
- mp4ff_write_int32(file, mdhd->duration);
- mp4ff_write_int16(file, mdhd->language);
- mp4ff_write_int16(file, 0x0000);
-
- mp4ff_atom_write_footer(file, &atom);
-}
-
--- a/common/mp4ff/mdia.c
+++ /dev/null
@@ -1,93 +1,0 @@
-#include "mp4ff.h"
-
-
-int mp4ff_mdia_init(mp4ff_mdia_t *mdia)
-{
- mp4ff_mdhd_init(&(mdia->mdhd));
- mp4ff_hdlr_init(&(mdia->hdlr));
- mp4ff_minf_init(&(mdia->minf));
-}
-
-int mp4ff_mdia_init_video(mp4ff_t *file,
- mp4ff_mdia_t *mdia,
- int frame_w,
- int frame_h,
- float frame_rate,
- int time_scale,
- char *compressor)
-{
- mp4ff_mdhd_init_video(file, &(mdia->mdhd), time_scale);
- mp4ff_minf_init_video(file, &(mdia->minf), frame_w, frame_h, mdia->mdhd.time_scale, frame_rate, compressor);
- mp4ff_hdlr_init_video(&(mdia->hdlr));
-}
-
-int mp4ff_mdia_init_audio(mp4ff_t *file,
- mp4ff_mdia_t *mdia,
- int channels,
- int sample_rate,
- int bits,
- int sample_size,
- int time_scale,
- int sample_duration,
- char *compressor)
-{
- mp4ff_mdhd_init_audio(file, &(mdia->mdhd), time_scale);
- mp4ff_minf_init_audio(file, &(mdia->minf), channels, sample_rate, bits, sample_size, time_scale, sample_duration, compressor);
- mp4ff_hdlr_init_audio(&(mdia->hdlr));
-}
-
-int mp4ff_mdia_delete(mp4ff_mdia_t *mdia)
-{
- mp4ff_mdhd_delete(&(mdia->mdhd));
- mp4ff_hdlr_delete(&(mdia->hdlr));
- mp4ff_minf_delete(&(mdia->minf));
-}
-
-int mp4ff_mdia_dump(mp4ff_mdia_t *mdia)
-{
- printf(" media\n");
- mp4ff_mdhd_dump(&(mdia->mdhd));
- mp4ff_hdlr_dump(&(mdia->hdlr));
- mp4ff_minf_dump(&(mdia->minf));
-}
-
-int mp4ff_read_mdia(mp4ff_t *file, mp4ff_mdia_t *mdia, mp4ff_atom_t *trak_atom)
-{
- mp4ff_atom_t leaf_atom;
-
- do
- {
- mp4ff_atom_read_header(file, &leaf_atom);
-
-/* mandatory */
- if(mp4ff_atom_is(&leaf_atom, "mdhd"))
- { mp4ff_read_mdhd(file, &(mdia->mdhd)); }
- else
- if(mp4ff_atom_is(&leaf_atom, "hdlr"))
- {
- mp4ff_read_hdlr(file, &(mdia->hdlr));
-/* Main Actor doesn't write component name */
- mp4ff_atom_skip(file, &leaf_atom);
-/*printf("mp4ff_read_mdia %ld\n", mp4ff_position(file)); */
- }
- else
- if(mp4ff_atom_is(&leaf_atom, "minf"))
- { mp4ff_read_minf(file, &(mdia->minf), &leaf_atom); }
- else
- mp4ff_atom_skip(file, &leaf_atom);
- }while(mp4ff_position(file) < trak_atom->end);
-
- return 0;
-}
-
-int mp4ff_write_mdia(mp4ff_t *file, mp4ff_mdia_t *mdia)
-{
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "mdia");
-
- mp4ff_write_mdhd(file, &(mdia->mdhd));
- mp4ff_write_hdlr(file, &(mdia->hdlr));
- mp4ff_write_minf(file, &(mdia->minf));
-
- mp4ff_atom_write_footer(file, &atom);
-}
--- a/common/mp4ff/minf.c
+++ /dev/null
@@ -1,124 +1,0 @@
-#include "mp4ff.h"
-
-
-
-int mp4ff_minf_init(mp4ff_minf_t *minf)
-{
- minf->is_video = minf->is_audio = 0;
- mp4ff_vmhd_init(&(minf->vmhd));
- mp4ff_smhd_init(&(minf->smhd));
- mp4ff_hdlr_init(&(minf->hdlr));
- mp4ff_dinf_init(&(minf->dinf));
- mp4ff_stbl_init(&(minf->stbl));
-}
-
-int mp4ff_minf_init_video(mp4ff_t *file,
- mp4ff_minf_t *minf,
- int frame_w,
- int frame_h,
- int time_scale,
- float frame_rate,
- char *compressor)
-{
- minf->is_video = 1;
- mp4ff_vmhd_init_video(file, &(minf->vmhd), frame_w, frame_h, frame_rate);
- mp4ff_stbl_init_video(file, &(minf->stbl), frame_w, frame_h, time_scale, frame_rate, compressor);
- mp4ff_hdlr_init_data(&(minf->hdlr));
- mp4ff_dinf_init_all(&(minf->dinf));
-}
-
-int mp4ff_minf_init_audio(mp4ff_t *file,
- mp4ff_minf_t *minf,
- int channels,
- int sample_rate,
- int bits,
- int sample_size,
- int time_scale,
- int sample_duration,
- char *compressor)
-{
- minf->is_audio = 1;
-/* smhd doesn't store anything worth initializing */
- mp4ff_stbl_init_audio(file, &(minf->stbl), channels, sample_rate, bits, sample_size, time_scale, sample_duration, compressor);
- mp4ff_hdlr_init_data(&(minf->hdlr));
- mp4ff_dinf_init_all(&(minf->dinf));
-}
-
-int mp4ff_minf_delete(mp4ff_minf_t *minf)
-{
- mp4ff_vmhd_delete(&(minf->vmhd));
- mp4ff_smhd_delete(&(minf->smhd));
- mp4ff_dinf_delete(&(minf->dinf));
- mp4ff_stbl_delete(&(minf->stbl));
- mp4ff_hdlr_delete(&(minf->hdlr));
-}
-
-int mp4ff_minf_dump(mp4ff_minf_t *minf)
-{
- printf(" media info\n");
- printf(" is_audio %d\n", minf->is_audio);
- printf(" is_video %d\n", minf->is_video);
- if(minf->is_audio) mp4ff_smhd_dump(&(minf->smhd));
- if(minf->is_video) mp4ff_vmhd_dump(&(minf->vmhd));
- mp4ff_hdlr_dump(&(minf->hdlr));
- mp4ff_dinf_dump(&(minf->dinf));
- mp4ff_stbl_dump(minf, &(minf->stbl));
-}
-
-int mp4ff_read_minf(mp4ff_t *file, mp4ff_minf_t *minf, mp4ff_atom_t *parent_atom)
-{
- mp4ff_atom_t leaf_atom;
- long pos = mp4ff_position(file);
-
- do
- {
- mp4ff_atom_read_header(file, &leaf_atom);
-
-/* mandatory */
- if(mp4ff_atom_is(&leaf_atom, "vmhd"))
- { minf->is_video = 1; mp4ff_read_vmhd(file, &(minf->vmhd)); }
- else
- if(mp4ff_atom_is(&leaf_atom, "smhd"))
- { minf->is_audio = 1; mp4ff_read_smhd(file, &(minf->smhd)); }
- else
- if(mp4ff_atom_is(&leaf_atom, "hdlr"))
- {
- mp4ff_read_hdlr(file, &(minf->hdlr));
-/* Main Actor doesn't write component name */
- mp4ff_atom_skip(file, &leaf_atom);
- }
- else
- if(mp4ff_atom_is(&leaf_atom, "dinf"))
- { mp4ff_read_dinf(file, &(minf->dinf), &leaf_atom); }
- else
- mp4ff_atom_skip(file, &leaf_atom);
- }while(mp4ff_position(file) < parent_atom->end);
-
- mp4ff_set_position(file, pos);
-
- do {
- mp4ff_atom_read_header(file, &leaf_atom);
-
- if(mp4ff_atom_is(&leaf_atom, "stbl")) {
- mp4ff_read_stbl(file, minf, &(minf->stbl), &leaf_atom);
- } else {
- mp4ff_atom_skip(file, &leaf_atom);
- }
- } while(mp4ff_position(file) < parent_atom->end);
-
- return 0;
-}
-
-int mp4ff_write_minf(mp4ff_t *file, mp4ff_minf_t *minf)
-{
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "minf");
-
- if(minf->is_video) mp4ff_write_vmhd(file, &(minf->vmhd));
- if(minf->is_audio) mp4ff_write_smhd(file, &(minf->smhd));
- mp4ff_write_hdlr(file, &(minf->hdlr));
- mp4ff_write_dinf(file, &(minf->dinf));
- mp4ff_write_stbl(file, minf, &(minf->stbl));
-
- mp4ff_atom_write_footer(file, &atom);
-}
--- a/common/mp4ff/moov.c
+++ /dev/null
@@ -1,130 +1,0 @@
-#include "mp4ff.h"
-
-
-
-int mp4ff_moov_init(mp4ff_moov_t *moov)
-{
- int i;
-
- moov->total_tracks = 0;
- for(i = 0 ; i < MAXTRACKS; i++) moov->trak[i] = 0;
- mp4ff_mvhd_init(&(moov->mvhd));
- mp4ff_iods_init(&(moov->iods));
- mp4ff_udta_init(&(moov->udta));
- return 0;
-}
-
-int mp4ff_moov_delete(mp4ff_moov_t *moov)
-{
- int i;
- while(moov->total_tracks) {
- mp4ff_delete_trak(moov, moov->trak[moov->total_tracks - 1]);
- }
- mp4ff_mvhd_delete(&(moov->mvhd));
- mp4ff_iods_delete(&(moov->iods));
- mp4ff_udta_delete(&(moov->udta));
- return 0;
-}
-
-int mp4ff_moov_dump(mp4ff_moov_t *moov)
-{
- int i;
- printf("movie\n");
- mp4ff_mvhd_dump(&(moov->mvhd));
- mp4ff_iods_dump(&(moov->iods));
- mp4ff_udta_dump(&(moov->udta));
- for(i = 0; i < moov->total_tracks; i++)
- mp4ff_trak_dump(moov->trak[i]);
-}
-
-
-int mp4ff_read_moov(mp4ff_t *file, mp4ff_moov_t *moov, mp4ff_atom_t *parent_atom)
-{
-/* mandatory mvhd */
- mp4ff_atom_t leaf_atom;
-
- do
- {
- mp4ff_atom_read_header(file, &leaf_atom);
-
- if(mp4ff_atom_is(&leaf_atom, "mvhd"))
- {
- mp4ff_read_mvhd(file, &(moov->mvhd));
- }
- else
- if(mp4ff_atom_is(&leaf_atom, "iods"))
- {
- mp4ff_read_iods(file, &(moov->iods));
- mp4ff_atom_skip(file, &leaf_atom);
- }
- else
- if(mp4ff_atom_is(&leaf_atom, "trak"))
- {
- mp4ff_trak_t *trak = mp4ff_add_trak(moov);
- mp4ff_read_trak(file, trak, &leaf_atom);
- }
- else
- if(mp4ff_atom_is(&leaf_atom, "udta"))
- {
- mp4ff_read_udta(file, &(moov->udta), &leaf_atom);
- mp4ff_atom_skip(file, &leaf_atom);
- }
- else
- {
- mp4ff_atom_skip(file, &leaf_atom);
- }
- }while(mp4ff_position(file) < parent_atom->end);
-
- return 0;
-}
-
-int mp4ff_write_moov(mp4ff_t *file, mp4ff_moov_t *moov)
-{
- mp4ff_atom_t atom;
- int i;
- long longest_duration = 0;
- long duration, timescale;
- mp4ff_atom_write_header(file, &atom, "moov");
-
-/* get the duration from the longest track in the mvhd's timescale */
- for(i = 0; i < moov->total_tracks; i++)
- {
- mp4ff_trak_fix_counts(file, moov->trak[i]);
- mp4ff_trak_duration(moov->trak[i], &duration, ×cale);
-
- duration = (long)((float)duration / timescale * moov->mvhd.time_scale);
-
- if(duration > longest_duration)
- {
- longest_duration = duration;
- }
- }
- moov->mvhd.duration = longest_duration;
- moov->mvhd.selection_duration = longest_duration;
-
- mp4ff_write_mvhd(file, &(moov->mvhd));
- mp4ff_write_iods(file, &(moov->iods));
- mp4ff_write_udta(file, &(moov->udta));
-
- for(i = 0; i < moov->total_tracks; i++)
- {
- mp4ff_write_trak(file, moov->trak[i], moov->mvhd.time_scale);
- }
-
- mp4ff_atom_write_footer(file, &atom);
-}
-
-int mp4ff_update_durations(mp4ff_moov_t *moov)
-{
-
-}
-
-int mp4ff_shift_offsets(mp4ff_moov_t *moov, long offset)
-{
- int i;
- for(i = 0; i < moov->total_tracks; i++)
- {
- mp4ff_trak_shift_offsets(moov->trak[i], offset);
- }
- return 0;
-}
--- /dev/null
+++ b/common/mp4ff/mp4atom.c
@@ -1,0 +1,422 @@
+/*
+** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
+** Copyright (C) 2003 M. Bakker, Ahead Software AG, http://www.nero.com
+**
+** This program is free software; you can redistribute it and/or modify
+** it under the terms of the GNU General Public License as published by
+** the Free Software Foundation; either version 2 of the License, or
+** (at your option) any later version.
+**
+** This program is distributed in the hope that it will be useful,
+** but WITHOUT ANY WARRANTY; without even the implied warranty of
+** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+** GNU General Public License for more details.
+**
+** You should have received a copy of the GNU General Public License
+** along with this program; if not, write to the Free Software
+** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+**
+** Any non-GPL usage of this software or parts of this software is strictly
+** forbidden.
+**
+** Commercial non-GPL licensing of this software is possible.
+** For more info contact Ahead Software through [email protected].
+**
+** $Id: mp4atom.c,v 1.1 2003/11/21 15:08:48 menno Exp $
+**/
+
+#include <stdlib.h>
+#include "mp4ff.h"
+
+
+/* parse atom header size */
+int32_t mp4ff_atom_get_size(int8_t *data)
+{
+ uint32_t result;
+ uint32_t a, b, c, d;
+
+ a = (uint8_t)data[0];
+ b = (uint8_t)data[1];
+ c = (uint8_t)data[2];
+ d = (uint8_t)data[3];
+
+ result = (a<<24) | (b<<16) | (c<<8) | d;
+ if (result > 0 && result < 8) result = 8;
+
+ return (int32_t)result;
+}
+
+/* comnapre 2 atom names, returns 1 for equal, 0 for unequal */
+int32_t mp4ff_atom_compare(int8_t a1, int8_t b1, int8_t c1, int8_t d1,
+ int8_t a2, int8_t b2, int8_t c2, int8_t d2)
+{
+ if (a1 == a2 && b1 == b2 && c1 == c2 && d1 == d2)
+ return 1;
+ else
+ return 0;
+}
+
+uint8_t mp4ff_atom_name_to_type(int8_t a, int8_t b, int8_t c, int8_t d)
+{
+ if (a == 'm')
+ {
+ if (mp4ff_atom_compare(a,b,c,d, 'm','o','o','v'))
+ return ATOM_MOOV;
+ else if (mp4ff_atom_compare(a,b,c,d, 'm','i','n','f'))
+ return ATOM_MINF;
+ else if (mp4ff_atom_compare(a,b,c,d, 'm','d','i','a'))
+ return ATOM_MDIA;
+ else if (mp4ff_atom_compare(a,b,c,d, 'm','d','a','t'))
+ return ATOM_MDAT;
+ else if (mp4ff_atom_compare(a,b,c,d, 'm','d','h','d'))
+ return ATOM_MDHD;
+ else if (mp4ff_atom_compare(a,b,c,d, 'm','v','h','d'))
+ return ATOM_MVHD;
+ else if (mp4ff_atom_compare(a,b,c,d, 'm','p','4','a'))
+ return ATOM_MP4A;
+ else if (mp4ff_atom_compare(a,b,c,d, 'm','p','4','v'))
+ return ATOM_MP4V;
+ else if (mp4ff_atom_compare(a,b,c,d, 'm','p','4','s'))
+ return ATOM_MP4S;
+ } else if (a == 't') {
+ if (mp4ff_atom_compare(a,b,c,d, 't','r','a','k'))
+ return ATOM_TRAK;
+ else if (mp4ff_atom_compare(a,b,c,d, 't','k','h','d'))
+ return ATOM_TKHD;
+ else if (mp4ff_atom_compare(a,b,c,d, 't','r','e','f'))
+ return ATOM_TREF;
+ } else if (a == 's') {
+ if (mp4ff_atom_compare(a,b,c,d, 's','t','b','l'))
+ return ATOM_STBL;
+ else if (mp4ff_atom_compare(a,b,c,d, 's','m','h','d'))
+ return ATOM_SMHD;
+ else if (mp4ff_atom_compare(a,b,c,d, 's','t','s','d'))
+ return ATOM_STSD;
+ else if (mp4ff_atom_compare(a,b,c,d, 's','t','t','s'))
+ return ATOM_STTS;
+ else if (mp4ff_atom_compare(a,b,c,d, 's','t','c','o'))
+ return ATOM_STCO;
+ else if (mp4ff_atom_compare(a,b,c,d, 's','t','s','c'))
+ return ATOM_STSC;
+ else if (mp4ff_atom_compare(a,b,c,d, 's','t','s','z'))
+ return ATOM_STSZ;
+ else if (mp4ff_atom_compare(a,b,c,d, 's','t','z','2'))
+ return ATOM_STZ2;
+ else if (mp4ff_atom_compare(a,b,c,d, 's','k','i','p'))
+ return ATOM_SKIP;
+ }
+
+ if (mp4ff_atom_compare(a,b,c,d, 'e','d','t','s'))
+ return ATOM_EDTS;
+ else if (mp4ff_atom_compare(a,b,c,d, 'e','s','d','s'))
+ return ATOM_ESDS;
+ else if (mp4ff_atom_compare(a,b,c,d, 'f','t','y','p'))
+ return ATOM_FTYP;
+ else if (mp4ff_atom_compare(a,b,c,d, 'f','r','e','e'))
+ return ATOM_FREE;
+ else if (mp4ff_atom_compare(a,b,c,d, 'h','m','h','d'))
+ return ATOM_HMHD;
+ else if (mp4ff_atom_compare(a,b,c,d, 'v','m','h','d'))
+ return ATOM_VMHD;
+ else
+ return ATOM_UNKNOWN;
+}
+
+/* read atom header, return atom size, atom size is with header included */
+int32_t mp4ff_atom_read_header(mp4ff_t *f, uint8_t *atom_type)
+{
+ int32_t size;
+ int32_t ret;
+ int8_t atom_header[8];
+
+ ret = mp4ff_read_data(f, atom_header, 8);
+ if (ret != 8)
+ return 0;
+
+ size = mp4ff_atom_get_size(atom_header);
+
+ //fprintf(stdout, "%c%c%c%c\n", atom_header[4], atom_header[5], atom_header[6], atom_header[7]);
+
+ *atom_type = mp4ff_atom_name_to_type(atom_header[4], atom_header[5], atom_header[6], atom_header[7]);
+
+ return size;
+}
+
+
+int32_t mp4ff_read_stsz(mp4ff_t *f)
+{
+ /* version */ mp4ff_read_char(f);
+ /* flags */ mp4ff_read_int24(f);
+ f->track[f->total_tracks - 1]->stsz_sample_size = mp4ff_read_int32(f);
+ f->track[f->total_tracks - 1]->stsz_sample_count = mp4ff_read_int32(f);
+
+ if (f->track[f->total_tracks - 1]->stsz_sample_size == 0)
+ {
+ int32_t i;
+ f->track[f->total_tracks - 1]->stsz_table =
+ (int32_t*)malloc(f->track[f->total_tracks - 1]->stsz_sample_count*sizeof(int32_t));
+
+ for (i = 0; i < f->track[f->total_tracks - 1]->stsz_sample_count; i++)
+ {
+ f->track[f->total_tracks - 1]->stsz_table[i] = mp4ff_read_int32(f);
+ }
+ }
+
+ return 0;
+}
+
+int32_t mp4ff_read_esds(mp4ff_t *f)
+{
+ uint8_t tag;
+
+ mp4ff_read_char(f); /* version */
+ mp4ff_read_int24(f); /* flags */
+
+ /* get and verify ES_DescrTag */
+ tag = mp4ff_read_char(f);
+ if (tag == 0x03)
+ {
+ /* read length */
+ if (mp4ff_read_mp4_descr_length(f) < 5 + 15)
+ {
+ return 1;
+ }
+ /* skip 3 bytes */
+ mp4ff_read_int24(f);
+ } else {
+ /* skip 2 bytes */
+ mp4ff_read_int16(f);
+ }
+
+ /* get and verify DecoderConfigDescrTab */
+ if (mp4ff_read_char(f) != 0x04)
+ {
+ return 1;
+ }
+
+ /* read length */
+ if (mp4ff_read_mp4_descr_length(f) < 15)
+ {
+ return 1;
+ }
+
+ /* skip 13 bytes */
+ mp4ff_read_int32(f);
+ mp4ff_read_int32(f);
+ mp4ff_read_int32(f);
+ mp4ff_read_char(f);
+
+ /* get and verify DecSpecificInfoTag */
+ if (mp4ff_read_char(f) != 0x05)
+ {
+ return 1;
+ }
+
+ /* read length */
+ f->track[f->total_tracks - 1]->decoderConfigLen = mp4ff_read_mp4_descr_length(f);
+
+ if (f->track[f->total_tracks - 1]->decoderConfig)
+ free(f->track[f->total_tracks - 1]->decoderConfig);
+ f->track[f->total_tracks - 1]->decoderConfig = malloc(f->track[f->total_tracks - 1]->decoderConfigLen);
+ if (f->track[f->total_tracks - 1]->decoderConfig)
+ {
+ mp4ff_read_data(f, f->track[f->total_tracks - 1]->decoderConfig, f->track[f->total_tracks - 1]->decoderConfigLen);
+ } else {
+ f->track[f->total_tracks - 1]->decoderConfigLen = 0;
+ }
+
+ /* will skip the remainder of the atom */
+ return 0;
+}
+
+int32_t mp4ff_read_mp4a(mp4ff_t *f)
+{
+ int32_t i, size;
+ uint8_t atom_type = 0;
+
+ for (i = 0; i < 6; i++)
+ {
+ mp4ff_read_char(f); /* reserved */
+ }
+ /* data_reference_index */ mp4ff_read_int16(f);
+
+ mp4ff_read_int32(f); /* reserved */
+ mp4ff_read_int32(f); /* reserved */
+
+ f->track[f->total_tracks - 1]->channelCount = mp4ff_read_int16(f);
+ f->track[f->total_tracks - 1]->sampleSize = mp4ff_read_int16(f);
+
+ mp4ff_read_int16(f);
+ mp4ff_read_int16(f);
+
+ f->track[f->total_tracks - 1]->sampleRate = mp4ff_read_int16(f);
+
+ mp4ff_read_int16(f);
+
+ size = mp4ff_atom_read_header(f, &atom_type);
+ if (atom_type == ATOM_ESDS)
+ {
+ mp4ff_read_esds(f);
+ }
+
+ return 0;
+}
+
+int32_t mp4ff_read_stsd(mp4ff_t *f)
+{
+ int32_t i;
+
+ mp4ff_read_char(f); /* version */
+ mp4ff_read_int24(f); /* flags */
+
+ f->track[f->total_tracks - 1]->stsd_entry_count = mp4ff_read_int32(f);
+
+ for (i = 0; i < f->track[f->total_tracks - 1]->stsd_entry_count; i++)
+ {
+ int32_t skip = mp4ff_position(f);
+ int32_t size;
+ uint8_t atom_type = 0;
+ size = mp4ff_atom_read_header(f, &atom_type);
+ skip += size;
+
+ if (atom_type == ATOM_MP4A)
+ {
+ f->track[f->total_tracks - 1]->type = TRACK_AUDIO;
+ mp4ff_read_mp4a(f);
+ } else if (atom_type == ATOM_MP4V) {
+ f->track[f->total_tracks - 1]->type = TRACK_VIDEO;
+ } else if (atom_type == ATOM_MP4S) {
+ f->track[f->total_tracks - 1]->type = TRACK_SYSTEM;
+ } else {
+ f->track[f->total_tracks - 1]->type = TRACK_UNKNOWN;
+ }
+
+ mp4ff_set_position(f, skip);
+ }
+
+ return 0;
+}
+
+int32_t mp4ff_read_stsc(mp4ff_t *f)
+{
+ int32_t i;
+
+ mp4ff_read_char(f); /* version */
+ mp4ff_read_int24(f); /* flags */
+ f->track[f->total_tracks - 1]->stsc_entry_count = mp4ff_read_int32(f);
+
+ f->track[f->total_tracks - 1]->stsc_first_chunk =
+ (int32_t*)malloc(f->track[f->total_tracks - 1]->stsc_entry_count*sizeof(int32_t));
+ f->track[f->total_tracks - 1]->stsc_samples_per_chunk =
+ (int32_t*)malloc(f->track[f->total_tracks - 1]->stsc_entry_count*sizeof(int32_t));
+ f->track[f->total_tracks - 1]->stsc_sample_desc_index =
+ (int32_t*)malloc(f->track[f->total_tracks - 1]->stsc_entry_count*sizeof(int32_t));
+
+ for (i = 0; i < f->track[f->total_tracks - 1]->stsc_entry_count; i++)
+ {
+ f->track[f->total_tracks - 1]->stsc_first_chunk[i] = mp4ff_read_int32(f);
+ f->track[f->total_tracks - 1]->stsc_samples_per_chunk[i] = mp4ff_read_int32(f);
+ f->track[f->total_tracks - 1]->stsc_sample_desc_index[i] = mp4ff_read_int32(f);
+ }
+
+ return 0;
+}
+
+int32_t mp4ff_read_stco(mp4ff_t *f)
+{
+ int32_t i;
+
+ /* version */ mp4ff_read_char(f);
+ /* flags */ mp4ff_read_int24(f);
+ f->track[f->total_tracks - 1]->stco_entry_count = mp4ff_read_int32(f);
+
+ f->track[f->total_tracks - 1]->stco_chunk_offset =
+ (int32_t*)malloc(f->track[f->total_tracks - 1]->stco_entry_count*sizeof(int32_t));
+
+ for (i = 0; i < f->track[f->total_tracks - 1]->stco_entry_count; i++)
+ {
+ f->track[f->total_tracks - 1]->stco_chunk_offset[i] = mp4ff_read_int32(f);
+ }
+
+ return 0;
+}
+
+int32_t mp4ff_read_stts(mp4ff_t *f)
+{
+ int32_t i;
+
+ /* version */ mp4ff_read_char(f);
+ /* flags */ mp4ff_read_int24(f);
+ f->track[f->total_tracks - 1]->stts_entry_count = mp4ff_read_int32(f);
+
+ f->track[f->total_tracks - 1]->stts_sample_count = (int32_t*)malloc(f->track[f->total_tracks - 1]->stts_entry_count * sizeof(int32_t));
+ f->track[f->total_tracks - 1]->stts_sample_delta = (int32_t*)malloc(f->track[f->total_tracks - 1]->stts_entry_count * sizeof(int32_t));
+
+ for (i = 0; i < f->track[f->total_tracks - 1]->stts_entry_count; i++)
+ {
+ f->track[f->total_tracks - 1]->stts_sample_count[i] = mp4ff_read_int32(f);
+ f->track[f->total_tracks - 1]->stts_sample_delta[i] = mp4ff_read_int32(f);
+ }
+
+ return 0;
+}
+
+int32_t mp4ff_read_mvhd(mp4ff_t *f)
+{
+ int32_t i;
+
+ /* version */ mp4ff_read_char(f);
+ /* flags */ mp4ff_read_int24(f);
+ /* creation_time */ mp4ff_read_int32(f);
+ /* modification_time */ mp4ff_read_int32(f);
+ f->time_scale = mp4ff_read_int32(f);
+ f->duration = mp4ff_read_int32(f);
+ /* preferred_rate */ mp4ff_read_int32(f); /*mp4ff_read_fixed32(f);*/
+ /* preferred_volume */ mp4ff_read_int16(f); /*mp4ff_read_fixed16(f);*/
+ for (i = 0; i < 10; i++)
+ {
+ /* reserved */ mp4ff_read_char(f);
+ }
+ for (i = 0; i < 9; i++)
+ {
+ mp4ff_read_int32(f); /* matrix */
+ }
+ /* preview_time */ mp4ff_read_int32(f);
+ /* preview_duration */ mp4ff_read_int32(f);
+ /* poster_time */ mp4ff_read_int32(f);
+ /* selection_time */ mp4ff_read_int32(f);
+ /* selection_duration */ mp4ff_read_int32(f);
+ /* current_time */ mp4ff_read_int32(f);
+ /* next_track_id */ mp4ff_read_int32(f);
+
+ return 0;
+}
+
+int32_t mp4ff_atom_read(mp4ff_t *f, int32_t size, int8_t atom_type)
+{
+ if (atom_type == ATOM_STSZ)
+ {
+ /* sample size box */
+ mp4ff_read_stsz(f);
+ } else if (atom_type == ATOM_STTS) {
+ /* time to sample box */
+ mp4ff_read_stts(f);
+ } else if (atom_type == ATOM_STSC) {
+ /* sample to chunk box */
+ mp4ff_read_stsc(f);
+ } else if (atom_type == ATOM_STCO) {
+ /* chunk offset box */
+ mp4ff_read_stco(f);
+ } else if (atom_type == ATOM_STSD) {
+ /* sample description box */
+ mp4ff_read_stsd(f);
+ } else if (atom_type == ATOM_MVHD) {
+ /* movie header box */
+ mp4ff_read_mvhd(f);
+ } else {
+ /* skip this atom: not needed for reading */
+ mp4ff_set_position(f, mp4ff_position(f)+size-8);
+ }
+
+ return 0;
+}
--- a/common/mp4ff/mp4ff.c
+++ b/common/mp4ff/mp4ff.c
@@ -1,1256 +1,249 @@
+/*
+** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
+** Copyright (C) 2003 M. Bakker, Ahead Software AG, http://www.nero.com
+**
+** This program is free software; you can redistribute it and/or modify
+** it under the terms of the GNU General Public License as published by
+** the Free Software Foundation; either version 2 of the License, or
+** (at your option) any later version.
+**
+** This program is distributed in the hope that it will be useful,
+** but WITHOUT ANY WARRANTY; without even the implied warranty of
+** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+** GNU General Public License for more details.
+**
+** You should have received a copy of the GNU General Public License
+** along with this program; if not, write to the Free Software
+** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+**
+** Any non-GPL usage of this software or parts of this software is strictly
+** forbidden.
+**
+** Commercial non-GPL licensing of this software is possible.
+** For more info contact Ahead Software through [email protected].
+**
+** $Id: mp4ff.c,v 1.2 2003/11/21 15:08:48 menno Exp $
+**/
+
+#include <stdlib.h>
+#include <string.h>
#include "mp4ff.h"
-#if 0
-int mp4ff_make_streamable(mp4_callback_t *in_path, mp4_callback_t *out_path)
+mp4ff_t *mp4ff_open_read(mp4ff_callback_t *f)
{
- mp4ff_t file, *old_file, new_file;
- int moov_exists = 0, mdat_exists = 0, result, atoms = 1;
- long mdat_start, mdat_size;
- mp4ff_atom_t leaf_atom;
- long moov_length;
+ mp4ff_t *ff = malloc(sizeof(mp4ff_t));
- mp4ff_init(&file);
+ memset(ff, 0, sizeof(mp4ff_t));
-/* find the moov atom in the old file */
-
- if(!(file.stream = FOPEN(in_path, _T("rb"))))
- {
- //perror("mp4ff_make_streamable");
- return 1;
- }
+ ff->stream = f;
- file.total_length = file.stream->get_length();
+ parse_atoms(ff);
-/* get the locations of moov and mdat atoms */
- do
- {
-/*printf("%x\n", mp4ff_position(&file)); */
- result = mp4ff_atom_read_header(&file, &leaf_atom);
-
- if(!result)
- {
- if(mp4ff_atom_is(&leaf_atom, "moov"))
- {
- moov_exists = atoms;
- moov_length = leaf_atom.size;
- }
- else
- if(mp4ff_atom_is(&leaf_atom, "mdat"))
- {
- mdat_start = mp4ff_position(&file) - HEADER_LENGTH;
- mdat_size = leaf_atom.size;
- mdat_exists = atoms;
- }
-
- mp4ff_atom_skip(&file, &leaf_atom);
-
- atoms++;
- }
- }while(!result && mp4ff_position(&file) < file.total_length);
-
- if(!moov_exists)
- {
- printf("mp4ff_make_streamable: no moov atom\n");
- return 1;
- }
-
- if(!mdat_exists)
- {
- printf("mp4ff_make_streamable: no mdat atom\n");
- return 1;
- }
-
-/* copy the old file to the new file */
- if(moov_exists && mdat_exists)
- {
-/* moov wasn't the first atom */
- if(moov_exists > 1)
- {
- char *buffer;
- long buf_size = 1000000;
-
- result = 0;
-
-/* read the header proper */
- if(!(old_file = mp4ff_open(in_path, 1, 0, 0)))
- {
- return 1;
- }
-
- mp4ff_shift_offsets(&(old_file->moov), moov_length);
-
-/* open the output file */
- if(!(new_file.stream = FOPEN(out_path, _T("wb"))))
- {
- //perror("mp4ff_make_streamable");
- result = 1;
- }
- else
- {
-/* set up some flags */
- new_file.wr = 1;
- new_file.rd = 0;
- mp4ff_write_moov(&new_file, &(old_file->moov));
-
- mp4ff_set_position(old_file, mdat_start);
-
- if(!(buffer = calloc(1, buf_size)))
- {
- result = 1;
- printf("mp4ff_make_streamable: out of memory\n");
- }
- else
- {
- while(mp4ff_position(old_file) < mdat_start + mdat_size && !result)
- {
- if(mp4ff_position(old_file) + buf_size > mdat_start + mdat_size)
- buf_size = mdat_start + mdat_size - mp4ff_position(old_file);
-
- if(!mp4ff_read_data(old_file, buffer, buf_size)) result = 1;
- if(!result)
- {
- if(!mp4ff_write_data(&new_file, buffer, buf_size)) result = 1;
- }
- }
- free(buffer);
- }
- fclose(new_file.stream);
- }
- mp4ff_close(old_file);
- }
- else
- {
- printf("mp4ff_make_streamable: header already at 0 offset\n");
- return 0;
- }
- }
-
- return 0;
+ return ff;
}
-#endif
-int mp4ff_set_time_scale(mp4ff_t *file, int time_scale)
+void mp4ff_close(mp4ff_t *ff)
{
- file->moov.mvhd.time_scale = time_scale;
-}
+ int32_t i;
-int mp4ff_set_copyright(mp4ff_t *file, char *string)
-{
- mp4ff_set_udta_string(&(file->moov.udta.copyright), &(file->moov.udta.copyright_len), string);
-}
+ for (i = 0; i < ff->total_tracks; i++)
+ {
+ if (ff->track[i])
+ {
+ if (ff->track[i]->stsz_table)
+ free(ff->track[i]->stsz_table);
+ if (ff->track[i]->stts_sample_count)
+ free(ff->track[i]->stts_sample_count);
+ if (ff->track[i]->stts_sample_delta)
+ free(ff->track[i]->stts_sample_delta);
+ if (ff->track[i]->stsc_first_chunk)
+ free(ff->track[i]->stsc_first_chunk);
+ if (ff->track[i]->stsc_samples_per_chunk)
+ free(ff->track[i]->stsc_samples_per_chunk);
+ if (ff->track[i]->stsc_sample_desc_index)
+ free(ff->track[i]->stsc_sample_desc_index);
+ if (ff->track[i]->stco_chunk_offset)
+ free(ff->track[i]->stco_chunk_offset);
+ if (ff->track[i]->decoderConfig)
+ free(ff->track[i]->decoderConfig);
+ free(ff->track[i]);
+ }
+ }
-int mp4ff_set_name(mp4ff_t *file, char *string)
-{
- mp4ff_set_udta_string(&(file->moov.udta.name), &(file->moov.udta.name_len), string);
+ if (ff) free(ff);
}
-int mp4ff_set_info(mp4ff_t *file, char *string)
-{
- mp4ff_set_udta_string(&(file->moov.udta.info), &(file->moov.udta.info_len), string);
-}
-int mp4ff_get_time_scale(mp4ff_t *file)
-{
- return file->moov.mvhd.time_scale;
-}
-char* mp4ff_get_copyright(mp4ff_t *file)
+void mp4ff_track_add(mp4ff_t *f)
{
- return file->moov.udta.copyright;
-}
+ f->total_tracks++;
-char* mp4ff_get_name(mp4ff_t *file)
-{
- return file->moov.udta.name;
-}
+ f->track[f->total_tracks - 1] = malloc(sizeof(mp4ff_track_t));
-char* mp4ff_get_info(mp4ff_t *file)
-{
- return file->moov.udta.info;
+ memset(f->track[f->total_tracks - 1], 0, sizeof(mp4ff_track_t));
}
-int mp4ff_get_iod_audio_profile_level(mp4ff_t *file)
+/* parse atoms that are sub atoms of other atoms */
+int32_t parse_sub_atoms(mp4ff_t *f, int32_t total_size)
{
- return file->moov.iods.audioProfileId;
-}
+ int32_t size;
+ uint8_t atom_type = 0;
+ int32_t counted_size = 0;
-int mp4ff_set_iod_audio_profile_level(mp4ff_t *file, int id)
-{
- mp4ff_iods_set_audio_profile(&file->moov.iods, id);
-}
+ while (counted_size < total_size)
+ {
+ size = mp4ff_atom_read_header(f, &atom_type);
+ counted_size += size;
-int mp4ff_get_iod_video_profile_level(mp4ff_t *file)
-{
- return file->moov.iods.videoProfileId;
-}
+ /* check for end of file */
+ if (size == 0)
+ break;
-int mp4ff_set_iod_video_profile_level(mp4ff_t *file, int id)
-{
- mp4ff_iods_set_video_profile(&file->moov.iods, id);
-}
+ /* we're starting to read a new track, update index,
+ * so that all data and tables get written in the right place
+ */
+ if (atom_type == ATOM_TRAK)
+ {
+ mp4ff_track_add(f);
+ }
-int mp4ff_video_tracks(mp4ff_t *file)
-{
- int i, result = 0;
- for(i = 0; i < file->moov.total_tracks; i++)
- {
- if(file->moov.trak[i]->mdia.minf.is_video) result++;
- }
- return result;
-}
+ /* parse subatoms */
+ if (atom_type < SUBATOMIC)
+ {
+ parse_sub_atoms(f, size-8);
+ } else {
+ mp4ff_atom_read(f, size, atom_type);
+ }
+ }
-int mp4ff_audio_tracks(mp4ff_t *file)
-{
- int i, result = 0;
- mp4ff_minf_t *minf;
- for(i = 0; i < file->moov.total_tracks; i++)
- {
- minf = &(file->moov.trak[i]->mdia.minf);
- if(minf->is_audio)
- result++;
- }
- return result;
+ return 0;
}
-int mp4ff_set_audio(mp4ff_t *file,
- int channels,
- long sample_rate,
- int bits,
- int sample_size,
- int time_scale,
- int sample_duration,
- char *compressor)
+/* parse root atoms */
+int32_t parse_atoms(mp4ff_t *f)
{
- int i, j;
- mp4ff_trak_t *trak;
+ int32_t size;
+ uint8_t atom_type = 0;
- /* delete any existing tracks */
- for(i = 0; i < file->total_atracks; i++) {
- mp4ff_delete_audio_map(&(file->atracks[i]));
- mp4ff_delete_trak(&(file->moov), file->atracks[i].track);
- }
- free(file->atracks);
- file->atracks = NULL;
- file->total_atracks = 0;
-
- if(channels) {
-#if 0
- /* Fake the bits parameter for some formats. */
- if(mp4ff_match_32(compressor, mp4ff_ULAW) ||
- mp4ff_match_32(compressor, mp4ff_IMA4)) bits = 16;
-#endif
-
- file->atracks = (mp4ff_audio_map_t*)
- calloc(1, sizeof(mp4ff_audio_map_t));
- trak = mp4ff_add_track(&(file->moov));
- mp4ff_trak_init_audio(file, trak, channels, sample_rate, bits,
- sample_size, time_scale, sample_duration, compressor);
- mp4ff_init_audio_map(&(file->atracks[0]), trak);
- file->atracks[file->total_atracks].track = trak;
- file->atracks[file->total_atracks].channels = channels;
- file->atracks[file->total_atracks].current_position = 0;
- file->atracks[file->total_atracks].current_chunk = 1;
- file->total_atracks++;
- }
- return 1; /* Return the number of tracks created */
-}
-
-int mp4ff_set_video(mp4ff_t *file,
- int tracks,
- int frame_w,
- int frame_h,
- float frame_rate,
- int time_scale,
- char *compressor)
-{
- int i, j;
- mp4ff_trak_t *trak;
-
- /* delete any existing tracks */
- for(i = 0; i < file->total_vtracks; i++) {
- mp4ff_delete_video_map(&(file->vtracks[i]));
- mp4ff_delete_trak(&(file->moov), file->vtracks[i].track);
- }
- free(file->vtracks);
- file->vtracks = NULL;
- file->total_vtracks = 0;
-
- if (tracks > 0) {
- file->total_vtracks = tracks;
- file->vtracks = (mp4ff_video_map_t*)calloc(1, sizeof(mp4ff_video_map_t) * file->total_vtracks);
- for(i = 0; i < tracks; i++)
- {
- trak = mp4ff_add_track(&(file->moov));
- mp4ff_trak_init_video(file, trak, frame_w, frame_h, frame_rate,
- time_scale, compressor);
- mp4ff_init_video_map(&(file->vtracks[i]), trak);
- }
- }
- return 0;
-}
-
-int mp4ff_set_framerate(mp4ff_t *file, float framerate)
-{
- int i;
- int new_time_scale, new_sample_duration;
- new_time_scale = mp4ff_get_timescale(framerate);
- new_sample_duration = (int)((float)new_time_scale / framerate + 0.5);
-
- for(i = 0; i < file->total_vtracks; i++)
- {
- file->vtracks[i].track->mdia.mdhd.time_scale = new_time_scale;
- file->vtracks[i].track->mdia.minf.stbl.stts.table[0].sample_duration = new_sample_duration;
- }
-}
-
-mp4ff_trak_t* mp4ff_add_track(mp4ff_moov_t *moov)
-{
- mp4ff_trak_t *trak;
- trak = moov->trak[moov->total_tracks] = calloc(1, sizeof(mp4ff_trak_t));
- mp4ff_trak_init(trak);
- trak->tkhd.track_id = moov->mvhd.next_track_id;
- moov->mvhd.next_track_id++;
- moov->total_tracks++;
- return trak;
-}
-
-/* ============================= Initialization functions */
-
-int mp4ff_init(mp4ff_t *file)
-{
- memset(file, 0, sizeof(mp4ff_t));
- mp4ff_mdat_init(&(file->mdat));
- mp4ff_moov_init(&(file->moov));
- return 0;
-}
-
-int mp4ff_delete(mp4ff_t *file)
-{
- int i;
- if(file->total_atracks)
- {
- for(i = 0; i < file->total_atracks; i++)
- mp4ff_delete_audio_map(&(file->atracks[i]));
- free(file->atracks);
- }
- if(file->total_vtracks)
- {
- for(i = 0; i < file->total_vtracks; i++)
- mp4ff_delete_video_map(&(file->vtracks[i]));
- free(file->vtracks);
- }
- file->total_atracks = 0;
- file->total_vtracks = 0;
- mp4ff_moov_delete(&(file->moov));
- mp4ff_mdat_delete(&(file->mdat));
- return 0;
-}
-
-/* =============================== Optimization functions */
-
-int mp4ff_get_timescale(float frame_rate)
-{
- int timescale = 600;
-/* Encode the 29.97, 23.976, 59.94 framerates as per DV freaks */
- if(frame_rate - (int)frame_rate != 0) timescale = (int)(frame_rate * 1001 + 0.5);
- else
- if((600 / frame_rate) - (int)(600 / frame_rate) != 0) timescale = (int)(frame_rate * 100 + 0.5);
- return timescale;
-}
-
-int mp4ff_seek_end(mp4ff_t *file)
-{
- mp4ff_set_position(file, file->mdat.size + file->mdat.start);
-/*printf("mp4ff_seek_end %ld\n", file->mdat.size + file->mdat.start); */
- mp4ff_update_positions(file);
- return 0;
-}
-
-int mp4ff_seek_start(mp4ff_t *file)
-{
- mp4ff_set_position(file, file->mdat.start + HEADER_LENGTH);
- mp4ff_update_positions(file);
- return 0;
-}
-
-long mp4ff_audio_length(mp4ff_t *file, int track)
-{
- if(file->total_atracks > 0)
- return mp4ff_track_samples(file, file->atracks[track].track);
-
- return 0;
-}
-
-long mp4ff_video_length(mp4ff_t *file, int track)
-{
-/*printf("mp4ff_video_length %d %d\n", mp4ff_track_samples(file, file->vtracks[track].track), track); */
- if(file->total_vtracks > 0)
- return mp4ff_track_samples(file, file->vtracks[track].track);
- return 0;
-}
-
-long mp4ff_audio_position(mp4ff_t *file, int track)
-{
- return file->atracks[track].current_position;
-}
-
-long mp4ff_video_position(mp4ff_t *file, int track)
-{
- return file->vtracks[track].current_position;
-}
-
-int mp4ff_update_positions(mp4ff_t *file)
-{
-/* Used for routines that change the positions of all tracks, like */
-/* seek_end and seek_start but not for routines that reposition one track, like */
-/* set_audio_position. */
-
- long mdat_offset = mp4ff_position(file) - file->mdat.start;
- long sample, chunk, chunk_offset;
- int i;
-
- if(file->total_atracks)
- {
- sample = mp4ff_offset_to_sample(file->atracks[0].track, mdat_offset);
- chunk = mp4ff_offset_to_chunk(&chunk_offset, file->atracks[0].track, mdat_offset);
- for(i = 0; i < file->total_atracks; i++)
- {
- file->atracks[i].current_position = sample;
- file->atracks[i].current_chunk = chunk;
- }
- }
-
- if(file->total_vtracks)
- {
- sample = mp4ff_offset_to_sample(file->vtracks[0].track, mdat_offset);
- chunk = mp4ff_offset_to_chunk(&chunk_offset, file->vtracks[0].track, mdat_offset);
- for(i = 0; i < file->total_vtracks; i++)
- {
- file->vtracks[i].current_position = sample;
- file->vtracks[i].current_chunk = chunk;
- }
- }
- return 0;
-}
-
-int mp4ff_set_audio_position(mp4ff_t *file, long sample, int track)
-{
- long offset, chunk_sample, chunk;
- mp4ff_trak_t *trak;
-
- if(file->total_atracks)
- {
- trak = file->atracks[track].track;
- file->atracks[track].current_position = sample;
- mp4ff_chunk_of_sample(&chunk_sample, &chunk, trak, sample);
- file->atracks[track].current_chunk = chunk;
- offset = mp4ff_sample_to_offset(trak, sample);
- mp4ff_set_position(file, offset);
- /*mp4ff_update_positions(file); */
- }
-
- return 0;
-}
-
-int mp4ff_set_video_position(mp4ff_t *file, long frame, int track)
-{
- long offset, chunk_sample, chunk;
- mp4ff_trak_t *trak;
-
- if(file->total_vtracks)
- {
- trak = file->vtracks[track].track;
- file->vtracks[track].current_position = frame;
- mp4ff_chunk_of_sample(&chunk_sample, &chunk, trak, frame);
- file->vtracks[track].current_chunk = chunk;
- offset = mp4ff_sample_to_offset(trak, frame);
- mp4ff_set_position(file, offset);
- /*mp4ff_update_positions(file); */
- }
- return 0;
-}
-
-int mp4ff_has_audio(mp4ff_t *file)
-{
- if(mp4ff_audio_tracks(file)) return 1;
- return 0;
-}
-
-long mp4ff_audio_sample_rate(mp4ff_t *file, int track)
-{
- if(file->total_atracks)
- return file->atracks[track].track->mdia.minf.stbl.stsd.table[0].sample_rate;
- return 0;
-}
-
-int mp4ff_audio_bits(mp4ff_t *file, int track)
-{
- if(file->total_atracks)
- return file->atracks[track].track->mdia.minf.stbl.stsd.table[0].sample_size;
-
- return 0;
-}
-
-int mp4ff_audio_time_scale(mp4ff_t *file, int track)
-{
- if(file->total_atracks) {
- return file->atracks[track].track->mdia.mdhd.time_scale;
- }
- return 0;
-}
-
-int mp4ff_audio_sample_duration(mp4ff_t *file, int track)
-{
- if(file->total_atracks) {
- return file->atracks[track].track->mdia.minf.stbl.stts.table[0].sample_duration;
- }
- return 0;
-}
-
-char* mp4ff_audio_compressor(mp4ff_t *file, int track)
-{
- if (file->atracks[track].track == NULL)
- return (NULL);
- return file->atracks[track].track->mdia.minf.stbl.stsd.table[0].format;
-}
-
-int mp4ff_track_channels(mp4ff_t *file, int track)
-{
- if(track < file->total_atracks)
- return file->atracks[track].channels;
-
- return 0;
-}
-
-int mp4ff_channel_location(mp4ff_t *file, int *mp4ff_track, int *mp4ff_channel, int channel)
-{
- int current_channel = 0, current_track = 0;
- *mp4ff_channel = 0;
- *mp4ff_track = 0;
- for(current_channel = 0, current_track = 0; current_track < file->total_atracks; )
- {
- if(channel >= current_channel)
- {
- *mp4ff_channel = channel - current_channel;
- *mp4ff_track = current_track;
- }
-
- current_channel += file->atracks[current_track].channels;
- current_track++;
- }
- return 0;
-}
-
-int mp4ff_has_video(mp4ff_t *file)
-{
- if(mp4ff_video_tracks(file)) return 1;
- return 0;
-}
-
-int mp4ff_video_width(mp4ff_t *file, int track)
-{
- if(file->total_vtracks) {
- int width =
- file->vtracks[track].track->mdia.minf.stbl.stsd.table[0].width;
- if (width) {
- return width;
- }
- return file->vtracks[track].track->tkhd.track_width;
- }
- return 0;
-}
-
-int mp4ff_video_height(mp4ff_t *file, int track)
-{
- if(file->total_vtracks) {
- int height = file->vtracks[track].track->mdia.minf.stbl.stsd.table[0].height;
- if (height) {
- return height;
- }
- return file->vtracks[track].track->tkhd.track_height;
- }
- return 0;
-}
+ while ((size = mp4ff_atom_read_header(f, &atom_type)) != 0)
+ {
+ if (atom_type == ATOM_MDAT && f->moov_read)
+ {
+ /* moov atom is before mdat, we can stop reading when mdat is encountered */
+ /* file position will stay at beginning of mdat data */
+ break;
+ }
-int mp4ff_video_depth(mp4ff_t *file, int track)
-{
- if(file->total_vtracks)
- return file->vtracks[track].track->mdia.minf.stbl.stsd.table[0].depth;
- return 0;
-}
+ if (atom_type == ATOM_MDAT && size > 8)
+ {
+ f->mdat_read = 1;
+ f->mdat_offset = mp4ff_position(f);
+ f->mdat_size = size;
+ }
+ if (atom_type == ATOM_MOOV && size > 8)
+ {
+ f->moov_read = 1;
+ f->moov_offset = mp4ff_position(f);
+ f->moov_size = size;
+ }
-int mp4ff_set_depth(mp4ff_t *file, int depth, int track)
-{
- int i;
+ /* parse subatoms */
+ if (atom_type < SUBATOMIC)
+ {
+ parse_sub_atoms(f, size-8);
+ } else {
+ /* skip this atom */
+ mp4ff_set_position(f, mp4ff_position(f)+size-8);
+ }
+ }
- for(i = 0; i < file->total_vtracks; i++)
- {
- file->vtracks[i].track->mdia.minf.stbl.stsd.table[0].depth = depth;
- }
-}
-
-float mp4ff_video_frame_rate(mp4ff_t *file, int track)
-{
- float ret = 0;
- int num = 0;
-
- if(file->total_vtracks) {
- ret = file->vtracks[track].track->mdia.mdhd.time_scale;
- if (file->vtracks[track].track->mdia.minf.stbl.stts.table[0].sample_duration == 0)
- num = 1;
- ret /=
- file->vtracks[track].track->mdia.minf.stbl.stts.table[num].sample_duration;
- }
- return ret;
-}
-
-char* mp4ff_video_compressor(mp4ff_t *file, int track)
-{
- if (file->vtracks[track].track == NULL)
- return (NULL);
-
- return file->vtracks[track].track->mdia.minf.stbl.stsd.table[0].format;
-}
-
-int mp4ff_video_time_scale(mp4ff_t *file, int track)
-{
- if(file->total_vtracks) {
- return file->vtracks[track].track->mdia.mdhd.time_scale;
- }
- return 0;
-}
-
-int mp4ff_video_frame_time(mp4ff_t *file, int track, long frame,
- long *start, int *duration)
-{
- mp4ff_stts_t *stts;
- int i;
- long f;
-
- if (file->total_vtracks == 0) {
- return 0;
- }
- stts = &(file->vtracks[track].track->mdia.minf.stbl.stts);
-
- if (frame < file->last_frame) {
- /* we need to reset our cached values */
- file->last_frame = 0;
- file->last_start = 0;
- file->last_stts_index = 0;
- }
-
- i = file->last_stts_index;
- f = file->last_frame;
- *start = file->last_start;
-
- while (i < stts->total_entries) {
- if (f + stts->table[i].sample_count <= frame) {
- *start += stts->table[i].sample_duration
- * stts->table[i].sample_count;
- f += stts->table[i].sample_count;
- i++;
-
- } else {
- /* cache the results for future use */
- file->last_stts_index = i;
- file->last_frame = f;
- file->last_start = *start;
-
- *start += stts->table[i].sample_duration * (frame - f);
- *duration = stts->table[i].sample_duration;
-
- return 1;
- }
- }
-
- /* error */
- return 0;
-}
-
-int mp4ff_get_mp4_video_decoder_config(mp4ff_t *file, int track, unsigned char** ppBuf, int* pBufSize)
-{
- mp4ff_esds_t* esds;
-
- if (!file->total_vtracks) {
- return 0;
- }
- esds = &file->vtracks[track].track->mdia.minf.stbl.stsd.table[0].esds;
- return mp4ff_esds_get_decoder_config(esds, ppBuf, pBufSize);
-}
-
-int mp4ff_set_mp4_video_decoder_config(mp4ff_t *file, int track, unsigned char* pBuf, int bufSize)
-{
- mp4ff_esds_t* esds;
-
- if (!file->total_vtracks) {
- return 0;
- }
- esds = &file->vtracks[track].track->mdia.minf.stbl.stsd.table[0].esds;
- return mp4ff_esds_set_decoder_config(esds, pBuf, bufSize);
-}
-
-int mp4ff_get_mp4_audio_decoder_config(mp4ff_t *file, int track, unsigned char** ppBuf, int* pBufSize)
-{
- mp4ff_esds_t* esds;
-
- if (!file->total_atracks) {
- return 0;
- }
- esds = &file->atracks[track].track->mdia.minf.stbl.stsd.table[0].esds;
- return mp4ff_esds_get_decoder_config(esds, ppBuf, pBufSize);
-}
-
-int mp4ff_set_mp4_audio_decoder_config(mp4ff_t *file, int track, unsigned char* pBuf, int bufSize)
-{
- mp4ff_esds_t* esds;
-
- if (!file->total_atracks) {
- return 0;
- }
- esds = &file->atracks[track].track->mdia.minf.stbl.stsd.table[0].esds;
- return mp4ff_esds_set_decoder_config(esds, pBuf, bufSize);
-}
-
-long mp4ff_samples_to_bytes(mp4ff_trak_t *track, long samples)
-{
- return samples
- * track->mdia.minf.stbl.stsd.table[0].channels
- * track->mdia.minf.stbl.stsd.table[0].sample_size / 8;
-}
-
-int mp4ff_write_audio(mp4ff_t *file, char *audio_buffer, long samples, int track)
-{
- long offset;
- int result;
- long bytes;
-
-/* Defeat 32 bit file size limit. */
- if(mp4ff_test_position(file)) return 1;
-
-/* write chunk for 1 track */
- bytes = samples * mp4ff_audio_bits(file, track) / 8 * file->atracks[track].channels;
- offset = mp4ff_position(file);
- result = mp4ff_write_data(file, audio_buffer, bytes);
-
- if(result) result = 0; else result = 1; /* defeat fwrite's return */
- mp4ff_update_tables(file,
- file->atracks[track].track,
- offset,
- file->atracks[track].current_chunk,
- file->atracks[track].current_position,
- samples,
- 0,
- 0,
- 0,
- 0);
- file->atracks[track].current_position += samples;
- file->atracks[track].current_chunk++;
- return result;
-}
-
-int mp4ff_write_audio_frame(mp4ff_t *file, unsigned char *audio_buffer, long bytes, int track)
-{
- long offset = mp4ff_position(file);
- int result = 0;
-
- /* Defeat 32 bit file size limit. */
- if(mp4ff_test_position(file)) return 1;
-
- result = mp4ff_write_data(file, audio_buffer, bytes);
- if(result) result = 0; else result = 1;
-
- mp4ff_update_tables(file,
- file->atracks[track].track,
- offset,
- file->atracks[track].current_chunk,
- file->atracks[track].current_position,
- 1,
- bytes,
- 0,
- 0,
- 0);
- file->atracks[track].current_position += 1;
- file->atracks[track].current_chunk++;
- return result;
-}
-
-int mp4ff_write_video_frame(mp4ff_t *file,
- unsigned char *video_buffer,
- long bytes,
- int track,
- unsigned char isKeyFrame,
- long duration,
- long renderingOffset)
-{
- long offset = mp4ff_position(file);
- int result = 0;
-
- /* Defeat 32 bit file size limit. */
- if(mp4ff_test_position(file)) return 1;
-
- result = mp4ff_write_data(file, video_buffer, bytes);
- if(result) result = 0; else result = 1;
-
- mp4ff_update_tables(file,
- file->vtracks[track].track,
- offset,
- file->vtracks[track].current_chunk,
- file->vtracks[track].current_position,
- 1,
- bytes,
- duration,
- isKeyFrame,
- renderingOffset);
- file->vtracks[track].current_position += 1;
- file->vtracks[track].current_chunk++;
- return result;
-}
-
-mp4_callback_t* mp4ff_get_fd(mp4ff_t *file)
-{
- if (file->stream->get_position() != file->file_position)
- file->stream->seek(file->file_position);
- return file->stream;
-}
-
-int mp4ff_write_frame_init(mp4ff_t *file, int track)
-{
- if(file->stream->get_position() != file->file_position)
- file->stream->seek(file->file_position);
- file->offset = mp4ff_position(file);
return 0;
}
-int mp4ff_write_frame_end(mp4ff_t *file, int track)
-{
- long bytes;
- file->file_position = file->stream->get_position();
- bytes = mp4ff_position(file) - file->offset;
- mp4ff_update_tables(file,
- file->vtracks[track].track,
- file->offset,
- file->vtracks[track].current_chunk,
- file->vtracks[track].current_position,
- 1,
- bytes,
- 0,
- 0,
- 0);
- file->vtracks[track].current_position += 1;
- file->vtracks[track].current_chunk++;
- return 0;
-}
-int mp4ff_write_audio_init(mp4ff_t *file, int track)
+int32_t mp4ff_get_sample_duration(mp4ff_t *f, int32_t track, int32_t sample)
{
- return mp4ff_write_frame_init(file, track);
-}
+ int32_t i, ci = 0, co = 0;
-int mp4ff_write_audio_end(mp4ff_t *file, int track, long samples)
-{
- long bytes;
- file->file_position = file->stream->get_position();
- bytes = mp4ff_position(file) - file->offset;
- mp4ff_update_tables(file,
- file->atracks[track].track,
- file->offset,
- file->atracks[track].current_chunk,
- file->atracks[track].current_position,
- samples,
- bytes,
- 0,
- 0,
- 0);
- file->atracks[track].current_position += samples;
- file->atracks[track].current_chunk++;
- return 0;
-}
-
-
-long mp4ff_read_audio(mp4ff_t *file, char *audio_buffer, long samples, int track)
-{
- long chunk_sample, chunk;
- int result = 1, track_num;
- mp4ff_trak_t *trak = file->atracks[track].track;
- long fragment_len, chunk_end;
- long position = file->atracks[track].current_position;
- long start = position, end = position + samples;
- long bytes, total_bytes = 0;
- long buffer_offset;
-
- mp4ff_chunk_of_sample(&chunk_sample, &chunk, trak, position);
- buffer_offset = 0;
-
- while(position < end && result)
- {
- mp4ff_set_audio_position(file, position, track);
- fragment_len = mp4ff_chunk_samples(trak, chunk);
- chunk_end = chunk_sample + fragment_len;
- fragment_len -= position - chunk_sample;
- if(position + fragment_len > chunk_end) fragment_len = chunk_end - position;
- if(position + fragment_len > end) fragment_len = end - position;
-
- bytes = mp4ff_samples_to_bytes(trak, fragment_len);
- result = mp4ff_read_data(file, &audio_buffer[buffer_offset], bytes);
-
- total_bytes += bytes;
- position += fragment_len;
- chunk_sample = position;
- buffer_offset += bytes;
- chunk++;
- }
-
- file->atracks[track].current_position = position;
- if(!result) return 0;
- return total_bytes;
-}
-
-int mp4ff_read_chunk(mp4ff_t *file, char *output, int track, long chunk, long byte_start, long byte_len)
-{
- mp4ff_set_position(file, mp4ff_chunk_to_offset(file->atracks[track].track, chunk) + byte_start);
- if(mp4ff_read_data(file, output, byte_len)) return 0;
- else
- return 1;
-}
-
-long mp4ff_frame_size(mp4ff_t *file, long frame, int track)
-{
- int bytes;
- mp4ff_trak_t *trak = file->vtracks[track].track;
-
- if(trak->mdia.minf.stbl.stsz.sample_size)
- {
- bytes = trak->mdia.minf.stbl.stsz.sample_size;
- }
- else
- {
- bytes = trak->mdia.minf.stbl.stsz.table[frame].size;
- }
-
- return bytes;
-}
-
-long mp4ff_get_sample_duration(mp4ff_t *file, long frame, int track)
-{
- int i, ci = 0, co = 0;
- mp4ff_trak_t *trak = file->atracks[track].track;
-
- for (i = 0; i < trak->mdia.minf.stbl.stts.total_entries; i++)
+ for (i = 0; i < f->track[track]->stts_entry_count; i++)
{
- int j;
- for (j = 0; j < trak->mdia.minf.stbl.stts.table[i].sample_count; j++)
+ int32_t j;
+ for (j = 0; j < f->track[track]->stts_sample_count[i]; j++)
{
- if (co == frame)
- return trak->mdia.minf.stbl.stts.table[ci].sample_duration;
+ if (co == sample)
+ return f->track[track]->stts_sample_delta[ci];
co++;
}
ci++;
}
-}
-long mp4ff_audio_frame_size(mp4ff_t *file, long frame, int track)
-{
- int bytes;
- mp4ff_trak_t *trak = file->atracks[track].track;
-
- if(trak->mdia.minf.stbl.stsz.sample_size)
- {
- bytes = trak->mdia.minf.stbl.stsz.sample_size;
- } else {
- bytes = trak->mdia.minf.stbl.stsz.table[frame].size;
- }
-
- return bytes;
+ return 0;
}
-long mp4ff_read_audio_frame(mp4ff_t *file, unsigned char *audio_buffer, int maxBytes, int track)
+int32_t mp4ff_read_sample(mp4ff_t *f, int32_t track, int32_t sample, uint8_t **audio_buffer, uint32_t *bytes)
{
- long bytes;
- int result = 0;
- mp4ff_trak_t *trak = file->atracks[track].track;
+ int32_t result = 0;
- bytes = mp4ff_audio_frame_size(file,
- file->atracks[track].current_position, track);
+ *bytes = mp4ff_audio_frame_size(f, track, sample);
- if (bytes > maxBytes) {
- return -bytes;
- }
+ *audio_buffer = (uint8_t*)malloc(*bytes);
- mp4ff_set_audio_position(file,
- file->atracks[track].current_position, track);
+ mp4ff_set_sample_position(f, track, sample);
- result = mp4ff_read_data(file, audio_buffer, bytes);
+ result = mp4ff_read_data(f, *audio_buffer, *bytes);
- file->atracks[track].current_position++;
+ if (!result)
+ return 0;
- if (!result)
- return 0;
- return bytes;
+ return *bytes;
}
-long mp4ff_read_frame(mp4ff_t *file, unsigned char *video_buffer, int track)
+int32_t mp4ff_get_decoder_config(mp4ff_t *f, int32_t track, uint8_t** ppBuf, uint32_t* pBufSize)
{
- long bytes;
- int result = 0;
-
- mp4ff_trak_t *trak = file->vtracks[track].track;
- bytes = mp4ff_frame_size(file, file->vtracks[track].current_position, track);
-
- if(!file->vtracks[track].frames_cached)
- {
- mp4ff_set_video_position(file, file->vtracks[track].current_position, track);
- result = mp4ff_read_data(file, video_buffer, bytes);
- }
- else
- {
- int i;
- unsigned char *cached_frame;
-
- if(file->vtracks[track].current_position >= file->vtracks[track].frames_cached) result = 1;
- if(!result)
- {
- cached_frame = file->vtracks[track].frame_cache[file->vtracks[track].current_position];
-
- for(i = 0; i < bytes; i++)
- video_buffer[i] = cached_frame[i];
- }
- }
- file->vtracks[track].current_position++;
-
- if(!result) return 0;
- return bytes;
-}
-
-int mp4ff_read_frame_init(mp4ff_t *file, int track)
-{
- mp4ff_trak_t *trak = file->vtracks[track].track;
- mp4ff_set_video_position(file, file->vtracks[track].current_position, track);
- if(file->stream->get_position() != file->file_position)
- file->stream->seek(file->file_position);
- return 0;
-}
-
-int mp4ff_read_frame_end(mp4ff_t *file, int track)
-{
- file->file_position = file->stream->get_position();
- file->vtracks[track].current_position++;
- return 0;
-}
-
-int mp4ff_init_video_map(mp4ff_video_map_t *vtrack, mp4ff_trak_t *trak)
-{
- vtrack->track = trak;
- vtrack->current_position = 0;
- vtrack->current_chunk = 1;
- vtrack->frame_cache = 0;
- vtrack->frames_cached = 0;
- return 0;
-}
-
-int mp4ff_delete_video_map(mp4ff_video_map_t *vtrack)
-{
- int i;
- if(vtrack->frames_cached)
- {
- for(i = 0; i < vtrack->frames_cached; i++)
- {
- free(vtrack->frame_cache[i]);
- }
- free(vtrack->frame_cache);
- vtrack->frames_cached = 0;
- }
- return 0;
-}
-
-int mp4ff_init_audio_map(mp4ff_audio_map_t *atrack, mp4ff_trak_t *trak)
-{
- atrack->track = trak;
- atrack->channels = trak->mdia.minf.stbl.stsd.table[0].channels;
- atrack->current_position = 0;
- atrack->current_chunk = 1;
- return 0;
-}
-
-int mp4ff_delete_audio_map(mp4ff_audio_map_t *atrack)
-{
- int i;
- return 0;
-}
-
-int mp4ff_read_info(mp4ff_t *file)
-{
- int result = 0, found_moov = 0;
- int i, j, k, m, channel, trak_channel, track;
- long start_position = mp4ff_position(file);
- mp4ff_atom_t leaf_atom;
- mp4ff_trak_t *trak;
-
- mp4ff_set_position(file, 0);
-
- do
- {
- result = mp4ff_atom_read_header(file, &leaf_atom);
- if(!result)
- {
- if(mp4ff_atom_is(&leaf_atom, "mdat")) {
- mp4ff_read_mdat(file, &(file->mdat), &leaf_atom);
- } else if(mp4ff_atom_is(&leaf_atom, "moov")) {
- mp4ff_read_moov(file, &(file->moov), &leaf_atom);
- found_moov = 1;
- } else {
- mp4ff_atom_skip(file, &leaf_atom);
- }
- }
- }while(!result && mp4ff_position(file) < file->total_length);
-
-/* go back to the original position */
- mp4ff_set_position(file, start_position);
-
- if(found_moov) {
-
- /* get tables for all the different tracks */
- file->total_atracks = mp4ff_audio_tracks(file);
- file->atracks = (mp4ff_audio_map_t*)calloc(1,
- sizeof(mp4ff_audio_map_t) * file->total_atracks);
-
- for(i = 0, track = 0; i < file->total_atracks; i++) {
- while(!file->moov.trak[track]->mdia.minf.is_audio)
- track++;
- mp4ff_init_audio_map(&(file->atracks[i]), file->moov.trak[track]);
- }
-
- file->total_vtracks = mp4ff_video_tracks(file);
- file->vtracks = (mp4ff_video_map_t*)calloc(1, sizeof(mp4ff_video_map_t) * file->total_vtracks);
-
- for(track = 0, i = 0; i < file->total_vtracks; i++)
- {
- while(!file->moov.trak[track]->mdia.minf.is_video)
- track++;
-
- mp4ff_init_video_map(&(file->vtracks[i]), file->moov.trak[track]);
- }
- }
-
- if(found_moov)
- return 0;
- else
- return 1;
-}
-
-
-int mp4ff_dump(mp4ff_t *file)
-{
- printf("mp4ff_dump\n");
- printf("movie data\n");
- printf(" size %ld\n", file->mdat.size);
- printf(" start %ld\n", file->mdat.start);
- mp4ff_moov_dump(&(file->moov));
- return 0;
-}
-
-
-/* ================================== Entry points ========================== */
-
-int mp4ff_check_sig(mp4_callback_t *path)
-{
- mp4ff_t file;
- mp4ff_atom_t leaf_atom;
- int result1 = 0, result2 = 0;
-
- mp4ff_init(&file);
- file.stream = path;
-
- file.total_length = file.stream->get_length();
-
- do
- {
- result1 = mp4ff_atom_read_header(&file, &leaf_atom);
-
- if(!result1)
- {
-/* just want the "moov" atom */
- if(mp4ff_atom_is(&leaf_atom, "moov"))
- {
- result2 = 1;
- }
- else
- mp4ff_atom_skip(&file, &leaf_atom);
- }
- }while(!result1 && !result2 && mp4ff_position(&file) < file.total_length);
-
- mp4ff_delete(&file);
- return result2;
-}
-
-mp4ff_t* mp4ff_open(mp4_callback_t *callbacks, int rd, int wr, int append)
-{
- mp4ff_t *new_file = malloc(sizeof(mp4ff_t));
- int exists = 0;
-
- mp4ff_init(new_file);
- new_file->stream = callbacks;
- new_file->wr = wr;
- new_file->rd = rd;
- new_file->mdat.start = 0;
-
- if(rd /*&& exists*/)
+ if (track >= f->total_tracks)
{
- new_file->total_length = new_file->stream->get_length();
-
- if(mp4ff_read_info(new_file))
- {
- mp4ff_close(new_file);
- new_file = 0;
- }
+ *ppBuf = NULL;
+ *pBufSize = 0;
+ return 1;
}
- if(wr)
+ if (f->track[track]->decoderConfig == NULL || f->track[track]->decoderConfigLen == 0)
{
- if(!exists || !append)
+ *ppBuf = NULL;
+ *pBufSize = 0;
+ } else {
+ *ppBuf = malloc(f->track[track]->decoderConfigLen);
+ if (*ppBuf == NULL)
{
- /* start the data atom */
- mp4ff_write_int32(new_file, 0);
- mp4ff_write_char32(new_file, "mdat");
- } else {
- mp4ff_set_position(new_file,
- new_file->mdat.start + new_file->mdat.size);
- new_file->stream->seek(new_file->mdat.start + new_file->mdat.size);
+ *pBufSize = 0;
+ return 1;
}
+ memcpy(*ppBuf, f->track[track]->decoderConfig, f->track[track]->decoderConfigLen);
+ *pBufSize = f->track[track]->decoderConfigLen;
}
- return new_file;
+
+ return 0;
}
-int mp4ff_write(mp4ff_t *file)
+int32_t mp4ff_total_tracks(mp4ff_t *f)
{
- int result = -1;
-
- if(!file->wr) {
- return result;
- }
-
- mp4ff_write_mdat(file, &(file->mdat));
- mp4ff_write_moov(file, &(file->moov));
-
- return result;
+ return f->total_tracks;
}
-int mp4ff_destroy(mp4ff_t *file)
+int32_t mp4ff_time_scale(mp4ff_t *f, int32_t track)
{
- mp4ff_delete(file);
- free(file);
- return 0;
+ return f->time_scale;
}
-int mp4ff_close(mp4ff_t *file)
+int32_t mp4ff_num_samples(mp4ff_t *f, int32_t track)
{
- int result = 0;
- if(file->wr)
- {
- mp4ff_write_mdat(file, &(file->mdat));
- mp4ff_write_moov(file, &(file->moov));
- }
+ int32_t i;
+ int32_t total = 0;
- mp4ff_delete(file);
- free(file);
- return result;
+ for (i = 0; i < f->track[track]->stts_entry_count; i++)
+ {
+ total += f->track[track]->stts_sample_count[i];
+ }
+ return total;
}
--- a/common/mp4ff/mp4ff.dsp
+++ b/common/mp4ff/mp4ff.dsp
@@ -40,8 +40,8 @@
# PROP Output_Dir "Release"
# PROP Intermediate_Dir "Release"
# PROP Target_Dir ""
-MTL=midl.exe
F90=df.exe
+MTL=midl.exe
# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /YX /FD /c
# ADD CPP /nologo /MD /W3 /GX /O1 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /YX /FD /c
# ADD BASE RSC /l 0x413 /d "NDEBUG"
@@ -65,8 +65,8 @@
# PROP Output_Dir "Debug"
# PROP Intermediate_Dir "Debug"
# PROP Target_Dir ""
-MTL=midl.exe
F90=df.exe
+MTL=midl.exe
# ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /YX /FD /GZ /c
# ADD CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /YX /FD /GZ /c
# ADD BASE RSC /l 0x413 /d "_DEBUG"
@@ -89,128 +89,20 @@
# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
# Begin Source File
-SOURCE=.\atom.c
+SOURCE=.\mp4atom.c
# End Source File
# Begin Source File
-SOURCE=.\ctts.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\dinf.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\dref.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\edts.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\elst.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\esds.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\hdlr.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\iods.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\matrix.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\mdat.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\mdhd.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\mdia.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\minf.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\moov.c
-# End Source File
-# Begin Source File
-
SOURCE=.\mp4ff.c
# End Source File
# Begin Source File
-SOURCE=.\mvhd.c
+SOURCE=.\mp4sample.c
# End Source File
# Begin Source File
-SOURCE=.\smhd.c
+SOURCE=.\mp4util.c
# End Source File
-# Begin Source File
-
-SOURCE=.\stbl.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\stco.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\stsc.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\stsd.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\stsdtable.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\stss.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\stsz.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\stts.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\tkhd.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\trak.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\udta.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\util.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\vmhd.c
-# End Source File
# End Group
# Begin Group "Header Files"
@@ -217,15 +109,7 @@
# PROP Default_Filter "h;hpp;hxx;hm;inl"
# Begin Source File
-SOURCE=.\funcprotos.h
-# End Source File
-# Begin Source File
-
SOURCE=.\mp4ff.h
-# End Source File
-# Begin Source File
-
-SOURCE=.\private.h
# End Source File
# End Group
# End Target
--- a/common/mp4ff/mp4ff.h
+++ b/common/mp4ff/mp4ff.h
@@ -1,246 +1,226 @@
+/*
+** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
+** Copyright (C) 2003 M. Bakker, Ahead Software AG, http://www.nero.com
+**
+** This program is free software; you can redistribute it and/or modify
+** it under the terms of the GNU General Public License as published by
+** the Free Software Foundation; either version 2 of the License, or
+** (at your option) any later version.
+**
+** This program is distributed in the hope that it will be useful,
+** but WITHOUT ANY WARRANTY; without even the implied warranty of
+** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+** GNU General Public License for more details.
+**
+** You should have received a copy of the GNU General Public License
+** along with this program; if not, write to the Free Software
+** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+**
+** Any non-GPL usage of this software or parts of this software is strictly
+** forbidden.
+**
+** Commercial non-GPL licensing of this software is possible.
+** For more info contact Ahead Software through [email protected].
+**
+** $Id: mp4ff.h,v 1.4 2003/11/21 15:08:48 menno Exp $
+**/
+
#ifndef MP4FF_H
#define MP4FF_H
#ifdef __cplusplus
extern "C" {
-#endif
+#endif /* __cplusplus */
-#ifdef _WIN32
- #include <stdio.h>
- #include <stdlib.h>
+#define MAX_TRACKS 1024
+#define TRACK_UNKNOWN 0
+#define TRACK_AUDIO 1
+#define TRACK_VIDEO 2
+#define TRACK_SYSTEM 3
-#else
-#ifdef HAVE_CONFIG_H
-# include "../../config.h"
-#endif
-#include <stdio.h>
-#if HAVE_SYS_TYPES_H
-# include <sys/types.h>
-#endif
-#if HAVE_SYS_STAT_H
-# include <sys/stat.h>
-#endif
-#if STDC_HEADERS
-# include <stdlib.h>
-# include <stddef.h>
-#else
-# if HAVE_STDLIB_H
-# include <stdlib.h>
-# endif
-#endif
-#if HAVE_STRING_H
-# if !STDC_HEADERS && HAVE_MEMORY_H
-# include <memory.h>
-# endif
-# include <string.h>
-#endif
-#if HAVE_STRINGS_H
-# include <strings.h>
-#endif
-#if HAVE_INTTYPES_H
-# include <inttypes.h>
-#else
-# if HAVE_STDINT_H
-# include <stdint.h>
-# else
-/* we need these... */
-typedef unsigned long long uint64_t;
-typedef unsigned long uint32_t;
-typedef unsigned short uint16_t;
-typedef unsigned char uint8_t;
-typedef long long int64_t;
-typedef long int32_t;
-typedef short int16_t;
-typedef char int8_t;
-# endif
-#endif
-#if HAVE_UNISTD_H
-# include <unistd.h>
-#endif
+#define SUBATOMIC 128
-#ifndef HAVE_FLOAT32_T
-typedef float float32_t;
-#endif
+/* atoms without subatoms */
+#define ATOM_FTYP 129
+#define ATOM_MDAT 130
+#define ATOM_MVHD 131
+#define ATOM_TKHD 132
+#define ATOM_TREF 133
+#define ATOM_MDHD 134
+#define ATOM_VMHD 135
+#define ATOM_SMHD 136
+#define ATOM_HMHD 137
+#define ATOM_STSD 138
+#define ATOM_STTS 139
+#define ATOM_STSZ 140
+#define ATOM_STZ2 141
+#define ATOM_STCO 142
+#define ATOM_STSC 143
+#define ATOM_MP4A 144
+#define ATOM_MP4V 145
+#define ATOM_MP4S 146
+#define ATOM_ESDS 147
-#if STDC_HEADERS
-# include <string.h>
+#define ATOM_UNKNOWN 255
+#define ATOM_FREE ATOM_UNKNOWN
+#define ATOM_SKIP ATOM_UNKNOWN
+
+/* atoms with subatoms */
+#define ATOM_MOOV 1
+#define ATOM_TRAK 2
+#define ATOM_EDTS 3
+#define ATOM_MDIA 4
+#define ATOM_MINF 5
+#define ATOM_STBL 6
+
+#ifdef _WIN32
+typedef __int8 int8_t;
+typedef unsigned __int8 uint8_t;
+typedef __int16 int16_t;
+typedef unsigned __int16 uint16_t;
+typedef __int32 int32_t;
+typedef unsigned __int32 uint32_t;
+typedef __int64 int64_t;
+typedef unsigned __int64 uint64_t;
#else
-# if !HAVE_STRCHR
-# define strchr index
-# define strrchr rindex
-# endif
-char *strchr(), *strrchr();
-# if !HAVE_MEMCPY
-# define memcpy(d, s, n) bcopy((s), (d), (n))
-# define memmove(d, s, n) bcopy((s), (d), (n))
-# endif
+#ifdef HAVE_INTTYPES_H
+#include <inttypes.h>
+#else
+#ifdef HAVE_STDINT_H
+#include <stdint.h>
#endif
-
-#ifndef FALSE
-#define FALSE 0
+#define u_int8_t uint8_t
+#define u_int16_t uint16_t
+#define u_int32_t uint32_t
+#define u_int64_t uint64_t
#endif
-#ifndef TRUE
-#define TRUE 1
#endif
-#endif
+/* file callback structure */
+typedef struct
+{
+ int32_t (*read)(void *udata, void *buffer, int32_t length);
+ int32_t (*seek)(void *udata, int32_t position);
+ void *user_data;
+} mp4ff_callback_t;
+typedef struct
+{
+ int32_t type;
+ int32_t channelCount;
+ int32_t sampleSize;
+ int32_t sampleRate;
-#include "private.h"
-#include "funcprotos.h"
+ /* stsd */
+ int32_t stsd_entry_count;
+ /* stsz */
+ int32_t stsz_sample_size;
+ int32_t stsz_sample_count;
+ int32_t *stsz_table;
+ /* stts */
+ int32_t stts_entry_count;
+ int32_t *stts_sample_count;
+ int32_t *stts_sample_delta;
-/* This is the reference for all your library entry points. */
+ /* stsc */
+ int32_t stsc_entry_count;
+ int32_t *stsc_first_chunk;
+ int32_t *stsc_samples_per_chunk;
+ int32_t *stsc_sample_desc_index;
+ /* stsc */
+ int32_t stco_entry_count;
+ int32_t *stco_chunk_offset;
-/* =========================== public interface ========================= // */
+ /* esde */
+ uint8_t *decoderConfig;
+ int32_t decoderConfigLen;
-/* return 1 if the file is a quicktime file */
-int mp4ff_check_sig(mp4_callback_t *path);
+} mp4ff_track_t;
-/* call this first to open the file and create all the objects */
-mp4ff_t* mp4ff_open(mp4_callback_t *callbacks, int rd, int wr, int append);
+/* mp4 main file structure */
+typedef struct
+{
+ /* stream to read from */
+ mp4ff_callback_t *stream;
+ int32_t current_position;
-/* make the quicktime file streamable */
-int mp4ff_make_streamable(mp4_callback_t *in_path, mp4_callback_t *out_path);
+ int32_t moov_read;
+ int32_t moov_offset;
+ int32_t moov_size;
+ int32_t mdat_read;
+ int32_t mdat_offset;
+ int32_t mdat_size;
-/* Set various options in the file. */
-int mp4ff_set_time_scale(mp4ff_t *file, int time_scale);
-int mp4ff_set_copyright(mp4ff_t *file, char *string);
-int mp4ff_set_name(mp4ff_t *file, char *string);
-int mp4ff_set_info(mp4ff_t *file, char *string);
-int mp4ff_get_time_scale(mp4ff_t *file);
-char* mp4ff_get_copyright(mp4ff_t *file);
-char* mp4ff_get_name(mp4ff_t *file);
-char* mp4ff_get_info(mp4ff_t *file);
+ /* mvhd */
+ int32_t time_scale;
+ int32_t duration;
-/* Read all the information about the file. */
-/* Requires a MOOV atom be present in the file. */
-/* If no MOOV atom exists return 1 else return 0. */
-int mp4ff_read_info(mp4ff_t *file);
+ /* incremental track index while reading the file */
+ int32_t total_tracks;
-/* set up tracks in a new file after opening and before writing */
-/* returns the number of quicktime tracks allocated */
-/* audio is stored two channels per quicktime track */
-int mp4ff_set_audio(mp4ff_t *file, int channels, long sample_rate, int bits, int sample_size, int time_scale, int sample_duration, char *compressor);
+ /* track data */
+ mp4ff_track_t *track[MAX_TRACKS];
+} mp4ff_t;
-/* Samplerate can be set after file is created */
-int mp4ff_set_framerate(mp4ff_t *file, float framerate);
-/* video is stored one layer per quicktime track */
-int mp4ff_set_video(mp4ff_t *file, int tracks, int frame_w, int frame_h, float frame_rate, int time_scale, char *compressor);
-/* routines for setting various video parameters */
-/* Set the depth of the track. */
-int mp4ff_set_depth(mp4ff_t *file, int depth, int track);
-
-/* close the file and delete all the objects */
-int mp4ff_write(mp4ff_t *file);
-int mp4ff_destroy(mp4ff_t *file);
-int mp4ff_close(mp4ff_t *file);
-
-/* get length information */
-/* channel numbers start on 1 for audio and video */
-long mp4ff_audio_length(mp4ff_t *file, int track);
-long mp4ff_video_length(mp4ff_t *file, int track);
-
-/* get position information */
-long mp4ff_audio_position(mp4ff_t *file, int track);
-long mp4ff_video_position(mp4ff_t *file, int track);
-
-/* get file information */
-int mp4ff_video_tracks(mp4ff_t *file);
-int mp4ff_audio_tracks(mp4ff_t *file);
-
-int mp4ff_has_audio(mp4ff_t *file);
-long mp4ff_audio_sample_rate(mp4ff_t *file, int track);
-int mp4ff_audio_bits(mp4ff_t *file, int track);
-int mp4ff_track_channels(mp4ff_t *file, int track);
-int mp4ff_audio_time_scale(mp4ff_t *file, int track);
-int mp4ff_audio_sample_duration(mp4ff_t *file, int track);
-char* mp4ff_audio_compressor(mp4ff_t *file, int track);
-
-int mp4ff_has_video(mp4ff_t *file);
-int mp4ff_video_width(mp4ff_t *file, int track);
-int mp4ff_video_height(mp4ff_t *file, int track);
-int mp4ff_video_depth(mp4ff_t *file, int track);
-float mp4ff_video_frame_rate(mp4ff_t *file, int track);
-char* mp4ff_video_compressor(mp4ff_t *file, int track);
-int mp4ff_video_time_scale(mp4ff_t *file, int track);
-
-int mp4ff_video_frame_time(mp4ff_t *file, int track, long frame,
- long *start_time, int *duration);
-
-int mp4ff_get_iod_audio_profile_level(mp4ff_t *file);
-int mp4ff_set_iod_audio_profile_level(mp4ff_t *file, int id);
-int mp4ff_get_iod_video_profile_level(mp4ff_t *file);
-int mp4ff_set_iod_video_profile_level(mp4ff_t *file, int id);
-
-int mp4ff_get_mp4_video_decoder_config(mp4ff_t *file, int track, unsigned char** ppBuf, int* pBufSize);
-int mp4ff_set_mp4_video_decoder_config(mp4ff_t *file, int track, unsigned char* pBuf, int bufSize);
-int mp4ff_get_mp4_audio_decoder_config(mp4ff_t *file, int track, unsigned char** ppBuf, int* pBufSize);
-int mp4ff_set_mp4_audio_decoder_config(mp4ff_t *file, int track, unsigned char* pBuf, int bufSize);
-
-/* number of bytes of raw data in this frame */
-long mp4ff_frame_size(mp4ff_t *file, long frame, int track);
-long mp4ff_audio_frame_size(mp4ff_t *file, long frame, int track);
-
-/* get the quicktime track and channel that the audio channel belongs to */
-/* channels and tracks start on 0 */
-int mp4ff_channel_location(mp4ff_t *file, int *mp4ff_track, int *mp4ff_channel, int channel);
-
-/* file positioning */
-int mp4ff_seek_end(mp4ff_t *file);
-int mp4ff_seek_start(mp4ff_t *file);
-
-/* set position of file descriptor relative to a track */
-int mp4ff_set_audio_position(mp4ff_t *file, long sample, int track);
-int mp4ff_set_video_position(mp4ff_t *file, long frame, int track);
-
-/* ========================== Access to raw data follows. */
-/* write data for one quicktime track */
-/* the user must handle conversion to the channels in this track */
-int mp4ff_write_audio(mp4ff_t *file, char *audio_buffer, long samples, int track);
-int mp4ff_write_audio_frame(mp4ff_t *file, unsigned char *audio_buffer, long bytes, int track);
-
-int mp4ff_write_video_frame(mp4ff_t *file, unsigned char *video_buffer, long bytes, int track, unsigned char isKeyFrame, long duration, long renderingOffset);
-
-/* for writing a frame using a library that needs a file descriptor */
-int mp4ff_write_frame_init(mp4ff_t *file, int track); /* call before fwrite */
-mp4_callback_t* mp4ff_get_fd(mp4ff_t *file); /* return a file descriptor */
-int mp4ff_write_frame_end(mp4ff_t *file, int track); /* call after fwrite */
-
-/* For reading and writing audio to a file descriptor. */
-int mp4ff_write_audio_end(mp4ff_t *file, int track, long samples); /* call after fwrite */
-
-/* Read an entire chunk. */
-/* read the number of bytes starting at the byte_start in the specified chunk */
-/* You must provide enough space to store the chunk. */
-int mp4ff_read_chunk(mp4ff_t *file, char *output, int track, long chunk, long byte_start, long byte_len);
+/* mp4util.c */
+int32_t mp4ff_read_data(mp4ff_t *f, int8_t *data, int32_t size);
+int32_t mp4ff_read_int32(mp4ff_t *f);
+int32_t mp4ff_read_int24(mp4ff_t *f);
+int16_t mp4ff_read_int16(mp4ff_t *f);
+int8_t mp4ff_read_char(mp4ff_t *f);
+uint32_t mp4ff_read_mp4_descr_length(mp4ff_t *f);
+int32_t mp4ff_position(mp4ff_t *f);
+int32_t mp4ff_set_position(mp4ff_t *f, int32_t position);
-/* read raw data */
-long mp4ff_read_audio(mp4ff_t *file, char *audio_buffer, long samples, int track);
-long mp4ff_read_audio_frame(mp4ff_t *file, unsigned char *audio_buffer, int maxBytes, int track);
-long mp4ff_read_frame(mp4ff_t *file, unsigned char *video_buffer, int track);
-long mp4ff_get_sample_duration(mp4ff_t *file, long frame, int track);
+/* mp4atom.c */
+int32_t mp4ff_atom_get_size(int8_t *data);
+int32_t mp4ff_atom_compare(int8_t a1, int8_t b1, int8_t c1, int8_t d1,
+ int8_t a2, int8_t b2, int8_t c2, int8_t d2);
+uint8_t mp4ff_atom_name_to_type(int8_t a, int8_t b, int8_t c, int8_t d);
+int32_t mp4ff_atom_read_header(mp4ff_t *f, uint8_t *atom_type);
+int32_t mp4ff_read_stsz(mp4ff_t *f);
+int32_t mp4ff_read_esds(mp4ff_t *f);
+int32_t mp4ff_read_mp4a(mp4ff_t *f);
+int32_t mp4ff_read_stsd(mp4ff_t *f);
+int32_t mp4ff_read_stsc(mp4ff_t *f);
+int32_t mp4ff_read_stco(mp4ff_t *f);
+int32_t mp4ff_read_stts(mp4ff_t *f);
+int32_t mp4ff_atom_read(mp4ff_t *f, int32_t size, int8_t atom_type);
-/* for reading frame using a library that needs a file descriptor */
-/* Frame caching doesn't work here. */
-int mp4ff_read_frame_init(mp4ff_t *file, int track);
-int mp4ff_read_frame_end(mp4ff_t *file, int track);
+/* mp4sample.c */
+int32_t mp4ff_chunk_of_sample(mp4ff_t *f, int32_t track, int32_t sample,
+ int32_t *chunk_sample, int32_t *chunk);
+int32_t mp4ff_chunk_to_offset(mp4ff_t *f, int32_t track, int32_t chunk);
+int32_t mp4ff_sample_range_size(mp4ff_t *f, int32_t track, int32_t chunk_sample, int32_t sample);
+int32_t mp4ff_sample_to_offset(mp4ff_t *f, int32_t track, int32_t sample);
+int32_t mp4ff_audio_frame_size(mp4ff_t *f, int32_t track, int32_t sample);
+int32_t mp4ff_set_sample_position(mp4ff_t *f, int32_t track, int32_t sample);
-/* Dump the file structures for the currently opened file. */
-int mp4ff_dump(mp4ff_t *file);
-/* Test the 32 bit overflow */
-int mp4ff_test_position(mp4ff_t *file);
+/* mp4ff.c */
+mp4ff_t *mp4ff_open_read(mp4ff_callback_t *f);
+void mp4ff_close(mp4ff_t *ff);
+void mp4ff_track_add(mp4ff_t *f);
+int32_t parse_sub_atoms(mp4ff_t *f, int32_t total_size);
+int32_t parse_atoms(mp4ff_t *f);
+int32_t mp4ff_get_sample_duration(mp4ff_t *f, int32_t track, int32_t sample);
+int32_t mp4ff_read_sample(mp4ff_t *f, int32_t track, int32_t sample, uint8_t **audio_buffer, uint32_t *bytes);
+int32_t mp4ff_get_decoder_config(mp4ff_t *f, int32_t track, uint8_t** ppBuf, uint32_t* pBufSize);
+int32_t mp4ff_total_tracks(mp4ff_t *f);
+int32_t mp4ff_time_scale(mp4ff_t *f, int32_t track);
+int32_t mp4ff_num_samples(mp4ff_t *f, int32_t track);
+
#ifdef __cplusplus
}
-#endif
+#endif /* __cplusplus */
-#endif
+#endif
\ No newline at end of file
--- /dev/null
+++ b/common/mp4ff/mp4sample.c
@@ -1,0 +1,143 @@
+/*
+** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
+** Copyright (C) 2003 M. Bakker, Ahead Software AG, http://www.nero.com
+**
+** This program is free software; you can redistribute it and/or modify
+** it under the terms of the GNU General Public License as published by
+** the Free Software Foundation; either version 2 of the License, or
+** (at your option) any later version.
+**
+** This program is distributed in the hope that it will be useful,
+** but WITHOUT ANY WARRANTY; without even the implied warranty of
+** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+** GNU General Public License for more details.
+**
+** You should have received a copy of the GNU General Public License
+** along with this program; if not, write to the Free Software
+** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+**
+** Any non-GPL usage of this software or parts of this software is strictly
+** forbidden.
+**
+** Commercial non-GPL licensing of this software is possible.
+** For more info contact Ahead Software through [email protected].
+**
+** $Id: mp4sample.c,v 1.1 2003/11/21 15:08:48 menno Exp $
+**/
+
+#include <stdlib.h>
+#include "mp4ff.h"
+
+
+int32_t mp4ff_chunk_of_sample(mp4ff_t *f, int32_t track, int32_t sample,
+ int32_t *chunk_sample, int32_t *chunk)
+{
+ int32_t total_entries = 0;
+ int32_t chunk2entry;
+ int32_t chunk1, chunk2, chunk1samples, range_samples, total = 0;
+
+ if (f->track[track] == NULL)
+ {
+ return -1;
+ }
+
+ total_entries = f->track[track]->stsc_entry_count;
+
+ chunk1 = 1;
+ chunk1samples = 0;
+ chunk2entry = 0;
+
+ do
+ {
+ chunk2 = f->track[track]->stsc_first_chunk[chunk2entry];
+ *chunk = chunk2 - chunk1;
+ range_samples = *chunk * chunk1samples;
+
+ if (sample < total + range_samples) break;
+
+ chunk1samples = f->track[track]->stsc_samples_per_chunk[chunk2entry];
+ chunk1 = chunk2;
+
+ if(chunk2entry < total_entries)
+ {
+ chunk2entry++;
+ total += range_samples;
+ }
+ } while (chunk2entry < total_entries);
+
+ if (chunk1samples)
+ *chunk = (sample - total) / chunk1samples + chunk1;
+ else
+ *chunk = 1;
+
+ *chunk_sample = total + (*chunk - chunk1) * chunk1samples;
+
+ return 0;
+}
+
+int32_t mp4ff_chunk_to_offset(mp4ff_t *f, int32_t track, int32_t chunk)
+{
+ if (f->track[track]->stco_entry_count && (chunk > f->track[track]->stco_entry_count))
+ {
+ return f->track[track]->stco_chunk_offset[f->track[track]->stco_entry_count - 1];
+ } else if (f->track[track]->stco_entry_count) {
+ return f->track[track]->stco_chunk_offset[chunk - 1];
+ } else {
+ return 8;
+ }
+
+ return 0;
+}
+
+int32_t mp4ff_sample_range_size(mp4ff_t *f, int32_t track, int32_t chunk_sample, int32_t sample)
+{
+ int32_t i, total;
+
+ if (f->track[track]->stsz_sample_size)
+ {
+ return sample * f->track[track]->channelCount * f->track[track]->sampleSize/8;
+ } else {
+ for(i = chunk_sample, total = 0; i < sample; i++)
+ {
+ total += f->track[track]->stsz_table[i];
+ }
+ }
+
+ return total;
+}
+
+int32_t mp4ff_sample_to_offset(mp4ff_t *f, int32_t track, int32_t sample)
+{
+ int32_t chunk, chunk_sample, chunk_offset1, chunk_offset2;
+
+ mp4ff_chunk_of_sample(f, track, sample, &chunk_sample, &chunk);
+
+ chunk_offset1 = mp4ff_chunk_to_offset(f, track, chunk);
+ chunk_offset2 = chunk_offset1 + mp4ff_sample_range_size(f, track, chunk_sample, sample);
+
+ return chunk_offset2;
+}
+
+int32_t mp4ff_audio_frame_size(mp4ff_t *f, int32_t track, int32_t sample)
+{
+ int32_t bytes;
+
+ if (f->track[track]->stsz_sample_size)
+ {
+ bytes = f->track[track]->stsz_sample_size;
+ } else {
+ bytes = f->track[track]->stsz_table[sample];
+ }
+
+ return bytes;
+}
+
+int32_t mp4ff_set_sample_position(mp4ff_t *f, int32_t track, int32_t sample)
+{
+ int32_t offset;
+
+ offset = mp4ff_sample_to_offset(f, track, sample);
+ mp4ff_set_position(f, offset);
+
+ return 0;
+}
--- /dev/null
+++ b/common/mp4ff/mp4util.c
@@ -1,0 +1,120 @@
+/*
+** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
+** Copyright (C) 2003 M. Bakker, Ahead Software AG, http://www.nero.com
+**
+** This program is free software; you can redistribute it and/or modify
+** it under the terms of the GNU General Public License as published by
+** the Free Software Foundation; either version 2 of the License, or
+** (at your option) any later version.
+**
+** This program is distributed in the hope that it will be useful,
+** but WITHOUT ANY WARRANTY; without even the implied warranty of
+** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+** GNU General Public License for more details.
+**
+** You should have received a copy of the GNU General Public License
+** along with this program; if not, write to the Free Software
+** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+**
+** Any non-GPL usage of this software or parts of this software is strictly
+** forbidden.
+**
+** Commercial non-GPL licensing of this software is possible.
+** For more info contact Ahead Software through [email protected].
+**
+** $Id: mp4util.c,v 1.1 2003/11/21 15:08:48 menno Exp $
+**/
+
+#include "mp4ff.h"
+
+int32_t mp4ff_read_data(mp4ff_t *f, int8_t *data, int32_t size)
+{
+ int32_t result = 1;
+
+ result = f->stream->read(f->stream->user_data, data, size);
+
+ f->current_position += size;
+
+ return result;
+}
+
+int32_t mp4ff_set_position(mp4ff_t *f, int32_t position)
+{
+ f->stream->seek(f->stream->user_data, position);
+ f->current_position = position;
+
+ return 0;
+}
+
+int32_t mp4ff_position(mp4ff_t *f)
+{
+ return f->current_position;
+}
+
+int32_t mp4ff_read_int32(mp4ff_t *f)
+{
+ uint32_t result;
+ uint32_t a, b, c, d;
+ int8_t data[4];
+
+ mp4ff_read_data(f, data, 4);
+ a = (uint8_t)data[0];
+ b = (uint8_t)data[1];
+ c = (uint8_t)data[2];
+ d = (uint8_t)data[3];
+
+ result = (a<<24) | (b<<16) | (c<<8) | d;
+ return (int32_t)result;
+}
+
+int32_t mp4ff_read_int24(mp4ff_t *f)
+{
+ uint32_t result;
+ uint32_t a, b, c;
+ int8_t data[4];
+
+ mp4ff_read_data(f, data, 3);
+ a = (uint8_t)data[0];
+ b = (uint8_t)data[1];
+ c = (uint8_t)data[2];
+
+ result = (a<<16) | (b<<8) | c;
+ return (int32_t)result;
+}
+
+int16_t mp4ff_read_int16(mp4ff_t *f)
+{
+ uint32_t result;
+ uint32_t a, b;
+ int8_t data[2];
+
+ mp4ff_read_data(f, data, 2);
+ a = (uint8_t)data[0];
+ b = (uint8_t)data[1];
+
+ result = (a<<8) | b;
+ return (int16_t)result;
+}
+
+int8_t mp4ff_read_char(mp4ff_t *f)
+{
+ int8_t output;
+ mp4ff_read_data(f, &output, 1);
+ return output;
+}
+
+uint32_t mp4ff_read_mp4_descr_length(mp4ff_t *f)
+{
+ uint8_t b;
+ uint8_t numBytes = 0;
+ uint32_t length = 0;
+
+ do
+ {
+ b = mp4ff_read_char(f);
+ numBytes++;
+ length = (length << 7) | (b & 0x7F);
+ } while ((b & 0x80) && numBytes < 4);
+
+ return length;
+}
--- a/common/mp4ff/mvhd.c
+++ /dev/null
@@ -1,111 +1,0 @@
-#include "mp4ff.h"
-
-
-
-int mp4ff_mvhd_init(mp4ff_mvhd_t *mvhd)
-{
- int i;
- mvhd->version = 0;
- mvhd->flags = 0;
- mvhd->creation_time = mp4ff_current_time();
- mvhd->modification_time = mp4ff_current_time();
- mvhd->time_scale = 90000;
- mvhd->duration = 0;
- mvhd->preferred_rate = 1.0;
- mvhd->preferred_volume = 0.996094;
- for(i = 0; i < 10; i++) mvhd->reserved[i] = 0;
- mp4ff_matrix_init(&(mvhd->matrix));
- mvhd->preview_time = 0;
- mvhd->preview_duration = 0;
- mvhd->poster_time = 0;
- mvhd->selection_time = 0;
- mvhd->selection_duration = 0;
- mvhd->current_time = 0;
- mvhd->next_track_id = 1;
- return 0;
-}
-
-int mp4ff_mvhd_delete(mp4ff_mvhd_t *mvhd)
-{
- return 0;
-}
-
-int mp4ff_mvhd_dump(mp4ff_mvhd_t *mvhd)
-{
- printf(" movie header\n");
- printf(" version %d\n", mvhd->version);
- printf(" flags %ld\n", mvhd->flags);
- printf(" creation_time %u\n", mvhd->creation_time);
- printf(" modification_time %u\n", mvhd->modification_time);
- printf(" time_scale %ld\n", mvhd->time_scale);
- printf(" duration %ld\n", mvhd->duration);
- printf(" preferred_rate %f\n", mvhd->preferred_rate);
- printf(" preferred_volume %f\n", mvhd->preferred_volume);
- mp4ff_print_chars(" reserved ", mvhd->reserved, 10);
- mp4ff_matrix_dump(&(mvhd->matrix));
- printf(" preview_time %ld\n", mvhd->preview_time);
- printf(" preview_duration %ld\n", mvhd->preview_duration);
- printf(" poster_time %ld\n", mvhd->poster_time);
- printf(" selection_time %ld\n", mvhd->selection_time);
- printf(" selection_duration %ld\n", mvhd->selection_duration);
- printf(" current_time %ld\n", mvhd->current_time);
- printf(" next_track_id %ld\n", mvhd->next_track_id);
-}
-
-int mp4ff_read_mvhd(mp4ff_t *file, mp4ff_mvhd_t *mvhd)
-{
- mvhd->version = mp4ff_read_char(file);
- mvhd->flags = mp4ff_read_int24(file);
- mvhd->creation_time = mp4ff_read_int32(file);
- mvhd->modification_time = mp4ff_read_int32(file);
- mvhd->time_scale = mp4ff_read_int32(file);
- mvhd->duration = mp4ff_read_int32(file);
- mvhd->preferred_rate = mp4ff_read_fixed32(file);
- mvhd->preferred_volume = mp4ff_read_fixed16(file);
- mp4ff_read_data(file, mvhd->reserved, 10);
- mp4ff_read_matrix(file, &(mvhd->matrix));
- mvhd->preview_time = mp4ff_read_int32(file);
- mvhd->preview_duration = mp4ff_read_int32(file);
- mvhd->poster_time = mp4ff_read_int32(file);
- mvhd->selection_time = mp4ff_read_int32(file);
- mvhd->selection_duration = mp4ff_read_int32(file);
- mvhd->current_time = mp4ff_read_int32(file);
- mvhd->next_track_id = mp4ff_read_int32(file);
-}
-
-int mp4ff_write_mvhd(mp4ff_t *file, mp4ff_mvhd_t *mvhd)
-{
- int i;
-
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "mvhd");
-
- mp4ff_write_char(file, mvhd->version);
- mp4ff_write_int24(file, mvhd->flags);
- mp4ff_write_int32(file, mvhd->creation_time);
- mp4ff_write_int32(file, mvhd->modification_time);
- mp4ff_write_int32(file, mvhd->time_scale);
- mp4ff_write_int32(file, mvhd->duration);
-
- mp4ff_write_int32(file, 0x00010000);
- mp4ff_write_int16(file, 0x0100);
- mp4ff_write_int16(file, 0x0000);
- mp4ff_write_int32(file, 0x00000000);
- mp4ff_write_int32(file, 0x00000000);
- mp4ff_write_int32(file, 0x00010000);
- for (i = 0; i < 3; i++) {
- mp4ff_write_int32(file, 0x00000000);
- }
- mp4ff_write_int32(file, 0x00010000);
- for (i = 0; i < 3; i++) {
- mp4ff_write_int32(file, 0x00000000);
- }
- mp4ff_write_int32(file, 0x40000000);
- for (i = 0; i < 6; i++) {
- mp4ff_write_int32(file, 0x00000000);
- }
-
- mp4ff_write_int32(file, mvhd->next_track_id);
-
- mp4ff_atom_write_footer(file, &atom);
-}
--- a/common/mp4ff/private.h
+++ /dev/null
@@ -1,509 +1,0 @@
-#ifndef PRIVATE_H
-#define PRIVATE_H
-
-/* ================================= structures */
-
-#define HEADER_LENGTH 8
-#define MAXTRACKS 1024
-
-#ifdef _WIN32
-typedef __int8 int8_t;
-typedef unsigned __int8 uint8_t;
-typedef __int16 int16_t;
-typedef unsigned __int16 uint16_t;
-typedef __int32 int32_t;
-typedef unsigned __int32 uint32_t;
-typedef __int64 int64_t;
-typedef unsigned __int64 uint64_t;
-typedef __int64 off_t;
-#else
-#ifdef HAVE_INTTYPES_H
-#include <inttypes.h>
-#else
-#ifdef HAVE_STDINT_H
-#include <stdint.h>
-#endif
-#define u_int8_t uint8_t
-#define u_int16_t uint16_t
-#define u_int32_t uint32_t
-#define u_int64_t uint64_t
-#endif
-
-#endif
-
-
-typedef struct
-{
- float values[9];
-} mp4ff_matrix_t;
-
-
-typedef struct
-{
- int version;
- long flags;
- unsigned long creation_time;
- unsigned long modification_time;
- int track_id;
- long reserved1;
- long duration;
- char reserved2[8];
- int layer;
- int alternate_group;
- float volume;
- long reserved3;
- mp4ff_matrix_t matrix;
- float track_width;
- float track_height;
- int is_video;
- int is_audio;
-} mp4ff_tkhd_t;
-
-
-
-
-/* ===================== sample table ======================== // */
-
-
-
-/* sample description */
-
-typedef struct
-{
- int version;
- long flags;
- int decoderConfigLen;
- unsigned char* decoderConfig;
-} mp4ff_esds_t;
-
-typedef struct
-{
- char format[4];
- char reserved[6];
- int data_reference;
-
-/* common to audio and video */
- int version;
- int revision;
- char vendor[4];
-
-/* video description */
- long temporal_quality;
- long spatial_quality;
- int width;
- int height;
- float dpi_horizontal;
- float dpi_vertical;
- long data_size;
- int frames_per_sample;
- char compressor_name[32];
- int depth;
- float gamma;
- int fields; /* 0, 1, or 2 */
- int field_dominance; /* 0 - unknown 1 - top first 2 - bottom first */
-
-/* audio description */
- int channels;
- int sample_size;
- int compression_id;
- int packet_size;
- float sample_rate;
-
-/* MP4 elementary stream descriptor */
- mp4ff_esds_t esds;
-
-} mp4ff_stsd_table_t;
-
-
-typedef struct
-{
- int version;
- long flags;
- long total_entries;
- mp4ff_stsd_table_t *table;
-} mp4ff_stsd_t;
-
-
-/* time to sample */
-typedef struct
-{
- long sample_count;
- long sample_duration;
-} mp4ff_stts_table_t;
-
-typedef struct
-{
- int version;
- long flags;
- long total_entries;
- long entries_allocated;
- mp4ff_stts_table_t *table;
-} mp4ff_stts_t;
-
-
-/* sync sample */
-typedef struct
-{
- long sample;
-} mp4ff_stss_table_t;
-
-typedef struct
-{
- int version;
- long flags;
- long total_entries;
- long entries_allocated;
- mp4ff_stss_table_t *table;
-} mp4ff_stss_t;
-
-
-/* sample to chunk */
-typedef struct
-{
- long chunk;
- long samples;
- long id;
-} mp4ff_stsc_table_t;
-
-typedef struct
-{
- int version;
- long flags;
- long total_entries;
-
- long entries_allocated;
- mp4ff_stsc_table_t *table;
-} mp4ff_stsc_t;
-
-
-/* sample size */
-typedef struct
-{
- long size;
-} mp4ff_stsz_table_t;
-
-typedef struct
-{
- int version;
- long flags;
- long sample_size;
- long total_entries;
-
- long entries_allocated; /* used by the library for allocating a table */
- mp4ff_stsz_table_t *table;
-} mp4ff_stsz_t;
-
-
-/* chunk offset */
-typedef struct
-{
- long offset;
-} mp4ff_stco_table_t;
-
-typedef struct
-{
- int version;
- long flags;
- long total_entries;
-
- long entries_allocated; /* used by the library for allocating a table */
- mp4ff_stco_table_t *table;
-} mp4ff_stco_t;
-
-/* composition time to sample */
-typedef struct
-{
- long sample_count;
- long sample_offset;
-} mp4ff_ctts_table_t;
-
-typedef struct
-{
- int version;
- long flags;
- long total_entries;
- long entries_allocated;
- mp4ff_ctts_table_t *table;
-} mp4ff_ctts_t;
-
-
-/* sample table */
-typedef struct
-{
- int version;
- long flags;
- mp4ff_stsd_t stsd;
- mp4ff_stts_t stts;
- mp4ff_stss_t stss;
- mp4ff_stsc_t stsc;
- mp4ff_stsz_t stsz;
- mp4ff_stco_t stco;
- mp4ff_ctts_t ctts;
-} mp4ff_stbl_t;
-
-/* data reference */
-
-typedef struct
-{
- long size;
- char type[4];
- int version;
- long flags;
- char *data_reference;
-} mp4ff_dref_table_t;
-
-typedef struct
-{
- int version;
- long flags;
- long total_entries;
- mp4ff_dref_table_t *table;
-} mp4ff_dref_t;
-
-/* data information */
-
-typedef struct
-{
- mp4ff_dref_t dref;
-} mp4ff_dinf_t;
-
-/* video media header */
-
-typedef struct
-{
- int version;
- long flags;
- int graphics_mode;
- int opcolor[3];
-} mp4ff_vmhd_t;
-
-
-/* sound media header */
-
-typedef struct
-{
- int version;
- long flags;
- int balance;
- int reserved;
-} mp4ff_smhd_t;
-
-/* handler reference */
-
-typedef struct
-{
- int version;
- long flags;
- char component_type[4];
- char component_subtype[4];
- long component_manufacturer;
- long component_flags;
- long component_flag_mask;
- char component_name[256];
-} mp4ff_hdlr_t;
-
-/* media information */
-
-typedef struct
-{
- int is_video;
- int is_audio;
- mp4ff_vmhd_t vmhd;
- mp4ff_smhd_t smhd;
- mp4ff_stbl_t stbl;
- mp4ff_hdlr_t hdlr;
- mp4ff_dinf_t dinf;
-} mp4ff_minf_t;
-
-
-/* media header */
-
-typedef struct
-{
- int version;
- long flags;
- unsigned long creation_time;
- unsigned long modification_time;
- long time_scale;
- long duration;
- int language;
- int quality;
-} mp4ff_mdhd_t;
-
-
-/* media */
-
-typedef struct
-{
- mp4ff_mdhd_t mdhd;
- mp4ff_minf_t minf;
- mp4ff_hdlr_t hdlr;
-} mp4ff_mdia_t;
-
-/* edit list */
-typedef struct
-{
- long duration;
- long time;
- float rate;
-} mp4ff_elst_table_t;
-
-typedef struct
-{
- int version;
- long flags;
- long total_entries;
-
- mp4ff_elst_table_t *table;
-} mp4ff_elst_t;
-
-typedef struct
-{
- mp4ff_elst_t elst;
-} mp4ff_edts_t;
-
-typedef struct
-{
- mp4ff_tkhd_t tkhd;
- mp4ff_mdia_t mdia;
- mp4ff_edts_t edts;
-} mp4ff_trak_t;
-
-typedef struct
-{
- int version;
- long flags;
- int audioProfileId;
- int videoProfileId;
-} mp4ff_iods_t;
-
-typedef struct
-{
- int version;
- long flags;
- unsigned long creation_time;
- unsigned long modification_time;
- long time_scale;
- long duration;
- float preferred_rate;
- float preferred_volume;
- char reserved[10];
- mp4ff_matrix_t matrix;
- long preview_time;
- long preview_duration;
- long poster_time;
- long selection_time;
- long selection_duration;
- long current_time;
- long next_track_id;
-} mp4ff_mvhd_t;
-
-typedef struct
-{
- char *copyright;
- int copyright_len;
- char *name;
- int name_len;
- char *info;
- int info_len;
-} mp4ff_udta_t;
-
-
-typedef struct
-{
- int total_tracks;
-
- mp4ff_mvhd_t mvhd;
- mp4ff_iods_t iods;
- mp4ff_trak_t *trak[MAXTRACKS];
- mp4ff_udta_t udta;
-} mp4ff_moov_t;
-
-typedef struct
-{
- long start;
- long size;
-} mp4ff_mdat_t;
-
-
-typedef struct
-{
- long start; /* byte start in file */
- long end; /* byte endpoint in file */
- long size; /* byte size for writing */
- char type[4];
-} mp4ff_atom_t;
-
-/* table of pointers to every track */
-typedef struct
-{
- mp4ff_trak_t *track; /* real quicktime track corresponding to this table */
- int channels; /* number of audio channels in the track */
- long current_position; /* current sample in output file */
- long current_chunk; /* current chunk in output file */
-
- void *codec;
-} mp4ff_audio_map_t;
-
-typedef struct
-{
- mp4ff_trak_t *track;
- long current_position;
- long current_chunk;
-
-/* Array of pointers to frames of raw data when caching frames. */
- unsigned char **frame_cache;
- long frames_cached;
-
- void *codec;
-} mp4ff_video_map_t;
-
-/* file descriptor passed to all routines */
-
-typedef struct
-{
- size_t (*read)(void *buffer, size_t length);
- size_t (*write)(void *buffer, size_t length);
- off_t (*get_position)();
- off_t (*get_length)();
- int (*seek)(off_t position);
-} mp4_callback_t;
-
-typedef struct
-{
- mp4_callback_t *stream;
- long total_length;
- mp4ff_mdat_t mdat;
- mp4ff_moov_t moov;
- int rd;
- int wr;
-
-/* mapping of audio channels to movie tracks */
-/* one audio map entry exists for each channel */
- int total_atracks;
- mp4ff_audio_map_t *atracks;
-
-/* mapping of video tracks to movie tracks */
- int total_vtracks;
- mp4ff_video_map_t *vtracks;
-
-/* for begining and ending frame writes where the user wants to write the */
-/* file descriptor directly */
- long offset;
-
-/* I/O */
- long file_position; /* Current position of file descriptor */
-
-/* Parameters for frame currently being decoded */
- int do_scaling;
- int in_x, in_y, in_w, in_h, out_w, out_h;
- int color_model;
-
-/* Cached value for mp4ff_video_frame */
- long last_frame;
- long last_start;
- int last_stts_index;
-
-} mp4ff_t;
-
-#endif
--- a/common/mp4ff/smhd.c
+++ /dev/null
@@ -1,46 +1,0 @@
-#include "mp4ff.h"
-
-
-
-
-int mp4ff_smhd_init(mp4ff_smhd_t *smhd)
-{
- smhd->version = 0;
- smhd->flags = 0;
- smhd->balance = 0;
- smhd->reserved = 0;
-}
-
-int mp4ff_smhd_delete(mp4ff_smhd_t *smhd)
-{
-}
-
-int mp4ff_smhd_dump(mp4ff_smhd_t *smhd)
-{
- printf(" sound media header\n");
- printf(" version %d\n", smhd->version);
- printf(" flags %d\n", smhd->flags);
- printf(" balance %d\n", smhd->balance);
- printf(" reserved %d\n", smhd->reserved);
-}
-
-int mp4ff_read_smhd(mp4ff_t *file, mp4ff_smhd_t *smhd)
-{
- smhd->version = mp4ff_read_char(file);
- smhd->flags = mp4ff_read_int24(file);
- smhd->balance = mp4ff_read_int16(file);
- smhd->reserved = mp4ff_read_int16(file);
-}
-
-int mp4ff_write_smhd(mp4ff_t *file, mp4ff_smhd_t *smhd)
-{
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "smhd");
-
- mp4ff_write_char(file, smhd->version);
- mp4ff_write_int24(file, smhd->flags);
-
- mp4ff_write_int32(file, 0x00000000);
-
- mp4ff_atom_write_footer(file, &atom);
-}
--- a/common/mp4ff/stbl.c
+++ /dev/null
@@ -1,132 +1,0 @@
-#include "mp4ff.h"
-
-int mp4ff_stbl_init(mp4ff_stbl_t *stbl)
-{
- stbl->version = 0;
- stbl->flags = 0;
- mp4ff_stsd_init(&(stbl->stsd));
- mp4ff_stts_init(&(stbl->stts));
- mp4ff_stss_init(&(stbl->stss));
- mp4ff_stsc_init(&(stbl->stsc));
- mp4ff_stsz_init(&(stbl->stsz));
- mp4ff_stco_init(&(stbl->stco));
- mp4ff_ctts_init(&(stbl->ctts));
-}
-
-int mp4ff_stbl_init_video(mp4ff_t *file,
- mp4ff_stbl_t *stbl,
- int frame_w,
- int frame_h,
- int time_scale,
- float frame_rate,
- char *compressor)
-{
- mp4ff_stsd_init_video(file, &(stbl->stsd), frame_w, frame_h, frame_rate, compressor);
- mp4ff_stts_init_video(file, &(stbl->stts), time_scale, frame_rate);
- mp4ff_stss_init_common(file, &(stbl->stss));
- mp4ff_stsc_init_video(file, &(stbl->stsc));
- mp4ff_stsz_init_video(file, &(stbl->stsz));
- mp4ff_stco_init_common(file, &(stbl->stco));
- mp4ff_ctts_init_common(file, &(stbl->ctts));
-}
-
-
-int mp4ff_stbl_init_audio(mp4ff_t *file,
- mp4ff_stbl_t *stbl,
- int channels,
- int sample_rate,
- int bits,
- int sample_size,
- int time_scale,
- int sample_duration,
- char *compressor)
-{
- mp4ff_stsd_init_audio(file, &(stbl->stsd), channels, sample_rate, bits, compressor);
- mp4ff_stts_init_audio(file, &(stbl->stts), time_scale, sample_duration);
- mp4ff_stss_init_common(file, &(stbl->stss));
- mp4ff_stsc_init_audio(file, &(stbl->stsc));
- mp4ff_stsz_init_audio(file, &(stbl->stsz), sample_size);
- mp4ff_stco_init_common(file, &(stbl->stco));
- mp4ff_ctts_init_common(file, &(stbl->ctts));
-}
-
-int mp4ff_stbl_delete(mp4ff_stbl_t *stbl)
-{
- mp4ff_stsd_delete(&(stbl->stsd));
- mp4ff_stts_delete(&(stbl->stts));
- mp4ff_stss_delete(&(stbl->stss));
- mp4ff_stsc_delete(&(stbl->stsc));
- mp4ff_stsz_delete(&(stbl->stsz));
- mp4ff_stco_delete(&(stbl->stco));
- mp4ff_ctts_delete(&(stbl->ctts));
-}
-
-int mp4ff_stbl_dump(void *minf_ptr, mp4ff_stbl_t *stbl)
-{
- printf(" sample table\n");
- mp4ff_stsd_dump(minf_ptr, &(stbl->stsd));
- mp4ff_stts_dump(&(stbl->stts));
- mp4ff_stss_dump(&(stbl->stss));
- mp4ff_stsc_dump(&(stbl->stsc));
- mp4ff_stsz_dump(&(stbl->stsz));
- mp4ff_stco_dump(&(stbl->stco));
- mp4ff_ctts_dump(&(stbl->ctts));
-}
-
-int mp4ff_read_stbl(mp4ff_t *file, mp4ff_minf_t *minf, mp4ff_stbl_t *stbl, mp4ff_atom_t *parent_atom)
-{
- mp4ff_atom_t leaf_atom;
-
- do
- {
- mp4ff_atom_read_header(file, &leaf_atom);
-
-/* mandatory */
- if(mp4ff_atom_is(&leaf_atom, "stsd"))
- {
- mp4ff_read_stsd(file, minf, &(stbl->stsd));
-/* Some codecs store extra information at the end of this */
- mp4ff_atom_skip(file, &leaf_atom);
- }
- else
- if(mp4ff_atom_is(&leaf_atom, "stts"))
- { mp4ff_read_stts(file, &(stbl->stts)); }
- else
- if(mp4ff_atom_is(&leaf_atom, "stss"))
- { mp4ff_read_stss(file, &(stbl->stss)); }
- else
- if(mp4ff_atom_is(&leaf_atom, "stsc"))
- { mp4ff_read_stsc(file, &(stbl->stsc)); }
- else
- if(mp4ff_atom_is(&leaf_atom, "stsz"))
- { mp4ff_read_stsz(file, &(stbl->stsz)); }
- else
- if(mp4ff_atom_is(&leaf_atom, "stco"))
- { mp4ff_read_stco(file, &(stbl->stco)); }
- else
- if(mp4ff_atom_is(&leaf_atom, "ctts"))
- { mp4ff_read_ctts(file, &(stbl->ctts)); }
- else
- mp4ff_atom_skip(file, &leaf_atom);
- }while(mp4ff_position(file) < parent_atom->end);
-
- return 0;
-}
-
-int mp4ff_write_stbl(mp4ff_t *file, mp4ff_minf_t *minf, mp4ff_stbl_t *stbl)
-{
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "stbl");
-
- mp4ff_write_stsd(file, minf, &(stbl->stsd));
- mp4ff_write_stts(file, &(stbl->stts));
- mp4ff_write_stss(file, &(stbl->stss));
- mp4ff_write_stsc(file, &(stbl->stsc));
- mp4ff_write_stsz(file, &(stbl->stsz));
- mp4ff_write_stco(file, &(stbl->stco));
- mp4ff_write_ctts(file, &(stbl->ctts));
-
- mp4ff_atom_write_footer(file, &atom);
-}
-
-
--- a/common/mp4ff/stco.c
+++ /dev/null
@@ -1,92 +1,0 @@
-#include "mp4ff.h"
-
-
-
-int mp4ff_stco_init(mp4ff_stco_t *stco)
-{
- stco->version = 0;
- stco->flags = 0;
- stco->total_entries = 0;
- stco->entries_allocated = 0;
-}
-
-int mp4ff_stco_delete(mp4ff_stco_t *stco)
-{
- if(stco->total_entries) free(stco->table);
- stco->total_entries = 0;
- stco->entries_allocated = 0;
-}
-
-int mp4ff_stco_init_common(mp4ff_t *file, mp4ff_stco_t *stco)
-{
- if(!stco->entries_allocated)
- {
- stco->entries_allocated = 2000;
- stco->total_entries = 0;
- stco->table = (mp4ff_stco_table_t*)malloc(sizeof(mp4ff_stco_table_t) * stco->entries_allocated);
-/*printf("mp4ff_stco_init_common %x\n", stco->table); */
- }
-}
-
-int mp4ff_stco_dump(mp4ff_stco_t *stco)
-{
- int i;
- printf(" chunk offset\n");
- printf(" version %d\n", stco->version);
- printf(" flags %d\n", stco->flags);
- printf(" total_entries %d\n", stco->total_entries);
- for(i = 0; i < stco->total_entries; i++)
- {
- printf(" offset %d %x\n", i, stco->table[i].offset);
- }
-}
-
-int mp4ff_read_stco(mp4ff_t *file, mp4ff_stco_t *stco)
-{
- int i;
- stco->version = mp4ff_read_char(file);
- stco->flags = mp4ff_read_int24(file);
- stco->total_entries = mp4ff_read_int32(file);
-/*printf("stco->total_entries %d %x\n", stco->total_entries, stco); */
- stco->entries_allocated = stco->total_entries;
- stco->table = (mp4ff_stco_table_t*)malloc(sizeof(mp4ff_stco_table_t) * stco->entries_allocated);
- for(i = 0; i < stco->total_entries; i++)
- {
- stco->table[i].offset = mp4ff_read_int32(file);
- }
-}
-
-int mp4ff_write_stco(mp4ff_t *file, mp4ff_stco_t *stco)
-{
- int i;
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "stco");
-
- mp4ff_write_char(file, stco->version);
- mp4ff_write_int24(file, stco->flags);
- mp4ff_write_int32(file, stco->total_entries);
- for(i = 0; i < stco->total_entries; i++)
- {
- mp4ff_write_int32(file, stco->table[i].offset);
- }
-
- mp4ff_atom_write_footer(file, &atom);
-}
-
-int mp4ff_update_stco(mp4ff_stco_t *stco, long chunk, long offset)
-{
- mp4ff_stco_table_t *new_table;
- long i;
-
- if(chunk > stco->entries_allocated)
- {
- stco->entries_allocated = chunk * 2;
- stco->table = (mp4ff_stco_table_t*)realloc(stco->table,
- sizeof(mp4ff_stco_table_t) * stco->entries_allocated);
- }
-
- stco->table[chunk - 1].offset = offset;
- if(chunk > stco->total_entries)
- stco->total_entries = chunk;
-}
-
--- a/common/mp4ff/stsc.c
+++ /dev/null
@@ -1,146 +1,0 @@
-#include "mp4ff.h"
-
-
-
-int mp4ff_stsc_init(mp4ff_stsc_t *stsc)
-{
- stsc->version = 0;
- stsc->flags = 0;
- stsc->total_entries = 0;
- stsc->entries_allocated = 0;
-}
-
-int mp4ff_stsc_init_table(mp4ff_t *file, mp4ff_stsc_t *stsc)
-{
- if(!stsc->total_entries)
- {
- stsc->total_entries = 1;
- stsc->entries_allocated = 1;
- stsc->table = (mp4ff_stsc_table_t*)malloc(sizeof(mp4ff_stsc_table_t) * stsc->entries_allocated);
- }
-}
-
-int mp4ff_stsc_init_video(mp4ff_t *file, mp4ff_stsc_t *stsc)
-{
- mp4ff_stsc_table_t *table;
- mp4ff_stsc_init_table(file, stsc);
- table = &(stsc->table[0]);
- table->chunk = 1;
- table->samples = 1;
- table->id = 1;
-}
-
-int mp4ff_stsc_init_audio(mp4ff_t *file, mp4ff_stsc_t *stsc)
-{
- mp4ff_stsc_table_t *table;
- mp4ff_stsc_init_table(file, stsc);
- table = &(stsc->table[0]);
- table->chunk = 1;
- table->samples = 0; /* set this after completion or after every audio chunk is written */
- table->id = 1;
-}
-
-int mp4ff_stsc_delete(mp4ff_stsc_t *stsc)
-{
- if(stsc->total_entries) free(stsc->table);
- stsc->total_entries = 0;
-}
-
-int mp4ff_stsc_dump(mp4ff_stsc_t *stsc)
-{
- int i;
- printf(" sample to chunk\n");
- printf(" version %d\n", stsc->version);
- printf(" flags %d\n", stsc->flags);
- printf(" total_entries %d\n", stsc->total_entries);
- for(i = 0; i < stsc->total_entries; i++)
- {
- printf(" chunk %d samples %d id %d\n",
- stsc->table[i].chunk, stsc->table[i].samples, stsc->table[i].id);
- }
-}
-
-int mp4ff_read_stsc(mp4ff_t *file, mp4ff_stsc_t *stsc)
-{
- int i;
- stsc->version = mp4ff_read_char(file);
- stsc->flags = mp4ff_read_int24(file);
- stsc->total_entries = mp4ff_read_int32(file);
-
- stsc->entries_allocated = stsc->total_entries;
- stsc->table = (mp4ff_stsc_table_t*)malloc(sizeof(mp4ff_stsc_table_t) * stsc->total_entries);
- for(i = 0; i < stsc->total_entries; i++)
- {
- stsc->table[i].chunk = mp4ff_read_int32(file);
- stsc->table[i].samples = mp4ff_read_int32(file);
- stsc->table[i].id = mp4ff_read_int32(file);
- }
-}
-
-
-int mp4ff_write_stsc(mp4ff_t *file, mp4ff_stsc_t *stsc)
-{
- int i, last_same;
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "stsc");
-
- for(i = 1, last_same = 0; i < stsc->total_entries; i++)
- {
- if(stsc->table[i].samples != stsc->table[last_same].samples)
- {
-/* An entry has a different sample count. */
- last_same++;
- if(last_same < i)
- {
-/* Move it up the list. */
- stsc->table[last_same] = stsc->table[i];
- }
- }
- }
- last_same++;
- stsc->total_entries = last_same;
-
-
- mp4ff_write_char(file, stsc->version);
- mp4ff_write_int24(file, stsc->flags);
- mp4ff_write_int32(file, stsc->total_entries);
- for(i = 0; i < stsc->total_entries; i++)
- {
- mp4ff_write_int32(file, stsc->table[i].chunk);
- mp4ff_write_int32(file, stsc->table[i].samples);
- mp4ff_write_int32(file, stsc->table[i].id);
- }
-
- mp4ff_atom_write_footer(file, &atom);
-}
-
-int mp4ff_update_stsc(mp4ff_stsc_t *stsc, long chunk, long samples)
-{
-/* mp4ff_stsc_table_t *table = stsc->table; */
- mp4ff_stsc_table_t *new_table;
- long i;
-
- if(chunk > stsc->entries_allocated)
- {
- stsc->entries_allocated = chunk * 2;
- new_table = (mp4ff_stsc_table_t*)malloc(sizeof(mp4ff_stsc_table_t) * stsc->entries_allocated);
- for(i = 0; i < stsc->total_entries; i++) new_table[i] = stsc->table[i];
- free(stsc->table);
- stsc->table = new_table;
- }
-
- stsc->table[chunk - 1].samples = samples;
- stsc->table[chunk - 1].chunk = chunk;
- stsc->table[chunk - 1].id = 1;
- if(chunk > stsc->total_entries) stsc->total_entries = chunk;
- return 0;
-}
-
-/* Optimizing while writing doesn't allow seeks during recording so */
-/* entries are created for every chunk and only optimized during */
-/* writeout. Unfortunately there's no way to keep audio synchronized */
-/* after overwriting a recording as the fractional audio chunk in the */
-/* middle always overwrites the previous location of a larger chunk. On */
-/* writing, the table must be optimized. RealProducer requires an */
-/* optimized table. */
-
--- a/common/mp4ff/stsd.c
+++ /dev/null
@@ -1,117 +1,0 @@
-#include "mp4ff.h"
-
-
-int mp4ff_stsd_init(mp4ff_stsd_t *stsd)
-{
- stsd->version = 0;
- stsd->flags = 0;
- stsd->total_entries = 0;
-}
-
-int mp4ff_stsd_init_table(mp4ff_stsd_t *stsd)
-{
- if(!stsd->total_entries)
- {
- stsd->total_entries = 1;
- stsd->table = (mp4ff_stsd_table_t*)malloc(sizeof(mp4ff_stsd_table_t) * stsd->total_entries);
- mp4ff_stsd_table_init(&(stsd->table[0]));
- }
-}
-
-int mp4ff_stsd_init_video(mp4ff_t *file,
- mp4ff_stsd_t *stsd,
- int frame_w,
- int frame_h,
- float frame_rate,
- char *compression)
-{
- mp4ff_stsd_table_t *table;
- mp4ff_stsd_init_table(stsd);
- table = &(stsd->table[0]);
-
- mp4ff_copy_char32(table->format, compression);
- table->width = frame_w;
- table->height = frame_h;
- table->frames_per_sample = 1;
- table->depth = 24;
-}
-
-int mp4ff_stsd_init_audio(mp4ff_t *file,
- mp4ff_stsd_t *stsd,
- int channels,
- int sample_rate,
- int bits,
- char *compressor)
-{
- mp4ff_stsd_table_t *table;
- mp4ff_stsd_init_table(stsd);
- table = &(stsd->table[0]);
-
- mp4ff_copy_char32(table->format, compressor);
- table->channels = channels;
- table->sample_size = bits;
- table->sample_rate = sample_rate;
-}
-
-int mp4ff_stsd_delete(mp4ff_stsd_t *stsd)
-{
- int i;
- if(stsd->total_entries)
- {
- for(i = 0; i < stsd->total_entries; i++)
- mp4ff_stsd_table_delete(&(stsd->table[i]));
- free(stsd->table);
- }
-
- stsd->total_entries = 0;
-}
-
-int mp4ff_stsd_dump(void *minf_ptr, mp4ff_stsd_t *stsd)
-{
- int i;
- printf(" sample description\n");
- printf(" version %d\n", stsd->version);
- printf(" flags %d\n", stsd->flags);
- printf(" total_entries %d\n", stsd->total_entries);
-
- for(i = 0; i < stsd->total_entries; i++)
- {
- mp4ff_stsd_table_dump(minf_ptr, &(stsd->table[i]));
- }
-}
-
-int mp4ff_read_stsd(mp4ff_t *file, mp4ff_minf_t *minf, mp4ff_stsd_t *stsd)
-{
- int i;
- mp4ff_atom_t leaf_atom;
-
- stsd->version = mp4ff_read_char(file);
- stsd->flags = mp4ff_read_int24(file);
- stsd->total_entries = mp4ff_read_int32(file);
- stsd->table = (mp4ff_stsd_table_t*)malloc(sizeof(mp4ff_stsd_table_t) * stsd->total_entries);
- for(i = 0; i < stsd->total_entries; i++)
- {
- mp4ff_stsd_table_init(&(stsd->table[i]));
- mp4ff_read_stsd_table(file, minf, &(stsd->table[i]));
- }
-}
-
-int mp4ff_write_stsd(mp4ff_t *file, mp4ff_minf_t *minf, mp4ff_stsd_t *stsd)
-{
- mp4ff_atom_t atom;
- int i;
- mp4ff_atom_write_header(file, &atom, "stsd");
-
- mp4ff_write_char(file, stsd->version);
- mp4ff_write_int24(file, stsd->flags);
- mp4ff_write_int32(file, stsd->total_entries);
- for(i = 0; i < stsd->total_entries; i++)
- {
- mp4ff_write_stsd_table(file, minf, stsd->table);
- }
-
- mp4ff_atom_write_footer(file, &atom);
-}
-
-
-
--- a/common/mp4ff/stsdtable.c
+++ /dev/null
@@ -1,253 +1,0 @@
-#include "mp4ff.h"
-
-
-int mp4ff_stsd_table_init(mp4ff_stsd_table_t *table)
-{
- int i;
- table->format[0] = 'y';
- table->format[1] = 'u';
- table->format[2] = 'v';
- table->format[3] = '2';
- for(i = 0; i < 6; i++) table->reserved[i] = 0;
- table->data_reference = 1;
-
- table->version = 0;
- table->revision = 0;
- table->vendor[0] = 'l';
- table->vendor[1] = 'n';
- table->vendor[2] = 'u';
- table->vendor[3] = 'x';
-
- table->temporal_quality = 0;
- table->spatial_quality = 258;
- table->width = 0;
- table->height = 0;
- table->dpi_horizontal = 72;
- table->dpi_vertical = 72;
- table->data_size = 0;
- table->frames_per_sample = 1;
- for(i = 0; i < 32; i++) table->compressor_name[i] = 0;
- sprintf(table->compressor_name, "Quicktime for Linux");
- table->depth = 24;
- table->gamma = 0;
- table->fields = 0;
- table->field_dominance = 1;
-
- table->channels = 0;
- table->sample_size = 0;
- table->compression_id = 0;
- table->packet_size = 0;
- table->sample_rate = 0;
-
- mp4ff_esds_init(&(table->esds));
-}
-
-int mp4ff_stsd_table_delete(mp4ff_stsd_table_t *table)
-{
- mp4ff_esds_delete(&(table->esds));
-}
-
-int mp4ff_stsd_table_dump(void *minf_ptr, mp4ff_stsd_table_t *table)
-{
- mp4ff_minf_t *minf = minf_ptr;
- printf(" format %c%c%c%c\n", table->format[0], table->format[1], table->format[2], table->format[3]);
- mp4ff_print_chars(" reserved ", table->reserved, 6);
- printf(" data_reference %d\n", table->data_reference);
-
- if(minf->is_audio) mp4ff_stsd_audio_dump(table);
- if(minf->is_video) mp4ff_stsd_video_dump(table);
-}
-
-int mp4ff_stsd_audio_dump(mp4ff_stsd_table_t *table)
-{
- printf(" version %d\n", table->version);
- printf(" revision %d\n", table->revision);
- printf(" vendor %c%c%c%c\n", table->vendor[0], table->vendor[1], table->vendor[2], table->vendor[3]);
- printf(" channels %d\n", table->channels);
- printf(" sample_size %d\n", table->sample_size);
- printf(" compression_id %d\n", table->compression_id);
- printf(" packet_size %d\n", table->packet_size);
- printf(" sample_rate %f\n", table->sample_rate);
-
- mp4ff_esds_dump(&(table->esds));
-}
-
-int mp4ff_stsd_video_dump(mp4ff_stsd_table_t *table)
-{
- printf(" version %d\n", table->version);
- printf(" revision %d\n", table->revision);
- printf(" vendor %c%c%c%c\n", table->vendor[0], table->vendor[1], table->vendor[2], table->vendor[3]);
- printf(" temporal_quality %ld\n", table->temporal_quality);
- printf(" spatial_quality %ld\n", table->spatial_quality);
- printf(" width %d\n", table->width);
- printf(" height %d\n", table->height);
- printf(" dpi_horizontal %f\n", table->dpi_horizontal);
- printf(" dpi_vertical %f\n", table->dpi_vertical);
- printf(" data_size %ld\n", table->data_size);
- printf(" frames_per_sample %d\n", table->frames_per_sample);
- printf(" compressor_name %s\n", table->compressor_name);
- printf(" depth %d\n", table->depth);
- printf(" gamma %f\n", table->gamma);
- if(table->fields)
- {
- printf(" fields %d\n", table->fields);
- printf(" field dominance %d\n", table->field_dominance);
- }
- mp4ff_esds_dump(&(table->esds));
-}
-
-int mp4ff_read_stsd_table(mp4ff_t *file, mp4ff_minf_t *minf, mp4ff_stsd_table_t *table)
-{
- mp4ff_atom_t leaf_atom;
-
- mp4ff_atom_read_header(file, &leaf_atom);
-
- table->format[0] = leaf_atom.type[0];
- table->format[1] = leaf_atom.type[1];
- table->format[2] = leaf_atom.type[2];
- table->format[3] = leaf_atom.type[3];
- mp4ff_read_data(file, table->reserved, 6);
- table->data_reference = mp4ff_read_int16(file);
-
- if(minf->is_audio) mp4ff_read_stsd_audio(file, table, &leaf_atom);
- if(minf->is_video) mp4ff_read_stsd_video(file, table, &leaf_atom);
-}
-
-int mp4ff_write_stsd_table(mp4ff_t *file, mp4ff_minf_t *minf, mp4ff_stsd_table_t *table)
-{
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, table->format);
-/*printf("mp4ff_write_stsd_table %c%c%c%c\n", table->format[0], table->format[1], table->format[2], table->format[3]); */
- mp4ff_write_data(file, table->reserved, 6);
- mp4ff_write_int16(file, table->data_reference);
-
- if(minf->is_audio) mp4ff_write_stsd_audio(file, table);
- if(minf->is_video) mp4ff_write_stsd_video(file, table);
-
- mp4ff_atom_write_footer(file, &atom);
-}
-
-int mp4ff_read_stsd_audio(mp4ff_t *file, mp4ff_stsd_table_t *table, mp4ff_atom_t *parent_atom)
-{
- table->version = mp4ff_read_int16(file);
- table->revision = mp4ff_read_int16(file);
- mp4ff_read_data(file, table->vendor, 4);
- table->channels = mp4ff_read_int16(file);
- table->sample_size = mp4ff_read_int16(file);
- table->compression_id = mp4ff_read_int16(file);
- table->packet_size = mp4ff_read_int16(file);
- table->sample_rate = mp4ff_read_fixed32(file);
-
- while (mp4ff_position(file) < parent_atom->end) {
- mp4ff_atom_t leaf_atom;
-
- mp4ff_atom_read_header(file, &leaf_atom);
-
- if(mp4ff_atom_is(&leaf_atom, "esds")) {
- mp4ff_read_esds(file, &(table->esds));
- mp4ff_atom_skip(file, &leaf_atom);
- } else {
- mp4ff_atom_skip(file, &leaf_atom);
- }
- }
-}
-
-int mp4ff_write_stsd_audio(mp4ff_t *file, mp4ff_stsd_table_t *table)
-{
- mp4ff_write_int32(file, 0);
- mp4ff_write_int32(file, 0);
- mp4ff_write_int16(file, 2);
- mp4ff_write_int16(file, 16);
- mp4ff_write_int32(file, 0);
- mp4ff_write_int16(file, table->sample_rate);
- mp4ff_write_int16(file, 0);
- mp4ff_write_esds_audio(file, &(table->esds), file->atracks[0].track->tkhd.track_id);
-}
-
-int mp4ff_read_stsd_video(mp4ff_t *file, mp4ff_stsd_table_t *table, mp4ff_atom_t *parent_atom)
-{
- mp4ff_atom_t leaf_atom;
- int len;
-
- table->version = mp4ff_read_int16(file);
- table->revision = mp4ff_read_int16(file);
- mp4ff_read_data(file, table->vendor, 4);
- table->temporal_quality = mp4ff_read_int32(file);
- table->spatial_quality = mp4ff_read_int32(file);
- table->width = mp4ff_read_int16(file);
- table->height = mp4ff_read_int16(file);
- table->dpi_horizontal = mp4ff_read_fixed32(file);
- table->dpi_vertical = mp4ff_read_fixed32(file);
- table->data_size = mp4ff_read_int32(file);
- table->frames_per_sample = mp4ff_read_int16(file);
- len = mp4ff_read_char(file);
- mp4ff_read_data(file, table->compressor_name, 31);
- table->depth = mp4ff_read_int16(file);
-
- while(mp4ff_position(file) < parent_atom->end)
- {
- mp4ff_atom_read_header(file, &leaf_atom);
-
- if(mp4ff_atom_is(&leaf_atom, "gama"))
- {
- table->gamma= mp4ff_read_fixed32(file);
- }
- else
- if(mp4ff_atom_is(&leaf_atom, "fiel"))
- {
- table->fields = mp4ff_read_char(file);
- table->field_dominance = mp4ff_read_char(file);
- }
- else
-/* if(mp4ff_atom_is(&leaf_atom, "mjqt")) */
-/* { */
-/* mp4ff_read_mjqt(file, &(table->mjqt)); */
-/* } */
-/* else */
-/* if(mp4ff_atom_is(&leaf_atom, "mjht")) */
-/* { */
-/* mp4ff_read_mjht(file, &(table->mjht)); */
-/* } */
-/* else */
- if(mp4ff_atom_is(&leaf_atom, "esds"))
- {
- mp4ff_read_esds(file, &(table->esds));
- mp4ff_atom_skip(file, &leaf_atom);
- }
- else
- {
- mp4ff_atom_skip(file, &leaf_atom);
- }
- }
-}
-
-int mp4ff_write_stsd_video(mp4ff_t *file, mp4ff_stsd_table_t *table)
-{
- int i;
-
- for (i = 0; i < 4; i++) {
- mp4ff_write_int32(file, 0);
- }
- mp4ff_write_int16(file, table->width);
- mp4ff_write_int16(file, table->height);
- mp4ff_write_int32(file, 0x00480000);
- mp4ff_write_int32(file, 0x00480000);
- mp4ff_write_int32(file, 0);
- mp4ff_write_int16(file, 1);
- for (i = 0; i < 32; i++) {
- mp4ff_write_char(file, 0);
- }
- mp4ff_write_int16(file, 24);
- mp4ff_write_int16(file, -1);
- mp4ff_write_esds_video(file, &(table->esds), file->vtracks[0].track->tkhd.track_id);
-
- if(table->fields)
- {
- mp4ff_atom_t atom;
-
- mp4ff_atom_write_header(file, &atom, "fiel");
- mp4ff_write_char(file, table->fields);
- mp4ff_write_char(file, table->field_dominance);
- mp4ff_atom_write_footer(file, &atom);
- }
-}
--- a/common/mp4ff/stss.c
+++ /dev/null
@@ -1,87 +1,0 @@
-#include "mp4ff.h"
-
-
-int mp4ff_stss_init(mp4ff_stss_t *stss)
-{
- stss->version = 0;
- stss->flags = 0;
- stss->total_entries = 0;
- stss->entries_allocated = 0;
-}
-
-int mp4ff_stss_init_common(mp4ff_t *file, mp4ff_stss_t *stss)
-{
- if (stss->entries_allocated == 0) {
- stss->entries_allocated = 100;
- stss->table = (mp4ff_stss_table_t*)
- malloc(sizeof(mp4ff_stss_table_t) * stss->entries_allocated);
- }
-}
-
-int mp4ff_stss_delete(mp4ff_stss_t *stss)
-{
- if(stss->total_entries)
- free(stss->table);
- stss->total_entries = 0;
-}
-
-int mp4ff_stss_dump(mp4ff_stss_t *stss)
-{
- int i;
- printf(" sync sample\n");
- printf(" version %d\n", stss->version);
- printf(" flags %d\n", stss->flags);
- printf(" total_entries %d\n", stss->total_entries);
- for(i = 0; i < stss->total_entries; i++)
- {
- printf(" sample %u\n", stss->table[i].sample);
- }
-}
-
-int mp4ff_read_stss(mp4ff_t *file, mp4ff_stss_t *stss)
-{
- int i;
- stss->version = mp4ff_read_char(file);
- stss->flags = mp4ff_read_int24(file);
- stss->total_entries = mp4ff_read_int32(file);
-
- stss->table = (mp4ff_stss_table_t*)malloc(sizeof(mp4ff_stss_table_t) * stss->total_entries);
- for(i = 0; i < stss->total_entries; i++)
- {
- stss->table[i].sample = mp4ff_read_int32(file);
- }
-}
-
-
-int mp4ff_write_stss(mp4ff_t *file, mp4ff_stss_t *stss)
-{
- int i;
- mp4ff_atom_t atom;
-
- if(stss->total_entries)
- {
- mp4ff_atom_write_header(file, &atom, "stss");
-
- mp4ff_write_char(file, stss->version);
- mp4ff_write_int24(file, stss->flags);
- mp4ff_write_int32(file, stss->total_entries);
- for(i = 0; i < stss->total_entries; i++)
- {
- mp4ff_write_int32(file, stss->table[i].sample);
- }
-
- mp4ff_atom_write_footer(file, &atom);
- }
-}
-
-int mp4ff_update_stss(mp4ff_stss_t *stss, long sample)
-{
- if (stss->total_entries >= stss->entries_allocated) {
- stss->entries_allocated *= 2;
- stss->table = (mp4ff_stss_table_t*)realloc(stss->table,
- sizeof(mp4ff_stss_table_t) * stss->entries_allocated);
- }
-
- stss->table[stss->total_entries++].sample = sample;
-}
-
--- a/common/mp4ff/stsz.c
+++ /dev/null
@@ -1,137 +1,0 @@
-#include "mp4ff.h"
-
-
-
-int mp4ff_stsz_init(mp4ff_stsz_t *stsz)
-{
- stsz->version = 0;
- stsz->flags = 0;
- stsz->sample_size = 0;
- stsz->total_entries = 0;
- stsz->entries_allocated = 0;
-}
-
-int mp4ff_stsz_init_video(mp4ff_t *file, mp4ff_stsz_t *stsz)
-{
- stsz->sample_size = 0;
- if(!stsz->entries_allocated)
- {
- stsz->entries_allocated = 2000;
- stsz->total_entries = 0;
- stsz->table = (mp4ff_stsz_table_t*)malloc(sizeof(mp4ff_stsz_table_t) * stsz->entries_allocated);
- }
-}
-
-int mp4ff_stsz_init_audio(mp4ff_t *file, mp4ff_stsz_t *stsz, int sample_size)
-{
- stsz->sample_size = sample_size; /* if == 0, then use table */
- stsz->total_entries = 0; /* set this when closing */
- stsz->entries_allocated = 0;
-}
-
-int mp4ff_stsz_delete(mp4ff_stsz_t *stsz)
-{
- if(!stsz->sample_size && stsz->total_entries)
- free(stsz->table);
- stsz->total_entries = 0;
- stsz->entries_allocated = 0;
-}
-
-int mp4ff_stsz_dump(mp4ff_stsz_t *stsz)
-{
- int i;
- printf(" sample size\n");
- printf(" version %d\n", stsz->version);
- printf(" flags %d\n", stsz->flags);
- printf(" sample_size %d\n", stsz->sample_size);
- printf(" total_entries %d\n", stsz->total_entries);
-
- if(!stsz->sample_size)
- {
- for(i = 0; i < stsz->total_entries; i++)
- {
- printf(" sample_size %d\n", stsz->table[i].size);
- }
- }
-}
-
-int mp4ff_read_stsz(mp4ff_t *file, mp4ff_stsz_t *stsz)
-{
- int i;
- stsz->version = mp4ff_read_char(file);
- stsz->flags = mp4ff_read_int24(file);
- stsz->sample_size = mp4ff_read_int32(file);
- stsz->total_entries = mp4ff_read_int32(file);
- stsz->entries_allocated = stsz->total_entries;
- if(!stsz->sample_size)
- {
- stsz->table = (mp4ff_stsz_table_t*)malloc(sizeof(mp4ff_stsz_table_t) * stsz->entries_allocated);
- for(i = 0; i < stsz->total_entries; i++)
- {
- stsz->table[i].size = mp4ff_read_int32(file);
- }
- }
-}
-
-int mp4ff_write_stsz(mp4ff_t *file, mp4ff_stsz_t *stsz)
-{
- int i, result;
- mp4ff_atom_t atom;
-
- mp4ff_atom_write_header(file, &atom, "stsz");
-
-/* optimize if possible */
-/* Xanim requires an unoptimized table for video. */
-/* if(!stsz->sample_size) */
-/* { */
-/* for(i = 0, result = 0; i < stsz->total_entries && !result; i++) */
-/* { */
-/* if(stsz->table[i].size != stsz->table[0].size) result = 1; */
-/* } */
-/* */
-/* if(!result) */
-/* { */
-/* stsz->sample_size = stsz->table[0].size; */
-/* stsz->total_entries = 0; */
-/* free(stsz->table); */
-/* } */
-/* } */
-
- mp4ff_write_char(file, stsz->version);
- mp4ff_write_int24(file, stsz->flags);
- mp4ff_write_int32(file, stsz->sample_size);
- if(stsz->sample_size)
- {
- mp4ff_write_int32(file, stsz->total_entries);
- }
- else
- {
- mp4ff_write_int32(file, stsz->total_entries);
- for(i = 0; i < stsz->total_entries; i++)
- {
- mp4ff_write_int32(file, stsz->table[i].size);
- }
- }
-
- mp4ff_atom_write_footer(file, &atom);
-}
-
-int mp4ff_update_stsz(mp4ff_stsz_t *stsz, long sample, long sample_size)
-{
- mp4ff_stsz_table_t *new_table;
- int i;
-
- if(!stsz->sample_size)
- {
- if(sample >= stsz->entries_allocated)
- {
- stsz->entries_allocated = sample * 2;
- stsz->table = (mp4ff_stsz_table_t *)realloc(stsz->table,
- sizeof(mp4ff_stsz_table_t) * stsz->entries_allocated);
- }
-
- stsz->table[sample].size = sample_size;
- if(sample >= stsz->total_entries)
- stsz->total_entries = sample + 1;
- }
-}
--- a/common/mp4ff/stts.c
+++ /dev/null
@@ -1,113 +1,0 @@
-#include "mp4ff.h"
-
-
-
-int mp4ff_stts_init(mp4ff_stts_t *stts)
-{
- stts->version = 0;
- stts->flags = 0;
- stts->total_entries = 0;
- stts->entries_allocated = 0;
-}
-
-int mp4ff_stts_init_table(mp4ff_stts_t *stts)
-{
- if(!stts->entries_allocated)
- {
- stts->entries_allocated = 1;
- stts->table = (mp4ff_stts_table_t*)
- malloc(sizeof(mp4ff_stts_table_t) * stts->entries_allocated);
- stts->total_entries = 1;
- }
-}
-
-int mp4ff_stts_init_video(mp4ff_t *file, mp4ff_stts_t *stts, int time_scale, float frame_rate)
-{
- mp4ff_stts_table_t *table;
- mp4ff_stts_init_table(stts);
- table = &(stts->table[0]);
-
- table->sample_count = 0; /* need to set this when closing */
- table->sample_duration = time_scale / frame_rate;
-}
-
-int mp4ff_stts_init_audio(mp4ff_t *file, mp4ff_stts_t *stts, int time_scale, int sample_duration)
-{
- mp4ff_stts_table_t *table;
- mp4ff_stts_init_table(stts);
- table = &(stts->table[0]);
-
- table->sample_count = 0; /* need to set this when closing or via update function */
- table->sample_duration = sample_duration;
-}
-
-int mp4ff_stts_delete(mp4ff_stts_t *stts)
-{
- if(stts->total_entries) free(stts->table);
- stts->total_entries = 0;
-}
-
-int mp4ff_stts_dump(mp4ff_stts_t *stts)
-{
- int i;
- printf(" time to sample\n");
- printf(" version %d\n", stts->version);
- printf(" flags %d\n", stts->flags);
- printf(" total_entries %d\n", stts->total_entries);
- for(i = 0; i < stts->total_entries; i++)
- {
- printf(" count %ld duration %ld\n", stts->table[i].sample_count, stts->table[i].sample_duration);
- }
-}
-
-int mp4ff_read_stts(mp4ff_t *file, mp4ff_stts_t *stts)
-{
- int i;
- stts->version = mp4ff_read_char(file);
- stts->flags = mp4ff_read_int24(file);
- stts->total_entries = mp4ff_read_int32(file);
-
- stts->table = (mp4ff_stts_table_t*)malloc(sizeof(mp4ff_stts_table_t) * stts->total_entries);
- for(i = 0; i < stts->total_entries; i++)
- {
- stts->table[i].sample_count = mp4ff_read_int32(file);
- stts->table[i].sample_duration = mp4ff_read_int32(file);
- }
-}
-
-int mp4ff_write_stts(mp4ff_t *file, mp4ff_stts_t *stts)
-{
- int i;
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "stts");
-
- mp4ff_write_char(file, stts->version);
- mp4ff_write_int24(file, stts->flags);
- mp4ff_write_int32(file, stts->total_entries);
- for(i = 0; i < stts->total_entries; i++)
- {
- mp4ff_write_int32(file, stts->table[i].sample_count);
- mp4ff_write_int32(file, stts->table[i].sample_duration);
- }
- mp4ff_atom_write_footer(file, &atom);
-}
-
-int mp4ff_update_stts(mp4ff_stts_t *stts, long sample_duration)
-{
- if (sample_duration == stts->table[stts->total_entries-1].sample_duration) {
- stts->table[stts->total_entries-1].sample_count++;
- } else {
- /* need a new entry in the table */
-
- /* allocate more entries if necessary */
- if (stts->total_entries >= stts->entries_allocated) {
- stts->entries_allocated *= 2;
- stts->table = (mp4ff_stts_table_t*)realloc(stts->table,
- sizeof(mp4ff_stts_table_t) * stts->entries_allocated);
- }
-
- stts->table[stts->total_entries].sample_count = 1;
- stts->table[stts->total_entries].sample_duration = sample_duration;
- stts->total_entries++;
- }
-}
--- a/common/mp4ff/tkhd.c
+++ /dev/null
@@ -1,136 +1,0 @@
-#include "mp4ff.h"
-
-
-int mp4ff_tkhd_init(mp4ff_tkhd_t *tkhd)
-{
- int i;
- tkhd->version = 0;
- tkhd->flags = 15;
- tkhd->creation_time = mp4ff_current_time();
- tkhd->modification_time = mp4ff_current_time();
- tkhd->track_id;
- tkhd->reserved1 = 0;
- tkhd->duration = 0; /* need to set this when closing */
- for(i = 0; i < 8; i++) tkhd->reserved2[i] = 0;
- tkhd->layer = 0;
- tkhd->alternate_group = 0;
- tkhd->volume = 0.996094;
- tkhd->reserved3 = 0;
- mp4ff_matrix_init(&(tkhd->matrix));
- tkhd->track_width = 0;
- tkhd->track_height = 0;
- tkhd->is_audio = 0 /*FALSE*/;
- tkhd->is_video = 0 /*FALSE*/;
- return 0;
-}
-
-int mp4ff_tkhd_init_audio(mp4ff_t *file,
- mp4ff_tkhd_t *tkhd)
-{
- tkhd->is_audio = 1 /*TRUE*/;
-}
-
-int mp4ff_tkhd_init_video(mp4ff_t *file,
- mp4ff_tkhd_t *tkhd,
- int frame_w,
- int frame_h)
-{
- tkhd->is_video = 1 /*TRUE*/;
- tkhd->track_width = frame_w;
- tkhd->track_height = frame_h;
- tkhd->volume = 0;
-}
-
-int mp4ff_tkhd_delete(mp4ff_tkhd_t *tkhd)
-{
- return 0;
-}
-
-int mp4ff_tkhd_dump(mp4ff_tkhd_t *tkhd)
-{
- printf(" track header\n");
- printf(" version %d\n", tkhd->version);
- printf(" flags %ld\n", tkhd->flags);
- printf(" creation_time %u\n", tkhd->creation_time);
- printf(" modification_time %u\n", tkhd->modification_time);
- printf(" track_id %d\n", tkhd->track_id);
- printf(" reserved1 %ld\n", tkhd->reserved1);
- printf(" duration %ld\n", tkhd->duration);
- mp4ff_print_chars(" reserved2 ", tkhd->reserved2, 8);
- printf(" layer %d\n", tkhd->layer);
- printf(" alternate_group %d\n", tkhd->alternate_group);
- printf(" volume %f\n", tkhd->volume);
- printf(" reserved3 %d\n", tkhd->reserved3);
- mp4ff_matrix_dump(&(tkhd->matrix));
- printf(" track_width %f\n", tkhd->track_width);
- printf(" track_height %f\n", tkhd->track_height);
-}
-
-int mp4ff_read_tkhd(mp4ff_t *file, mp4ff_tkhd_t *tkhd)
-{
- tkhd->version = mp4ff_read_char(file);
- tkhd->flags = mp4ff_read_int24(file);
- tkhd->creation_time = mp4ff_read_int32(file);
- tkhd->modification_time = mp4ff_read_int32(file);
- tkhd->track_id = mp4ff_read_int32(file);
- tkhd->reserved1 = mp4ff_read_int32(file);
- tkhd->duration = mp4ff_read_int32(file);
- mp4ff_read_data(file, tkhd->reserved2, 8);
- tkhd->layer = mp4ff_read_int16(file);
- tkhd->alternate_group = mp4ff_read_int16(file);
- tkhd->volume = mp4ff_read_fixed16(file);
- tkhd->reserved3 = mp4ff_read_int16(file);
- mp4ff_read_matrix(file, &(tkhd->matrix));
- tkhd->track_width = mp4ff_read_fixed32(file);
- tkhd->track_height = mp4ff_read_fixed32(file);
-}
-
-int mp4ff_write_tkhd(mp4ff_t *file, mp4ff_tkhd_t *tkhd)
-{
- int i;
-
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "tkhd");
-
- mp4ff_write_char(file, tkhd->version);
- if (tkhd->flags != 0) {
- mp4ff_write_int24(file, 1);
- } else {
- mp4ff_write_int24(file, tkhd->flags);
- }
- mp4ff_write_int32(file, tkhd->creation_time);
- mp4ff_write_int32(file, tkhd->modification_time);
- mp4ff_write_int32(file, tkhd->track_id);
- mp4ff_write_int32(file, tkhd->reserved1);
- mp4ff_write_int32(file, tkhd->duration);
-
- for (i = 0; i < 3; i++) {
- mp4ff_write_int32(file, 0x00000000);
- }
- if (tkhd->is_audio) {
- mp4ff_write_int16(file, 0x0100);
- } else {
- mp4ff_write_int16(file, 0x0000);
- }
- mp4ff_write_int16(file, 0x0000);
- mp4ff_write_int32(file, 0x00010000);
- for (i = 0; i < 3; i++) {
- mp4ff_write_int32(file, 0x00000000);
- }
- mp4ff_write_int32(file, 0x00010000);
- for (i = 0; i < 3; i++) {
- mp4ff_write_int32(file, 0x00000000);
- }
- mp4ff_write_int32(file, 0x40000000);
- if (tkhd->is_video) {
- mp4ff_write_int32(file, 0x01400000);
- mp4ff_write_int32(file, 0x00F00000);
- } else {
- mp4ff_write_int32(file, 0x00000000);
- mp4ff_write_int32(file, 0x00000000);
- }
-
- mp4ff_atom_write_footer(file, &atom);
-}
-
-
--- a/common/mp4ff/trak.c
+++ /dev/null
@@ -1,503 +1,0 @@
-#include "mp4ff.h"
-
-
-
-
-int mp4ff_trak_init(mp4ff_trak_t *trak)
-{
- mp4ff_tkhd_init(&(trak->tkhd));
- mp4ff_edts_init(&(trak->edts));
- mp4ff_mdia_init(&(trak->mdia));
- return 0;
-}
-
-int mp4ff_trak_init_video(mp4ff_t *file,
- mp4ff_trak_t *trak,
- int frame_w,
- int frame_h,
- float frame_rate,
- int time_scale,
- char *compressor)
-{
- mp4ff_tkhd_init_video(file, &(trak->tkhd), frame_w, frame_h);
- mp4ff_mdia_init_video(file, &(trak->mdia), frame_w, frame_h,
- frame_rate, time_scale, compressor);
- mp4ff_edts_init_table(&(trak->edts));
-
- return 0;
-}
-
-int mp4ff_trak_init_audio(mp4ff_t *file,
- mp4ff_trak_t *trak,
- int channels,
- int sample_rate,
- int bits,
- int sample_size,
- int time_scale,
- int sample_duration,
- char *compressor)
-{
- mp4ff_mdia_init_audio(file, &(trak->mdia), channels, sample_rate, bits,
- sample_size, time_scale, sample_duration, compressor);
- mp4ff_edts_init_table(&(trak->edts));
-
- return 0;
-}
-
-int mp4ff_trak_delete(mp4ff_trak_t *trak)
-{
- mp4ff_tkhd_delete(&(trak->tkhd));
- return 0;
-}
-
-
-int mp4ff_trak_dump(mp4ff_trak_t *trak)
-{
- printf(" track\n");
- mp4ff_tkhd_dump(&(trak->tkhd));
- mp4ff_edts_dump(&(trak->edts));
- mp4ff_mdia_dump(&(trak->mdia));
-
- return 0;
-}
-
-
-mp4ff_trak_t* mp4ff_add_trak(mp4ff_moov_t *moov)
-{
- if(moov->total_tracks < MAXTRACKS)
- {
- moov->trak[moov->total_tracks] = malloc(sizeof(mp4ff_trak_t));
- mp4ff_trak_init(moov->trak[moov->total_tracks]);
- moov->total_tracks++;
- }
- return moov->trak[moov->total_tracks - 1];
-}
-
-mp4ff_trak_t* mp4ff_find_track_by_id(mp4ff_moov_t *moov, int trackId)
-{
- int i;
-
- for (i = 0; i < moov->total_tracks; i++) {
- if (moov->trak[i]->tkhd.track_id == trackId) {
- return moov->trak[i];
- }
- }
-
- return NULL;
-}
-
-int mp4ff_delete_trak(mp4ff_moov_t *moov, mp4ff_trak_t *trak)
-{
- int i, j;
-
- for (i = 0; i < moov->total_tracks; i++) {
- if (moov->trak[i] == trak) {
- mp4ff_trak_delete(trak);
- free(trak);
- moov->trak[i] = NULL;
- for (j = i + 1; j < moov->total_tracks; j++, i++) {
- moov->trak[i] = moov->trak[j];
- }
- moov->trak[j] = NULL;
- moov->total_tracks--;
- return 0;
- }
- }
- return -1;
-}
-
-
-int mp4ff_read_trak(mp4ff_t *file, mp4ff_trak_t *trak, mp4ff_atom_t *trak_atom)
-{
- mp4ff_atom_t leaf_atom;
-
- do
- {
- mp4ff_atom_read_header(file, &leaf_atom);
-
-/* mandatory */
- if(mp4ff_atom_is(&leaf_atom, "tkhd"))
- { mp4ff_read_tkhd(file, &(trak->tkhd)); }
- else
- if(mp4ff_atom_is(&leaf_atom, "mdia"))
- { mp4ff_read_mdia(file, &(trak->mdia), &leaf_atom); }
- else
-/* optional */
- if(mp4ff_atom_is(&leaf_atom, "edts"))
- { mp4ff_read_edts(file, &(trak->edts), &leaf_atom); }
- else
- mp4ff_atom_skip(file, &leaf_atom);
- }while(mp4ff_position(file) < trak_atom->end);
-
- return 0;
-}
-
-int mp4ff_write_trak(mp4ff_t *file, mp4ff_trak_t *trak, long moov_time_scale)
-{
- long duration;
- long timescale;
- mp4ff_atom_t atom;
- mp4ff_atom_write_header(file, &atom, "trak");
- mp4ff_trak_duration(trak, &duration, ×cale);
-
- /* printf("mp4ff_write_trak duration %d\n", duration); */
-
- /* get duration in movie's units */
- if (timescale) {
- trak->tkhd.duration =
- (long)((float)duration / timescale * moov_time_scale);
- } else {
- trak->tkhd.duration = 0;
- }
- trak->mdia.mdhd.duration = duration;
- trak->mdia.mdhd.time_scale = timescale;
-
- mp4ff_write_tkhd(file, &(trak->tkhd));
- mp4ff_write_edts(file, &(trak->edts), trak->tkhd.duration);
- mp4ff_write_mdia(file, &(trak->mdia));
-
- mp4ff_atom_write_footer(file, &atom);
-
- return 0;
-}
-
-long mp4ff_track_end(mp4ff_trak_t *trak)
-{
-/* get the byte endpoint of the track in the file */
- long size = 0;
- long chunk, chunk_offset, chunk_samples, sample;
- mp4ff_stsz_t *stsz = &(trak->mdia.minf.stbl.stsz);
- mp4ff_stsz_table_t *table = stsz->table;
- mp4ff_stsc_t *stsc = &(trak->mdia.minf.stbl.stsc);
- mp4ff_stco_t *stco;
-
-/* get the last chunk offset */
-/* the chunk offsets contain the HEADER_LENGTH themselves */
- stco = &(trak->mdia.minf.stbl.stco);
- chunk = stco->total_entries;
- size = chunk_offset = stco->table[chunk - 1].offset;
-
-/* get the number of samples in the last chunk */
- chunk_samples = stsc->table[stsc->total_entries - 1].samples;
-
-/* get the size of last samples */
-#ifdef NOTDEF
- if(stsz->sample_size)
- {
-/* assume audio so calculate the sample size */
- size += chunk_samples * stsz->sample_size
- * trak->mdia.minf.stbl.stsd.table[0].channels
- * trak->mdia.minf.stbl.stsd.table[0].sample_size / 8;
- }
- else
- {
-/* assume video */
-#endif
- for(sample = stsz->total_entries - chunk_samples;
- sample >= 0 && sample < stsz->total_entries; sample++)
- {
- size += stsz->table[sample].size;
- }
-#ifdef NOTDEF
- }
-#endif
-
- return size;
-}
-
-long mp4ff_track_samples(mp4ff_t *file, mp4ff_trak_t *trak)
-{
-/*printf("file->rd %d file->wr %d\n", file->rd, file->wr); */
- if(file->wr)
- {
-/* get the sample count when creating a new file */
- mp4ff_stsc_table_t *table = trak->mdia.minf.stbl.stsc.table;
- long total_entries = trak->mdia.minf.stbl.stsc.total_entries;
- long chunk = trak->mdia.minf.stbl.stco.total_entries;
- long sample;
-
- if(chunk)
- {
- sample = mp4ff_sample_of_chunk(trak, chunk);
- sample += table[total_entries - 1].samples;
- }
- else
- sample = 0;
-
- return sample;
- }
- else
- {
-/* get the sample count when reading only */
- mp4ff_stts_t *stts = &(trak->mdia.minf.stbl.stts);
- int i;
- long total = 0;
-
- for(i = 0; i < stts->total_entries; i++)
- {
- total += stts->table[i].sample_count;
- }
- return total;
- }
-}
-
-long mp4ff_sample_of_chunk(mp4ff_trak_t *trak, long chunk)
-{
- mp4ff_stsc_table_t *table = trak->mdia.minf.stbl.stsc.table;
- long total_entries = trak->mdia.minf.stbl.stsc.total_entries;
- long chunk1entry, chunk2entry;
- long chunk1, chunk2, chunks, total = 0;
-
- for(chunk1entry = total_entries - 1, chunk2entry = total_entries;
- chunk1entry >= 0;
- chunk1entry--, chunk2entry--)
- {
- chunk1 = table[chunk1entry].chunk;
-
- if(chunk > chunk1)
- {
- if(chunk2entry < total_entries)
- {
- chunk2 = table[chunk2entry].chunk;
-
- if(chunk < chunk2) chunk2 = chunk;
- }
- else
- chunk2 = chunk;
-
- chunks = chunk2 - chunk1;
-
- total += chunks * table[chunk1entry].samples;
- }
- }
-
- return total;
-}
-
-int mp4ff_chunk_of_sample(long *chunk_sample, long *chunk, mp4ff_trak_t *trak, long sample)
-{
- mp4ff_stsc_table_t *table = NULL;
- long total_entries = 0;
- long chunk2entry;
- long chunk1, chunk2, chunk1samples, range_samples, total = 0;
-
- if (trak == NULL) {
- return -1;
- }
- table = trak->mdia.minf.stbl.stsc.table;
- total_entries = trak->mdia.minf.stbl.stsc.total_entries;
-
- chunk1 = 1;
- chunk1samples = 0;
- chunk2entry = 0;
-
- do
- {
- chunk2 = table[chunk2entry].chunk;
- *chunk = chunk2 - chunk1;
- range_samples = *chunk * chunk1samples;
-
- if(sample < total + range_samples) break;
-
- chunk1samples = table[chunk2entry].samples;
- chunk1 = chunk2;
-
- if(chunk2entry < total_entries)
- {
- chunk2entry++;
- total += range_samples;
- }
- }while(chunk2entry < total_entries);
-
- if(chunk1samples)
- *chunk = (sample - total) / chunk1samples + chunk1;
- else
- *chunk = 1;
-
- *chunk_sample = total + (*chunk - chunk1) * chunk1samples;
- return 0;
-}
-
-long mp4ff_chunk_to_offset(mp4ff_trak_t *trak, long chunk)
-{
- mp4ff_stco_table_t *table = NULL;
-
- if (trak == NULL) {
- return -1;
- }
- table = trak->mdia.minf.stbl.stco.table;
-
- if(trak->mdia.minf.stbl.stco.total_entries && chunk > trak->mdia.minf.stbl.stco.total_entries)
- return table[trak->mdia.minf.stbl.stco.total_entries - 1].offset;
- else
- if(trak->mdia.minf.stbl.stco.total_entries)
- return table[chunk - 1].offset;
- else
- return HEADER_LENGTH;
-
- return 0;
-}
-
-long mp4ff_offset_to_chunk(long *chunk_offset, mp4ff_trak_t *trak, long offset)
-{
- mp4ff_stco_table_t *table = trak->mdia.minf.stbl.stco.table;
- int i;
-
- for(i = trak->mdia.minf.stbl.stco.total_entries - 1; i >= 0; i--)
- {
- if(table[i].offset <= offset)
- {
- *chunk_offset = table[i].offset;
- return i + 1;
- }
- }
- *chunk_offset = HEADER_LENGTH;
- return 1;
-}
-
-long mp4ff_sample_range_size(mp4ff_trak_t *trak, long chunk_sample, long sample)
-{
- mp4ff_stsz_table_t *table = trak->mdia.minf.stbl.stsz.table;
- long i, total;
-
- if(trak->mdia.minf.stbl.stsz.sample_size)
- {
-/* assume audio */
- return mp4ff_samples_to_bytes(trak, sample - chunk_sample);
- }
- else
- {
-/* probably video */
- for(i = chunk_sample, total = 0; i < sample; i++)
- {
- total += trak->mdia.minf.stbl.stsz.table[i].size;
- }
- }
- return total;
-}
-
-long mp4ff_sample_to_offset(mp4ff_trak_t *trak, long sample)
-{
- long chunk, chunk_sample, chunk_offset1, chunk_offset2;
-
- if (trak == NULL) {
- return -1;
- }
-
- mp4ff_chunk_of_sample(&chunk_sample, &chunk, trak, sample);
- chunk_offset1 = mp4ff_chunk_to_offset(trak, chunk);
- chunk_offset2 = chunk_offset1 + mp4ff_sample_range_size(trak, chunk_sample, sample);
-/*printf("mp4ff_sample_to_offset chunk %d sample %d chunk_offset %d chunk_sample %d chunk_offset + samples %d\n", */
-/* chunk, sample, chunk_offset1, chunk_sample, chunk_offset2); */
- return chunk_offset2;
-}
-
-long mp4ff_offset_to_sample(mp4ff_trak_t *trak, long offset)
-{
- long chunk_offset;
- long chunk = mp4ff_offset_to_chunk(&chunk_offset, trak, offset);
- long chunk_sample = mp4ff_sample_of_chunk(trak, chunk);
- long sample, sample_offset;
- mp4ff_stsz_table_t *table = trak->mdia.minf.stbl.stsz.table;
- long total_samples = trak->mdia.minf.stbl.stsz.total_entries;
-
- if(trak->mdia.minf.stbl.stsz.sample_size)
- {
- sample = chunk_sample + (offset - chunk_offset) /
- trak->mdia.minf.stbl.stsz.sample_size;
- }
- else
- for(sample = chunk_sample, sample_offset = chunk_offset;
- sample_offset < offset && sample < total_samples; )
- {
- sample_offset += table[sample].size;
- if(sample_offset < offset) sample++;
- }
-
- return sample;
-}
-
-int mp4ff_update_tables(mp4ff_t *file,
- mp4ff_trak_t *trak,
- long offset,
- long chunk,
- long sample,
- long samples,
- long sample_size,
- long sample_duration,
- unsigned char isSyncSample,
- long renderingOffset)
-{
- if (offset + sample_size > file->mdat.size) {
- file->mdat.size = offset + sample_size;
- }
- mp4ff_update_stco(&(trak->mdia.minf.stbl.stco), chunk, offset);
- if (sample_size) {
- mp4ff_update_stsz(&(trak->mdia.minf.stbl.stsz), sample, sample_size);
- }
- mp4ff_update_stsc(&(trak->mdia.minf.stbl.stsc), chunk, samples);
- if (sample_duration) {
- mp4ff_update_stts(&(trak->mdia.minf.stbl.stts), sample_duration);
- }
- if (isSyncSample) {
- mp4ff_update_stss(&(trak->mdia.minf.stbl.stss), sample);
- }
- mp4ff_update_ctts(&(trak->mdia.minf.stbl.ctts), renderingOffset);
- return 0;
-}
-
-int mp4ff_trak_duration(mp4ff_trak_t *trak, long *duration, long *timescale)
-{
- mp4ff_stts_t *stts = &(trak->mdia.minf.stbl.stts);
- int i;
- *duration = 0;
-
- for(i = 0; i < stts->total_entries; i++) {
- *duration += stts->table[i].sample_duration * stts->table[i].sample_count;
- }
-
- *timescale = trak->mdia.mdhd.time_scale;
- return 0;
-}
-
-int mp4ff_trak_fix_counts(mp4ff_t *file, mp4ff_trak_t *trak)
-{
- long samples = mp4ff_track_samples(file, trak);
-
- if (trak->mdia.minf.stbl.stts.total_entries == 1) {
- trak->mdia.minf.stbl.stts.table[0].sample_count = samples;
- }
-
- if(trak->mdia.minf.stbl.stsz.sample_size)
- trak->mdia.minf.stbl.stsz.total_entries = samples;
-
- return 0;
-}
-
-long mp4ff_chunk_samples(mp4ff_trak_t *trak, long chunk)
-{
- long result, current_chunk;
- mp4ff_stsc_t *stsc = &(trak->mdia.minf.stbl.stsc);
- long i = stsc->total_entries - 1;
-
- do
- {
- current_chunk = stsc->table[i].chunk;
- result = stsc->table[i].samples;
- i--;
- }while(i >= 0 && current_chunk > chunk);
-
- return result;
-}
-
-int mp4ff_trak_shift_offsets(mp4ff_trak_t *trak, long offset)
-{
- mp4ff_stco_t *stco = &(trak->mdia.minf.stbl.stco);
- int i;
-
- for(i = 0; i < stco->total_entries; i++)
- {
- stco->table[i].offset += offset;
- }
- return 0;
-}
--- a/common/mp4ff/udta.c
+++ /dev/null
@@ -1,164 +1,0 @@
-#include "mp4ff.h"
-
-#define DEFAULT_INFO "Made with Quicktime for Linux"
-
-int mp4ff_udta_init(mp4ff_udta_t *udta)
-{
- udta->copyright = 0;
- udta->copyright_len = 0;
- udta->name = 0;
- udta->name_len = 0;
-
- udta->info = malloc(strlen(DEFAULT_INFO) + 1);
- udta->info_len = strlen(DEFAULT_INFO);
- sprintf(udta->info, DEFAULT_INFO);
-
- return 0;
-}
-
-int mp4ff_udta_delete(mp4ff_udta_t *udta)
-{
- if(udta->copyright_len)
- {
- free(udta->copyright);
- }
- if(udta->name_len)
- {
- free(udta->name);
- }
- if(udta->info_len)
- {
- free(udta->info);
- }
-
- mp4ff_udta_init(udta);
- return 0;
-}
-
-int mp4ff_udta_dump(mp4ff_udta_t *udta)
-{
- printf(" user data (udta)\n");
- if(udta->copyright_len) printf(" copyright -> %s\n", udta->copyright);
- if(udta->name_len) printf(" name -> %s\n", udta->name);
- if(udta->info_len) printf(" info -> %s\n", udta->info);
-}
-
-int mp4ff_read_udta(mp4ff_t *file, mp4ff_udta_t *udta, mp4ff_atom_t *udta_atom)
-{
- mp4ff_atom_t leaf_atom;
- int result = 0;
-
- do
- {
- /* udta atoms can be terminated by a 4 byte zero */
- if (udta_atom->end - mp4ff_position(file) < HEADER_LENGTH) {
- unsigned char trash[HEADER_LENGTH];
- int remainder = udta_atom->end - mp4ff_position(file);
- mp4ff_read_data(file, trash, remainder);
- break;
- }
-
- mp4ff_atom_read_header(file, &leaf_atom);
-
-#if 0
- if(mp4ff_atom_is(&leaf_atom, "�cpy"))
- {
- result += mp4ff_read_udta_string(file, &(udta->copyright), &(udta->copyright_len));
- }
- else
- if(mp4ff_atom_is(&leaf_atom, "�nam"))
- {
- result += mp4ff_read_udta_string(file, &(udta->name), &(udta->name_len));
- }
- else
- if(mp4ff_atom_is(&leaf_atom, "�inf"))
- {
- result += mp4ff_read_udta_string(file, &(udta->info), &(udta->info_len));
- }
- else
-#endif
- mp4ff_atom_skip(file, &leaf_atom);
- }while(mp4ff_position(file) < udta_atom->end);
-
- return result;
-}
-
-int mp4ff_write_udta(mp4ff_t *file, mp4ff_udta_t *udta)
-{
- mp4ff_atom_t atom, subatom;
-
- /*
- * Empty udta atom makes Darwin Streaming Server unhappy
- * so avoid it
- */
-#if 1
- return;
-#else
- if (udta->copyright_len == 0 && udta->hnti.rtp.string == NULL) {
- return;
- }
-
- mp4ff_atom_write_header(file, &atom, "udta");
-
- if(udta->copyright_len)
- {
- mp4ff_atom_write_header(file, &subatom, "�cpy");
- mp4ff_write_udta_string(file, udta->copyright, udta->copyright_len);
- mp4ff_atom_write_footer(file, &subatom);
- }
-
-#if 0
- if(udta->name_len && !file->use_mp4)
- {
- mp4ff_atom_write_header(file, &subatom, "�nam");
- mp4ff_write_udta_string(file, udta->name, udta->name_len);
- mp4ff_atom_write_footer(file, &subatom);
- }
-
- if(udta->info_len && !file->use_mp4)
- {
- mp4ff_atom_write_header(file, &subatom, "�inf");
- mp4ff_write_udta_string(file, udta->info, udta->info_len);
- mp4ff_atom_write_footer(file, &subatom);
- }
-#endif
- if (udta->hnti.rtp.string != NULL) {
- mp4ff_write_hnti(file, &(udta->hnti));
- }
-
- mp4ff_atom_write_footer(file, &atom);
-#endif
-}
-
-int mp4ff_read_udta_string(mp4ff_t *file, char **string, int *size)
-{
- int result;
-
- if(*size) free(*string);
- *size = mp4ff_read_int16(file); /* Size of string */
- mp4ff_read_int16(file); /* Discard language code */
- *string = malloc(*size + 1);
- result = mp4ff_read_data(file, *string, *size);
- (*string)[*size] = 0;
- return !result;
-}
-
-int mp4ff_write_udta_string(mp4ff_t *file, char *string, int size)
-{
- int new_size = strlen(string);
- int result;
-
- mp4ff_write_int16(file, new_size); /* String size */
- mp4ff_write_int16(file, 0); /* Language code */
- result = mp4ff_write_data(file, string, new_size);
- return !result;
-}
-
-int mp4ff_set_udta_string(char **string, int *size, char *new_string)
-{
- if(*size) free(*string);
- *size = strlen(new_string + 1);
- *string = malloc(*size + 1);
- strcpy(*string, new_string);
- return 0;
-}
--- a/common/mp4ff/util.c
+++ /dev/null
@@ -1,356 +1,0 @@
-#include <time.h>
-#include "mp4ff.h"
-
-/* Disk I/O */
-
-
-int mp4ff_read_data(mp4ff_t *file, char *data, int size)
-{
- int result = 1;
-
- if (file->stream->get_position() != file->file_position)
- file->stream->seek(file->file_position);
- result = file->stream->read(data, size);
-
- file->file_position += size;
-
- return result;
-}
-
-int mp4ff_write_data(mp4ff_t *file, char *data, int size)
-{
- int result;
-
- if (file->stream->get_position() != file->file_position)
- file->stream->seek(file->file_position);
- result = file->stream->write(data, size);
-
- file->file_position += size;
-
- return result;
-}
-
-int mp4ff_test_position(mp4ff_t *file)
-{
- if (mp4ff_position(file) < 0)
- {
- printf("mp4ff_test_position: 32 bit overflow\n");
- return 1;
- }
- else
- return 0;
-}
-
-int mp4ff_read_pascal(mp4ff_t *file, char *data)
-{
- char len = mp4ff_read_char(file);
- mp4ff_read_data(file, data, len);
- data[len] = 0;
-}
-
-int mp4ff_write_pascal(mp4ff_t *file, char *data)
-{
- char len = strlen(data);
- mp4ff_write_data(file, &len, 1);
- mp4ff_write_data(file, data, len);
-}
-
-float mp4ff_read_fixed32(mp4ff_t *file)
-{
- unsigned long a, b, c, d;
- unsigned char data[4];
-
- mp4ff_read_data(file, data, 4);
-/* fread(data, 4, 1, file->stream); */
- a = data[0];
- b = data[1];
- c = data[2];
- d = data[3];
-
- a = (a << 8) + b;
- b = (c << 8) + d;
-
- return (float)a + (float)b / 65536;
-}
-
-int mp4ff_write_fixed32(mp4ff_t *file, float number)
-{
- unsigned char data[4];
- int a, b;
-
- a = number;
- b = (number - a) * 65536;
- data[0] = a >> 8;
- data[1] = a & 0xff;
- data[2] = b >> 8;
- data[3] = b & 0xff;
-
- return mp4ff_write_data(file, data, 4);
-}
-
-int mp4ff_write_int64(mp4ff_t *file, uint64_t value)
-{
- unsigned char data[8];
- int i;
-
- for (i = 7; i >= 0; i--) {
- data[i] = value & 0xff;
- value >>= 8;
- }
-
- return mp4ff_write_data(file, data, 8);
-}
-
-int mp4ff_write_int32(mp4ff_t *file, long value)
-{
- unsigned char data[4];
-
- data[0] = (value & 0xff000000) >> 24;
- data[1] = (value & 0xff0000) >> 16;
- data[2] = (value & 0xff00) >> 8;
- data[3] = value & 0xff;
-
- return mp4ff_write_data(file, data, 4);
-}
-
-int mp4ff_write_char32(mp4ff_t *file, char *string)
-{
- return mp4ff_write_data(file, string, 4);
-}
-
-
-float mp4ff_read_fixed16(mp4ff_t *file)
-{
- unsigned char data[2];
-
- mp4ff_read_data(file, data, 2);
- return (float)data[0] + (float)data[1] / 256;
-}
-
-int mp4ff_write_fixed16(mp4ff_t *file, float number)
-{
- unsigned char data[2];
- int a, b;
-
- a = number;
- b = (number - a) * 256;
- data[0] = a;
- data[1] = b;
-
- return mp4ff_write_data(file, data, 2);
-}
-
-uint64_t mp4ff_read_int64(mp4ff_t *file)
-{
- unsigned char data[8];
- uint64_t result = 0;
- int i;
-
- mp4ff_read_data(file, data, 8);
-
- for (i = 0; i < 8; i++) {
- result |= ((uint64_t)data[i]) << ((7 - i) * 8);
- }
-
- return result;
-}
-
-long mp4ff_read_int32(mp4ff_t *file)
-{
- unsigned long result;
- unsigned long a, b, c, d;
- char data[4];
-
- mp4ff_read_data(file, data, 4);
- a = (unsigned char)data[0];
- b = (unsigned char)data[1];
- c = (unsigned char)data[2];
- d = (unsigned char)data[3];
-
- result = (a<<24) | (b<<16) | (c<<8) | d;
- return (long)result;
-}
-
-
-long mp4ff_read_int24(mp4ff_t *file)
-{
- unsigned long result;
- unsigned long a, b, c;
- char data[4];
-
- mp4ff_read_data(file, data, 3);
-/* fread(data, 3, 1, file->stream); */
- a = (unsigned char)data[0];
- b = (unsigned char)data[1];
- c = (unsigned char)data[2];
-
- result = (a<<16) | (b<<8) | c;
- return (long)result;
-}
-
-int mp4ff_write_int24(mp4ff_t *file, long number)
-{
- unsigned char data[3];
- data[0] = (number & 0xff0000) >> 16;
- data[1] = (number & 0xff00) >> 8;
- data[2] = (number & 0xff);
-
- return mp4ff_write_data(file, data, 3);
-/* return fwrite(data, 3, 1, file->stream); */
-}
-
-int mp4ff_read_int16(mp4ff_t *file)
-{
- unsigned long result;
- unsigned long a, b;
- char data[2];
-
- mp4ff_read_data(file, data, 2);
-/* fread(data, 2, 1, file->stream); */
- a = (unsigned char)data[0];
- b = (unsigned char)data[1];
-
- result = (a<<8) | b;
- return (int)result;
-}
-
-int mp4ff_write_int16(mp4ff_t *file, int number)
-{
- unsigned char data[2];
- data[0] = (number & 0xff00) >> 8;
- data[1] = (number & 0xff);
-
- return mp4ff_write_data(file, data, 2);
-/* return fwrite(data, 2, 1, file->stream); */
-}
-
-int mp4ff_read_char(mp4ff_t *file)
-{
- char output;
- mp4ff_read_data(file, &output, 1);
- return output;
-}
-
-int mp4ff_write_char(mp4ff_t *file, char x)
-{
- return mp4ff_write_data(file, &x, 1);
-}
-
-int mp4ff_read_char32(mp4ff_t *file, char *string)
-{
- mp4ff_read_data(file, string, 4);
-/* fread(string, 4, 1, file->stream); */
-}
-
-long mp4ff_position(mp4ff_t *file)
-{
- return file->file_position;
-}
-
-int mp4ff_set_position(mp4ff_t *file, long position)
-{
- file->file_position = position;
- return 0;
-/* fseek(file->stream, position, SEEK_SET); */
-}
-
-int mp4ff_copy_char32(char *output, char *input)
-{
- *output++ = *input++;
- *output++ = *input++;
- *output++ = *input++;
- *output = *input;
-}
-
-
-void mp4ff_print_chars(char *desc, char *input, int len)
-{
- int i;
-
- printf("%s", desc);
- for(i = 0; i < len; i++)
- printf("%c", input[i]);
- printf("\n");
-}
-
-unsigned long mp4ff_current_time()
-{
- time_t t = 0;
- //time(&t);
- return (t+(66*31536000)+1468800);
-}
-
-int mp4ff_match_32(char *input, char *output)
-{
- if(input[0] == output[0] &&
- input[1] == output[1] &&
- input[2] == output[2] &&
- input[3] == output[3])
- return 1;
- else
- return 0;
-}
-
-int mp4ff_read_mp4_descr_length(mp4ff_t *file)
-{
- uint8_t b;
- uint8_t numBytes = 0;
- uint32_t length = 0;
-
- do {
- b = mp4ff_read_char(file);
- numBytes++;
- length = (length << 7) | (b & 0x7F);
- } while ((b & 0x80) && numBytes < 4);
-
- return length;
-}
-
-int mp4ff_write_mp4_descr_length(mp4ff_t *file, int length, unsigned char compact)
-{
- uint8_t b;
- int8_t i;
- int8_t numBytes;
-
- if (compact) {
- if (length <= 0x7F) {
- numBytes = 1;
- } else if (length <= 0x3FFF) {
- numBytes = 2;
- } else if (length <= 0x1FFFFF) {
- numBytes = 3;
- } else {
- numBytes = 4;
- }
- } else {
- numBytes = 4;
- }
-
- for (i = numBytes-1; i >= 0; i--) {
- b = (length >> (i * 7)) & 0x7F;
- if (i != 0) {
- b |= 0x80;
- }
- mp4ff_write_char(file, b);
- }
-
- return numBytes;
-}
-
-void mp4ff_atom_hexdump(mp4ff_t* file, mp4ff_atom_t* atom)
-{
- int i;
- int oldPos;
-
- oldPos = mp4ff_position(file);
- mp4ff_set_position(file, atom->start);
- printf("atom hex dump:\n");
- for (i = 0; i < atom->size; i++) {
- printf("%02x ", (uint8_t)mp4ff_read_char(file));
- if ((i % 16) == 0 && i > 0) {
- printf("\n");
- }
- }
- printf("\n");
- mp4ff_set_position(file, oldPos);
-}
--- a/common/mp4ff/vmhd.c
+++ /dev/null
@@ -1,58 +1,0 @@
-#include "mp4ff.h"
-
-
-int mp4ff_vmhd_init(mp4ff_vmhd_t *vmhd)
-{
- vmhd->version = 0;
- vmhd->flags = 1;
- vmhd->graphics_mode = 64;
- vmhd->opcolor[0] = 32768;
- vmhd->opcolor[1] = 32768;
- vmhd->opcolor[2] = 32768;
-}
-
-int mp4ff_vmhd_init_video(mp4ff_t *file,
- mp4ff_vmhd_t *vmhd,
- int frame_w,
- int frame_h,
- float frame_rate)
-{
-}
-
-int mp4ff_vmhd_delete(mp4ff_vmhd_t *vmhd)
-{
-}
-
-int mp4ff_vmhd_dump(mp4ff_vmhd_t *vmhd)
-{
- printf(" video media header\n");
- printf(" version %d\n", vmhd->version);
- printf(" flags %d\n", vmhd->flags);
- printf(" graphics_mode %d\n", vmhd->graphics_mode);
- printf(" opcolor %d %d %d\n", vmhd->opcolor[0], vmhd->opcolor[1], vmhd->opcolor[2]);
-}
-
-int mp4ff_read_vmhd(mp4ff_t *file, mp4ff_vmhd_t *vmhd)
-{
- int i;
- vmhd->version = mp4ff_read_char(file);
- vmhd->flags = mp4ff_read_int24(file);
- vmhd->graphics_mode = mp4ff_read_int16(file);
- for(i = 0; i < 3; i++)
- vmhd->opcolor[i] = mp4ff_read_int16(file);
-}
-
-int mp4ff_write_vmhd(mp4ff_t *file, mp4ff_vmhd_t *vmhd)
-{
- mp4ff_atom_t atom;
-
- mp4ff_atom_write_header(file, &atom, "vmhd");
-
- mp4ff_write_char(file, vmhd->version);
- mp4ff_write_int24(file, vmhd->flags);
-
- mp4ff_write_int64(file, (uint64_t)0);
-
- mp4ff_atom_write_footer(file, &atom);
-}
-