9.6 Binder系统_驱动情景分析_server的多线程实现

当多个client对server发出请求的时候,如果server忙不过来的时候会创建多线程来处理请求

那么忙不过来由谁来判断?

server进程有个binder_proc结构体,其里面有todo链表(放有client发过来的数据),并且会唤醒等待在binder_proc.wait上的线程,如果有线程在wait上等待,表面server进程忙的过来;如果wait上空了,就表面server太忙了,驱动会向应用程序反馈

(1)驱动判断是否忙不过来

(2)驱动向APP发请求:创建新线程

(3)APP创建新线程

分析驱动向APP发出“创建新线程请求”的条件

(1)proc->requested_threads = 0;//未处理的新线程请求(如果已经申请了新线程请求则该变量不为0)

(2)proc->ready_threads =0;//空闲线程数为0

(3)已启动的线程数< max_threads(进程的最大线程数)

怎么写APP?

(1)设置max_threads,否则默认的是0

(2)收到驱动发来的BR_SPAWN_LOOPER请求后,创建新线程

(3)新线程发出ioctl:BC_REGISTER_LOOPER

(4)像主线程一样,进入一个循环,进行"read driver和处理"循环

原文地址:https://www.cnblogs.com/liusiluandzhangkun/p/9152045.html

时间: 2024-11-04 09:00:03

9.6 Binder系统_驱动情景分析_server的多线程实现的相关文章

Binder系统_驱动情景分析7_binder_server的多线程(1)

怎么写APP: 1.设置max_threads void binder_set_maxthreads(struct binder_state *bs, int threads) { ioctl(bs->fd, BINDER_SET_MAX_THREADS, &threads); } 记得在在binder.h中声明 D:\4412\APP_0003_Binder_C_App(2)\test_server.c 2.收到BR_SPAWN_LOOPER后创建新线程 3.新线程发出ioctl:BC_R

9.5 Binder系统_驱动情景分析_transaction_stack机制

参考文章:http://www.cnblogs.com/samchen2009/p/3316001.html test_server服务进程可能有多个线程,而在发送数据的时候handle只表示了那个进程 (1)发给谁?handle只表示了那个进程,数据是发给进程还是某个线程 一般数据放在binder_proc的todo链表,其会唤醒等待与binder_proc.wait上的空闲线程: 对于双向传输,则放在binder_thread.todo链表上,然后唤醒该线程(用transaction_sta

第6课第2节_Binder系统_驱动情景分析_打印数据交互过程

添加宏: 功能:把NAME(n) 中的n作为字符串返回,eg:BR_NOOP作为字符串返回 BR开头:Binder--->IPC BC开头:IPC------>Binder #define NAME(n) case n: return #n const char *binder_cmd_name(uint32_t cmd) { switch(cmd) { NAME(BR_NOOP); NAME(BR_TRANSACTION_COMPLETE); NAME(BR_INCREFS); NAME(B

Android : 跟我学Binder --- (4) 驱动情景分析

目录: Android : 跟我学Binder --- (1) 什么是Binder IPC?为何要使用Binder机制? Android : 跟我学Binder --- (2) AIDL分析及手动实现 Android : 跟我学Binder --- (3) C程序示例 Android : 跟我学Binder --- (4) 驱动情景分析 Android : 跟我学Binder --- (5) server的多线程实现(未写) Android : 跟我学Binder --- (6) c++实现_(

[RK3288][Android6.0] 系统按键驱动流程分析【转】

本文转载自:http://blog.csdn.net/kris_fei/article/details/77894406 Rockchip的按键驱动位于 kernel/drivers/input/keyboard/rk_keys.c 默认支持的keys在dts中定义: 其中power key作为普通gpio,具有唤醒功能.而其他按键比如,volume up/down 可以通过adc精确读取到gpio的电压值,原理图如下:   和一般的按键一样,驱动是通过内核input子系统来将keys注册供用户

读android系统源码情景分析笔记(一)

android2.3系统驱动模块由内核模块,硬件抽象模块,用户调用模块(jni)组成,内核模块和linux一致,硬件抽象模块主要需要定义两个结构:hw_module_t和hw_device_t. hw_module_t包含模块id,版本号,署名和一个函数指针: int open (struct hw_module_t* module, const char* id, struct hw_device_t** device); hw_device_t包含版本,hw_module_t的引用和一个函数

9.7 Binder系统_c++实现_内部机制1

1. 内部机制_回顾binder框架关键点 binder进程通讯过程情景举例: test_server通过addservice向service_manager注册服务 test_client通过getservice向service_manager获取服务 然后test_client使用服务和test_server通讯 在上述通讯过程中涉及的对驱动访问: (1)注册服务过程add_service a.test_server为每个服务构造一个flat_binder_object结构体,不同服务结构体

《Android系统源代码情景分析》连载回忆录:灵感之源

上个月,在花了一年半时间之后,写了55篇文章,分析完成了Chromium在Android上的实现,以及Android基于Chromium实现的WebView.学到了很多东西,不过也挺累的,平均不到两个星期一篇文章.本来想休息一段时间后,再继续分析Chromium使用的JS引擎V8.不过某天晚上,躺在床上睡不着,鬼使神差想着去创建一个个人站点,用来连载<Android系统源代码情景分析>一书的内容. 事情是这样的,躺在床上睡不着,就去申请了一个域名,0xcc0xcd.com.域名申请到了,总不能

Linux MTD子系统 _从模型分析到Flash驱动模板

MTD(Memory Technology Device)即常说的Flash等使用存储芯片的存储设备,MTD子系统对应的是块设备驱动框架中的设备驱动层,可以说,MTD就是针对Flash设备设计的标准化硬件驱动框架.本文基于3.14内核,讨论MTD驱动框架. MTD子系统框架 设备节点层:MTD框架可以在/dev下创建字符设备节点(主设备号90)以及块设备节点(主设备号31), 用户通过访问此设备节点即可访问MTD字符设备或块设备. MTD设备层: 基于MTD原始设备, Linux在这一层次定义出