blob: a2b49a3eceea4a4c99cb06b954436968f2d3cb17 [file] [log] [blame]
Glenn Kasten99e53b82012-01-19 08:59:58 -08001/*
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08002**
3** Copyright 2007, The Android Open Source Project
4**
Glenn Kastene53b9ea2012-03-12 16:29:55 -07005** 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
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08008**
Glenn Kastene53b9ea2012-03-12 16:29:55 -07009** http://www.apache.org/licenses/LICENSE-2.0
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080010**
Glenn Kastene53b9ea2012-03-12 16:29:55 -070011** 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
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080015** limitations under the License.
16*/
17
Eric Laurent34f1d8e2009-11-04 08:27:26 -080018#define LOG_TAG "IAudioTrack"
19//#define LOG_NDEBUG 0
20#include <utils/Log.h>
21
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080022#include <stdint.h>
23#include <sys/types.h>
24
Mathias Agopian75624082009-05-19 19:08:10 -070025#include <binder/Parcel.h>
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080026
27#include <media/IAudioTrack.h>
28
29namespace android {
30
31enum {
32 GET_CBLK = IBinder::FIRST_CALL_TRANSACTION,
33 START,
34 STOP,
35 FLUSH,
Glenn Kastene4756fe2012-11-29 13:38:14 -080036 RESERVED, // was MUTE
Eric Laurentbe916aa2010-06-01 23:49:17 -070037 PAUSE,
John Grossman4ff14ba2012-02-08 16:37:41 -080038 ATTACH_AUX_EFFECT,
39 ALLOCATE_TIMED_BUFFER,
40 QUEUE_TIMED_BUFFER,
41 SET_MEDIA_TIME_TRANSFORM,
Richard Fitzgeraldad3af332013-03-25 16:54:37 +000042 SET_PARAMETERS
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080043};
44
45class BpAudioTrack : public BpInterface<IAudioTrack>
46{
47public:
48 BpAudioTrack(const sp<IBinder>& impl)
49 : BpInterface<IAudioTrack>(impl)
50 {
51 }
Glenn Kastene53b9ea2012-03-12 16:29:55 -070052
Glenn Kasten10995862012-01-03 14:50:23 -080053 virtual sp<IMemory> getCblk() const
54 {
55 Parcel data, reply;
56 sp<IMemory> cblk;
57 data.writeInterfaceToken(IAudioTrack::getInterfaceDescriptor());
58 status_t status = remote()->transact(GET_CBLK, data, &reply);
59 if (status == NO_ERROR) {
60 cblk = interface_cast<IMemory>(reply.readStrongBinder());
61 }
62 return cblk;
63 }
64
Glenn Kasten3acbd052012-02-28 10:39:56 -080065 virtual status_t start()
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080066 {
67 Parcel data, reply;
68 data.writeInterfaceToken(IAudioTrack::getInterfaceDescriptor());
Eric Laurent34f1d8e2009-11-04 08:27:26 -080069 status_t status = remote()->transact(START, data, &reply);
70 if (status == NO_ERROR) {
71 status = reply.readInt32();
72 } else {
Steve Block5ff1dd52012-01-05 23:22:43 +000073 ALOGW("start() error: %s", strerror(-status));
Eric Laurent34f1d8e2009-11-04 08:27:26 -080074 }
75 return status;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080076 }
Glenn Kastene53b9ea2012-03-12 16:29:55 -070077
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080078 virtual void stop()
79 {
80 Parcel data, reply;
81 data.writeInterfaceToken(IAudioTrack::getInterfaceDescriptor());
82 remote()->transact(STOP, data, &reply);
83 }
Glenn Kastene53b9ea2012-03-12 16:29:55 -070084
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080085 virtual void flush()
86 {
87 Parcel data, reply;
88 data.writeInterfaceToken(IAudioTrack::getInterfaceDescriptor());
89 remote()->transact(FLUSH, data, &reply);
90 }
91
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080092 virtual void pause()
93 {
94 Parcel data, reply;
95 data.writeInterfaceToken(IAudioTrack::getInterfaceDescriptor());
96 remote()->transact(PAUSE, data, &reply);
97 }
Glenn Kastene53b9ea2012-03-12 16:29:55 -070098
Eric Laurentbe916aa2010-06-01 23:49:17 -070099 virtual status_t attachAuxEffect(int effectId)
100 {
101 Parcel data, reply;
102 data.writeInterfaceToken(IAudioTrack::getInterfaceDescriptor());
103 data.writeInt32(effectId);
104 status_t status = remote()->transact(ATTACH_AUX_EFFECT, data, &reply);
105 if (status == NO_ERROR) {
106 status = reply.readInt32();
107 } else {
Steve Block5ff1dd52012-01-05 23:22:43 +0000108 ALOGW("attachAuxEffect() error: %s", strerror(-status));
Eric Laurentbe916aa2010-06-01 23:49:17 -0700109 }
110 return status;
111 }
John Grossman4ff14ba2012-02-08 16:37:41 -0800112
113 virtual status_t allocateTimedBuffer(size_t size, sp<IMemory>* buffer) {
114 Parcel data, reply;
115 data.writeInterfaceToken(IAudioTrack::getInterfaceDescriptor());
116 data.writeInt32(size);
117 status_t status = remote()->transact(ALLOCATE_TIMED_BUFFER,
118 data, &reply);
119 if (status == NO_ERROR) {
120 status = reply.readInt32();
121 if (status == NO_ERROR) {
122 *buffer = interface_cast<IMemory>(reply.readStrongBinder());
123 }
124 }
125 return status;
126 }
127
128 virtual status_t queueTimedBuffer(const sp<IMemory>& buffer,
129 int64_t pts) {
130 Parcel data, reply;
131 data.writeInterfaceToken(IAudioTrack::getInterfaceDescriptor());
132 data.writeStrongBinder(buffer->asBinder());
133 data.writeInt64(pts);
134 status_t status = remote()->transact(QUEUE_TIMED_BUFFER,
135 data, &reply);
136 if (status == NO_ERROR) {
137 status = reply.readInt32();
138 }
139 return status;
140 }
141
142 virtual status_t setMediaTimeTransform(const LinearTransform& xform,
143 int target) {
144 Parcel data, reply;
145 data.writeInterfaceToken(IAudioTrack::getInterfaceDescriptor());
146 data.writeInt64(xform.a_zero);
147 data.writeInt64(xform.b_zero);
148 data.writeInt32(xform.a_to_b_numer);
149 data.writeInt32(xform.a_to_b_denom);
150 data.writeInt32(target);
151 status_t status = remote()->transact(SET_MEDIA_TIME_TRANSFORM,
152 data, &reply);
153 if (status == NO_ERROR) {
154 status = reply.readInt32();
155 }
156 return status;
157 }
Richard Fitzgeraldad3af332013-03-25 16:54:37 +0000158
159 virtual status_t setParameters(const String8& keyValuePairs) {
160 Parcel data, reply;
161 data.writeInterfaceToken(IAudioTrack::getInterfaceDescriptor());
162 data.writeString8(keyValuePairs);
163 status_t status = remote()->transact(SET_PARAMETERS, data, &reply);
164 if (status == NO_ERROR) {
165 status = reply.readInt32();
166 }
167 return status;
168 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800169};
170
171IMPLEMENT_META_INTERFACE(AudioTrack, "android.media.IAudioTrack");
172
173// ----------------------------------------------------------------------
174
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800175status_t BnAudioTrack::onTransact(
176 uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags)
177{
Glenn Kastene53b9ea2012-03-12 16:29:55 -0700178 switch (code) {
179 case GET_CBLK: {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800180 CHECK_INTERFACE(IAudioTrack, data, reply);
181 reply->writeStrongBinder(getCblk()->asBinder());
182 return NO_ERROR;
183 } break;
184 case START: {
185 CHECK_INTERFACE(IAudioTrack, data, reply);
Glenn Kasten3acbd052012-02-28 10:39:56 -0800186 reply->writeInt32(start());
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800187 return NO_ERROR;
188 } break;
189 case STOP: {
190 CHECK_INTERFACE(IAudioTrack, data, reply);
191 stop();
192 return NO_ERROR;
193 } break;
194 case FLUSH: {
195 CHECK_INTERFACE(IAudioTrack, data, reply);
196 flush();
197 return NO_ERROR;
198 } break;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800199 case PAUSE: {
200 CHECK_INTERFACE(IAudioTrack, data, reply);
201 pause();
202 return NO_ERROR;
203 }
Eric Laurentbe916aa2010-06-01 23:49:17 -0700204 case ATTACH_AUX_EFFECT: {
205 CHECK_INTERFACE(IAudioTrack, data, reply);
206 reply->writeInt32(attachAuxEffect(data.readInt32()));
207 return NO_ERROR;
208 } break;
John Grossman4ff14ba2012-02-08 16:37:41 -0800209 case ALLOCATE_TIMED_BUFFER: {
210 CHECK_INTERFACE(IAudioTrack, data, reply);
211 sp<IMemory> buffer;
212 status_t status = allocateTimedBuffer(data.readInt32(), &buffer);
213 reply->writeInt32(status);
214 if (status == NO_ERROR) {
215 reply->writeStrongBinder(buffer->asBinder());
216 }
217 return NO_ERROR;
218 } break;
219 case QUEUE_TIMED_BUFFER: {
220 CHECK_INTERFACE(IAudioTrack, data, reply);
221 sp<IMemory> buffer = interface_cast<IMemory>(
222 data.readStrongBinder());
223 uint64_t pts = data.readInt64();
224 reply->writeInt32(queueTimedBuffer(buffer, pts));
225 return NO_ERROR;
226 } break;
227 case SET_MEDIA_TIME_TRANSFORM: {
228 CHECK_INTERFACE(IAudioTrack, data, reply);
229 LinearTransform xform;
230 xform.a_zero = data.readInt64();
231 xform.b_zero = data.readInt64();
232 xform.a_to_b_numer = data.readInt32();
233 xform.a_to_b_denom = data.readInt32();
234 int target = data.readInt32();
235 reply->writeInt32(setMediaTimeTransform(xform, target));
236 return NO_ERROR;
237 } break;
Richard Fitzgeraldad3af332013-03-25 16:54:37 +0000238 case SET_PARAMETERS: {
239 CHECK_INTERFACE(IAudioTrack, data, reply);
240 String8 keyValuePairs(data.readString8());
241 reply->writeInt32(setParameters(keyValuePairs));
242 return NO_ERROR;
243 } break;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800244 default:
245 return BBinder::onTransact(code, data, reply, flags);
246 }
247}
248
249}; // namespace android