blob: 864daa569dc5379304c1cc017bacdf7488486923 [file] [log] [blame]
Eric Laurent81784c32012-11-19 14:55:58 -08001/*
2**
3** Copyright 2012, The Android Open Source Project
4**
5** Licensed under the Apache License, Version 2.0 (the "License");
6** you may not use this file except in compliance with the License.
7** You may obtain a copy of the License at
8**
9** http://www.apache.org/licenses/LICENSE-2.0
10**
11** Unless required by applicable law or agreed to in writing, software
12** distributed under the License is distributed on an "AS IS" BASIS,
13** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14** See the License for the specific language governing permissions and
15** limitations under the License.
16*/
17
18#ifndef INCLUDING_FROM_AUDIOFLINGER_H
19 #error This header file should only be included from AudioFlinger.h
20#endif
21
22// base for record and playback
23class TrackBase : public ExtendedAudioBufferProvider, public RefBase {
24
25public:
26 enum track_state {
27 IDLE,
Eric Laurent81784c32012-11-19 14:55:58 -080028 FLUSHED,
29 STOPPED,
Eric Laurentbfb1b832013-01-07 09:53:42 -080030 // next 2 states are currently used for fast tracks
31 // and offloaded tracks only
Eric Laurent81784c32012-11-19 14:55:58 -080032 STOPPING_1, // waiting for first underrun
33 STOPPING_2, // waiting for presentation complete
34 RESUMING,
35 ACTIVE,
36 PAUSING,
Glenn Kasten6dd62fb2013-12-05 16:35:58 -080037 PAUSED,
38 STARTING_1, // for RecordTrack only
39 STARTING_2, // for RecordTrack only
Eric Laurent81784c32012-11-19 14:55:58 -080040 };
41
Glenn Kasten6181ffd2014-05-13 10:41:52 -070042 // where to allocate the data buffer
43 enum alloc_type {
44 ALLOC_CBLK, // allocate immediately after control block
45 ALLOC_READONLY, // allocate from a separate read-only heap per thread
46 ALLOC_PIPE, // do not allocate; use the pipe buffer
Eric Laurent83b88082014-06-20 18:31:16 -070047 ALLOC_LOCAL, // allocate a local buffer
48 ALLOC_NONE, // do not allocate:use the buffer passed to TrackBase constructor
49 };
50
51 enum track_type {
52 TYPE_DEFAULT,
53 TYPE_TIMED,
54 TYPE_OUTPUT,
55 TYPE_PATCH,
Glenn Kasten6181ffd2014-05-13 10:41:52 -070056 };
57
Eric Laurent81784c32012-11-19 14:55:58 -080058 TrackBase(ThreadBase *thread,
59 const sp<Client>& client,
60 uint32_t sampleRate,
61 audio_format_t format,
62 audio_channel_mask_t channelMask,
63 size_t frameCount,
Eric Laurent83b88082014-06-20 18:31:16 -070064 void *buffer,
Glenn Kastene3aa6592012-12-04 12:22:46 -080065 int sessionId,
Marco Nelissen462fd2f2013-01-14 14:12:05 -080066 int uid,
Glenn Kasten755b0a62014-05-13 11:30:28 -070067 IAudioFlinger::track_flags_t flags,
Glenn Kastend776ac62014-05-07 09:16:09 -070068 bool isOut,
Eric Laurent83b88082014-06-20 18:31:16 -070069 alloc_type alloc = ALLOC_CBLK,
70 track_type type = TYPE_DEFAULT);
Eric Laurent81784c32012-11-19 14:55:58 -080071 virtual ~TrackBase();
Eric Laurent83b88082014-06-20 18:31:16 -070072 virtual status_t initCheck() const;
Eric Laurent81784c32012-11-19 14:55:58 -080073
74 virtual status_t start(AudioSystem::sync_event_t event,
75 int triggerSession) = 0;
76 virtual void stop() = 0;
77 sp<IMemory> getCblk() const { return mCblkMemory; }
78 audio_track_cblk_t* cblk() const { return mCblk; }
79 int sessionId() const { return mSessionId; }
Marco Nelissen462fd2f2013-01-14 14:12:05 -080080 int uid() const { return mUid; }
Eric Laurent81784c32012-11-19 14:55:58 -080081 virtual status_t setSyncEvent(const sp<SyncEvent>& event);
82
Glenn Kastend776ac62014-05-07 09:16:09 -070083 sp<IMemory> getBuffers() const { return mBufferMemory; }
Eric Laurent83b88082014-06-20 18:31:16 -070084 void* buffer() const { return mBuffer; }
Glenn Kasten755b0a62014-05-13 11:30:28 -070085 bool isFastTrack() const { return (mFlags & IAudioFlinger::TRACK_FAST) != 0; }
Eric Laurent83b88082014-06-20 18:31:16 -070086 bool isTimedTrack() const { return (mType == TYPE_TIMED); }
87 bool isOutputTrack() const { return (mType == TYPE_OUTPUT); }
88 bool isPatchTrack() const { return (mType == TYPE_PATCH); }
89 bool isExternalTrack() const { return !isOutputTrack() && !isPatchTrack(); }
Glenn Kastend776ac62014-05-07 09:16:09 -070090
Eric Laurent81784c32012-11-19 14:55:58 -080091protected:
92 TrackBase(const TrackBase&);
93 TrackBase& operator = (const TrackBase&);
94
95 // AudioBufferProvider interface
96 virtual status_t getNextBuffer(AudioBufferProvider::Buffer* buffer, int64_t pts) = 0;
97 virtual void releaseBuffer(AudioBufferProvider::Buffer* buffer);
98
99 // ExtendedAudioBufferProvider interface is only needed for Track,
100 // but putting it in TrackBase avoids the complexity of virtual inheritance
101 virtual size_t framesReady() const { return SIZE_MAX; }
102
Glenn Kastenc9b2e202013-02-26 11:32:32 -0800103 audio_format_t format() const { return mFormat; }
Eric Laurent81784c32012-11-19 14:55:58 -0800104
105 uint32_t channelCount() const { return mChannelCount; }
106
107 audio_channel_mask_t channelMask() const { return mChannelMask; }
108
Glenn Kasten9f80dd22012-12-18 15:57:32 -0800109 virtual uint32_t sampleRate() const { return mSampleRate; }
Eric Laurent81784c32012-11-19 14:55:58 -0800110
Eric Laurent81784c32012-11-19 14:55:58 -0800111 bool isStopped() const {
112 return (mState == STOPPED || mState == FLUSHED);
113 }
114
Eric Laurentbfb1b832013-01-07 09:53:42 -0800115 // for fast tracks and offloaded tracks only
Eric Laurent81784c32012-11-19 14:55:58 -0800116 bool isStopping() const {
117 return mState == STOPPING_1 || mState == STOPPING_2;
118 }
119 bool isStopping_1() const {
120 return mState == STOPPING_1;
121 }
122 bool isStopping_2() const {
123 return mState == STOPPING_2;
124 }
125
126 bool isTerminated() const {
Eric Laurentbfb1b832013-01-07 09:53:42 -0800127 return mTerminated;
128 }
129
130 void terminate() {
131 mTerminated = true;
Eric Laurent81784c32012-11-19 14:55:58 -0800132 }
133
Glenn Kastene3aa6592012-12-04 12:22:46 -0800134 bool isOut() const { return mIsOut; }
135 // true for Track and TimedTrack, false for RecordTrack,
Eric Laurent81784c32012-11-19 14:55:58 -0800136 // this could be a track type if needed later
137
138 const wp<ThreadBase> mThread;
139 /*const*/ sp<Client> mClient; // see explanation at ~TrackBase() why not const
140 sp<IMemory> mCblkMemory;
141 audio_track_cblk_t* mCblk;
Glenn Kastend776ac62014-05-07 09:16:09 -0700142 sp<IMemory> mBufferMemory; // currently non-0 for fast RecordTrack only
Eric Laurent81784c32012-11-19 14:55:58 -0800143 void* mBuffer; // start of track buffer, typically in shared memory
Glenn Kastene3aa6592012-12-04 12:22:46 -0800144 // except for OutputTrack when it is in local memory
Eric Laurent81784c32012-11-19 14:55:58 -0800145 // we don't really need a lock for these
146 track_state mState;
147 const uint32_t mSampleRate; // initial sample rate only; for tracks which
148 // support dynamic rates, the current value is in control block
149 const audio_format_t mFormat;
150 const audio_channel_mask_t mChannelMask;
Glenn Kastenf6ed4232013-07-16 11:16:27 -0700151 const uint32_t mChannelCount;
Eric Laurent81784c32012-11-19 14:55:58 -0800152 const size_t mFrameSize; // AudioFlinger's view of frame size in shared memory,
153 // where for AudioTrack (but not AudioRecord),
154 // 8-bit PCM samples are stored as 16-bit
155 const size_t mFrameCount;// size of track buffer given at createTrack() or
156 // openRecord(), and then adjusted as needed
157
Eric Laurent81784c32012-11-19 14:55:58 -0800158 const int mSessionId;
Marco Nelissen462fd2f2013-01-14 14:12:05 -0800159 int mUid;
Eric Laurent81784c32012-11-19 14:55:58 -0800160 Vector < sp<SyncEvent> >mSyncEvents;
Glenn Kasten755b0a62014-05-13 11:30:28 -0700161 const IAudioFlinger::track_flags_t mFlags;
Glenn Kastene3aa6592012-12-04 12:22:46 -0800162 const bool mIsOut;
163 ServerProxy* mServerProxy;
Glenn Kastenda6ef132013-01-10 12:31:01 -0800164 const int mId;
165 sp<NBAIO_Sink> mTeeSink;
166 sp<NBAIO_Source> mTeeSource;
Eric Laurentbfb1b832013-01-07 09:53:42 -0800167 bool mTerminated;
Eric Laurent83b88082014-06-20 18:31:16 -0700168 track_type mType; // must be one of TYPE_DEFAULT, TYPE_OUTPUT, TYPE_PATCH ...
169};
170
171// PatchProxyBufferProvider interface is implemented by PatchTrack and PatchRecord.
172// it provides buffer access methods that map those of a ClientProxy (see AudioTrackShared.h)
173class PatchProxyBufferProvider
174{
175public:
176
177 virtual ~PatchProxyBufferProvider() {}
178
179 virtual status_t obtainBuffer(Proxy::Buffer* buffer,
180 const struct timespec *requested = NULL) = 0;
181 virtual void releaseBuffer(Proxy::Buffer* buffer) = 0;
Eric Laurent81784c32012-11-19 14:55:58 -0800182};