sles_allinclusive.h revision 01679db9a9318689f17b3ea4f69dbfc66a4a0583
1773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi/*
2773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi * Copyright (C) 2010 The Android Open Source Project
3773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi *
4773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi * Licensed under the Apache License, Version 2.0 (the "License");
5773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi * you may not use this file except in compliance with the License.
6773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi * You may obtain a copy of the License at
7773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi *
8773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi *      http://www.apache.org/licenses/LICENSE-2.0
9773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi *
10773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi * Unless required by applicable law or agreed to in writing, software
11773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi * distributed under the License is distributed on an "AS IS" BASIS,
12773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi * See the License for the specific language governing permissions and
14773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi * limitations under the License.
15773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi */
16773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
17369f3138f19f7102bf0f98b890ab84c8df633a93Glenn Kasten/** \file sles_allinclusive.h Everything including the kitchen sink */
18369f3138f19f7102bf0f98b890ab84c8df633a93Glenn Kasten
19c6853892c94800e72c0bd676d5d2136d48cea76eGlenn Kasten#include <SLES/OpenSLES.h>
20c6853892c94800e72c0bd676d5d2136d48cea76eGlenn Kasten#include <OMXAL/OpenMAXAL.h>
21a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#ifdef ANDROID
22c6853892c94800e72c0bd676d5d2136d48cea76eGlenn Kasten#include <SLES/OpenSLES_Android.h>
23c6853892c94800e72c0bd676d5d2136d48cea76eGlenn Kasten#include <OMXAL/OpenMAXAL_Android.h>
24a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#endif
25773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include <stddef.h> // offsetof
26773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include <stdlib.h> // malloc
27773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include <string.h> // memcmp
2833b27581efde3ee91652bfec35194b2d54603c7cCarl Shapiro#include <strings.h>
29773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include <stdio.h>  // debugging
30773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include <assert.h> // debugging
31773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include <pthread.h>
3232918086b694fc383c8c2d590ac45492801676f7Glenn Kasten#include <unistd.h> // usleep
33d2a7f0d6883a6d3835642e7b282f05ed1c54fe63Glenn Kasten#include <errno.h>
34773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
35e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten#ifndef __cplusplus
36e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kastentypedef int bool;
37e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten#ifndef false
38e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten#define false 0
39e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten#endif
40e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten#ifndef true
41e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten#define true 1
42e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten#endif
43e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten#endif
44e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten
45a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten// The OpenSLES.h definitions of SL_PROFILES_... have casts, so are unusable by preprocessor
46a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#define USE_PROFILES_PHONE    0x1   // == SL_PROFILES_PHONE
47a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#define USE_PROFILES_MUSIC    0x2   // == SL_PROFILES_MUSIC
48a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#define USE_PROFILES_GAME     0x4   // == SL_PROFILES_GAME
49a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten// Pseudo profiles, used to decide whether to include code for incomplete or untested features
50a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten// Features that are not in union of all profiles: audio recorder, LED, Vibra
51a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#define USE_PROFILES_OPTIONAL 0x8
52a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten// Features that are in the intersection of all profiles:
53a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten// object priorities, preemption, loss of control, device configuration
54a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#define USE_PROFILES_BASE     0x10
55a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten
56773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include "MPH.h"
57773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include "MPH_to.h"
58a6d984c32855a239f7f79a3d3b7f2ddfb8cb9697Glenn Kasten#include "devices.h"
59262059f71a68edc5e510427c63f5f1623d3672a8Glenn Kasten#include "ut/OpenSLESUT.h"
60d2a7f0d6883a6d3835642e7b282f05ed1c54fe63Glenn Kasten#include "ThreadPool.h"
61773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
62b0ab2dee391dd2cb257faeaba252ee6ecccc5f03Glenn Kastentypedef struct CEngine_struct CEngine;
63acd88797a1d3b8225bab888d29036e245f275be5Glenn Kastentypedef struct CAudioPlayer_struct CAudioPlayer;
643af2a8dd03f3113d5da1000dd79c143a9f0c4f36Jean-Michel Trivitypedef struct CAudioRecorder_struct CAudioRecorder;
656a357b8fa57b0bc1557cd5ab9f9fb86aabaaa18cGlenn Kastentypedef struct C3DGroup_struct C3DGroup;
66e5bf0d2c9531a7064eb3ddcafaf93ac1b0974037Glenn Kastentypedef struct COutputMix_struct COutputMix;
67acd88797a1d3b8225bab888d29036e245f275be5Glenn Kasten
68773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#ifdef USE_SNDFILE
69773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include <sndfile.h>
70262059f71a68edc5e510427c63f5f1623d3672a8Glenn Kasten#include "desktop/SLSndFile.h"
71773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#endif // USE_SNDFILE
72773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
73773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#ifdef USE_SDL
74773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include <SDL/SDL_audio.h>
75773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#endif // USE_SDL
76773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
77581a0f550f15f6fc22199cb85775a220f668b480Jean-Michel Trivi#define STEREO_CHANNELS 2
78581a0f550f15f6fc22199cb85775a220f668b480Jean-Michel Trivi
791a9c2615d0933d183fcb1b9e34ec8f0da2a85153Glenn Kasten/**
801a9c2615d0933d183fcb1b9e34ec8f0da2a85153Glenn Kasten * Constants to define unknown property values
811a9c2615d0933d183fcb1b9e34ec8f0da2a85153Glenn Kasten */
821a9c2615d0933d183fcb1b9e34ec8f0da2a85153Glenn Kasten#define UNKNOWN_NUMCHANNELS 0
831a9c2615d0933d183fcb1b9e34ec8f0da2a85153Glenn Kasten#define UNKNOWN_SAMPLERATE  0
841a9c2615d0933d183fcb1b9e34ec8f0da2a85153Glenn Kasten#define UNKNOWN_CHANNELMASK 0
851a9c2615d0933d183fcb1b9e34ec8f0da2a85153Glenn Kasten
86ef8931ae547cd703e69df9ad350d69825da0f546Jean-Michel Trivi#ifdef ANDROID
877a79f519d89eb0e1a5b3f4005484b16d6854d7e2Glenn Kasten#include <utils/Log.h>
885b09aa864215690580b18eb802927e8cc7eb4861Jean-Michel Trivi#include <utils/KeyedVector.h>
89773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include "media/AudioSystem.h"
903af2a8dd03f3113d5da1000dd79c143a9f0c4f36Jean-Michel Trivi#include "media/mediarecorder.h"
913af2a8dd03f3113d5da1000dd79c143a9f0c4f36Jean-Michel Trivi#include "media/AudioRecord.h"
92773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include "media/AudioTrack.h"
93773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#include "media/mediaplayer.h"
946fff2c605cdc46a10037e011d8fb47702ae70c37Jean-Michel Trivi#include <utils/String8.h>
95b6e3c1093dfbdec29e620e85d0d81cc39395a45fJean-Michel Trivi#define ANDROID_SL_MILLIBEL_MAX 0
96262059f71a68edc5e510427c63f5f1623d3672a8Glenn Kasten#include "android/android_sles_conversions.h"
97262059f71a68edc5e510427c63f5f1623d3672a8Glenn Kasten#include "android/android_defs.h"
9814e903028c4abfc1b2fbfab6560e3b864086f895Glenn Kasten#endif
99e5bf0d2c9531a7064eb3ddcafaf93ac1b0974037Glenn Kasten
100773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#ifdef USE_OUTPUTMIXEXT
101262059f71a68edc5e510427c63f5f1623d3672a8Glenn Kasten#include "desktop/OutputMixExt.h"
102773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#endif
103773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
104a7b79e766ec6d95e9236168c27461c2ebaef4659Glenn Kasten#include "sllog.h"
105a7b79e766ec6d95e9236168c27461c2ebaef4659Glenn Kasten
1061d081e49a10543018e1ae33792bd3d30504719baGlenn Kastentypedef enum {
1071d081e49a10543018e1ae33792bd3d30504719baGlenn Kasten    predestroy_error,   // Application should not be calling destroy now
1081d081e49a10543018e1ae33792bd3d30504719baGlenn Kasten    predestroy_ok,      // OK to destroy object now
1091d081e49a10543018e1ae33792bd3d30504719baGlenn Kasten    predestroy_again    // Application did nothing wrong, but should destroy again to be effective
1101d081e49a10543018e1ae33792bd3d30504719baGlenn Kasten} predestroy_t;
1111d081e49a10543018e1ae33792bd3d30504719baGlenn Kasten
112773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi// Hook functions
113773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
114773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivitypedef void (*VoidHook)(void *self);
115a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten//typedef SLresult (*ResultHook)(void *self);
1163d146e0a31f5ee2a7d9807c4e99994084fdd3283Jean-Michel Trivitypedef SLresult (*AsyncHook)(void *self, SLboolean async);
117928ea4ffff40c82987cfb1ac9e3095fdc6968709Glenn Kastentypedef bool (*BoolHook)(void *self);
1181d081e49a10543018e1ae33792bd3d30504719baGlenn Kastentypedef predestroy_t (*PreDestroyHook)(void *self);
119b90cb3de9b67383be4e077d807464044f6f18f7aJean-Michel Trivi
1205e3b06982dbf1eae237cc74326e66d51d3cdd664Glenn Kasten// Describes how an interface is related to a given class, used in iid_vtable::mInterface
121773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
1225e3b06982dbf1eae237cc74326e66d51d3cdd664Glenn Kasten#define INTERFACE_IMPLICIT            0 // no need for application to request prior to GetInterface
1235e3b06982dbf1eae237cc74326e66d51d3cdd664Glenn Kasten#define INTERFACE_EXPLICIT            1 // must be requested explicitly during object creation
1245e3b06982dbf1eae237cc74326e66d51d3cdd664Glenn Kasten#define INTERFACE_DYNAMIC             2 // can be requested after object creation
1255e3b06982dbf1eae237cc74326e66d51d3cdd664Glenn Kasten#define INTERFACE_UNAVAILABLE         3 // this interface is not available on objects of this class
126104c000a6f36b871ca11e0394db1e5217f374cafGlenn Kasten#define INTERFACE_IMPLICIT_PREREALIZE 4 // implicit, and can call GetInterface before Realize
127104c000a6f36b871ca11e0394db1e5217f374cafGlenn Kasten#define INTERFACE_EXPLICIT_PREREALIZE 5 // explicit, and can call GetInterface before Realize
128104c000a6f36b871ca11e0394db1e5217f374cafGlenn Kasten// 6 and 7 are reserved for the meaningless DYNAMIC_PREREALIZE and UNAVAILABLE_PREREALIZE
129c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten// note that INTERFACE_OPTIONAL is always re-mapped to one of the above
130104c000a6f36b871ca11e0394db1e5217f374cafGlenn Kasten#define INTERFACE_PREREALIZE          4 // bit-mask to test for calling GetInterface before Realize
131c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten
132c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten// Profile-specific interfaces
133c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten
134a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#if USE_PROFILES & USE_PROFILES_BASE
135c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_IMPLICIT_BASE       INTERFACE_IMPLICIT
136c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_EXPLICIT_BASE       INTERFACE_EXPLICIT
137c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#else
138c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_IMPLICIT_BASE       INTERFACE_UNAVAILABLE
139c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_EXPLICIT_BASE       INTERFACE_UNAVAILABLE
140c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#endif
141c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten
142a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#if USE_PROFILES & USE_PROFILES_GAME
143c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_DYNAMIC_GAME        INTERFACE_DYNAMIC
144c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_EXPLICIT_GAME       INTERFACE_EXPLICIT
145c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#else
146c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_DYNAMIC_GAME        INTERFACE_OPTIONAL
147c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_EXPLICIT_GAME       INTERFACE_OPTIONAL
148c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#endif
149c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten
150a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#if USE_PROFILES & USE_PROFILES_MUSIC
151c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_DYNAMIC_MUSIC       INTERFACE_DYNAMIC
152c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#else
153c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_DYNAMIC_MUSIC       INTERFACE_OPTIONAL
154c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#endif
155c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten
156a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#if USE_PROFILES & (USE_PROFILES_GAME | USE_PROFILES_MUSIC)
157c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_DYNAMIC_GAME_MUSIC  INTERFACE_DYNAMIC
158c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_EXPLICIT_GAME_MUSIC INTERFACE_EXPLICIT
159c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#else
160c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_DYNAMIC_GAME_MUSIC  INTERFACE_OPTIONAL
161c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_EXPLICIT_GAME_MUSIC INTERFACE_OPTIONAL
162c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#endif
163c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten
164a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#if USE_PROFILES & (USE_PROFILES_GAME | USE_PROFILES_PHONE)
165c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_EXPLICIT_GAME_PHONE INTERFACE_EXPLICIT
166c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#else
167c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_EXPLICIT_GAME_PHONE INTERFACE_OPTIONAL
168c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#endif
169c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten
170a3080daa505f91df51a808c85ddb37c48745bf7cGlenn Kasten#if USE_PROFILES & USE_PROFILES_OPTIONAL
171c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_OPTIONAL            INTERFACE_EXPLICIT
172c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_DYNAMIC_OPTIONAL    INTERFACE_DYNAMIC
1737a79f519d89eb0e1a5b3f4005484b16d6854d7e2Glenn Kasten#else
174c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_OPTIONAL            INTERFACE_UNAVAILABLE
175c3845706778edec308bd9ced559cec0a456608bdGlenn Kasten#define INTERFACE_DYNAMIC_OPTIONAL    INTERFACE_UNAVAILABLE
1767a79f519d89eb0e1a5b3f4005484b16d6854d7e2Glenn Kasten#endif
1777a79f519d89eb0e1a5b3f4005484b16d6854d7e2Glenn Kasten
178510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten// Describes how an interface is related to a given object
179510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten
180a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_UNINITIALIZED 0  ///< not available
181a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_INITIALIZED   1  ///< not requested at object creation time
182a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_EXPOSED       2  ///< requested at object creation time
183a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_ADDING_1      3  ///< part 1 of asynchronous AddInterface, pending
184a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_ADDING_2      4  ///< synchronous AddInterface, or part 2 of asynchronous
185a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_ADDED         5  ///< AddInterface has completed
186a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_REMOVING      6  ///< unlocked phase of (synchronous) RemoveInterface
187a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_SUSPENDING    7  ///< suspend in progress
188a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_SUSPENDED     8  ///< suspend has completed
189a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_RESUMING_1    9  ///< part 1 of asynchronous ResumeInterface, pending
190a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_RESUMING_2   10  ///< synchronous ResumeInterface, or part 2 of asynchronous
191a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_ADDING_1A    11  ///< part 1 of asynchronous AddInterface, aborted
192a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten#define INTERFACE_RESUMING_1A  12  ///< part 1 of asynchronous ResumeInterface, aborted
193510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten
194b3e52a63baaea367cf411348b68ecd8fd429b029Jean-Michel Trivi
195773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi// Maps an interface ID to its offset within the class that exposes it
196773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
197773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivistruct iid_vtable {
19801e9f5fa4698856f92bcfd88188ee4c8397b22dbGlenn Kasten    unsigned char mMPH;         // primary MPH for this interface, does not include any aliases
19901e9f5fa4698856f92bcfd88188ee4c8397b22dbGlenn Kasten    unsigned char mInterface;   // relationship of interface to this class
200773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi    /*size_t*/ unsigned short mOffset;
201773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi};
202773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
203773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi// Per-class const data shared by all instances of the same class
204773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
20572a04d8e9e059dad969d166a6a70491fe1e65970Glenn Kastentypedef struct {
20601e9f5fa4698856f92bcfd88188ee4c8397b22dbGlenn Kasten    const struct iid_vtable *mInterfaces;   // maps interface index to info about that interface
207510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten    SLuint32 mInterfaceCount;  // number of possible interfaces
208773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi    const signed char *mMPH_to_index;
20976dde6cd71bdb39459f38218e8aa2b7c19e790dbGlenn Kasten    const char * const mName;
210773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi    size_t mSize;
2118b8875067dd02b79361abb00c5d65b02a8ae72b0Glenn Kasten    // OpenSL ES and OpenMAX AL object IDs come from different ranges, and some objects such as
2128b8875067dd02b79361abb00c5d65b02a8ae72b0Glenn Kasten    // Engine, Output Mix, LED, and Vibra belong to both APIs, so we keep both object IDs
2138b8875067dd02b79361abb00c5d65b02a8ae72b0Glenn Kasten    SLuint16 mSLObjectID;   // OpenSL ES object ID
2148b8875067dd02b79361abb00c5d65b02a8ae72b0Glenn Kasten    XAuint16 mXAObjectID;   // OpenMAX AL object ID
215510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten    // hooks
2164260ff7b8f65fdfe8d0176cdce66faf0a10c4b10Glenn Kasten    AsyncHook mRealize;     // called with mutex locked; can temporarily unlock mutex (for async)
2174260ff7b8f65fdfe8d0176cdce66faf0a10c4b10Glenn Kasten    AsyncHook mResume;      // called with mutex locked; can temporarily unlock mutex (for async)
2184260ff7b8f65fdfe8d0176cdce66faf0a10c4b10Glenn Kasten    VoidHook mDestroy;      // called with mutex locked and must keep mutex locked throughout
2194260ff7b8f65fdfe8d0176cdce66faf0a10c4b10Glenn Kasten    PreDestroyHook mPreDestroy; // called with mutex locked; can temporarily unlock mutex (for wait)
22072a04d8e9e059dad969d166a6a70491fe1e65970Glenn Kasten} ClassTable;
221773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
222773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi// BufferHeader describes each element of a BufferQueue, other than the data
223d2a7f0d6883a6d3835642e7b282f05ed1c54fe63Glenn Kastentypedef struct {
224773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi    const void *mBuffer;
225773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi    SLuint32 mSize;
226d2a7f0d6883a6d3835642e7b282f05ed1c54fe63Glenn Kasten} BufferHeader;
227773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
22870c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi#ifdef ANDROID
22970c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi// Holds information about all commands that can be passed alongside an MPEG-2 TS buffer
23070c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi// Is used with buffers of type kAndroidBufferTypeMpeg2Ts
23170c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivitypedef struct {
23270c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi    SLuint32 mTsCmdCode;
233e9236d046fdb5cac0696c42e03443a2439188146Jean-Michel Trivi    SLAuint64 mPts;
23470c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi} Mpeg2TsCommands;
23570c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi
236bb832e853d4afb11b0a3287b2eb0cad87696d631Jean-Michel Trivi// Holds information about all commands that can be passed alongside an AAC ADTS buffer
237bb832e853d4afb11b0a3287b2eb0cad87696d631Jean-Michel Trivi// Is used with buffers of type kAndroidBufferTypeAacadts
238bb832e853d4afb11b0a3287b2eb0cad87696d631Jean-Michel Trivitypedef struct {
239bb832e853d4afb11b0a3287b2eb0cad87696d631Jean-Michel Trivi    SLuint32 mAdtsCmdCode;
240bb832e853d4afb11b0a3287b2eb0cad87696d631Jean-Michel Trivi} AdtsCommands;
241bb832e853d4afb11b0a3287b2eb0cad87696d631Jean-Michel Trivi
24270c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi// Union of the different structures to hold items stored in an AdvancedBufferHeader
24370c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi//   when an item comes from an AndroidBufferQueue as the data source, it's a command
24470c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi//   when an item is output to an AndroidBufferQueue as the data sink, it's a message (or metadata)
24570c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivitypedef union {
24670c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi    Mpeg2TsCommands mTsCmdData;
247bb832e853d4afb11b0a3287b2eb0cad87696d631Jean-Michel Trivi    AdtsCommands    mAdtsCmdData;
24870c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi} AdvancedBufferItems;
24970c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi
250d158d31a6bbb06426b71c3d097b7768bc3fb79a3Jean-Michel Trivi// AdvancedBufferHeader describes each element of an AndroidBufferQueue, other than the data
251d158d31a6bbb06426b71c3d097b7768bc3fb79a3Jean-Michel Trivi//  and associated messages
252d158d31a6bbb06426b71c3d097b7768bc3fb79a3Jean-Michel Trivitypedef struct {
253d158d31a6bbb06426b71c3d097b7768bc3fb79a3Jean-Michel Trivi    const void *mDataBuffer;
254d158d31a6bbb06426b71c3d097b7768bc3fb79a3Jean-Michel Trivi    SLuint32 mDataSize;
255d158d31a6bbb06426b71c3d097b7768bc3fb79a3Jean-Michel Trivi    SLuint32 mDataSizeConsumed;
25670c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi    AdvancedBufferItems mItems;
25737dc2fccf3f122b79ebd554de209d0a3c94ae161Jean-Michel Trivi    const void *mBufferContext;
2581c853a41d9d9886e60618a7c878ce3912f46bf3cJean-Michel Trivi    SLuint32 mBufferState;
259d158d31a6bbb06426b71c3d097b7768bc3fb79a3Jean-Michel Trivi} AdvancedBufferHeader;
26070c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi#endif
261d158d31a6bbb06426b71c3d097b7768bc3fb79a3Jean-Michel Trivi
262773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#ifdef USE_SNDFILE
263773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
2646a357b8fa57b0bc1557cd5ab9f9fb86aabaaa18cGlenn Kasten#define SndFile_BUFSIZE 512     // in 16-bit samples
2656a357b8fa57b0bc1557cd5ab9f9fb86aabaaa18cGlenn Kasten#define SndFile_NUMBUFS 2
2666a357b8fa57b0bc1557cd5ab9f9fb86aabaaa18cGlenn Kasten
267773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivistruct SndFile {
268773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi    // save URI also?
269773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi    SLchar *mPathname;
270773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi    SNDFILE *mSNDFILE;
2714b65ef9efdf5aba01bea89d8cdd64f500560a28dGlenn Kasten    SF_INFO mSfInfo;
272e5bf0d2c9531a7064eb3ddcafaf93ac1b0974037Glenn Kasten    pthread_mutex_t mMutex; // protects mSNDFILE only
273e5bf0d2c9531a7064eb3ddcafaf93ac1b0974037Glenn Kasten    SLboolean mEOF;         // sf_read returned zero sample frames
2748c065779232fdd89abace68d2fc7bea786a010d7Glenn Kasten    SLuint32 mWhich;        // which buffer to use next
2756a357b8fa57b0bc1557cd5ab9f9fb86aabaaa18cGlenn Kasten    short mBuffer[SndFile_BUFSIZE * SndFile_NUMBUFS];
276773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi};
277773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
278773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi#endif // USE_SNDFILE
279773e0429cbb9e85b4f1c6eb5a095ccd7b57f5ba4Jean-Michel Trivi
280cafa51fdd8b3f29ebaa0682070100825a9cce2a8Glenn Kasten#include "data.h"
281cafa51fdd8b3f29ebaa0682070100825a9cce2a8Glenn Kasten#include "itfstruct.h"
282cafa51fdd8b3f29ebaa0682070100825a9cce2a8Glenn Kasten#include "classes.h"
283a6d984c32855a239f7f79a3d3b7f2ddfb8cb9697Glenn Kasten
28461ac0ade16f84d877dfd8d0e984eb203d4a2901dGlenn Kastenstruct MPH_init {
285a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten    VoidHook mInit;     // called first to initialize the interface, right after object is allocated
286a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten    // Each interface is initialized regardless whether it is exposed to application.
287a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten    VoidHook mResume;   // called to resume interface after suspension, not currently used
288a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten    VoidHook mDeinit;   // called last when object is about to be destroyed
289a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten    BoolHook mExpose;   // called after initialization, only if interface is exposed to application
290711332800108ad6e0e594796e5f8db0da3eff402Glenn Kasten    VoidHook mRemove;   // called by DynamicInterfaceManager::RemoveInterface, and prior to mDeinit
291a9a70a4451545034c9263dd55b181f2912534c37Glenn Kasten    // will need a suspend hook when suspend is implemented
29261ac0ade16f84d877dfd8d0e984eb203d4a2901dGlenn Kasten};
29361ac0ade16f84d877dfd8d0e984eb203d4a2901dGlenn Kasten
29461ac0ade16f84d877dfd8d0e984eb203d4a2901dGlenn Kastenextern /*static*/ int IID_to_MPH(const SLInterfaceID iid);
29561ac0ade16f84d877dfd8d0e984eb203d4a2901dGlenn Kastenextern /*static*/ const struct MPH_init MPH_init_table[MPH_MAX];
296bcc5c7225e3b7a1dbf2e9e830987f69167acf06fGlenn Kastenextern SLresult checkInterfaces(const ClassTable *clazz,
297979a3f8743646af9999a89dff9e13b972b7efd87Glenn Kasten    SLuint32 numInterfaces, const SLInterfaceID *pInterfaceIds,
298979a3f8743646af9999a89dff9e13b972b7efd87Glenn Kasten    const SLboolean *pInterfaceRequired, unsigned *pExposedMask);
299bcc5c7225e3b7a1dbf2e9e830987f69167acf06fGlenn Kastenextern IObject *construct(const ClassTable *clazz,
300979a3f8743646af9999a89dff9e13b972b7efd87Glenn Kasten    unsigned exposedMask, SLEngineItf engine);
301979a3f8743646af9999a89dff9e13b972b7efd87Glenn Kastenextern const ClassTable *objectIDtoClass(SLuint32 objectID);
302979a3f8743646af9999a89dff9e13b972b7efd87Glenn Kastenextern const struct SLInterfaceID_ SL_IID_array[MPH_MAX];
303b7154f2324c8ae44b820c07c69aaa80a4bb9e418Glenn Kastenextern SLuint32 IObjectToObjectID(IObject *object);
304bcc5c7225e3b7a1dbf2e9e830987f69167acf06fGlenn Kastenextern void IObject_Publish(IObject *thiz);
305f51dba65751107c930759938775b75531ec1f330Glenn Kastenextern void IObject_Destroy(SLObjectItf self);
306b7154f2324c8ae44b820c07c69aaa80a4bb9e418Glenn Kasten
307d07ed7df4ec9338f97f12627690d58ed9b34f25bGlenn Kasten// Map an interface to it's "object ID" (which is really a class ID).
308d07ed7df4ec9338f97f12627690d58ed9b34f25bGlenn Kasten// Note: this operation is undefined on IObject, as it lacks an mThis.
309d07ed7df4ec9338f97f12627690d58ed9b34f25bGlenn Kasten// If you have an IObject, then use IObjectToObjectID directly.
310b7154f2324c8ae44b820c07c69aaa80a4bb9e418Glenn Kasten
311bcc5c7225e3b7a1dbf2e9e830987f69167acf06fGlenn Kasten#define InterfaceToObjectID(thiz) IObjectToObjectID((thiz)->mThis)
312daf661248ff6ea2e21799e5114c78b7c1d49630eGlenn Kasten
313d07ed7df4ec9338f97f12627690d58ed9b34f25bGlenn Kasten// Map an interface to it's corresponding IObject.
314d07ed7df4ec9338f97f12627690d58ed9b34f25bGlenn Kasten// Note: this operation is undefined on IObject, as it lacks an mThis.
315d07ed7df4ec9338f97f12627690d58ed9b34f25bGlenn Kasten// If you have an IObject, then you're done -- you already have what you need.
316d07ed7df4ec9338f97f12627690d58ed9b34f25bGlenn Kasten
317bcc5c7225e3b7a1dbf2e9e830987f69167acf06fGlenn Kasten#define InterfaceToIObject(thiz) ((thiz)->mThis)
318d07ed7df4ec9338f97f12627690d58ed9b34f25bGlenn Kasten
319bcc5c7225e3b7a1dbf2e9e830987f69167acf06fGlenn Kasten#define InterfaceToCAudioPlayer(thiz) (((CAudioPlayer*)InterfaceToIObject(thiz)))
3201fec6cc920db52e63c67eafd2034e52b8eb5780dJean-Michel Trivi
321bcc5c7225e3b7a1dbf2e9e830987f69167acf06fGlenn Kasten#define InterfaceToCAudioRecorder(thiz) (((CAudioRecorder*)InterfaceToIObject(thiz)))
3223af2a8dd03f3113d5da1000dd79c143a9f0c4f36Jean-Michel Trivi
3237b726bdcd996f1cab3a584c04ce1afc07bc8fbe7Glenn Kasten#define InterfaceToCAudioRecorder(thiz) (((CAudioRecorder*)InterfaceToIObject(thiz)))
3247b726bdcd996f1cab3a584c04ce1afc07bc8fbe7Glenn Kasten
32592b245bf8828db9e469febebbe8774c00570b5b9Jean-Michel Trivi#define InterfaceToCMediaPlayer(thiz) (((CMediaPlayer*)InterfaceToIObject(thiz)))
32692b245bf8828db9e469febebbe8774c00570b5b9Jean-Michel Trivi
327ef8931ae547cd703e69df9ad350d69825da0f546Jean-Michel Trivi#ifdef ANDROID
328b2aeb0f1009555181dabb944fe05901cb6e6f632Jean-Michel Trivi#include "android/MediaPlayer_to_android.h"
329b2aeb0f1009555181dabb944fe05901cb6e6f632Jean-Michel Trivi#include "android/OutputMix_to_android.h"
330b2aeb0f1009555181dabb944fe05901cb6e6f632Jean-Michel Trivi#include "android/AudioPlayer_to_android.h"
331b2aeb0f1009555181dabb944fe05901cb6e6f632Jean-Michel Trivi#include "android/AudioRecorder_to_android.h"
332daf661248ff6ea2e21799e5114c78b7c1d49630eGlenn Kasten#endif
333daf661248ff6ea2e21799e5114c78b7c1d49630eGlenn Kasten
3341d081e49a10543018e1ae33792bd3d30504719baGlenn Kastenextern predestroy_t C3DGroup_PreDestroy(void *self);
335f51dba65751107c930759938775b75531ec1f330Glenn Kasten
3363a413f1863daa026ed2b9fc9eac01e1341116cdbGlenn Kastenextern SLresult CAudioPlayer_Realize(void *self, SLboolean async);
337928ea4ffff40c82987cfb1ac9e3095fdc6968709Glenn Kastenextern SLresult CAudioPlayer_Resume(void *self, SLboolean async);
3383a413f1863daa026ed2b9fc9eac01e1341116cdbGlenn Kastenextern void CAudioPlayer_Destroy(void *self);
3391d081e49a10543018e1ae33792bd3d30504719baGlenn Kastenextern predestroy_t CAudioPlayer_PreDestroy(void *self);
3403af2a8dd03f3113d5da1000dd79c143a9f0c4f36Jean-Michel Trivi
3413af2a8dd03f3113d5da1000dd79c143a9f0c4f36Jean-Michel Triviextern SLresult CAudioRecorder_Realize(void *self, SLboolean async);
3423af2a8dd03f3113d5da1000dd79c143a9f0c4f36Jean-Michel Triviextern SLresult CAudioRecorder_Resume(void *self, SLboolean async);
3433af2a8dd03f3113d5da1000dd79c143a9f0c4f36Jean-Michel Triviextern void CAudioRecorder_Destroy(void *self);
3441d081e49a10543018e1ae33792bd3d30504719baGlenn Kastenextern predestroy_t CAudioRecorder_PreDestroy(void *self);
3453af2a8dd03f3113d5da1000dd79c143a9f0c4f36Jean-Michel Trivi
346d2a7f0d6883a6d3835642e7b282f05ed1c54fe63Glenn Kastenextern SLresult CEngine_Realize(void *self, SLboolean async);
347928ea4ffff40c82987cfb1ac9e3095fdc6968709Glenn Kastenextern SLresult CEngine_Resume(void *self, SLboolean async);
348d2a7f0d6883a6d3835642e7b282f05ed1c54fe63Glenn Kastenextern void CEngine_Destroy(void *self);
3491d081e49a10543018e1ae33792bd3d30504719baGlenn Kastenextern predestroy_t CEngine_PreDestroy(void *self);
350711332800108ad6e0e594796e5f8db0da3eff402Glenn Kastenextern void CEngine_Destroyed(CEngine *self);
3513af2a8dd03f3113d5da1000dd79c143a9f0c4f36Jean-Michel Trivi
3527e01bc6208fb5b4a2a0019d67bf74373f8ee9428Jean-Michel Triviextern SLresult COutputMix_Realize(void *self, SLboolean async);
3537e01bc6208fb5b4a2a0019d67bf74373f8ee9428Jean-Michel Triviextern SLresult COutputMix_Resume(void *self, SLboolean async);
3547e01bc6208fb5b4a2a0019d67bf74373f8ee9428Jean-Michel Triviextern void COutputMix_Destroy(void *self);
3551d081e49a10543018e1ae33792bd3d30504719baGlenn Kastenextern predestroy_t COutputMix_PreDestroy(void *self);
3567e01bc6208fb5b4a2a0019d67bf74373f8ee9428Jean-Michel Trivi
35794a37e8117fb72790882dfb815f99e2365754c74Glenn Kastenextern SLresult CMediaPlayer_Realize(void *self, SLboolean async);
35894a37e8117fb72790882dfb815f99e2365754c74Glenn Kastenextern SLresult CMediaPlayer_Resume(void *self, SLboolean async);
35994a37e8117fb72790882dfb815f99e2365754c74Glenn Kastenextern void CMediaPlayer_Destroy(void *self);
3601d081e49a10543018e1ae33792bd3d30504719baGlenn Kastenextern predestroy_t CMediaPlayer_PreDestroy(void *self);
36194a37e8117fb72790882dfb815f99e2365754c74Glenn Kasten
36200d2d554e04ac369367c903dbf53b975355d1bcdGlenn Kasten#ifdef USE_SDL
363768edbc2a8e7f197548cf1141689dd237d19c455Glenn Kastenextern void SDL_open(IEngine *thisEngine);
364768edbc2a8e7f197548cf1141689dd237d19c455Glenn Kastenextern void SDL_close(void);
36500d2d554e04ac369367c903dbf53b975355d1bcdGlenn Kasten#endif
36601679db9a9318689f17b3ea4f69dbfc66a4a0583Glenn Kasten
367510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten#define SL_OBJECT_STATE_REALIZING_1  ((SLuint32) 0x4) // async realize on work queue
368510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten#define SL_OBJECT_STATE_REALIZING_2  ((SLuint32) 0x5) // sync realize, or async realize hook
369510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten#define SL_OBJECT_STATE_RESUMING_1   ((SLuint32) 0x6) // async resume on work queue
370510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten#define SL_OBJECT_STATE_RESUMING_2   ((SLuint32) 0x7) // sync resume, or async resume hook
371510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten#define SL_OBJECT_STATE_SUSPENDING   ((SLuint32) 0x8) // suspend in progress
372510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten#define SL_OBJECT_STATE_REALIZING_1A ((SLuint32) 0x9) // abort while async realize on work queue
373510f3671f716f6835282e4b0fd0275c20e9dadd8Glenn Kasten#define SL_OBJECT_STATE_RESUMING_1A  ((SLuint32) 0xA) // abort while async resume on work queue
374928ea4ffff40c82987cfb1ac9e3095fdc6968709Glenn Kasten#define SL_OBJECT_STATE_DESTROYING   ((SLuint32) 0xB) // destroy object when no strong references
37501679db9a9318689f17b3ea4f69dbfc66a4a0583Glenn Kasten
37601679db9a9318689f17b3ea4f69dbfc66a4a0583Glenn Kasten#ifdef USE_OUTPUTMIXEXT
37701679db9a9318689f17b3ea4f69dbfc66a4a0583Glenn Kasten#define SL_PLAYSTATE_STOPPING ((SLuint32) 0x4) // Play::Stop while PLAYING
37801679db9a9318689f17b3ea4f69dbfc66a4a0583Glenn Kasten// If we needed it, could have PLAYING mean mixer is currently reading from front buffer,
37901679db9a9318689f17b3ea4f69dbfc66a4a0583Glenn Kasten// while PLAYABLE would mean application requested PLAYING, but buffer queue is empty
38001679db9a9318689f17b3ea4f69dbfc66a4a0583Glenn Kasten#endif
38101679db9a9318689f17b3ea4f69dbfc66a4a0583Glenn Kasten
382b52bc98b576a9b56e82eca435849bd55e54b6bc1Glenn Kasten#ifndef ANDROID
383d2a7f0d6883a6d3835642e7b282f05ed1c54fe63Glenn Kastenextern void *sync_start(void *arg);
384b52bc98b576a9b56e82eca435849bd55e54b6bc1Glenn Kasten#endif
385d2a7f0d6883a6d3835642e7b282f05ed1c54fe63Glenn Kastenextern SLresult err_to_result(int err);
3867245a5b0889fec8996e3a9d270e551cc1bf940abGlenn Kasten
3877245a5b0889fec8996e3a9d270e551cc1bf940abGlenn Kasten#ifdef __GNUC__
388d07ed7df4ec9338f97f12627690d58ed9b34f25bGlenn Kasten#define ctz __builtin_ctz
3897245a5b0889fec8996e3a9d270e551cc1bf940abGlenn Kasten#else
3907245a5b0889fec8996e3a9d270e551cc1bf940abGlenn Kastenextern unsigned ctz(unsigned);
3917245a5b0889fec8996e3a9d270e551cc1bf940abGlenn Kasten#endif
39240d1c40832a448e23d0bb37512aee53222575c2eGlenn Kastenextern const char * const interface_names[MPH_MAX];
393e5bf0d2c9531a7064eb3ddcafaf93ac1b0974037Glenn Kasten#include "platform.h"
3947b726bdcd996f1cab3a584c04ce1afc07bc8fbe7Glenn Kasten#include "attr.h"
3957b726bdcd996f1cab3a584c04ce1afc07bc8fbe7Glenn Kasten#include "handlers.h"
396cafa51fdd8b3f29ebaa0682070100825a9cce2a8Glenn Kasten#include "trace.h"
3974b65ef9efdf5aba01bea89d8cdd64f500560a28dGlenn Kasten
3984b65ef9efdf5aba01bea89d8cdd64f500560a28dGlenn Kasten#ifdef USE_SNDFILE
3994b65ef9efdf5aba01bea89d8cdd64f500560a28dGlenn Kastenextern void audioPlayerTransportUpdate(CAudioPlayer *audioPlayer);
4004b65ef9efdf5aba01bea89d8cdd64f500560a28dGlenn Kasten#endif
401e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten
402e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kastenextern SLresult IBufferQueue_Enqueue(SLBufferQueueItf self, const void *pBuffer, SLuint32 size);
403e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kastenextern SLresult IBufferQueue_Clear(SLBufferQueueItf self);
404e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kastenextern SLresult IBufferQueue_RegisterCallback(SLBufferQueueItf self,
405e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten    slBufferQueueCallback callback, void *pContext);
406e5d006b298ce7683d66f7ec86136403cf5fb20d6Glenn Kasten
407bcc5c7225e3b7a1dbf2e9e830987f69167acf06fGlenn Kastenextern bool IsInterfaceInitialized(IObject *thiz, unsigned MPH);
408928ea4ffff40c82987cfb1ac9e3095fdc6968709Glenn Kastenextern SLresult AcquireStrongRef(IObject *object, SLuint32 expectedObjectID);
409928ea4ffff40c82987cfb1ac9e3095fdc6968709Glenn Kastenextern void ReleaseStrongRef(IObject *object);
410928ea4ffff40c82987cfb1ac9e3095fdc6968709Glenn Kastenextern void ReleaseStrongRefAndUnlockExclusive(IObject *object);
411f51dba65751107c930759938775b75531ec1f330Glenn Kasten
412f51dba65751107c930759938775b75531ec1f330Glenn Kastenextern COutputMix *CAudioPlayer_GetOutputMix(CAudioPlayer *audioPlayer);
413b0ab2dee391dd2cb257faeaba252ee6ecccc5f03Glenn Kastenextern SLresult IEngineCapabilities_QueryLEDCapabilities(SLEngineCapabilitiesItf self,
414b0ab2dee391dd2cb257faeaba252ee6ecccc5f03Glenn Kasten    SLuint32 *pIndex, SLuint32 *pLEDDeviceID, SLLEDDescriptor *pDescriptor);
415b0ab2dee391dd2cb257faeaba252ee6ecccc5f03Glenn Kastenextern SLresult IEngineCapabilities_QueryVibraCapabilities(SLEngineCapabilitiesItf self,
416b0ab2dee391dd2cb257faeaba252ee6ecccc5f03Glenn Kasten    SLuint32 *pIndex, SLuint32 *pVibraDeviceID, SLVibraDescriptor *pDescriptor);
4178db0b106cdce5f5216b1535492de7930ad738aedGlenn Kasten
4188db0b106cdce5f5216b1535492de7930ad738aedGlenn Kastenextern CEngine *theOneTrueEngine;
4198db0b106cdce5f5216b1535492de7930ad738aedGlenn Kastenextern pthread_mutex_t theOneTrueMutex;
4201d081e49a10543018e1ae33792bd3d30504719baGlenn Kastenextern unsigned theOneTrueRefCount;
421527f8ca99f2938d6569fc25dcf3256985a54dec6Glenn Kasten
422527f8ca99f2938d6569fc25dcf3256985a54dec6Glenn Kastenextern LI_API SLresult liCreateEngine(SLObjectItf *pEngine, SLuint32 numOptions,
423527f8ca99f2938d6569fc25dcf3256985a54dec6Glenn Kasten    const SLEngineOption *pEngineOptions, SLuint32 numInterfaces,
424527f8ca99f2938d6569fc25dcf3256985a54dec6Glenn Kasten    const SLInterfaceID *pInterfaceIds, const SLboolean *pInterfaceRequired,
425527f8ca99f2938d6569fc25dcf3256985a54dec6Glenn Kasten    const ClassTable *pCEngine_class);
426527f8ca99f2938d6569fc25dcf3256985a54dec6Glenn Kastenextern LI_API SLresult liQueryNumSupportedInterfaces(SLuint32 *pNumSupportedInterfaces,
427527f8ca99f2938d6569fc25dcf3256985a54dec6Glenn Kasten        const ClassTable *clazz);
428527f8ca99f2938d6569fc25dcf3256985a54dec6Glenn Kastenextern LI_API SLresult liQuerySupportedInterfaces(SLuint32 index, SLInterfaceID *pInterfaceId,
429527f8ca99f2938d6569fc25dcf3256985a54dec6Glenn Kasten        const ClassTable *clazz);
430377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten
431377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten// The EnqueueAsyncCallback macros provide a safe way to asynchronously call an application-level
432377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten// callback handler that is permitted to do almost anything, including block.  This is intended
433377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten// primarily for "notification" callbacks such as play head progress.  Do not use for callbacks
434377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten// which must be synchronous, such as buffer queue completions.  The enqueue may fail if
435377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten// the callback queue is full.  This almost always indicates an application error such as blocking
436377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten// for an excessive time within a callback handler or requesting too frequent callbacks.  The
437377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten// recommended recovery is to either retry later, or log a warning or error as appropriate.
438377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten// If the callback absolutely must be called, then you should be calling it directly instead.
439377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten// Example usage:
440377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten//  CAudioPlayer *ap;
441377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten//  SLresult result = EnqueueAsyncCallback_ppi(ap, playCallback, &ap->mPlay.mItf, playContext,
442377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten//       SL_PLAYEVENT_HEADATEND);
443377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten//  if (SL_RESULT_SUCCESS != result) {
444377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten//    LOGW("Callback %p(%p, %p, SL_PLAYEVENT_HEADATEND) dropped", playCallback, &ap->mPlay.mItf,
445377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten//        playContext);
446377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten//  }
447377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten// which replaces:
448377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten//  (*playCallback)(&ap->mPlay.mItf, playContext, SL_PLAYEVENT_HEADATEND);
449377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten#define EnqueueAsyncCallback_ppi(object, handler, p1, p2, i1) \
450377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten        ThreadPool_add_ppi(&(object)->mObject.mEngine->mThreadPool, \
451377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten            (ClosureHandler_ppi) (handler), (p1), (p2), (i1))
452377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten#define EnqueueAsyncCallback_ppii(object, handler, p1, p2, i1, i2) \
453377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten        ThreadPool_add_ppii(&(object)->mObject.mEngine->mThreadPool, \
454377aa54ce344adcbc8bac731c6db9e7e39b432c5Glenn Kasten            (ClosureHandler_ppii) (handler), (p1), (p2), (i1), (i2))
45585133c817f6f387cd7d072988a8818f18bb53702Jean-Michel Trivi#define EnqueueAsyncCallback_piipp(object, handler, p1, i1, i2, p2, p3) \
45685133c817f6f387cd7d072988a8818f18bb53702Jean-Michel Trivi        ThreadPool_add_piipp(&(object)->mObject.mEngine->mThreadPool, \
45785133c817f6f387cd7d072988a8818f18bb53702Jean-Michel Trivi            (ClosureHandler_piipp) (handler), (p1), (i1), (i2), (p2), (p3))
458a60dbf554549d10780f473b6e1373aa07aec3a28Glenn Kasten
459a60dbf554549d10780f473b6e1373aa07aec3a28Glenn Kasten#define SL_PREFETCHEVENT_NONE ((SLuint32) 0)    // placeholder for non-existent SL_PREFETCHEVENT_*
460