首页 > 代码库 > adb命令执行过程解析

adb命令执行过程解析

本文将以"adb connect "和"adb shell"两个命令为例,解析adb命令的实现过程。

 

一、adb connect命令执行过程

 

目前adb支持两种形式建立host端和device端的连接:USB和网络。
 
adb connect命令的作用就是建立host和device之间的TCP/IP连接。

 

1、client端
adb_commnadline() -> adb_query() -> adb_connect("host:connect:xx.xx.xx.xx") ->
 
_adb_connect("host:connect:xx.xx.xx.xx") -> writex(fd, ...) ,
 
其中fd是service对5037端口进行监听的描述符。
 
2、service端
client端发来的数据 -> local_socket_event_func() -> smart_socket_enqueue() -> create_host_service_socket()
 
-> host_service_to_socket() ->connect_service() ,
 
conncet_service()中会与xx.xx.xx.xx.:5555建立socket连接,然后通过register_socket_transport()创建对这个socket的
 
听。 
adb connect命令处理相对来说比较简单,只涉及client和service端。 另外一些复杂的命令最后会由server端处理,
 
比如adb shell 。
 

二、adb shell命令执行过程(以通过网络方式连接为例)

 

1、client端

adb_commandline() -> interactive_shell() -> adb_connect("shell:") -> _adb_connect("shell:")

->socket_loopback_client(),

 
这样就跟本地的service建立了一个socket连接(通过本地的5037端口),然后开始向service端发送数据。
2、service端
在上一篇<<Android ADB实现解析>>中讲到,service端代码执行install_listener(local_name, "*smartsocket*", NULL, 0)
 
之后,就开始监听本地5037端口,处理函数设置为ss_listener_event_func()。因此,这时service端收到client的数据,将
 
触发ss_listener_event_func() , 该函数中通过create_local_socket()和connect_to_smartsocket构造一个
 
asokcet(关联5037端口),  这个asocket负责与client端通信,通过fevent_install()设置监听,回调处理函数为
 
local_socket_event_func()。local_socket_event_func()对应进入FDE_READ处理部分,先创建一个apacket, 再调用
 
s->peer->enqueue(), 在前面的connect_to_smartsocket()中, s->peer已经指向了ss, 所以调用ss->enqueue函数,也就是
 
smart_socket_enqueue(), 如果收到的数据是"shell" ,就调用connect_to_remote(), 这时service端将向server端发送
 
A_OPEN命令开始一系列通讯。
3、server端
同样是在上一篇<<Android ADB实现解析>>中讲到, server端代码执行local_init()之后,会开始监听本地5555端口。因此,
 
当收到第二步中发来的数据后,output_thread先读取数据,触发transport_socket_events() -> handle_packet() ->
 
create_local_service_socket() -> service_to_fd() -> create_subproc_thread(),
 
create_subproc_thread()将fork一个进程执行exec /system/bin/sh。
 
完成这些之后, client端就出现shell的提示符, 这以后的shell命令就通过socket发送到server, 由server端新fork的
 
线程处理,将结果再通过socket返回client端显示。
 
三、小结
通过以上两个命令的解析,再结合上一篇<<Android ADB实现解析>>, 对adb中命令的实现过程已经有了大概的了解,其它
 
命令的处理类似。 但整个adb系统比较复杂,两篇文章只讲解了一个粗略的结构,许多细节没有一一解析,后续如果有机会,
 
将再就某些细节部分作深入研究。

adb命令执行过程解析