本文转载自: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. Spoj-BITDIFF Bit Difference

    Given an integer array of N integers, find the sum of bit differences in all the pairs that can be f ...

  2. P3102 [USACO14FEB]秘密代码Secret Code

    题目描述 Farmer John has secret message that he wants to hide from his cows; the message is a string of ...

  3. UVa1363 Joseph's Problem

    把整个序列进行拆分成[k,k/2),[k/2, k/3), [k/3,k/4)...k[k/a, k/b)的形式,对于k/i(整除)相同的项,k%i成等差数列. /*by SilverN*/ #inc ...

  4. net3:Calendar控件的使用

    原文发布时间为:2008-07-29 -- 来源于本人的百度文章 [由搬家工具导入] using System;using System.Data;using System.Configuration ...

  5. leetcode 15. 3Sum 二维vector

    传送门 15. 3Sum My Submissions Question Total Accepted: 108534 Total Submissions: 584814 Difficulty: Me ...

  6. EGO V2

    Original EGO: mkdir -p ~/Library/Developer/Xcode/UserData/FontAndColorThemes; cd ~/Library/Developer ...

  7. ajax 提交数组,mybatis 数组接受

    function jinxingzhong() { // 配送单编号:psd2017090103 var divHtml = ""; $.ajax({ type: "PO ...

  8. [Bzoj3675][Apio2014]序列分割(斜率优化)

    3675: [Apio2014]序列分割 Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 4021  Solved: 1569[Submit][Stat ...

  9. UOJ 41. 矩阵变换

    Discription 给出一个 N 行 M 列的矩阵A, 保证满足以下性质:     1.M>N.     2.矩阵中每个数都是 [0,N] 中的自然数.     3.每行中, [1,N] 中 ...

  10. Java8 时区DateTime API

    原文:http://www.yiibai.com/java8/java8_zoneddateapi.html 时区日期时间的API正在使用当时区要被考虑时. 让我们来看看他们的操作. 选择使用任何编辑 ...