binder系统驱动情景分析 transaction_stack机制

参考
binder_transactioner_transaction

在这里插入图片描述
个人感觉似乎就是
源进程把数据放到 目的进程的 todo 链表,从而唤醒目的进程,数据被目的进程处理。

当一个进程进入 binder驱动,那么就会创建一个 binder_proc 结构体
结构体binder_proc用来描述一个正在使用Binder进程间通信机制的进程。当一个进程调用函数open打开/dev/binder设备文件时,
Binder驱动程序就会为该进程创建一个binder_proc结构体,并且保存在全局的binder_procs链表中。

当A给B发送数据的时候
数据会带上
BC_TRANSACTION
binder 驱动会把 BC_TRANSACTION 变为
BR_TRANSACTION 再发送给 B
B 回复 A
数据会带上
BC_REPCY
binder 驱动会把 BC_REPCY 变为
BR_REPCY 再回复给 A

服务进程下 不仅有 binder_proc (代表进程) 还有 binder_thread (代表线程) 他们都有 todo 链表

红框中可以看到 当执行 BC_TRANSACTION 就会 在binder_transaction结构体中赋值,然后进行传递。
然后在第三步 全部出栈

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值