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>
|
* Copyright (C) 2010 The Android Open Source Project
|
||||||
#include <binder/IServiceManager.h>
|
*
|
||||||
#include <utils/Log.h>
|
* 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>
|
#include <SurfaceFlinger.h>
|
||||||
|
|
||||||
using namespace android;
|
using namespace android;
|
||||||
|
|
||||||
int main(int argc, char** argv)
|
int main(int argc, char** argv) {
|
||||||
{
|
SurfaceFlinger::publishAndJoinThreadPool();
|
||||||
sp<ProcessState> proc(ProcessState::self());
|
return 0;
|
||||||
sp<IServiceManager> sm = defaultServiceManager();
|
|
||||||
LOGI("ServiceManager: %p", sm.get());
|
|
||||||
SurfaceFlinger::instantiate();
|
|
||||||
ProcessState::self()->startThreadPool();
|
|
||||||
IPCThreadState::self()->joinThreadPool();
|
|
||||||
}
|
}
|
||||||
|
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);
|
return BnAudioFlinger::onTransact(code, data, reply, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
void AudioFlinger::instantiate() {
|
|
||||||
defaultServiceManager()->addService(
|
|
||||||
String16("media.audio_flinger"), new AudioFlinger());
|
|
||||||
}
|
|
||||||
|
|
||||||
}; // namespace android
|
}; // namespace android
|
||||||
|
@ -31,10 +31,12 @@
|
|||||||
#include <utils/Atomic.h>
|
#include <utils/Atomic.h>
|
||||||
#include <utils/Errors.h>
|
#include <utils/Errors.h>
|
||||||
#include <utils/threads.h>
|
#include <utils/threads.h>
|
||||||
#include <binder/MemoryDealer.h>
|
|
||||||
#include <utils/SortedVector.h>
|
#include <utils/SortedVector.h>
|
||||||
#include <utils/Vector.h>
|
#include <utils/Vector.h>
|
||||||
|
|
||||||
|
#include <binder/BinderService.h>
|
||||||
|
#include <binder/MemoryDealer.h>
|
||||||
|
|
||||||
#include <hardware_legacy/AudioHardwareInterface.h>
|
#include <hardware_legacy/AudioHardwareInterface.h>
|
||||||
|
|
||||||
#include "AudioBufferProvider.h"
|
#include "AudioBufferProvider.h"
|
||||||
@ -58,10 +60,13 @@ class AudioResampler;
|
|||||||
|
|
||||||
static const nsecs_t kStandbyTimeInNsecs = seconds(3);
|
static const nsecs_t kStandbyTimeInNsecs = seconds(3);
|
||||||
|
|
||||||
class AudioFlinger : public BnAudioFlinger
|
class AudioFlinger :
|
||||||
|
public BinderService<AudioFlinger>,
|
||||||
|
public BnAudioFlinger
|
||||||
{
|
{
|
||||||
|
friend class BinderService<AudioFlinger>;
|
||||||
public:
|
public:
|
||||||
static void instantiate();
|
static char const* getServiceName() { return "media.audio_flinger"; }
|
||||||
|
|
||||||
virtual status_t dump(int fd, const Vector<String16>& args);
|
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();
|
return mClient[cameraId].promote();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CameraService::instantiate() {
|
|
||||||
defaultServiceManager()->addService(String16("media.camera"),
|
|
||||||
new CameraService());
|
|
||||||
}
|
|
||||||
|
|
||||||
status_t CameraService::onTransact(
|
status_t CameraService::onTransact(
|
||||||
uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags) {
|
uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags) {
|
||||||
// Permission checks
|
// Permission checks
|
||||||
|
@ -19,6 +19,8 @@
|
|||||||
#ifndef ANDROID_SERVERS_CAMERA_CAMERASERVICE_H
|
#ifndef ANDROID_SERVERS_CAMERA_CAMERASERVICE_H
|
||||||
#define ANDROID_SERVERS_CAMERA_CAMERASERVICE_H
|
#define ANDROID_SERVERS_CAMERA_CAMERASERVICE_H
|
||||||
|
|
||||||
|
#include <binder/BinderService.h>
|
||||||
|
|
||||||
#include <camera/ICameraService.h>
|
#include <camera/ICameraService.h>
|
||||||
#include <camera/CameraHardwareInterface.h>
|
#include <camera/CameraHardwareInterface.h>
|
||||||
|
|
||||||
@ -30,11 +32,14 @@ namespace android {
|
|||||||
class MemoryHeapBase;
|
class MemoryHeapBase;
|
||||||
class MediaPlayer;
|
class MediaPlayer;
|
||||||
|
|
||||||
class CameraService: public BnCameraService
|
class CameraService :
|
||||||
|
public BinderService<CameraService>,
|
||||||
|
public BnCameraService
|
||||||
{
|
{
|
||||||
class Client;
|
class Client;
|
||||||
|
friend class BinderService<CameraService>;
|
||||||
public:
|
public:
|
||||||
static void instantiate();
|
static char const* getServiceName() { return "media.camera"; }
|
||||||
|
|
||||||
CameraService();
|
CameraService();
|
||||||
virtual ~CameraService();
|
virtual ~CameraService();
|
||||||
|
@ -63,20 +63,6 @@
|
|||||||
#define DISPLAY_COUNT 1
|
#define DISPLAY_COUNT 1
|
||||||
|
|
||||||
namespace android {
|
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)
|
SurfaceFlinger::LayerVector::LayerVector(const SurfaceFlinger::LayerVector& rhs)
|
||||||
|
@ -29,6 +29,7 @@
|
|||||||
|
|
||||||
#include <binder/IMemory.h>
|
#include <binder/IMemory.h>
|
||||||
#include <binder/Permission.h>
|
#include <binder/Permission.h>
|
||||||
|
#include <binder/BinderService.h>
|
||||||
|
|
||||||
#include <ui/PixelFormat.h>
|
#include <ui/PixelFormat.h>
|
||||||
#include <surfaceflinger/ISurfaceComposer.h>
|
#include <surfaceflinger/ISurfaceComposer.h>
|
||||||
@ -167,11 +168,13 @@ enum {
|
|||||||
eTraversalNeeded = 0x02
|
eTraversalNeeded = 0x02
|
||||||
};
|
};
|
||||||
|
|
||||||
class SurfaceFlinger : public BnSurfaceComposer, protected Thread
|
class SurfaceFlinger :
|
||||||
|
public BinderService<SurfaceFlinger>,
|
||||||
|
public BnSurfaceComposer,
|
||||||
|
protected Thread
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
static void instantiate();
|
static char const* getServiceName() { return "SurfaceFlinger"; }
|
||||||
static void shutdown();
|
|
||||||
|
|
||||||
SurfaceFlinger();
|
SurfaceFlinger();
|
||||||
virtual ~SurfaceFlinger();
|
virtual ~SurfaceFlinger();
|
||||||
|
Reference in New Issue
Block a user