binder的传递

client端通过servicemanager拿到的服务端的bpbinder是否和 servicemanager保存的映射表里面的bpbinder一样?

答案是不一样

这里来详细讲一下
binger通信过程,对使用者是透明的,即使用者可以认为拿到的就是一个服务端的接口对象,直接调用这个对象就能获取服务端的接口提供的功能。

但其地层则是通过bpbinder 和bbinder来进行通信的(一种代理的模式)

即客户端通过bpbinder来进行服务端接口的调用,而同进程则通过bbinder来进行调用

而这个bpbinder 如何生成,以及传递,以及如何代理将接口转到服务端的接口是如何实现的?
bpbinder其实是对hander的封装,这个hander就是驱动层两个进程的映射,驱动根据这个hander能够找到对应的服务端,服务端也能找到对应的客户端,

这也就解释了bpbinder如何调用到service段的bbinder的接口的,内核层可以通过映射找到bbiner的接口,并调用,就是这么简单,因为内核层不存在进程间的限制。
而bpbiner的传递过程也是经过驱动重新和服务端映射的,因此传递给另一个进程的bpbinder其实是驱动重新映射的新的bpbinder,而如果传递的是同一个进程的bpbinder,那么驱动也会转化为bbinder。这个详细的流程我下一步要去驱动里找下详细的步骤。这里举例一个大概的流程:从servicemanager里面get(“ams”)拿到的就是传递过来一个bpbinder,这个驱动是如何转化成一个新的bpbinder的呢,我门来看看把:
client端通过驱动拿到bpbiner的时候,驱动会找到binder对应的该进程的handler,没有则创建对应的hander及bindernode结构体,并传给ipcthreadstate,创建一个新的bpbineder

日常工作中不需要了解这么多,就随便写下这些吧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值