binder流程

1,service_manager.c启动的时候,会调用一个无限循环binder_loop方法,在这个方法中有个ioctl方法,这个方法应该是阻塞方法吧
他是不停的监听,客户端连接和服务端注册的任务

2,当一个服务启动后,首先往binder进行服务注册,他注册的时候,也会ioctl后,然后被binder驱动指向目标端 service_manager 进程
接着 service_manager -->binder_loop 中的ioctl方法不再阻塞,然后来到binder_parse方法中,进行注册。

3,当客户端请求往服务端传递数据的时候,他应该封装了一个带有请求目标服务端的参数的parcel,通过ioctl被binder驱动拦截到,
binder驱动首先请求service_manager 进程查找被请求的服务是不是存在,这个时候,应该又触发了binder_loop下的ioctl方法不再阻塞,
然后来到binder_parse方法中,进行查找对应的服务,如果存在,则直接告知客户端请求服务端已经接受,此时binder会给客户端创建引用对象,这个引用对象,开始代替客户端,等待服务端响应。
4,这个时候,binder驱动应该会联系某某服务,给服务端一个地址,让她去处理某个事宜,同时给服务端创建一个实体对象。

5,服务端处理好数据后,把数据写到对应的内核缓存处,然后通过Br_replay告知 binder驱动(通过实体对象)已经处理完成了,同时给Binder驱动一个地址信息,相关处理已经放在某某地方了,请客户端自行去拿吧。

6,binder驱动(对应的引用对象)屁颠屁颠的通过service_manage进程找到具体的客户端,然后告诉客户端,小客,你去某某地方拿数据吧。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

liujun3512159

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值