`
rayloo
  • 浏览: 86672 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

为 Android添加底层核心服务(一)

阅读更多

1. 为什么要写底层核心服务呢?
因为底层核心服务是 Android框架里最接近 Linux/Driver的部分。为了充分发挥硬件设备的差异化特性,核心服务是让上层 Java应用程序来使用 Driver/HW Device 特色的重要管道。例如 Media、 Telephone等底层硬件。

在开机过程中,就可以启动核心服务(汉字输入法服务等),让众多应用程序来共同使用。

由于共用,所以能有效降低 Java应用程序的大小( Size)。

2. 核心服务与 Java 层的 Service有何区别和关系?
Android具有两层服务

--Java层 SDK-based Service

--C++层的 Code Service

3. 编写自己的核心服务( C++ 层)
1). 要点
核心服务通常在独立的进程( Process )里执行。

必须提供 IBinder 接口,让应用程序可以进行跨进程的绑定( Binding )和调用。

因为共用,所以必须确保多线程安全( Thread-safe )。

使用 C++ 来实现,并调用 IServiceManager::addService() 函数添加到系统的 Binder Driver 里。

上层应用程序通过 ServiceManager 获取该服务。

上层应用程序通过 IBinder::transact() 函数来与核心服进行数据交互。

2). 添加服务
下面详细介绍如何添加一个底层服务到系统中,假设服务名为 AddService ,其用途是对传入的参数加上 1000 ,并返回结果。

服务实现
进入 android 源码 的目录 frameworks/base ,在该目录下建立自己的目录,假设为 addservice ,再在这个目录中建立两个子目录 addserver 和 libaddservice , addserver 用于存放服务的启动文件,其最终的生成为可执行文件,在系统启动的时候运行, libaddservice 用于存放服务的实现文件,最终会生成动态链接库,有 addserver 调用。

首先,服务的实现文件包括两个文件, AddService.h 和 AddService.cpp ,

以下是 AddService.h :

#ifndef ANDROID_GUILH_ADD_SERVICE_H

#define ANDROID_GUILH_ADD_SERVICE_H

#include <utils/RefBase.h>

#include <binder/IInterface.h>

#include <binder/Parcel.h>

#include <utils/threads.h>

namespace android {

class AddService : public BBinder{// 从 BBinder 派生,实现本地接口

public:

static int instantiate();

AddService();

virtual ~AddService();

virtual status_t onTransact(uint32_t, const Parcel&, Parcel*, uint32_t);

};

}; //namespace

#endif

然后是服务的实现文件 AddService.cpp :

#include "AddService.h"

#include <binder/IServiceManager.h>

#include <binder/IPCThreadState.h>

namespace android {

static struct sigaction oldact;

static pthread_key_t sigbuskey;

// 把自己注册到系统中

int AddService::instantiate() {

LOGE("AddService instantiate");

int r = defaultServiceManager()->addService(

String16("guilh.add"), new AddService());// 这里主要是把 //AddSerice 这个服务添加到 Binder Driver 中服务名为 guilh.add

LOGE("AddService r = %d\n", r);

return r;

}

// 构造函数

AddService::AddService()

{

LOGV("AddService created");

mNextConnId = 1;

pthread_key_create(&sigbuskey, NULL);

}

// 析构函数

AddService::~AddService()

{

pthread_key_delete(sigbuskey);

LOGV("AddService destroyed");

}

// 这个是服务具体的本地实现,功能实现都应该放在这里面,通过传入执行代码( code ) // 的不同来执行不同的操作,上层隐射为不同的 api 。

status_t AddService::onTransact(

uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags){

switch(code) {

case 0: {// 根据 code 的不同执行不同的操作

pid_t pid = data.readInt32();

int num = data.readInt32();

num = num + 1000;

reply->writeInt32(num);

return NO_ERROR;

}

break;

default:

return BBinder::onTransact(code, data, reply, flags);

}

}}; //namespace

以下是编译服务的 Android.mk ,和上面的 cpp 放在一起。

LOCAL_PATH:= $(call my-dir)

include $(CLEAR_VARS)

LOCAL_SRC_FILES:= \

AddService.cpp

LOCAL_C_INCLUDES := \

$(JNI_H_INCLUDE)

LOCAL_SHARED_LIBRARIES := \

libcutils \

libutils \

libbinder \

libandroid_runtime

LOCAL_PRELINK_MODULE := false

LOCAL_MODULE := libAdd

include $(BUILD_SHARED_LIBRARY) #这一行表示编译为动态库

在命令行中退出到 android/目录级 加载编译环境 . build/envsetup.sh

然后 lunch。

然后在 cd /android/frameworks/base/addservice/ libaddservice/ 目录 输入 mm

之后在 out 目录产出 libAdd.so 文件。

在此 完成核心服务第一步。

服务进程实现
进入到 cd /android/frameworks/base/addservice/addserver/ 目录

增加一个文件 addserver.cpp ,文件内容如下:

#include <sys/types.h>

#include <unistd.h>

#include <grp.h>

#include <binder/IPCThreadState.h>

#include <binder/ProcessState.h>

#include <binder/IServiceManager.h>

#include <utils/Log.h>

#include <private/android_filesystem_config.h>

#include "../libaddservice/AddService.h"

//#include <libadd/AddService.h>

using namespace android;

int main(int argc, char** argv)

{

sp<ProcessState> proc(ProcessState::self());

sp<IServiceManager> sm = defaultServiceManager();//取得 ServiceManager

LOGI("ServiceManager: %p", sm.get());

AddService::instantiate();//把自己添加到 ServiceManager中

ProcessState::self()->startThreadPool();//启动缓冲池

IPCThreadState::self()->joinThreadPool();//这里是把服务添加到 Binder闭合循环进程中

}

以上为底层服务的标准操作。

下面是这个服务 makefile:

include $(CLEAR_VARS)

LOCAL_SRC_FILES:= \

addserver.cpp

LOCAL_SHARED_LIBRARIES := \

libAdd \

libutils \

libbinder

LOCAL_MODULE:= addserver

include $(BUILD_EXECUTABLE)//编译为可执行文件

退出后当前目录执行 mm即可在 out目录的 system/bin下产出 addserver可执行文件。

实现服务进程开机自动运行
进入到 /android/system/core/rootdir/目录中有个 init.rc文件

vi init.rc

在 service中添加

service addservice /system/bin/addserver //将 /system/bin/addserver作为一个服务启动,服务的名称为 addservice(这个不重要)。

最后退出到 android/目录下执行全编译:

输入 . build/envsetup.sh

Lunch

Make

完成之后

Emulator打开模拟器

打开另一个 shell终端 输入 adb shell 进入模拟器模式 如果 adbshell系统提示没有发现该命令 就在 android/out/host/linux-x86/bin/中输入 ./adb shell

在输入 ps 查看进程 找到是否有 addserver进程

如果有就成功一半。


测试我们的服务

随便在 android/packages/apps 中 建立一个简单的应用程序,

这里可以直接在 eclipse 中建立好工程 拷贝到 android/packages/apps 中,然后为应用添加一个 Android.mk 文件,可以从其他应用中拷贝来修改。

在应用程序中测试服务的代码:

private void test(){

try{

IBinder binder = ServiceManager.getService("guilh.add");// 取得服务

Parcel data = Parcel.obtain();

Parcel reply = Parcel.obtain();

if(binder == null)

Log.d(TAG,"failed to get service");

data.writeInt(Process.myPid());// 固定操作

data.writeInt(100);// 传入参数

binder.transact(0, data, reply, 0);// 执行远程调用

Log.d(TAG,"result="+reply.readInt());// 验证结果

}catch(Exception e){

Log.d(TAG,e.toString());

}

(以上部分资料来源于高焕堂 android 核心服务,欢迎提出您的意见及建议)

分享到:
评论

相关推荐

    Android的底层库

    2. **C语言底层库libcutils**:这是一个为Android系统特别设计的C语言库,包含了一系列实用工具函数,如字符串操作、日志记录等。 3. **Init进程**:这是Android启动的第一个用户空间进程,负责启动其他服务和进程。...

    android教程(底层)

    2. **Framework(框架层)**:这一层包含了Android的核心代码,主要是Java语言编写。同时,Vendor可以在此基础上进行扩展,添加自己的服务和功能。 3. **Native Libraries(原生库)**:这一层提供了大量的C/C++库...

    Android底层系统开发培训

    在Android系统开发中,底层驱动开发是至关重要的一个环节,它是连接硬件与上层应用程序的桥梁,确保设备的正常运行和高效性能。本培训课程专注于Android底层系统开发,旨在帮助学员深入理解Android驱动的工作原理,...

    android 底层系统开发资料

    在Android系统开发中,底层系统开发是一个至关重要的领域,它涉及到操作系统内核、硬件驱动、系统服务等多个关键组件。这份“android 底层系统开发资料”涵盖了这一领域的核心分析和平台介绍,对于深入理解Android...

    Android 底层驱动原理

    系统服务是Android系统的核心组件,如电源管理、网络管理等。库提供各种功能支持,框架API是应用程序开发的接口,而应用程序层则包含用户安装的各种应用。 1.3 Android专用驱动 Android引入了一些专有的驱动,如...

    Android底层系统原理及开发须知

    Android系统是基于Linux内核的开源移动操作系统,其底层系统原理和开发涉及到多个核心领域,包括内核定制、驱动程序开发、系统服务构建以及性能优化等。本篇将深入探讨这些关键知识点,帮助具备Linux系统移植经验的...

    Audio系统综述 Android底层开发

    MediaPlayerService是另一个重要的服务,它的实例化发生在`MediaPlayerService::instantiate()`函数中,同样通过调用`defaultServiceManager()-&gt;addService()`添加到服务管理器,使得“media.player”服务可用。...

    Android底层开发平台

    这意味着Android利用了Linux的一些核心特性,如进程管理、内存管理、网络栈、驱动模型等,同时添加了自己的一系列服务和应用程序接口(APIs)。 - **核心组件**:Android的核心组件包括Linux内核、HAL (硬件抽象层)、...

    android底层

    3. **驱动程序**:在Android底层,驱动程序是硬件功能的核心实现,它们在Linux内核中运行,为HAL提供服务。驱动程序包括GPU驱动、音频驱动、电源管理驱动、传感器驱动等,每个驱动对应硬件设备的一个特定功能。 4. ...

    04_Android的底层库和程序-Android课件

    Android作为全球最广泛使用的移动操作系统之一,其底层架构和核心组件对于理解整个系统的运作机制至关重要。Android底层库和程序不仅支持了系统的稳定运行,还为开发者提供了丰富的API来构建高质量的应用程序。本文...

    Android底层开发技术实战详解——内核、移植和驱动

    《Android底层开发技术实战详解——内核、移植和驱动》这...《Android底层开发技术实战详解——内核、移植和驱动》这本书正是为了帮助读者掌握这些技能而编写,通过实际案例和实践指导,为读者提供了宝贵的参考资料。

    android系统底层到应用层全方位剖析

    2. **Linux内核**:作为Android的基础,Linux内核提供了进程管理、内存管理、文件系统、网络协议栈等核心服务。内核还支持各种驱动程序,使硬件功能得以充分利用。Android对Linux内核进行了一些定制,例如添加特定的...

    【Android系统原理与开发要点详解】04_Android的底层库和程序

    Android作为全球最广泛使用的移动操作系统之一,其底层架构和核心技术对于开发者来说至关重要。本篇文章将深入探讨Android的底层库和程序,包括它们的结构组成、核心组件以及如何添加本地程序和库等内容。 #### 二...

    Android底层架构介绍与内幕分析

    2. **应用程序框架层**:提供了一整套API供开发者使用,允许访问核心服务,如内容提供者、资源管理器、通知管理器和活动管理器。内容提供者使数据跨应用共享成为可能,资源管理器用于访问非代码资源,通知管理器用于...

    android中的全局悬浮框不影响底层操作

    本文将深入探讨如何在Android中创建一个全局悬浮框,并确保它不会干扰底层操作。 首先,悬浮框的实现主要依赖于Android的`SYSTEM_ALERT_WINDOW`权限。在AndroidManifest.xml文件中,你需要添加以下权限: ```xml ...

    android如何从驱动到app添加一个系统服务

    本篇将深入探讨如何实现从底层驱动到顶层应用层的整个流程,以新增一个名为`LedService`的服务为例。 #### 一、Android系统层次结构概述 Android系统自底向上分为以下几层: 1. **Kernel**(内核层):主要负责与...

    Android平台移植与底层开发

    - **Android操作系统内核**:需要一个支持新硬件的Android-enabled内核,这通常意味着需要对现有内核进行修改或添加新的驱动支持。 - **Dalvik虚拟机解释器**:为了支持不同的指令集和架构,可能需要对Dalvik VM进行...

    android底层开发[收集].pdf

    《Android 底层开发》一书的讨论主要围绕着Android系统的开放性、与其基于的Linux内核的关系以及如何在Ubuntu环境下进行Android源代码的下载、编译和安装。Android系统在移动平台的崛起,特别是对比iOS的封闭性,...

Global site tag (gtag.js) - Google Analytics