blob: 619ac78e3790c7d15f77de737d8dff67861c65b2 [file] [log] [blame]
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2007 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef ANDROID_IAUDIOTRACK_H
18#define ANDROID_IAUDIOTRACK_H
19
20#include <stdint.h>
21#include <sys/types.h>
22
23#include <utils/RefBase.h>
24#include <utils/Errors.h>
Mathias Agopian75624082009-05-19 19:08:10 -070025#include <binder/IInterface.h>
26#include <binder/IMemory.h>
John Grossman4ff14ba2012-02-08 16:37:41 -080027#include <utils/LinearTransform.h>
Richard Fitzgeraldad3af332013-03-25 16:54:37 +000028#include <utils/String8.h>
Glenn Kasten53cec222013-08-29 09:01:02 -070029#include <media/AudioTimestamp.h>
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080030
31namespace android {
32
33// ----------------------------------------------------------------------------
34
35class IAudioTrack : public IInterface
36{
Glenn Kastene53b9ea2012-03-12 16:29:55 -070037public:
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080038 DECLARE_META_INTERFACE(AudioTrack);
39
Glenn Kasten10995862012-01-03 14:50:23 -080040 /* Get this track's control block */
41 virtual sp<IMemory> getCblk() const = 0;
42
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080043 /* After it's created the track is not active. Call start() to
Glenn Kasten3acbd052012-02-28 10:39:56 -080044 * make it active.
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080045 */
Glenn Kasten3acbd052012-02-28 10:39:56 -080046 virtual status_t start() = 0;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080047
48 /* Stop a track. If set, the callback will cease being called and
Glenn Kastene53b9ea2012-03-12 16:29:55 -070049 * obtainBuffer will return an error. Buffers that are already released
Glenn Kasten99e53b82012-01-19 08:59:58 -080050 * will continue to be processed, unless/until flush() is called.
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080051 */
52 virtual void stop() = 0;
53
Glenn Kasten99e53b82012-01-19 08:59:58 -080054 /* Flush a stopped or paused track. All pending/released buffers are discarded.
55 * This function has no effect if the track is not stopped or paused.
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080056 */
57 virtual void flush() = 0;
58
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080059 /* Pause a track. If set, the callback will cease being called and
Glenn Kastene53b9ea2012-03-12 16:29:55 -070060 * obtainBuffer will return an error. Buffers that are already released
Glenn Kasten99e53b82012-01-19 08:59:58 -080061 * will continue to be processed, unless/until flush() is called.
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080062 */
63 virtual void pause() = 0;
64
Eric Laurentbe916aa2010-06-01 23:49:17 -070065 /* Attach track auxiliary output to specified effect. Use effectId = 0
66 * to detach track from effect.
67 */
68 virtual status_t attachAuxEffect(int effectId) = 0;
69
John Grossman4ff14ba2012-02-08 16:37:41 -080070
71 /* Allocate a shared memory buffer suitable for holding timed audio
72 samples */
73 virtual status_t allocateTimedBuffer(size_t size,
74 sp<IMemory>* buffer) = 0;
75
76 /* Queue a buffer obtained via allocateTimedBuffer for playback at the given
77 timestamp */
78 virtual status_t queueTimedBuffer(const sp<IMemory>& buffer,
79 int64_t pts) = 0;
80
81 /* Define the linear transform that will be applied to the timestamps
82 given to queueTimedBuffer (which are expressed in media time).
83 Target specifies whether this transform converts media time to local time
84 or Tungsten time. The values for target are defined in AudioTrack.h */
85 virtual status_t setMediaTimeTransform(const LinearTransform& xform,
86 int target) = 0;
Richard Fitzgeraldad3af332013-03-25 16:54:37 +000087
88 /* Send parameters to the audio hardware */
89 virtual status_t setParameters(const String8& keyValuePairs) = 0;
Glenn Kasten53cec222013-08-29 09:01:02 -070090
Glenn Kasten200092b2014-08-15 15:13:30 -070091 /* Return NO_ERROR if timestamp is valid. timestamp is undefined otherwise. */
Glenn Kasten53cec222013-08-29 09:01:02 -070092 virtual status_t getTimestamp(AudioTimestamp& timestamp) = 0;
Eric Laurent59fe0102013-09-27 18:48:26 -070093
94 /* Signal the playback thread for a change in control block */
95 virtual void signal() = 0;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080096};
97
98// ----------------------------------------------------------------------------
99
100class BnAudioTrack : public BnInterface<IAudioTrack>
101{
102public:
103 virtual status_t onTransact( uint32_t code,
104 const Parcel& data,
105 Parcel* reply,
106 uint32_t flags = 0);
107};
108
109// ----------------------------------------------------------------------------
110
111}; // namespace android
112
113#endif // ANDROID_IAUDIOTRACK_H