ServiceManager启动
通过 init进程 这篇 我们知道 在解析init.rc时主要做了ServiceManager,zygote的启动
下面我们来看ServiceManager,源码路径
frameworks/native/cmds/servicemanager/service_manager.c
我们主要观察Main函数
int main(int argc, char** argv)
{
struct binder_state *bs;
if (argc > 1) {
driver = argv[1];
} else {
driver = "/dev/binder";
}
//打开BinderDriver(驱动),调用mmap函数映射到进程地址空间,申请128k内存作为接收client请求数据的缓冲区
// 这里至关重要 开启了Binder驱动后面的AMS,PMS等才能跨进程通讯
bs = binder_open(driver, 128*1024);
//通过ioctl(icController)告诉BinderDriver(驱动程序)它自己是Binder上下文管理者
//(也就是SeverManager角色,管理zygote进程中执行SystemServer时启动的各种服务)
//将自己的Binder节点设置为0节点,可以理解为服务管家
if (binder_become_context_manager(bs)) {
ALOGE("cannot become context manager (%s)\n", strerror(errno));
return -1;
}
// 开启消息循环(for死循环)等待接收client 申请服务的请求 相当于服务端
binder_loop(bs, svcmgr_handler);
return 0;
}
总结
- 打开Binder驱动
- 将自己注册为ServiceManger角色 告诉Binder自己就是系统服务的管理者
- 开启循环 等待接收client 申请服务的请求
- 此时相当于一个服务端