在init.rc文件中,有定义serviceservicemanager /system/bin/servicemanager,在系统初始化会解析init.rc文件时,遇到这句话,将会把servicemanager加载到服务启动列表中,同时它也是第一个启动的服务。
ServiceManager的相关代码位于frameworks/native/cmds/servicemanager文件夹中。总体来说,它的初始化分为三个步骤:
1. 通过调用binder_open打开/dev/binder字符设备,并映射了一段进程虚拟地址空间,通过binder驱动的处理,这段虚拟地址空间也可以被内核同时访问(无需先复制),因为binder驱动在内核中同时也映射了一段虚拟地址空间,它们映射的目标物理地址是一样的,也就是说这两个不同的虚拟地址空间都同时映射到了一块相同的物理地址空间。这一步主要是为接下来的数据通信提供内存空间,作为binder transaction过程中的数据存放处。
2. 作为Service Manager,它的特殊性在于:首先,它有一个固定的句柄值,即0。其次,它必须是第一个调用binder_become_context_manager函数的进程。通过这个函数,binder驱动就会为其创建一个结点,这个结点是全局的。
3. 最后通过binder_loop进入消息循环,并安装对应的消息处理函数。这里,通过向驱动下达BC_ENTER_LOOPER命令,使当前进程处于BINDER_LOOPER_STATE_ENTERED状态。

本文深入剖析了Android系统中Service Manager的初始化过程,包括打开/dev/binder设备、成为上下文管理器以及进入消息循环的步骤。同时,文章还介绍了如何在C++和Java层调用Service Manager的功能,涉及BpServiceManager、Binder IPC以及ServiceManagerProxy等关键组件。
最低0.47元/天 解锁文章
1104

被折叠的 条评论
为什么被折叠?



