Merge "Fix issue 2667797: [Audio Effect Framework] new base class and binder interfaces for effect control." into kraken
This commit is contained in:
56
include/media/IEffect.h
Normal file
56
include/media/IEffect.h
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2010 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_IEFFECT_H
|
||||||
|
#define ANDROID_IEFFECT_H
|
||||||
|
|
||||||
|
#include <utils/RefBase.h>
|
||||||
|
#include <binder/IInterface.h>
|
||||||
|
#include <binder/Parcel.h>
|
||||||
|
#include <binder/IMemory.h>
|
||||||
|
|
||||||
|
namespace android {
|
||||||
|
|
||||||
|
class IEffect: public IInterface
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
DECLARE_META_INTERFACE(Effect);
|
||||||
|
|
||||||
|
virtual status_t enable() = 0;
|
||||||
|
|
||||||
|
virtual status_t disable() = 0;
|
||||||
|
|
||||||
|
virtual status_t command(int cmdCode, int cmdSize, void *pCmdData, int *pReplySize, void *pReplyData) = 0;
|
||||||
|
|
||||||
|
virtual void disconnect() = 0;
|
||||||
|
|
||||||
|
virtual sp<IMemory> getCblk() const = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class BnEffect: public BnInterface<IEffect>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
virtual status_t onTransact( uint32_t code,
|
||||||
|
const Parcel& data,
|
||||||
|
Parcel* reply,
|
||||||
|
uint32_t flags = 0);
|
||||||
|
};
|
||||||
|
|
||||||
|
}; // namespace android
|
||||||
|
|
||||||
|
#endif // ANDROID_IEFFECT_H
|
50
include/media/IEffectClient.h
Normal file
50
include/media/IEffectClient.h
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2010 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_IEFFECTCLIENT_H
|
||||||
|
#define ANDROID_IEFFECTCLIENT_H
|
||||||
|
|
||||||
|
#include <utils/RefBase.h>
|
||||||
|
#include <binder/IInterface.h>
|
||||||
|
#include <binder/Parcel.h>
|
||||||
|
#include <binder/IMemory.h>
|
||||||
|
|
||||||
|
namespace android {
|
||||||
|
|
||||||
|
class IEffectClient: public IInterface
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
DECLARE_META_INTERFACE(EffectClient);
|
||||||
|
|
||||||
|
virtual void controlStatusChanged(bool controlGranted) = 0;
|
||||||
|
virtual void enableStatusChanged(bool enabled) = 0;
|
||||||
|
virtual void commandExecuted(int cmdCode, int cmdSize, void *pCmdData, int replySize, void *pReplyData) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class BnEffectClient: public BnInterface<IEffectClient>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
virtual status_t onTransact( uint32_t code,
|
||||||
|
const Parcel& data,
|
||||||
|
Parcel* reply,
|
||||||
|
uint32_t flags = 0);
|
||||||
|
};
|
||||||
|
|
||||||
|
}; // namespace android
|
||||||
|
|
||||||
|
#endif // ANDROID_IEFFECTCLIENT_H
|
@ -26,7 +26,9 @@ LOCAL_SRC_FILES:= \
|
|||||||
MediaScannerClient.cpp \
|
MediaScannerClient.cpp \
|
||||||
autodetect.cpp \
|
autodetect.cpp \
|
||||||
IMediaDeathNotifier.cpp \
|
IMediaDeathNotifier.cpp \
|
||||||
MediaProfiles.cpp
|
MediaProfiles.cpp \
|
||||||
|
IEffect.cpp \
|
||||||
|
IEffectClient.cpp
|
||||||
|
|
||||||
LOCAL_SHARED_LIBRARIES := \
|
LOCAL_SHARED_LIBRARIES := \
|
||||||
libui libcutils libutils libbinder libsonivox libicuuc libexpat libsurfaceflinger_client libcamera_client
|
libui libcutils libutils libbinder libsonivox libicuuc libexpat libsurfaceflinger_client libcamera_client
|
||||||
|
191
media/libmedia/IEffect.cpp
Normal file
191
media/libmedia/IEffect.cpp
Normal file
@ -0,0 +1,191 @@
|
|||||||
|
/*
|
||||||
|
**
|
||||||
|
** Copyright 2010, 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
//#define LOG_NDEBUG 0
|
||||||
|
#define LOG_TAG "IEffect"
|
||||||
|
#include <utils/Log.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <binder/Parcel.h>
|
||||||
|
#include <media/IEffect.h>
|
||||||
|
|
||||||
|
namespace android {
|
||||||
|
|
||||||
|
enum {
|
||||||
|
ENABLE = IBinder::FIRST_CALL_TRANSACTION,
|
||||||
|
DISABLE,
|
||||||
|
COMMAND,
|
||||||
|
DISCONNECT,
|
||||||
|
GET_CBLK
|
||||||
|
};
|
||||||
|
|
||||||
|
class BpEffect: public BpInterface<IEffect>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
BpEffect(const sp<IBinder>& impl)
|
||||||
|
: BpInterface<IEffect>(impl)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
status_t enable()
|
||||||
|
{
|
||||||
|
LOGV("enable");
|
||||||
|
Parcel data, reply;
|
||||||
|
data.writeInterfaceToken(IEffect::getInterfaceDescriptor());
|
||||||
|
remote()->transact(ENABLE, data, &reply);
|
||||||
|
return reply.readInt32();
|
||||||
|
}
|
||||||
|
|
||||||
|
status_t disable()
|
||||||
|
{
|
||||||
|
LOGV("disable");
|
||||||
|
Parcel data, reply;
|
||||||
|
data.writeInterfaceToken(IEffect::getInterfaceDescriptor());
|
||||||
|
remote()->transact(DISABLE, data, &reply);
|
||||||
|
return reply.readInt32();
|
||||||
|
}
|
||||||
|
|
||||||
|
status_t command(int cmdCode, int cmdSize, void *pCmdData, int *pReplySize, void *pReplyData)
|
||||||
|
{
|
||||||
|
LOGV("command");
|
||||||
|
Parcel data, reply;
|
||||||
|
data.writeInterfaceToken(IEffect::getInterfaceDescriptor());
|
||||||
|
data.writeInt32(cmdCode);
|
||||||
|
int size = cmdSize;
|
||||||
|
if (pCmdData == NULL) {
|
||||||
|
size = 0;
|
||||||
|
}
|
||||||
|
data.writeInt32(size);
|
||||||
|
if (size) {
|
||||||
|
data.write(pCmdData, size);
|
||||||
|
}
|
||||||
|
if (pReplySize == NULL) {
|
||||||
|
size = 0;
|
||||||
|
} else {
|
||||||
|
size = *pReplySize;
|
||||||
|
}
|
||||||
|
data.writeInt32(size);
|
||||||
|
remote()->transact(COMMAND, data, &reply);
|
||||||
|
status_t status = reply.readInt32();
|
||||||
|
size = reply.readInt32();
|
||||||
|
if (size != 0 && pReplyData != NULL && pReplySize != NULL) {
|
||||||
|
reply.read(pReplyData, size);
|
||||||
|
*pReplySize = size;
|
||||||
|
}
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
void disconnect()
|
||||||
|
{
|
||||||
|
LOGV("disconnect");
|
||||||
|
Parcel data, reply;
|
||||||
|
data.writeInterfaceToken(IEffect::getInterfaceDescriptor());
|
||||||
|
remote()->transact(DISCONNECT, data, &reply);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual sp<IMemory> getCblk() const
|
||||||
|
{
|
||||||
|
Parcel data, reply;
|
||||||
|
sp<IMemory> cblk;
|
||||||
|
data.writeInterfaceToken(IEffect::getInterfaceDescriptor());
|
||||||
|
status_t status = remote()->transact(GET_CBLK, data, &reply);
|
||||||
|
if (status == NO_ERROR) {
|
||||||
|
cblk = interface_cast<IMemory>(reply.readStrongBinder());
|
||||||
|
}
|
||||||
|
return cblk;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
IMPLEMENT_META_INTERFACE(Effect, "android.media.IEffect");
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
status_t BnEffect::onTransact(
|
||||||
|
uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags)
|
||||||
|
{
|
||||||
|
switch(code) {
|
||||||
|
case ENABLE: {
|
||||||
|
LOGV("ENABLE");
|
||||||
|
CHECK_INTERFACE(IEffect, data, reply);
|
||||||
|
reply->writeInt32(enable());
|
||||||
|
return NO_ERROR;
|
||||||
|
} break;
|
||||||
|
|
||||||
|
case DISABLE: {
|
||||||
|
LOGV("DISABLE");
|
||||||
|
CHECK_INTERFACE(IEffect, data, reply);
|
||||||
|
reply->writeInt32(disable());
|
||||||
|
return NO_ERROR;
|
||||||
|
} break;
|
||||||
|
|
||||||
|
case COMMAND: {
|
||||||
|
LOGV("COMMAND");
|
||||||
|
CHECK_INTERFACE(IEffect, data, reply);
|
||||||
|
int cmdCode = data.readInt32();
|
||||||
|
int cmdSize = data.readInt32();
|
||||||
|
char *cmd = NULL;
|
||||||
|
if (cmdSize) {
|
||||||
|
cmd = (char *)malloc(cmdSize);
|
||||||
|
data.read(cmd, cmdSize);
|
||||||
|
}
|
||||||
|
int replySize = data.readInt32();
|
||||||
|
int replySz = replySize;
|
||||||
|
char *resp = NULL;
|
||||||
|
if (replySize) {
|
||||||
|
resp = (char *)malloc(replySize);
|
||||||
|
}
|
||||||
|
status_t status = command(cmdCode, cmdSize, cmd, &replySz, resp);
|
||||||
|
reply->writeInt32(status);
|
||||||
|
if (replySz < replySize) {
|
||||||
|
replySize = replySz;
|
||||||
|
}
|
||||||
|
reply->writeInt32(replySize);
|
||||||
|
if (replySize) {
|
||||||
|
reply->write(resp, replySize);
|
||||||
|
}
|
||||||
|
if (cmd) {
|
||||||
|
free(cmd);
|
||||||
|
}
|
||||||
|
if (resp) {
|
||||||
|
free(resp);
|
||||||
|
}
|
||||||
|
return NO_ERROR;
|
||||||
|
} break;
|
||||||
|
|
||||||
|
case DISCONNECT: {
|
||||||
|
LOGV("DISCONNECT");
|
||||||
|
CHECK_INTERFACE(IEffect, data, reply);
|
||||||
|
disconnect();
|
||||||
|
return NO_ERROR;
|
||||||
|
} break;
|
||||||
|
|
||||||
|
case GET_CBLK: {
|
||||||
|
CHECK_INTERFACE(IEffect, data, reply);
|
||||||
|
reply->writeStrongBinder(getCblk()->asBinder());
|
||||||
|
return NO_ERROR;
|
||||||
|
} break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
return BBinder::onTransact(code, data, reply, flags);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
}; // namespace android
|
||||||
|
|
141
media/libmedia/IEffectClient.cpp
Normal file
141
media/libmedia/IEffectClient.cpp
Normal file
@ -0,0 +1,141 @@
|
|||||||
|
/*
|
||||||
|
**
|
||||||
|
** Copyright 2010, 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
//#define LOG_NDEBUG 0
|
||||||
|
#define LOG_TAG "IEffectClient"
|
||||||
|
#include <utils/Log.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <media/IEffectClient.h>
|
||||||
|
|
||||||
|
namespace android {
|
||||||
|
|
||||||
|
enum {
|
||||||
|
CONTROL_STATUS_CHANGED = IBinder::FIRST_CALL_TRANSACTION,
|
||||||
|
ENABLE_STATUS_CHANGED,
|
||||||
|
COMMAND_EXECUTED
|
||||||
|
};
|
||||||
|
|
||||||
|
class BpEffectClient: public BpInterface<IEffectClient>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
BpEffectClient(const sp<IBinder>& impl)
|
||||||
|
: BpInterface<IEffectClient>(impl)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void controlStatusChanged(bool controlGranted)
|
||||||
|
{
|
||||||
|
LOGV("controlStatusChanged");
|
||||||
|
Parcel data, reply;
|
||||||
|
data.writeInterfaceToken(IEffectClient::getInterfaceDescriptor());
|
||||||
|
data.writeInt32((uint32_t)controlGranted);
|
||||||
|
remote()->transact(CONTROL_STATUS_CHANGED, data, &reply, IBinder::FLAG_ONEWAY);
|
||||||
|
}
|
||||||
|
|
||||||
|
void enableStatusChanged(bool enabled)
|
||||||
|
{
|
||||||
|
LOGV("enableStatusChanged");
|
||||||
|
Parcel data, reply;
|
||||||
|
data.writeInterfaceToken(IEffectClient::getInterfaceDescriptor());
|
||||||
|
data.writeInt32((uint32_t)enabled);
|
||||||
|
remote()->transact(ENABLE_STATUS_CHANGED, data, &reply, IBinder::FLAG_ONEWAY);
|
||||||
|
}
|
||||||
|
|
||||||
|
void commandExecuted(int cmdCode, int cmdSize, void *pCmdData, int replySize, void *pReplyData)
|
||||||
|
{
|
||||||
|
LOGV("commandExecuted");
|
||||||
|
Parcel data, reply;
|
||||||
|
data.writeInterfaceToken(IEffectClient::getInterfaceDescriptor());
|
||||||
|
data.writeInt32(cmdCode);
|
||||||
|
int size = cmdSize;
|
||||||
|
if (pCmdData == NULL) {
|
||||||
|
size = 0;
|
||||||
|
}
|
||||||
|
data.writeInt32(size);
|
||||||
|
if (size) {
|
||||||
|
data.write(pCmdData, size);
|
||||||
|
}
|
||||||
|
size = replySize;
|
||||||
|
if (pReplyData == NULL) {
|
||||||
|
size = 0;
|
||||||
|
}
|
||||||
|
data.writeInt32(size);
|
||||||
|
if (size) {
|
||||||
|
data.write(pReplyData, size);
|
||||||
|
}
|
||||||
|
remote()->transact(COMMAND_EXECUTED, data, &reply, IBinder::FLAG_ONEWAY);
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
IMPLEMENT_META_INTERFACE(EffectClient, "android.media.IEffectClient");
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
status_t BnEffectClient::onTransact(
|
||||||
|
uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags)
|
||||||
|
{
|
||||||
|
switch(code) {
|
||||||
|
case CONTROL_STATUS_CHANGED: {
|
||||||
|
LOGV("CONTROL_STATUS_CHANGED");
|
||||||
|
CHECK_INTERFACE(IEffectClient, data, reply);
|
||||||
|
bool hasControl = (bool)data.readInt32();
|
||||||
|
controlStatusChanged(hasControl);
|
||||||
|
return NO_ERROR;
|
||||||
|
} break;
|
||||||
|
case ENABLE_STATUS_CHANGED: {
|
||||||
|
LOGV("ENABLE_STATUS_CHANGED");
|
||||||
|
CHECK_INTERFACE(IEffectClient, data, reply);
|
||||||
|
bool enabled = (bool)data.readInt32();
|
||||||
|
enableStatusChanged(enabled);
|
||||||
|
return NO_ERROR;
|
||||||
|
} break;
|
||||||
|
case COMMAND_EXECUTED: {
|
||||||
|
LOGV("COMMAND_EXECUTED");
|
||||||
|
CHECK_INTERFACE(IEffectClient, data, reply);
|
||||||
|
int cmdCode = data.readInt32();
|
||||||
|
int cmdSize = data.readInt32();
|
||||||
|
char *cmd = NULL;
|
||||||
|
if (cmdSize) {
|
||||||
|
cmd = (char *)malloc(cmdSize);
|
||||||
|
data.read(cmd, cmdSize);
|
||||||
|
}
|
||||||
|
int replySize = data.readInt32();
|
||||||
|
char *resp = NULL;
|
||||||
|
if (replySize) {
|
||||||
|
resp = (char *)malloc(replySize);
|
||||||
|
data.read(resp, replySize);
|
||||||
|
}
|
||||||
|
commandExecuted(cmdCode, cmdSize, cmd, replySize, resp);
|
||||||
|
if (cmd) {
|
||||||
|
free(cmd);
|
||||||
|
}
|
||||||
|
if (resp) {
|
||||||
|
free(resp);
|
||||||
|
}
|
||||||
|
return NO_ERROR;
|
||||||
|
} break;
|
||||||
|
default:
|
||||||
|
return BBinder::onTransact(code, data, reply, flags);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
}; // namespace android
|
||||||
|
|
Reference in New Issue
Block a user