am 24651682
: added BinderService<> template to help creating native binder services
Merge commit '24651682edaf71e8a826f23a7ea09bc97c8072c4' into gingerbread-plus-aosp * commit '24651682edaf71e8a826f23a7ea09bc97c8072c4': added BinderService<> template to help creating native binder services
This commit is contained in:
@ -1,18 +1,25 @@
|
||||
#include <binder/IPCThreadState.h>
|
||||
#include <binder/ProcessState.h>
|
||||
#include <binder/IServiceManager.h>
|
||||
#include <utils/Log.h>
|
||||
/*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#include <binder/BinderService.h>
|
||||
#include <SurfaceFlinger.h>
|
||||
|
||||
using namespace android;
|
||||
|
||||
int main(int argc, char** argv)
|
||||
{
|
||||
sp<ProcessState> proc(ProcessState::self());
|
||||
sp<IServiceManager> sm = defaultServiceManager();
|
||||
LOGI("ServiceManager: %p", sm.get());
|
||||
SurfaceFlinger::instantiate();
|
||||
ProcessState::self()->startThreadPool();
|
||||
IPCThreadState::self()->joinThreadPool();
|
||||
int main(int argc, char** argv) {
|
||||
SurfaceFlinger::publishAndJoinThreadPool();
|
||||
return 0;
|
||||
}
|
||||
|
60
include/binder/BinderService.h
Normal file
60
include/binder/BinderService.h
Normal file
@ -0,0 +1,60 @@
|
||||
/*
|
||||
* 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_BINDER_SERVICE_H
|
||||
#define ANDROID_BINDER_SERVICE_H
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
#include <utils/Errors.h>
|
||||
#include <utils/String16.h>
|
||||
|
||||
#include <binder/IServiceManager.h>
|
||||
#include <binder/IPCThreadState.h>
|
||||
#include <binder/ProcessState.h>
|
||||
#include <binder/IServiceManager.h>
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
namespace android {
|
||||
|
||||
template<typename SERVICE>
|
||||
class BinderService
|
||||
{
|
||||
public:
|
||||
static status_t publish() {
|
||||
sp<IServiceManager> sm(defaultServiceManager());
|
||||
return sm->addService(String16(SERVICE::getServiceName()), new SERVICE());
|
||||
}
|
||||
|
||||
static void publishAndJoinThreadPool() {
|
||||
sp<ProcessState> proc(ProcessState::self());
|
||||
sp<IServiceManager> sm(defaultServiceManager());
|
||||
sm->addService(String16(SERVICE::getServiceName()), new SERVICE());
|
||||
ProcessState::self()->startThreadPool();
|
||||
IPCThreadState::self()->joinThreadPool();
|
||||
}
|
||||
|
||||
static void instantiate() { publish(); }
|
||||
|
||||
static status_t shutdown() {
|
||||
return NO_ERROR;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
}; // namespace android
|
||||
// ---------------------------------------------------------------------------
|
||||
#endif // ANDROID_BINDER_SERVICE_H
|
@ -6068,11 +6068,4 @@ status_t AudioFlinger::onTransact(
|
||||
return BnAudioFlinger::onTransact(code, data, reply, flags);
|
||||
}
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
void AudioFlinger::instantiate() {
|
||||
defaultServiceManager()->addService(
|
||||
String16("media.audio_flinger"), new AudioFlinger());
|
||||
}
|
||||
|
||||
}; // namespace android
|
||||
|
@ -31,10 +31,12 @@
|
||||
#include <utils/Atomic.h>
|
||||
#include <utils/Errors.h>
|
||||
#include <utils/threads.h>
|
||||
#include <binder/MemoryDealer.h>
|
||||
#include <utils/SortedVector.h>
|
||||
#include <utils/Vector.h>
|
||||
|
||||
#include <binder/BinderService.h>
|
||||
#include <binder/MemoryDealer.h>
|
||||
|
||||
#include <hardware_legacy/AudioHardwareInterface.h>
|
||||
|
||||
#include "AudioBufferProvider.h"
|
||||
@ -58,10 +60,13 @@ class AudioResampler;
|
||||
|
||||
static const nsecs_t kStandbyTimeInNsecs = seconds(3);
|
||||
|
||||
class AudioFlinger : public BnAudioFlinger
|
||||
class AudioFlinger :
|
||||
public BinderService<AudioFlinger>,
|
||||
public BnAudioFlinger
|
||||
{
|
||||
friend class BinderService<AudioFlinger>;
|
||||
public:
|
||||
static void instantiate();
|
||||
static char const* getServiceName() { return "media.audio_flinger"; }
|
||||
|
||||
virtual status_t dump(int fd, const Vector<String16>& args);
|
||||
|
||||
|
@ -192,11 +192,6 @@ sp<CameraService::Client> CameraService::getClientById(int cameraId) {
|
||||
return mClient[cameraId].promote();
|
||||
}
|
||||
|
||||
void CameraService::instantiate() {
|
||||
defaultServiceManager()->addService(String16("media.camera"),
|
||||
new CameraService());
|
||||
}
|
||||
|
||||
status_t CameraService::onTransact(
|
||||
uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags) {
|
||||
// Permission checks
|
||||
|
@ -19,6 +19,8 @@
|
||||
#ifndef ANDROID_SERVERS_CAMERA_CAMERASERVICE_H
|
||||
#define ANDROID_SERVERS_CAMERA_CAMERASERVICE_H
|
||||
|
||||
#include <binder/BinderService.h>
|
||||
|
||||
#include <camera/ICameraService.h>
|
||||
#include <camera/CameraHardwareInterface.h>
|
||||
|
||||
@ -30,11 +32,14 @@ namespace android {
|
||||
class MemoryHeapBase;
|
||||
class MediaPlayer;
|
||||
|
||||
class CameraService: public BnCameraService
|
||||
class CameraService :
|
||||
public BinderService<CameraService>,
|
||||
public BnCameraService
|
||||
{
|
||||
class Client;
|
||||
friend class BinderService<CameraService>;
|
||||
public:
|
||||
static void instantiate();
|
||||
static char const* getServiceName() { return "media.camera"; }
|
||||
|
||||
CameraService();
|
||||
virtual ~CameraService();
|
||||
|
@ -63,20 +63,6 @@
|
||||
#define DISPLAY_COUNT 1
|
||||
|
||||
namespace android {
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
|
||||
void SurfaceFlinger::instantiate() {
|
||||
defaultServiceManager()->addService(
|
||||
String16("SurfaceFlinger"), new SurfaceFlinger());
|
||||
}
|
||||
|
||||
void SurfaceFlinger::shutdown() {
|
||||
// we should unregister here, but not really because
|
||||
// when (if) the service manager goes away, all the services
|
||||
// it has a reference to will leave too.
|
||||
}
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
|
||||
SurfaceFlinger::LayerVector::LayerVector(const SurfaceFlinger::LayerVector& rhs)
|
||||
|
@ -29,6 +29,7 @@
|
||||
|
||||
#include <binder/IMemory.h>
|
||||
#include <binder/Permission.h>
|
||||
#include <binder/BinderService.h>
|
||||
|
||||
#include <ui/PixelFormat.h>
|
||||
#include <surfaceflinger/ISurfaceComposer.h>
|
||||
@ -167,11 +168,13 @@ enum {
|
||||
eTraversalNeeded = 0x02
|
||||
};
|
||||
|
||||
class SurfaceFlinger : public BnSurfaceComposer, protected Thread
|
||||
class SurfaceFlinger :
|
||||
public BinderService<SurfaceFlinger>,
|
||||
public BnSurfaceComposer,
|
||||
protected Thread
|
||||
{
|
||||
public:
|
||||
static void instantiate();
|
||||
static void shutdown();
|
||||
static char const* getServiceName() { return "SurfaceFlinger"; }
|
||||
|
||||
SurfaceFlinger();
|
||||
virtual ~SurfaceFlinger();
|
||||
|
Reference in New Issue
Block a user