diff options
author | Eric Laurent <elaurent@google.com> | 2014-05-16 23:37:50 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2014-05-16 23:37:50 +0000 |
commit | c5baa188068bac4c71ffdca62f09134a59f87454 (patch) | |
tree | 4c02abc86dc61447c92acd40efb43afbe82abfb5 /core | |
parent | f2eba13932d0bdd90fefa6cd9a94e59c209a0866 (diff) | |
parent | bc11a696f6856624de532a6830d5db9dbbe2384c (diff) | |
download | frameworks_base-c5baa188068bac4c71ffdca62f09134a59f87454.zip frameworks_base-c5baa188068bac4c71ffdca62f09134a59f87454.tar.gz frameworks_base-c5baa188068bac4c71ffdca62f09134a59f87454.tar.bz2 |
Merge "AudioSystem: native to JAVA status translation"
Diffstat (limited to 'core')
-rw-r--r-- | core/jni/android_media_AudioErrors.h | 56 | ||||
-rw-r--r-- | core/jni/android_media_AudioRecord.cpp | 46 | ||||
-rw-r--r-- | core/jni/android_media_AudioTrack.cpp | 74 |
3 files changed, 99 insertions, 77 deletions
diff --git a/core/jni/android_media_AudioErrors.h b/core/jni/android_media_AudioErrors.h new file mode 100644 index 0000000..4907830 --- /dev/null +++ b/core/jni/android_media_AudioErrors.h @@ -0,0 +1,56 @@ +/* + * Copyright (C) 2014 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef ANDROID_MEDIA_AUDIOERRORS_H +#define ANDROID_MEDIA_AUDIOERRORS_H + +#include <utils/Errors.h> + +namespace android { +// status codes used by JAVA APIs. Translation from native error codes is done by +// nativeToJavaStatus() +// must be kept in sync with values in +// frameworks/base/media/java/android/media/AudioSystem.java. +enum { + AUDIO_JAVA_SUCCESS = 0, + AUDIO_JAVA_ERROR = -1, + AUDIO_JAVA_BAD_VALUE = -2, + AUDIO_JAVA_INVALID_OPERATION = -3, + AUDIO_JAVA_PERMISSION_DENIED = -4, + AUDIO_JAVA_NO_INIT = -5, + AUDIO_JAVA_DEAD_OBJECT = -6, +}; + +static inline jint nativeToJavaStatus(status_t status) { + switch (status) { + case NO_ERROR: + return AUDIO_JAVA_SUCCESS; + case BAD_VALUE: + return AUDIO_JAVA_BAD_VALUE; + case INVALID_OPERATION: + return AUDIO_JAVA_INVALID_OPERATION; + case PERMISSION_DENIED: + return AUDIO_JAVA_PERMISSION_DENIED; + case NO_INIT: + return AUDIO_JAVA_NO_INIT; + case DEAD_OBJECT: + return AUDIO_JAVA_DEAD_OBJECT; + default: + return AUDIO_JAVA_ERROR; + } +} +}; // namespace android +#endif // ANDROID_MEDIA_AUDIOERRORS_H diff --git a/core/jni/android_media_AudioRecord.cpp b/core/jni/android_media_AudioRecord.cpp index 09bdc61..a54eba1 100644 --- a/core/jni/android_media_AudioRecord.cpp +++ b/core/jni/android_media_AudioRecord.cpp @@ -27,6 +27,7 @@ #include <media/AudioRecord.h> #include "android_media_AudioFormat.h" +#include "android_media_AudioErrors.h" // ---------------------------------------------------------------------------- @@ -55,29 +56,12 @@ static SortedVector <audiorecord_callback_cookie *> sAudioRecordCallBackCookies; // ---------------------------------------------------------------------------- -#define AUDIORECORD_SUCCESS 0 -#define AUDIORECORD_ERROR -1 -#define AUDIORECORD_ERROR_BAD_VALUE -2 -#define AUDIORECORD_ERROR_INVALID_OPERATION -3 #define AUDIORECORD_ERROR_SETUP_ZEROFRAMECOUNT -16 #define AUDIORECORD_ERROR_SETUP_INVALIDCHANNELMASK -17 #define AUDIORECORD_ERROR_SETUP_INVALIDFORMAT -18 #define AUDIORECORD_ERROR_SETUP_INVALIDSOURCE -19 #define AUDIORECORD_ERROR_SETUP_NATIVEINITFAILED -20 -jint android_media_translateRecorderErrorCode(int code) { - switch (code) { - case NO_ERROR: - return AUDIORECORD_SUCCESS; - case BAD_VALUE: - return AUDIORECORD_ERROR_BAD_VALUE; - case INVALID_OPERATION: - return AUDIORECORD_ERROR_INVALID_OPERATION; - default: - return AUDIORECORD_ERROR; - } -} - // ---------------------------------------------------------------------------- static void recorderCallback(int event, void* user, void *info) { @@ -197,13 +181,13 @@ android_media_AudioRecord_setup(JNIEnv *env, jobject thiz, jobject weak_this, if (jSession == NULL) { ALOGE("Error creating AudioRecord: invalid session ID pointer"); - return (jint) AUDIORECORD_ERROR; + return (jint) AUDIO_JAVA_ERROR; } jint* nSession = (jint *) env->GetPrimitiveArrayCritical(jSession, NULL); if (nSession == NULL) { ALOGE("Error creating AudioRecord: Error retrieving session id pointer"); - return (jint) AUDIORECORD_ERROR; + return (jint) AUDIO_JAVA_ERROR; } int sessionId = nSession[0]; env->ReleasePrimitiveArrayCritical(jSession, nSession, 0); @@ -259,7 +243,7 @@ android_media_AudioRecord_setup(JNIEnv *env, jobject thiz, jobject weak_this, // of the Java object (in mNativeCallbackCookie) so we can free the memory in finalize() env->SetLongField(thiz, javaAudioRecordFields.nativeCallbackCookie, (jlong)lpCallbackData); - return (jint) AUDIORECORD_SUCCESS; + return (jint) AUDIO_JAVA_SUCCESS; // failure: native_init_failure: @@ -280,10 +264,10 @@ android_media_AudioRecord_start(JNIEnv *env, jobject thiz, jint event, jint trig sp<AudioRecord> lpRecorder = getAudioRecord(env, thiz); if (lpRecorder == NULL ) { jniThrowException(env, "java/lang/IllegalStateException", NULL); - return (jint) AUDIORECORD_ERROR; + return (jint) AUDIO_JAVA_ERROR; } - return (jint) android_media_translateRecorderErrorCode( + return nativeToJavaStatus( lpRecorder->start((AudioSystem::sync_event_t)event, triggerSession)); } @@ -383,7 +367,7 @@ static jint android_media_AudioRecord_readInByteArray(JNIEnv *env, jobject thiz env->ReleaseByteArrayElements(javaAudioData, recordBuff, 0); if (readSize < 0) { - readSize = AUDIORECORD_ERROR_INVALID_OPERATION; + readSize = (jint)AUDIO_JAVA_INVALID_OPERATION; } return (jint) readSize; } @@ -428,7 +412,7 @@ static jint android_media_AudioRecord_readInShortArray(JNIEnv *env, jobject thi env->ReleaseShortArrayElements(javaAudioData, recordBuff, 0); if (readSize < 0) { - readSize = AUDIORECORD_ERROR_INVALID_OPERATION; + readSize = (jint)AUDIO_JAVA_INVALID_OPERATION; } else { readSize /= sizeof(short); } @@ -461,7 +445,7 @@ static jint android_media_AudioRecord_readInDirectBuffer(JNIEnv *env, jobject t ssize_t readSize = lpRecorder->read(nativeFromJavaBuf, capacity < sizeInBytes ? capacity : sizeInBytes); if (readSize < 0) { - readSize = AUDIORECORD_ERROR_INVALID_OPERATION; + readSize = (jint)AUDIO_JAVA_INVALID_OPERATION; } return (jint)readSize; } @@ -475,9 +459,9 @@ static jint android_media_AudioRecord_set_marker_pos(JNIEnv *env, jobject thiz, if (lpRecorder == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioRecord pointer for setMarkerPosition()"); - return AUDIORECORD_ERROR; + return (jint)AUDIO_JAVA_ERROR; } - return android_media_translateRecorderErrorCode( lpRecorder->setMarkerPosition(markerPos) ); + return nativeToJavaStatus( lpRecorder->setMarkerPosition(markerPos) ); } @@ -490,7 +474,7 @@ static jint android_media_AudioRecord_get_marker_pos(JNIEnv *env, jobject thiz) if (lpRecorder == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioRecord pointer for getMarkerPosition()"); - return AUDIORECORD_ERROR; + return (jint)AUDIO_JAVA_ERROR; } lpRecorder->getMarkerPosition(&markerPos); return (jint)markerPos; @@ -506,9 +490,9 @@ static jint android_media_AudioRecord_set_pos_update_period(JNIEnv *env, jobjec if (lpRecorder == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioRecord pointer for setPositionUpdatePeriod()"); - return AUDIORECORD_ERROR; + return (jint)AUDIO_JAVA_ERROR; } - return android_media_translateRecorderErrorCode( lpRecorder->setPositionUpdatePeriod(period) ); + return nativeToJavaStatus( lpRecorder->setPositionUpdatePeriod(period) ); } @@ -521,7 +505,7 @@ static jint android_media_AudioRecord_get_pos_update_period(JNIEnv *env, jobjec if (lpRecorder == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioRecord pointer for getPositionUpdatePeriod()"); - return AUDIORECORD_ERROR; + return (jint)AUDIO_JAVA_ERROR; } lpRecorder->getPositionUpdatePeriod(&period); return (jint)period; diff --git a/core/jni/android_media_AudioTrack.cpp b/core/jni/android_media_AudioTrack.cpp index 5fcb5f3..e548e91 100644 --- a/core/jni/android_media_AudioTrack.cpp +++ b/core/jni/android_media_AudioTrack.cpp @@ -32,6 +32,7 @@ #include <binder/MemoryBase.h> #include "android_media_AudioFormat.h" +#include "android_media_AudioErrors.h" // ---------------------------------------------------------------------------- @@ -94,31 +95,12 @@ static SortedVector <audiotrack_callback_cookie *> sAudioTrackCallBackCookies; // ---------------------------------------------------------------------------- #define DEFAULT_OUTPUT_SAMPLE_RATE 44100 -#define AUDIOTRACK_SUCCESS 0 -#define AUDIOTRACK_ERROR -1 -#define AUDIOTRACK_ERROR_BAD_VALUE -2 -#define AUDIOTRACK_ERROR_INVALID_OPERATION -3 #define AUDIOTRACK_ERROR_SETUP_AUDIOSYSTEM -16 #define AUDIOTRACK_ERROR_SETUP_INVALIDCHANNELMASK -17 #define AUDIOTRACK_ERROR_SETUP_INVALIDFORMAT -18 #define AUDIOTRACK_ERROR_SETUP_INVALIDSTREAMTYPE -19 #define AUDIOTRACK_ERROR_SETUP_NATIVEINITFAILED -20 - -jint android_media_translateErrorCode(int code) { - switch (code) { - case NO_ERROR: - return AUDIOTRACK_SUCCESS; - case BAD_VALUE: - return AUDIOTRACK_ERROR_BAD_VALUE; - case INVALID_OPERATION: - return AUDIOTRACK_ERROR_INVALID_OPERATION; - default: - return AUDIOTRACK_ERROR; - } -} - - // ---------------------------------------------------------------------------- static void audioCallback(int event, void* user, void *info) { @@ -249,13 +231,13 @@ android_media_AudioTrack_setup(JNIEnv *env, jobject thiz, jobject weak_this, if (jSession == NULL) { ALOGE("Error creating AudioTrack: invalid session ID pointer"); - return (jint) AUDIOTRACK_ERROR; + return (jint) AUDIO_JAVA_ERROR; } jint* nSession = (jint *) env->GetPrimitiveArrayCritical(jSession, NULL); if (nSession == NULL) { ALOGE("Error creating AudioTrack: Error retrieving session id pointer"); - return (jint) AUDIOTRACK_ERROR; + return (jint) AUDIO_JAVA_ERROR; } int sessionId = nSession[0]; env->ReleasePrimitiveArrayCritical(jSession, nSession, 0); @@ -346,7 +328,7 @@ android_media_AudioTrack_setup(JNIEnv *env, jobject thiz, jobject weak_this, //ALOGV("storing lpJniStorage: %x\n", (long)lpJniStorage); env->SetLongField(thiz, javaAudioTrackFields.jniData, (jlong)lpJniStorage); - return (jint) AUDIOTRACK_SUCCESS; + return (jint) AUDIO_JAVA_SUCCESS; // failures: native_init_failure: @@ -596,7 +578,7 @@ static jint android_media_AudioTrack_write_native_bytes(JNIEnv *env, jobject th ScopedBytesRO bytes(env, javaBytes); if (bytes.get() == NULL) { ALOGE("Error retrieving source of audio data to play, can't play"); - return AUDIOTRACK_ERROR_BAD_VALUE; + return (jint)AUDIO_JAVA_BAD_VALUE; } jint written = writeToTrack(lpTrack, javaAudioFormat, bytes.get(), byteOffset, @@ -695,7 +677,7 @@ static jint android_media_AudioTrack_get_native_frame_count(JNIEnv *env, jobjec if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for frameCount()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } return lpTrack->frameCount(); @@ -709,9 +691,9 @@ static jint android_media_AudioTrack_set_playback_rate(JNIEnv *env, jobject thi if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for setSampleRate()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } - return android_media_translateErrorCode(lpTrack->setSampleRate(sampleRateInHz)); + return nativeToJavaStatus(lpTrack->setSampleRate(sampleRateInHz)); } @@ -721,7 +703,7 @@ static jint android_media_AudioTrack_get_playback_rate(JNIEnv *env, jobject thi if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for getSampleRate()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } return (jint) lpTrack->getSampleRate(); } @@ -734,9 +716,9 @@ static jint android_media_AudioTrack_set_marker_pos(JNIEnv *env, jobject thiz, if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for setMarkerPosition()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } - return android_media_translateErrorCode( lpTrack->setMarkerPosition(markerPos) ); + return nativeToJavaStatus( lpTrack->setMarkerPosition(markerPos) ); } @@ -748,7 +730,7 @@ static jint android_media_AudioTrack_get_marker_pos(JNIEnv *env, jobject thiz) if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for getMarkerPosition()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } lpTrack->getMarkerPosition(&markerPos); return (jint)markerPos; @@ -762,9 +744,9 @@ static jint android_media_AudioTrack_set_pos_update_period(JNIEnv *env, jobject if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for setPositionUpdatePeriod()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } - return android_media_translateErrorCode( lpTrack->setPositionUpdatePeriod(period) ); + return nativeToJavaStatus( lpTrack->setPositionUpdatePeriod(period) ); } @@ -776,7 +758,7 @@ static jint android_media_AudioTrack_get_pos_update_period(JNIEnv *env, jobject if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for getPositionUpdatePeriod()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } lpTrack->getPositionUpdatePeriod(&period); return (jint)period; @@ -790,9 +772,9 @@ static jint android_media_AudioTrack_set_position(JNIEnv *env, jobject thiz, if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for setPosition()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } - return android_media_translateErrorCode( lpTrack->setPosition(position) ); + return nativeToJavaStatus( lpTrack->setPosition(position) ); } @@ -804,7 +786,7 @@ static jint android_media_AudioTrack_get_position(JNIEnv *env, jobject thiz) { if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for getPosition()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } lpTrack->getPosition(&position); return (jint)position; @@ -818,7 +800,7 @@ static jint android_media_AudioTrack_get_latency(JNIEnv *env, jobject thiz) { if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for latency()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } return (jint)lpTrack->latency(); } @@ -830,7 +812,7 @@ static jint android_media_AudioTrack_get_timestamp(JNIEnv *env, jobject thiz, j if (lpTrack == NULL) { ALOGE("Unable to retrieve AudioTrack pointer for getTimestamp()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } AudioTimestamp timestamp; status_t status = lpTrack->getTimestamp(timestamp); @@ -838,13 +820,13 @@ static jint android_media_AudioTrack_get_timestamp(JNIEnv *env, jobject thiz, j jlong* nTimestamp = (jlong *) env->GetPrimitiveArrayCritical(jTimestamp, NULL); if (nTimestamp == NULL) { ALOGE("Unable to get array for getTimestamp()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } nTimestamp[0] = (jlong) timestamp.mPosition; nTimestamp[1] = (jlong) ((timestamp.mTime.tv_sec * 1000000000LL) + timestamp.mTime.tv_nsec); env->ReleasePrimitiveArrayCritical(jTimestamp, nTimestamp, 0); } - return (jint) android_media_translateErrorCode(status); + return (jint) nativeToJavaStatus(status); } @@ -855,9 +837,9 @@ static jint android_media_AudioTrack_set_loop(JNIEnv *env, jobject thiz, if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for setLoop()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } - return android_media_translateErrorCode( lpTrack->setLoop(loopStart, loopEnd, loopCount) ); + return nativeToJavaStatus( lpTrack->setLoop(loopStart, loopEnd, loopCount) ); } @@ -867,9 +849,9 @@ static jint android_media_AudioTrack_reload(JNIEnv *env, jobject thiz) { if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for reload()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } - return android_media_translateErrorCode( lpTrack->reload() ); + return nativeToJavaStatus( lpTrack->reload() ); } @@ -952,9 +934,9 @@ static jint android_media_AudioTrack_attachAuxEffect(JNIEnv *env, jobject thiz, if (lpTrack == NULL) { jniThrowException(env, "java/lang/IllegalStateException", "Unable to retrieve AudioTrack pointer for attachAuxEffect()"); - return AUDIOTRACK_ERROR; + return (jint)AUDIO_JAVA_ERROR; } - return android_media_translateErrorCode( lpTrack->attachAuxEffect(effectId) ); + return nativeToJavaStatus( lpTrack->attachAuxEffect(effectId) ); } // ---------------------------------------------------------------------------- |