AudioTrackShared.h revision 0c9d26d187017f7fb028ab52a0fbc6395142faa4
189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project/*
289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project
389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *
489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * you may not use this file except in compliance with the License.
689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * You may obtain a copy of the License at
789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *
889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *
1089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
1189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
1289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * See the License for the specific language governing permissions and
1489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * limitations under the License.
1589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project */
1689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
1789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#ifndef ANDROID_AUDIO_TRACK_SHARED_H
1889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#define ANDROID_AUDIO_TRACK_SHARED_H
1989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
2089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <stdint.h>
2189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <sys/types.h>
2289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
2389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <utils/threads.h>
2489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
2589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectnamespace android {
2689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
2789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// ----------------------------------------------------------------------------
2889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
2989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// Maximum cumulated timeout milliseconds before restarting audioflinger thread
3089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#define MAX_STARTUP_TIMEOUT_MS  3000    // Longer timeout period at startup to cope with A2DP init time
3189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#define MAX_RUN_TIMEOUT_MS      1000
3289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#define WAIT_PERIOD_MS          10
331703cdfee717b1b312bf8979816a9e2f16a82e5dEric Laurent#define RESTORE_TIMEOUT_MS      5000    // Maximum waiting time for a track to be restored
3489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
35d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent#define CBLK_UNDERRUN_MSK       0x0001
36d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent#define CBLK_UNDERRUN_ON        0x0001  // underrun (out) or overrrun (in) indication
37d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent#define CBLK_UNDERRUN_OFF       0x0000  // no underrun
38d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent#define CBLK_DIRECTION_MSK      0x0002
39d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent#define CBLK_DIRECTION_OUT      0x0002  // this cblk is for an AudioTrack
40d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent#define CBLK_DIRECTION_IN       0x0000  // this cblk is for an AudioRecord
41d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent#define CBLK_FORCEREADY_MSK     0x0004
42d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent#define CBLK_FORCEREADY_ON      0x0004  // track is considered ready immediately by AudioFlinger
43d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent#define CBLK_FORCEREADY_OFF     0x0000  // track is ready when buffer full
44d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent#define CBLK_INVALID_MSK        0x0008
4544d9848d6656777a18019223e0d35f2fcc67719aEric Laurent#define CBLK_INVALID_ON         0x0008  // track buffer is invalidated by AudioFlinger:
4644d9848d6656777a18019223e0d35f2fcc67719aEric Laurent#define CBLK_INVALID_OFF        0x0000  // must be re-created
4744d9848d6656777a18019223e0d35f2fcc67719aEric Laurent#define CBLK_DISABLED_MSK       0x0010
4844d9848d6656777a18019223e0d35f2fcc67719aEric Laurent#define CBLK_DISABLED_ON        0x0010  // track disabled by AudioFlinger due to underrun:
4944d9848d6656777a18019223e0d35f2fcc67719aEric Laurent#define CBLK_DISABLED_OFF       0x0000  // must be re-started
501703cdfee717b1b312bf8979816a9e2f16a82e5dEric Laurent#define CBLK_RESTORING_MSK      0x0020
511703cdfee717b1b312bf8979816a9e2f16a82e5dEric Laurent#define CBLK_RESTORING_ON       0x0020  // track is being restored after invalidation
521703cdfee717b1b312bf8979816a9e2f16a82e5dEric Laurent#define CBLK_RESTORING_OFF      0x0000  // by AudioFlinger
531703cdfee717b1b312bf8979816a9e2f16a82e5dEric Laurent#define CBLK_RESTORED_MSK       0x0040
541703cdfee717b1b312bf8979816a9e2f16a82e5dEric Laurent#define CBLK_RESTORED_ON        0x0040  // track has been restored after invalidation
551703cdfee717b1b312bf8979816a9e2f16a82e5dEric Laurent#define CBLK_RESTORED_OFF       0x0040  // by AudioFlinger
563acbd053c842e76e1a40fc8a0bf62de87eebf00fGlenn Kasten#define CBLK_FAST               0x0080  // AudioFlinger successfully created a fast track
5789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
581a0ae5be3d1273cba12584b33830d859510fbf82Glenn Kasten// Important: do not add any virtual methods, including ~
5989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstruct audio_track_cblk_t
6089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
6189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
6289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    // The data members are grouped so that members accessed frequently and in the same context
6389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    // are in the same line of data cache.
64362c4e697d8e9c034e964ac7b40227e054491547Glenn Kasten                Mutex       lock;           // sizeof(int)
65362c4e697d8e9c034e964ac7b40227e054491547Glenn Kasten                Condition   cv;             // sizeof(int)
6699e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten
6799e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                // next 4 are offsets within "buffers"
6889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    volatile    uint32_t    user;
6989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    volatile    uint32_t    server;
7089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                uint32_t    userBase;
7189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                uint32_t    serverBase;
7299e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten
7399e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                // if there is a shared buffer, "buffers" is the value of pointer() for the shared
7499e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                // buffer, otherwise "buffers" points immediately after the control block
75d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent                void*       buffers;
76d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent                uint32_t    frameCount;
7799e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten
78d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent                // Cache line boundary
7999e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten
80d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent                uint32_t    loopStart;
8199e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                uint32_t    loopEnd;        // read-only for server, read/write for client
8299e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                int         loopCount;      // read/write for client
83b1cf75c4935001f61057989ee3cf27bbf09ecd9cGlenn Kasten
84b1cf75c4935001f61057989ee3cf27bbf09ecd9cGlenn Kasten                // Channel volumes are fixed point U4.12, so 0x1000 means 1.0.
85b1cf75c4935001f61057989ee3cf27bbf09ecd9cGlenn Kasten                // Left channel is in [0:15], right channel is in [16:31].
86b1cf75c4935001f61057989ee3cf27bbf09ecd9cGlenn Kasten                // Always read and write the combined pair atomically.
87b1cf75c4935001f61057989ee3cf27bbf09ecd9cGlenn Kasten                // For AudioTrack only, not used by AudioRecord.
8883d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kastenprivate:
8983d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten                uint32_t    mVolumeLR;
9083d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kastenpublic:
91b1cf75c4935001f61057989ee3cf27bbf09ecd9cGlenn Kasten
92573266210fb2b2e7d86fbd46d0dfe16763611d91Eric Laurent                uint32_t    sampleRate;
9399e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten
94c2f1f07084818942352c6bbfb36af9b6b330eb4eEric Laurent                // NOTE: audio_track_cblk_t::frameSize is not equal to AudioTrack::frameSize() for
95c2f1f07084818942352c6bbfb36af9b6b330eb4eEric Laurent                // 8 bit PCM data: in this case,  mCblk->frameSize is based on a sample size of
96c2f1f07084818942352c6bbfb36af9b6b330eb4eEric Laurent                // 16 bit because data is converted to 16 bit before being stored in buffer
97d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent
9899e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                // read-only for client, server writes once at initialization and is then read-only
99b9980659501d0428d65d8292f3c32da69d37fbd2Glenn Kasten                uint8_t     frameSize;       // would normally be size_t, but 8 bits is plenty
1000c9d26d187017f7fb028ab52a0fbc6395142faa4Glenn Kasten                uint8_t     mName;           // normal tracks: track name, fast tracks: track index
10199e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten
10299e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                // used by client only
10389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                uint16_t    bufferTimeoutMs; // Maximum cumulated timeout before restarting audioflinger
104c2f1f07084818942352c6bbfb36af9b6b330eb4eEric Laurent
10599e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                uint16_t    waitTimeMs;      // Cumulated wait time, used by client only
10605632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kastenprivate:
10799e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                // client write-only, server read-only
10805632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten                uint16_t    mSendLevel;      // Fixed point U4.12 so 0x1000 means 1.0
10905632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kastenpublic:
11038ccae2c0324daa305f3fe77d25fdf5edec0b0e1Eric Laurent    volatile    int32_t     flags;
11138ccae2c0324daa305f3fe77d25fdf5edec0b0e1Eric Laurent
112d1b449aad6c087a69f5ec66b7facb2845b73f1cbEric Laurent                // Cache line boundary (32 bytes)
1130d255b2d9061ba31f13ada3fc0f7e51916407176Jean-Michel Trivi
11499e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                // Since the control block is always located in shared memory, this constructor
11599e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                // is only used for placement new().  It is never used for regular new() or stack.
11689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                            audio_track_cblk_t();
11799e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                uint32_t    stepUser(uint32_t frameCount);      // called by client only, where
11899e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                // client includes regular AudioTrack and AudioFlinger::PlaybackThread::OutputTrack
11999e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                bool        stepServer(uint32_t frameCount);    // called by server only
12089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                void*       buffer(uint32_t offset) const;
12189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                uint32_t    framesAvailable();
12289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                uint32_t    framesAvailable_l();
12399e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten                uint32_t    framesReady();                      // called by server only
12438ccae2c0324daa305f3fe77d25fdf5edec0b0e1Eric Laurent                bool        tryLock();
12505632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten
12605632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten                // No barriers on the following operations, so the ordering of loads/stores
12705632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten                // with respect to other parameters is UNPREDICTABLE. That's considered safe.
12805632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten
12905632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten                // for AudioTrack client only, caller must limit to 0.0 <= sendLevel <= 1.0
13005632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten                void        setSendLevel(float sendLevel) {
13105632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten                    mSendLevel = uint16_t(sendLevel * 0x1000);
13205632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten                }
13305632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten
13405632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten                // for AudioFlinger only; the return value must be validated by the caller
13505632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten                uint16_t    getSendLevel_U4_12() const {
13605632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten                    return mSendLevel;
13705632a5fa4b88ca474294887fc92a9fcdf0e2352Glenn Kasten                }
13883d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten
13983d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten                // for AudioTrack client only, caller must limit to 0 <= volumeLR <= 0x10001000
14083d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten                void        setVolumeLR(uint32_t volumeLR) {
14183d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten                    mVolumeLR = volumeLR;
14283d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten                }
14383d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten
14483d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten                // for AudioFlinger only; the return value must be validated by the caller
14583d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten                uint32_t    getVolumeLR() const {
14683d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten                    return mVolumeLR;
14783d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten                }
14883d86538c4c479a9225c75ab27938e8f05abb9c8Glenn Kasten
14989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project};
15089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
15189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
15289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// ----------------------------------------------------------------------------
15389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
15489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}; // namespace android
15589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
15689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#endif // ANDROID_AUDIO_TRACK_SHARED_H
157