summaryrefslogtreecommitdiffstats
path: root/services/audioflinger/AudioMixer.h
diff options
context:
space:
mode:
authorGlenn Kasten <gkasten@google.com>2012-03-21 08:19:04 -0700
committerAndroid (Google) Code Review <android-gerrit@google.com>2012-03-21 08:19:04 -0700
commitccf89b54f973f11082150d02ed957f7e967fbc8b (patch)
treeb3446119a9b6c03dcca98d1d9ee31a83adb8acad /services/audioflinger/AudioMixer.h
parent63c1faa8dea7feb90255d31ef2a133d8f2818844 (diff)
parent5c94b6c7689a335e26a86e8a0d04b56dc627738e (diff)
downloadframeworks_av-ccf89b54f973f11082150d02ed957f7e967fbc8b.zip
frameworks_av-ccf89b54f973f11082150d02ed957f7e967fbc8b.tar.gz
frameworks_av-ccf89b54f973f11082150d02ed957f7e967fbc8b.tar.bz2
Merge "AudioMixer can be configured for fewer max tracks"
Diffstat (limited to 'services/audioflinger/AudioMixer.h')
-rw-r--r--services/audioflinger/AudioMixer.h9
1 files changed, 8 insertions, 1 deletions
diff --git a/services/audioflinger/AudioMixer.h b/services/audioflinger/AudioMixer.h
index ab80a9a..856450c 100644
--- a/services/audioflinger/AudioMixer.h
+++ b/services/audioflinger/AudioMixer.h
@@ -31,7 +31,8 @@ namespace android {
class AudioMixer
{
public:
- AudioMixer(size_t frameCount, uint32_t sampleRate);
+ AudioMixer(size_t frameCount, uint32_t sampleRate,
+ uint32_t maxNumTracks = MAX_NUM_TRACKS);
/*virtual*/ ~AudioMixer(); // non-virtual saves a v-table, restore if sub-classed
@@ -189,11 +190,17 @@ private:
int32_t *outputTemp;
int32_t *resampleTemp;
int32_t reserved[2];
+ // FIXME allocate dynamically to save some memory when maxNumTracks < MAX_NUM_TRACKS
track_t tracks[MAX_NUM_TRACKS]; __attribute__((aligned(32)));
};
// bitmask of allocated track names, where bit 0 corresponds to TRACK0 etc.
uint32_t mTrackNames;
+
+ // bitmask of configured track names; ~0 if maxNumTracks == MAX_NUM_TRACKS,
+ // but will have fewer bits set if maxNumTracks < MAX_NUM_TRACKS
+ const uint32_t mConfiguredNames;
+
const uint32_t mSampleRate;
state_t mState __attribute__((aligned(32)));