本文转载自:http://blog.csdn.net/wlwl0071986/article/details/50935496

一、adb守护进程的初始化

源码路径:~/system/core/adb/adb.c

int main(int argc, char **argv)

---> start_device_log()

---> property_get("persist.adb.trace_mask", value, "")  // 如果定义了该属性,则打开对应adb log开关

---> adb_main(0, DEFAULT_ADB_PORT)

---> init_transport_registration()  //在注册adb传输通道之前,初始化注册通道的处理函数

---> property_get("service.adb.tcp.port", value, "")

---> local_init(port)  //如果定义了该属性,则使用指定接口通过tcp连接adbd

---> adb_thread_create(&thr, server_socket_thread, (void *)port)  //创建adbd socket传输线程

---> adb_socket_accept(serverfd, &addr, &alen)  //侦听来自adb server的连接请求

---> register_socket_transport(fd, "host", port, 1)  //如果连接成功,

//则注册一个socket传输通道和server进行命令交互

---> access("/dev/android_adb", F_OK)

---> usb_init()  //如果没有设置tcp端口,并且android_adb存在,则使用usb连接adbd

---> adb_thread_create(&tid, usb_open_thread, h)  //创建打开android_adb文件的线程

---> usb_open_thread()

---> unix_open("/dev/android_adb", O_RDWR) //打开android_adb

---> register_usb_transport(usb, 0, 1)

---> init_usb_transport(...)  //初始化usb传输通道的数据结构

---> register_transport(t)  //往transport_registration_send描述符写注册命令

---> transport_registration_recv()  //处理函数通过transport_registration_recv描述符接收到的命令

---> adb_thread_create(&input_thread_ptr, input_thread, t)  //创建adb输入通道

---> adb_thread_create(&output_thread_ptr, output_thread, t)  //创建adb输出通道

以上为adb守护进程初始化的大致流程,创建传输通道的细节,大家可以跟踪代码看看。

二、adb的运行机制和框架结构

下面以一张图来进行分析:

完整的数据处理流程:

1:PC端adb server发送cmd到小机端

2:adbd(adb daemon)的output thread从/dev/android_usb读取到cmd并解析

(adbd和内核usb driver通过/dev/android_usb进行数据交互)

3:output_thread将解析的cmd写到socketpair的A端

4:fdevent_loop通过select socketpair的B端,得知A端有数据写入,B端可读,然后读取cmd,

进行处理(handle_packet)

5:处理完后将结果写到socketpair的B端

6:Input_thread阻塞式读取socketpair的A端

7:Input_thread读取到数据后,写入/dev/android_usb

8:由usb driver将response发给pc端

output_thread负责读取/dev/android_usb,Input_thread负责写入

ADB运行框架原理解析【转】的更多相关文章

  1. Linux入门:运行级别解析

    Linux入门:运行级别解析   一.查看当前运行级别 Ubuntu中,runlevel命令 可以查看当前运行级别: CentOS中,who -r 命令查看当前运行级别:   www.2cto.com ...

  2. [MapReduce_3] MapReduce 程序运行流程解析

    0. 说明 Word Count 程序运行流程解析 &&  MapReduce 程序运行流程解析 1. Word Count 程序运行流程解析 2. MapReduce 程序运行流程图

  3. ADB 运行原理

    ADB基本命令和简介 ADB就是Android Debug Bridge,Android调试桥的意思,很形象.需要在电脑上安装SDK Platform Tools 对应的版本才能使用 基于ADB的工具 ...

  4. (转)Apache和Nginx运行原理解析

    Apache和Nginx运行原理解析 原文:https://www.server110.com/nginx/201402/6543.html Web服务器 Web服务器也称为WWW(WORLD WID ...

  5. View Animation 运行原理解析

    Android 平台目前提供了两大类动画,在 Android 3.0 之前,一大类是 View Animation,包括 Tween animation(补间动画),Frame animation(帧 ...

  6. 老李推荐:第8章2节《MonkeyRunner源码剖析》MonkeyRunner启动运行过程-解析处理命令行参数 2

    我们这一节会先去分析下monkeyrunner是如何对参数进行处理的,我们跳转到MonkeyRunnerOptions这个类里面的processOptions这个方法: 93   public sta ...

  7. MapReduce 运行全过程解析

    关注公众号,大家可以在公众号后台回复“博客园”,免费获得作者 Java 知识体系/面试必看资料. 前言 前面我们讲了 MapReduce 的编程模型,我们知道他主要分成两大阶段来完成一项任务,一是 m ...

  8. php运行步骤解析

    2000年, PHP4.0发布的时候,引入了Zend Engine. Zend引擎把PHP代码的执行切分成两个阶段: 一. Zend Engine 解析PHP代码并生成二进制中间码Zend Opcod ...

  9. 转:Apache和Nginx运行原理解析

    Web服务器 Web服务器也称为WWW(WORLD WIDE WEB)服务器,主要功能是提供网上信息浏览服务. 应用层使用HTTP协议. HTML文档格式. 浏览器统一资源定位器(URL). Web服 ...

随机推荐

  1. uva 11762 数学期望+记忆化搜索

    题目大意:给一个正整数N,每次可以在不超过N的素数中随机选择一个P,如果P是N的约数,则把N变成N/p,否则N不变,问平均情况下需要多少次随机选择,才能把N变成1? 分析:根据数学期望的线性和全期望公 ...

  2. C Looooops(poj 2115)

    大致题意: 对于C的for(i=A ; i!=B ;i +=C)循环语句,问在k位存储系统中循环几次才会结束. 若在有限次内结束,则输出循环次数. 否则输出死循环. 解题思路: 题意不难理解,只是利用 ...

  3. Idea配置Tomcat以及maven

    配置Tamcat Run-->Edit Configurations +-->如果列表里没有tomcat-->点击33 items more irrelevant继续寻找--> ...

  4. Codeforces 665C Simple Strings【暴力,贪心】

    题目链接: http://codeforces.com/contest/665/problem/C 题意: 改变最少的字符,使得最终序列无相同的连续的字符. 分析: 对每一个与前一个字符相同的字符,枚 ...

  5. java实现简单的算法

    排序大的分类可以分为两种:内排序和外排序.在排序过程中,全部记录存放在内存,则称为内排序,如果排序过程中需要使用外存,则称为外排序.下面讲的排序都是属于内排序. 内排序有可以分为以下几类: (1).插 ...

  6. java集合系列之HashMap源码

    java集合系列之HashMap源码 HashMap的源码可真不好消化!!! 首先简单介绍一下HashMap集合的特点.HashMap存放键值对,键值对封装在Node(代码如下,比较简单,不再介绍)节 ...

  7. 数字巨头们的表态--<大佬与大话>

    作者魏武挥 类别非虚构 / 中篇 本书为作者为<21世纪商业评论>的专栏文章合集,共20篇,算是第一卷吧,后期还会写下去.这个专栏的名字叫<大佬与大话>,专门收集TMT圈子商业 ...

  8. Matlab多项式拟合測试

    x=0:0.2:4; %生成等差数列 rnd=rand(1,size(x,2))*5; %生成一组随机数 y=x.*x.*x+x.*x+6+rnd; %生成y=x^3+x^2+6函数在垂直方向5个尺度 ...

  9. 【effective c++】定制new和delete

    条款49: 了解new-handler的行为 operator new 和 operator delete只适合用来分配单一对象.array所用的内存由operator new[]分配出来,并由ope ...

  10. memcached优化方法

    工作原理     基本概念:slab,page.chunk.     slab,是一个逻辑概念. 它是在启动memcached实例的时候预处理好的,每一个slab相应一个chunk size.也就是说 ...