/*
* Copyright (C) 2010 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.
*/
#ifndef ANDROID_ISTREAMSOURCE_H_
#define ANDROID_ISTREAMSOURCE_H_
#include <binder/IInterface.h>
namespace android {
struct AMessage;
class IMemory;
struct IStreamListener;
struct IStreamSource : public IInterface {
DECLARE_META_INTERFACE(StreamSource);
virtual void setListener(const sp<IStreamListener> &listener) = 0;
virtual void setBuffers(const Vector<sp<IMemory> > &buffers) = 0;
virtual void onBufferAvailable(size_t index) = 0;
enum {
// Video PES packets contain exactly one (aligned) access unit.
kFlagAlignedVideoData = 1,
// Timestamps are in ALooper::GetNowUs() units.
kFlagIsRealTimeData = 2,
};
virtual uint32_t flags() const { return 0; }
};
struct IStreamListener : public IInterface {
DECLARE_META_INTERFACE(StreamListener);
enum Command {
EOS,
DISCONTINUITY,
};
virtual void queueBuffer(size_t index, size_t size) = 0;
// When signalling a discontinuity you can optionally
// specify an int64_t PTS timestamp in "msg".
// If present, rendering of data following the discontinuity
// will be suppressed until media time reaches this timestamp.
static const char *const kKeyResumeAtPTS;
// When signalling a discontinuity you can optionally
// specify the type(s) of discontinuity, i.e. if the
// audio format has changed, the video format has changed,
// time has jumped or any combination thereof.
// To do so, include a non-zero int32_t value
// under the key "kKeyDiscontinuityMask" when issuing the DISCONTINUITY
// command.
// If there is a change in audio/video format, The new logical stream
// must start with proper codec initialization
// information for playback to continue, i.e. SPS and PPS in the case
// of AVC video etc.
// If this key is not present, only a time discontinuity is assumed.
// The value should be a bitmask of values from
// ATSParser::DiscontinuityType.
static const char *const kKeyDiscontinuityMask;
// Optionally signalled as part of a discontinuity that includes
// DISCONTINUITY_TIME. It indicates the media time (in us) to be associated
// with the next PTS occuring in the stream. The value is of type int64_t.
static const char *const kKeyMediaTimeUs;
// Optionally signalled as part of a discontinuity that includes
// DISCONTINUITY_TIME. It indicates the media time (in us) of a recent
// sample from the same content, and is used as a hint for the parser to
// handle PTS wraparound. This is required when a new parser is created
// to continue parsing content from the same timeline.
static const char *const kKeyRecentMediaTimeUs;
virtual void issueCommand(
Command cmd, bool synchronous, const sp<AMessage> &msg = NULL) = 0;
};
////////////////////////////////////////////////////////////////////////////////
struct BnStreamSource : public BnInterface<IStreamSource> {
virtual status_t onTransact(
uint32_t code, const Parcel &data, Parcel *reply,
uint32_t flags = 0);
};
struct BnStreamListener : public BnInterface<IStreamListener> {
virtual status_t onTransact(
uint32_t code, const Parcel &data, Parcel *reply,
uint32_t flags = 0);
};
} // namespace android
#endif // ANDROID_ISTREAMSOURCE_H_