| /* |
| * Copyright (C) 2011 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| /** |
| |
| ************************************************************************ |
| * @file M4SYS_Stream.h |
| * @brief Stream manipulation |
| * @note This file defines the stream structure. |
| ************************************************************************ |
| */ |
| |
| #ifndef M4SYS_STREAM_H |
| #define M4SYS_STREAM_H |
| |
| #include "M4OSA_Types.h" |
| #include "M4OSA_Memory.h" |
| #include "M4OSA_Time.h" |
| |
| typedef M4OSA_UInt32 M4SYS_StreamID; |
| |
| /** The streamType type provides a way to distinguish all streams (AAC, AMR, YUV420, MPEG-4 Video, |
| H263). Stream types can be sorted in 2 ways: |
| @arg Some of them are raw data, others are encoded |
| @arg Some of them are related to an audio media, a video media... |
| @n So a specific naming convention has been designed to allow a quick parsing of the streamType |
| value to return the above categories. StreamType is an un-signed integer on 16 bits. |
| @arg The first byte (MSB) defines the codec type. It can be either Audio,Video, Picture, |
| Text or Scene. |
| @arg The second byte (LSB) defines the sub-codecs type (ie YUV420, PCM_16 bits, AMR...). |
| Moreover if this value is greater than 0x80 the stream is a raw stream, else the stream |
| is an encoded one |
| @n 0x0000 is a forbidden value, it describes an unknown stream */ |
| |
| typedef enum { |
| M4SYS_kUnknown = 0x0000, |
| /* Stream type definition |
| 0xYYZZ : YY is the codec type (Audio, Video, Picture, Scene ...) |
| ZZ is the sub-codec type (AAC, AMR , ...) |
| if ZZ is greater than 0x80 it is a raw format*/ |
| |
| /* Audio ones : Range from [0x0100-0x01FF]*/ |
| M4SYS_kAudioUnknown = 0x0100, |
| M4SYS_kAAC = 0x0101, |
| M4SYS_kCELP = 0x0102, |
| M4SYS_kAMR = 0x0103, |
| M4SYS_kAMR_WB = 0x0104, |
| M4SYS_kMP3 = 0x0105, |
| M4SYS_kMIDI = 0x0106, |
| M4SYS_kWMA = 0x0107, |
| M4SYS_kREALAUDIO = 0x0108, |
| M4SYS_kEVRC = 0x0109, |
| M4SYS_kPCM_16bitsS = 0x0181, /* PCM 16 bits Signed */ |
| M4SYS_kPCM_16bitsU = 0x0182, /* PCM 16 bits Un-signed */ |
| M4SYS_kPCM_8bitsU = 0x0183, /* PCM 8 bits Un-signed */ |
| /* FixAA 2008/03/03 types: M4SYS_kPCM_16bitsS, M4SYS_kPCM_16bitsU and M4SYS_kPCM_8bitsU |
| are now only used by AudioMixer and ReaderAVI => An update is necessary in the future for use |
| type M4SYS_kPCM */ |
| M4SYS_kXMF = 0x0184, |
| M4SYS_kSMAF = 0x0185, |
| M4SYS_kIMEL = 0x0186, |
| M4SYS_kBBA = 0x0187, |
| M4SYS_kBPC = 0x0188, |
| M4SYS_kADPCM = 0x0189, /* ADPCM added */ |
| M4SYS_kPCM = 0x0190, /* stream type added: PCM; PR2569 fixAA */ |
| M4SYS_kAudioAll = 0x01FF, /* all audio streams */ |
| |
| /* Video ones : Range [0x0200-0x02FF]*/ |
| M4SYS_kVideoUnknown = 0x0200, |
| M4SYS_kMPEG_4 = 0x0201, |
| M4SYS_kH263 = 0x0202, |
| M4SYS_kH263pp = 0x0203, |
| M4SYS_kH264 = 0x0204, |
| M4SYS_kREALVIDEO = 0x0205, |
| M4SYS_kYUV420 = 0x0281, |
| M4SYS_kRGB32 = 0x0282, |
| M4SYS_kBGR32 = 0x0283, |
| M4SYS_kRGB24 = 0x0284, |
| M4SYS_kBGR24 = 0x0285, |
| M4SYS_kVideoAll = 0x02FF, /* all video streams */ |
| |
| /* Picture ones : Range [0x0300-0x03FF]*/ |
| M4SYS_kPictureUnknown = 0x0300, |
| M4SYS_kJPEG = 0x0301, |
| M4SYS_kGIF = 0x0302, |
| M4SYS_kBMP = 0x0383, |
| M4SYS_kStillAll = 0x03FF, /* all still picture streams */ |
| |
| /* Text ones : Range [0x0400-0x04FF]*/ |
| M4SYS_kTextUnknown = 0x0400, |
| M4SYS_kTimedText = 0x0401, |
| M4SYS_kUTF8 = 0x0481, |
| M4SYS_kUTF16 = 0x0482, |
| M4SYS_kUCS2 = 0x0483, |
| M4SYS_kTextAll = 0x04FF, /* all text streams */ |
| |
| /* Scene & Graphics ones : Range [0x0500-0x05FF]*/ |
| M4SYS_kSceneUnknown = 0x0500, |
| M4SYS_kSMIL = 0x0501, |
| M4SYS_kBIFS = 0x0502, |
| M4SYS_kSceneAll = 0x05FF, /* all scene streams */ |
| |
| /* hinted ones : Range [0x0600-0x06FF]*/ |
| M4SYS_kHintedUnknown = 0x0600, |
| M4SYS_kRTP = 0x0601, |
| M4SYS_kMPEG2_TS = 0x0602, |
| M4SYS_kHintedAll = 0x06FF, /* all packetized streams */ |
| |
| /* MPEG-4 system ones : Range [0x0700-0x07FF]*/ |
| M4SYS_kSysUnknown = 0x0700, |
| M4SYS_kODS = 0x0701, |
| M4SYS_kIPMP = 0x0702, |
| M4SYS_kOCI = 0x0703, |
| M4SYS_kSysAll = 0x07FF /* all system streams*/ |
| } M4SYS_StreamType ; |
| |
| typedef struct { |
| M4SYS_StreamID streamID ; |
| M4OSA_UInt32 value ; |
| } M4SYS_StreamIDValue ; |
| |
| typedef struct { |
| M4SYS_StreamID streamID ; |
| M4OSA_UInt32 size ; |
| M4OSA_MemAddr32 addr ; |
| } M4SYS_StreamIDmemAddr ; |
| |
| /** This strucure defines a set of properties associated to a stream*/ |
| typedef struct { |
| M4SYS_StreamID streamID; /**< The ID of the stream. It must be unique for a media |
| (ie in a MP4 file, two tracks can not have two times the same ID). |
| 0 is forbidden.*/ |
| M4SYS_StreamType streamType; /**< The stream type of the stream*/ |
| M4OSA_UInt8 profileLevel; /**< The profile & level of a stream. It is related to the |
| stream type & the definition comes from the standard bodies |
| (i.e. MPEG-4 Video & MPEG-4 Audio). Some values are |
| pre-defined: 0xFE=userPrivate 0xFF=no Profile & |
| Level specified*/ |
| M4OSA_UInt32 decoderSpecificInfoSize; /**< The decoder configuration. These bytes are |
| needed to initialise a decoder.*/ |
| M4OSA_MemAddr32 decoderSpecificInfo; /**< The size (in bytes) of the decoder specific info.*/ |
| M4OSA_UInt32 timeScale; /**< The time scale of the stream. It means that all timing |
| duration of this stream are computed in this timescale |
| (ie timeScale = 8000, means there are 8000 ticks in |
| one second)*/ |
| M4OSA_Time duration; /**< The stream duration of this stream. The time unit is the |
| time scale. The value can be set to M4SYS_UnknownTime if |
| the duration is not known.*/ |
| M4OSA_Int32 averageBitrate; /**< The average bitrate (in bit per second) of this stream. |
| The average bitrate is computed on the stream duration. |
| -1 value means either there is no average bitrate or no |
| average bitrate is provided.*/ |
| M4OSA_Int32 maxBitrate; /**< The maximum bitrate (in bit per second) of this stream. |
| The maximum bitrate is computed on a sliding window of 1 |
| second. -1 value means either there is no max. bitrate or |
| no max. bitrate is provided.*/ |
| } M4SYS_StreamDescription; |
| |
| typedef enum { |
| M4SYS_kPreviousRAP = 0x01 , |
| M4SYS_kNextRAP = 0x02 , |
| M4SYS_kClosestRAP = 0x03 , |
| M4SYS_kNoRAPprevious = 0x11 , |
| M4SYS_kNoRAPnext = 0x12 , |
| M4SYS_kNoRAPclosest = 0x13 , |
| M4SYS_kBeginning = 0x20 |
| } M4SYS_SeekAccessMode ; |
| |
| #endif /*M4SYS_STREAM_H*/ |
| |
| |
| |