利用systrace中跟踪binder通信过程

文章通过一份tracelog展示了如何解析systrace抓取的Android系统日志,特别是关注了binder通信的细节。1546InputReader线程从sleeping状态被唤醒,变为runable,在CPU5上运行,并通过binder向surfaceflinger(501)发送消息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

systrace抓取到的trace日志中会记录android系统的很多通信过程,其中也包括了binder的通信细节。这里我们以一份trace log进行简单解析:

 红框:现场名字及线程号,这里是截图所以没有体现出来,这个线程是system_server中的1102  1546 InputReader线程。

蓝框:表明当前线程的状态是runable, 点击蓝色横条,我们可以看到更多详细信息:

上图红框中的信息表明,线程从sleeping状态切换到了Runable状态,由tid 0唤醒。

点击绿色横条,可以看到这个thread是运行在CPU5上。以及其运行的开始时间&持续时间。

 点击binder transaction async这个方块,可以看到更多binder通信的信息

 再点击下方slice栏中的信息可以知道binder的通信走向:

 从trace中可以看到,1546 InputReader线程通过binder向surfaceflinger(501)的线程发送了消息.

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值