summaryrefslogtreecommitdiffstats
path: root/media/libmedia/IAudioPolicyService.cpp
diff options
context:
space:
mode:
authorEric Laurent <elaurent@google.com>2014-11-05 12:15:36 -0800
committerEric Laurent <elaurent@google.com>2014-11-05 12:33:59 -0800
commit74adca9ad30b7f8a70d40c5237bade0d16c4ea58 (patch)
tree13e642689e945e69b76ac095a6bec978debf4084 /media/libmedia/IAudioPolicyService.cpp
parented1e55c5276a1c031e9b2f016387c7d2fe7bc47f (diff)
downloadframeworks_av-74adca9ad30b7f8a70d40c5237bade0d16c4ea58.zip
frameworks_av-74adca9ad30b7f8a70d40c5237bade0d16c4ea58.tar.gz
frameworks_av-74adca9ad30b7f8a70d40c5237bade0d16c4ea58.tar.bz2
IAudioPolicyService: bound array size in queryDefaultPreProcessing
Bug: 18226810. Change-Id: Ib8e2bfe835a8681aac50bf23161db14e50c9a124
Diffstat (limited to 'media/libmedia/IAudioPolicyService.cpp')
-rw-r--r--media/libmedia/IAudioPolicyService.cpp9
1 files changed, 6 insertions, 3 deletions
diff --git a/media/libmedia/IAudioPolicyService.cpp b/media/libmedia/IAudioPolicyService.cpp
index 256cb3f..180f5fb 100644
--- a/media/libmedia/IAudioPolicyService.cpp
+++ b/media/libmedia/IAudioPolicyService.cpp
@@ -23,6 +23,7 @@
#include <binder/Parcel.h>
+#include <media/AudioEffect.h>
#include <media/IAudioPolicyService.h>
#include <system/audio.h>
@@ -916,16 +917,18 @@ status_t BnAudioPolicyService::onTransact(
CHECK_INTERFACE(IAudioPolicyService, data, reply);
int audioSession = data.readInt32();
uint32_t count = data.readInt32();
+ if (count > AudioEffect::kMaxPreProcessing) {
+ count = AudioEffect::kMaxPreProcessing;
+ }
uint32_t retCount = count;
- effect_descriptor_t *descriptors =
- (effect_descriptor_t *)new char[count * sizeof(effect_descriptor_t)];
+ effect_descriptor_t *descriptors = new effect_descriptor_t[count];
status_t status = queryDefaultPreProcessing(audioSession, descriptors, &retCount);
reply->writeInt32(status);
if (status != NO_ERROR && status != NO_MEMORY) {
retCount = 0;
}
reply->writeInt32(retCount);
- if (retCount) {
+ if (retCount != 0) {
if (retCount < count) {
count = retCount;
}