1 在客户端的程序调用:
sp<IBinder> server = sm->getService(binderLibTestServiceName);
status_t t = server-> pingBinder();
2 那么pingBinder的作用是什么呢?
在客户端拿到的IBinder对象实际是一个BpBinder对象,我们可以通过如下代码验证:
sp<IBinder> server = sm->getService(binderLibTestServiceName);
sp<BpBinder> bp = static_cast<BpBinder*>(server.get());
printf("before pingBinder\n");
status_t t = bp-> pingBinder(); // PING_TRANSACTION
那么 BpBinder的 pingBinder 是如何实现的呢?
如下:
status_t BpBinder::pingBinder()
{
Parcel data;
data.markForBinder(sp<BpBinder>::fromExisting(this));
Parcel reply;
return transact(PING_TRANSACTION, data, &reply);
}
transact函数是请求执行服务端的操作,PING_TRANSACTION为操作码(code),服务端肯定有对应此code的处理,由于我们自己写service的时候没有实现对PING_TRANSACTION的处理,所以这个处理一定是系统已经帮我们做好了。
接下来通过在源码中搜索 PING_TRANSACTION,我们得知,
在 BBinder::transact()函数中有对 PING_TRANSACTION的处理,即直接返回 NO_ERROR; 那 BBinder的 transact()又是哪里被调用的呢?继续搜索对BBinder::transact函数的调用,我们得知 在 IPCThreadState的 executeCommand()中有调用
BBinder::transact函数,继续,IPCThreadState::joinThreadPool(bool isMain) 循环不断的从binder驱动取数据,然后解析,最终交给executeCommand来处理。
以上,即为我们的分析。
结论: pingBinder即为测试客户端到服务端的调用通路是否正常。