adb.h revision fd96db17b7f07eb6615af01fd1908b74383bf04b
1dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/*
2dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project
3dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project *
4dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
5dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * you may not use this file except in compliance with the License.
6dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * You may obtain a copy of the License at
7dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project *
8dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
9dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project *
10dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
11dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
12dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * See the License for the specific language governing permissions and
14dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * limitations under the License.
15dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project */
16dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
17dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#ifndef __ADB_H
18dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define __ADB_H
19dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
20dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#include <limits.h>
21dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
22408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall#include "transport.h"  /* readx(), writex() */
23408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall
24dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define MAX_PAYLOAD 4096
25dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
26dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define A_SYNC 0x434e5953
27dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define A_CNXN 0x4e584e43
28dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define A_OPEN 0x4e45504f
29dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define A_OKAY 0x59414b4f
30dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define A_CLSE 0x45534c43
31dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define A_WRTE 0x45545257
32dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
33dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define A_VERSION 0x01000000        // ADB protocol version
34dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
35dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define ADB_VERSION_MAJOR 1         // Used for help/version information
36dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define ADB_VERSION_MINOR 0         // Used for help/version information
37dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
3807edefe4cecbddaf6282e556e04a1e1ef21c404aMike Lockwood#define ADB_SERVER_VERSION    29    // Increment this when we want to force users to start a new adb server
39dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
40dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct amessage amessage;
41dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct apacket apacket;
42dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct asocket asocket;
43dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct alistener alistener;
44dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct aservice aservice;
45dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct atransport atransport;
46dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct adisconnect  adisconnect;
47dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct usb_handle usb_handle;
48dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
49dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct amessage {
50dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned command;       /* command identifier constant      */
51dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned arg0;          /* first argument                   */
52dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned arg1;          /* second argument                  */
53dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned data_length;   /* length of payload (0 is allowed) */
54dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned data_check;    /* checksum of data payload         */
55dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned magic;         /* command ^ 0xffffffff             */
56dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
57dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
58dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct apacket
59dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project{
60dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    apacket *next;
61dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
62dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned len;
63dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned char *ptr;
64dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
65dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    amessage msg;
66dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned char data[MAX_PAYLOAD];
67dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
68dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
69dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* An asocket represents one half of a connection between a local and
70dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** remote entity.  A local asocket is bound to a file descriptor.  A
71dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** remote asocket is bound to the protocol engine.
72dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
73dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct asocket {
74dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* chain pointers for the local/remote list of
75dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** asockets that this asocket lives in
76dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
77dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    asocket *next;
78dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    asocket *prev;
79dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
80dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* the unique identifier for this asocket
81dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
82dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned id;
83dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
84dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* flag: set when the socket's peer has closed
85dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** but packets are still queued for delivery
86dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
87dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int    closing;
88dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
89f366b3698b409405e1ee88476d1186f29fe14b06Benoit Goby        /* flag: quit adbd when both ends close the
90f366b3698b409405e1ee88476d1186f29fe14b06Benoit Goby        ** local service socket
91f366b3698b409405e1ee88476d1186f29fe14b06Benoit Goby        */
92f366b3698b409405e1ee88476d1186f29fe14b06Benoit Goby    int    exit_on_close;
93f366b3698b409405e1ee88476d1186f29fe14b06Benoit Goby
94dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* the asocket we are connected to
95dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
96dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
97dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    asocket *peer;
98dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
99dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* For local asockets, the fde is used to bind
100dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** us to our fd event system.  For remote asockets
101dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** these fields are not used.
102dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
103dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    fdevent fde;
104dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int fd;
105dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
106dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* queue of apackets waiting to be written
107dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
108dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    apacket *pkt_first;
109dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    apacket *pkt_last;
110dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
111dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* enqueue is called by our peer when it has data
112dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** for us.  It should return 0 if we can accept more
113dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** data or 1 if not.  If we return 1, we must call
114dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** peer->ready() when we once again are ready to
115dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** receive data.
116dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
117dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int (*enqueue)(asocket *s, apacket *pkt);
118dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
119dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* ready is called by the peer when it is ready for
120dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** us to send data via enqueue again
121dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
122dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void (*ready)(asocket *s);
123dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
124dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* close is called by the peer when it has gone away.
125dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** we are not allowed to make any further calls on the
126dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** peer once our close method is called.
127dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
128dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void (*close)(asocket *s);
129dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
130dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* socket-type-specific extradata */
131dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void *extra;
132dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
1330e7c4274c687446dbe30a814278d7a6b99da8c4eJP Abgrall    	/* A socket is bound to atransport */
134dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    atransport *transport;
135dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
136dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
137dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
138dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* the adisconnect structure is used to record a callback that
139dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** will be called whenever a transport is disconnected (e.g. by the user)
140dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** this should be used to cleanup objects that depend on the
141dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** transport (e.g. remote sockets, listeners, etc...)
142dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
143dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct  adisconnect
144dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project{
145dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void        (*func)(void*  opaque, atransport*  t);
146dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void*         opaque;
147dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    adisconnect*  next;
148dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    adisconnect*  prev;
149dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
150dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
151dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
152dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* a transport object models the connection to a remote device or emulator
153dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** there is one transport per connected device/emulator. a "local transport"
154dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** connects through TCP (for the emulator), while a "usb transport" through
155dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** USB (for real devices)
156dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project**
157dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** note that kTransportHost doesn't really correspond to a real transport
158dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** object, it's a special value used to indicate that a client wants to
159dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** connect to a service implemented within the ADB server itself.
160dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
161dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef enum transport_type {
162dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        kTransportUsb,
163dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        kTransportLocal,
164dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        kTransportAny,
165dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        kTransportHost,
166dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project} transport_type;
167dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
168dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct atransport
169dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project{
170dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    atransport *next;
171dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    atransport *prev;
172dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
173dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int (*read_from_remote)(apacket *p, atransport *t);
174dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int (*write_to_remote)(apacket *p, atransport *t);
175dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void (*close)(atransport *t);
176dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void (*kick)(atransport *t);
177dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
178dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int fd;
179dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int transport_socket;
180dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    fdevent transport_fde;
181dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int ref_count;
182dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned sync_token;
183dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int connection_state;
184dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    transport_type type;
185dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
186dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* usb handle or socket fd as needed */
187dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    usb_handle *usb;
188dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int sfd;
189dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
190dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* used to identify transports for clients */
191dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    char *serial;
192dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    char *product;
193e109d266c12c5f537d429ca4b892f2719e02c2daScott Anderson    char *devpath;
194d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzinger    int adb_port; // Use for emulators (local transport)
195dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
196dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* a list of adisconnect callbacks called when the transport is kicked */
197dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int          kicked;
198dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    adisconnect  disconnects;
199dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
200dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
201dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
202dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* A listener is an entity which binds to a local port
203dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** and, upon receiving a connection on that port, creates
204dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** an asocket to connect the new local connection to a
205dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** specific remote service.
206dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project**
207dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** TODO: some listeners read from the new connection to
208dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** determine what exact service to connect to on the far
209dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** side.
210dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
211dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct alistener
212dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project{
213dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    alistener *next;
214dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    alistener *prev;
215dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
216dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    fdevent fde;
217dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int fd;
218dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
219dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    const char *local_name;
220dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    const char *connect_to;
221dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    atransport *transport;
222dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    adisconnect  disconnect;
223dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
224dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
225dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
226dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid print_packet(const char *label, apacket *p);
227dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
228dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket *find_local_socket(unsigned id);
229dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid install_local_socket(asocket *s);
230dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid remove_socket(asocket *s);
231dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid close_all_sockets(atransport *t);
232dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
233dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define  LOCAL_CLIENT_PREFIX  "emulator-"
234dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
235dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket *create_local_socket(int fd);
236dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket *create_local_service_socket(const char *destination);
237dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
238dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket *create_remote_socket(unsigned id, atransport *t);
239dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid connect_to_remote(asocket *s, const char *destination);
240dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid connect_to_smartsocket(asocket *s);
241dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
242dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid fatal(const char *fmt, ...);
243dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid fatal_errno(const char *fmt, ...);
244dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
245dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid handle_packet(apacket *p, atransport *t);
246dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid send_packet(apacket *p, atransport *t);
247dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
2483166410a82f43d39201be98a8d35c51baa86cb53Alexey Tarasovvoid get_my_path(char *s, size_t maxLen);
249a84a42eb20d43ffa2695a69d583a6e09532b49d9Stefan Hilzingerint launch_server(int server_port);
250a84a42eb20d43ffa2695a69d583a6e09532b49d9Stefan Hilzingerint adb_main(int is_daemon, int server_port);
251dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
252dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
253dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* transports are ref-counted
254dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** get_device_transport does an acquire on your behalf before returning
255dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
256dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid init_transport_registration(void);
257e109d266c12c5f537d429ca4b892f2719e02c2daScott Andersonint  list_transports(char *buf, size_t  bufsize, int show_devpath);
258dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid update_transports(void);
259dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
260dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket*  create_device_tracker(void);
261dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
262dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* Obtain a transport from the available transports.
263dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** If state is != CS_ANY, only transports in that state are considered.
264dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** If serial is non-NULL then only the device with that serial will be chosen.
265dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** If no suitable transport is found, error is set.
266dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
267dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectatransport *acquire_one_transport(int state, transport_type ttype, const char* serial, char **error_out);
268dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid   add_transport_disconnect( atransport*  t, adisconnect*  dis );
269dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid   remove_transport_disconnect( atransport*  t, adisconnect*  dis );
270dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid   run_transport_disconnects( atransport*  t );
271dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid   kick_transport( atransport*  t );
272dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
273dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* initialize a transport object's func pointers and state */
274d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzinger#if ADB_HOST
275d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzingerint get_available_local_transport_index();
276d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzinger#endif
2772f38b699713dc2587a771bd5d4c6a47329728f5eMike Lockwoodint  init_socket_transport(atransport *t, int s, int port, int local);
27895b837d38b730353af79f8669b5166007e038ac3Mike Lockwoodvoid init_usb_transport(atransport *t, usb_handle *usb, int state);
279dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
280dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* for MacOS X cleanup */
281dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid close_usb_devices();
282dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
283dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* cause new transports to be init'd and added to the list */
2842f38b699713dc2587a771bd5d4c6a47329728f5eMike Lockwoodvoid register_socket_transport(int s, const char *serial, int port, int local);
28574d7ff8cfd490852d3df1c4b9d8a21beed619caaMike Lockwood
286cbbe79add1410b53ec65936cfb1b74cac68467f0Mike Lockwood/* these should only be used for the "adb disconnect" command */
28774d7ff8cfd490852d3df1c4b9d8a21beed619caaMike Lockwoodvoid unregister_transport(atransport *t);
288cbbe79add1410b53ec65936cfb1b74cac68467f0Mike Lockwoodvoid unregister_all_tcp_transports();
28974d7ff8cfd490852d3df1c4b9d8a21beed619caaMike Lockwood
290e109d266c12c5f537d429ca4b892f2719e02c2daScott Andersonvoid register_usb_transport(usb_handle *h, const char *serial, const char *devpath, unsigned writeable);
29195b837d38b730353af79f8669b5166007e038ac3Mike Lockwood
29295b837d38b730353af79f8669b5166007e038ac3Mike Lockwood/* this should only be used for transports with connection_state == CS_NOPERM */
29395b837d38b730353af79f8669b5166007e038ac3Mike Lockwoodvoid unregister_usb_transport(usb_handle *usb);
294dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
29574d7ff8cfd490852d3df1c4b9d8a21beed619caaMike Lockwoodatransport *find_transport(const char *serial);
296d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzinger#if ADB_HOST
297d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzingeratransport* find_emulator_transport_by_adb_port(int adb_port);
298d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzinger#endif
29974d7ff8cfd490852d3df1c4b9d8a21beed619caaMike Lockwood
300dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint service_to_fd(const char *name);
301dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#if ADB_HOST
302dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket *host_service_to_socket(const char*  name, const char *serial);
303dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
304dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
305dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#if !ADB_HOST
306dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint       init_jdwp(void);
307dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket*  create_jdwp_service_socket();
308dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket*  create_jdwp_tracker_service_socket();
309dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint       create_jdwp_connection_fd(int  jdwp_pid);
310dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
311dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
312dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#if !ADB_HOST
313702967afb1bebc97c0b8a23c075d4932820ef7a3Christopher Tatetypedef enum {
314702967afb1bebc97c0b8a23c075d4932820ef7a3Christopher Tate    BACKUP,
315702967afb1bebc97c0b8a23c075d4932820ef7a3Christopher Tate    RESTORE
316702967afb1bebc97c0b8a23c075d4932820ef7a3Christopher Tate} BackupOperation;
317702967afb1bebc97c0b8a23c075d4932820ef7a3Christopher Tateint backup_service(BackupOperation operation, char* args);
318dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid framebuffer_service(int fd, void *cookie);
319dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid log_service(int fd, void *cookie);
320dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid remount_service(int fd, void *cookie);
321dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectchar * get_log_file_path(const char * log_name);
322dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
323dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
324dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* packet allocator */
325dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectapacket *get_apacket(void);
326dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid put_apacket(apacket *p);
327dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
328dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint check_header(apacket *p);
329dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint check_data(apacket *p);
330dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
331dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* define ADB_TRACE to 1 to enable tracing support, or 0 to disable it */
332dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
333dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define  ADB_TRACE    1
334dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
335dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* IMPORTANT: if you change the following list, don't
336dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * forget to update the corresponding 'tags' table in
337dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * the adb_trace_init() function implemented in adb.c
338dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project */
339dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef enum {
340408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall    TRACE_ADB = 0,   /* 0x001 */
341dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_SOCKETS,
342dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_PACKETS,
343dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_TRANSPORT,
344408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall    TRACE_RWX,       /* 0x010 */
345dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_USB,
346dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_SYNC,
347dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_SYSDEPS,
348408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall    TRACE_JDWP,      /* 0x100 */
349408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall    TRACE_SERVICES,
350dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project} AdbTrace;
351dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
352dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#if ADB_TRACE
353dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
35428781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine#if !ADB_HOST
35528781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine/*
35628781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine * When running inside the emulator, guest's adbd can connect to 'adb-debug'
35728781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine * qemud service that can display adb trace messages (on condition that emulator
35828781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine * has been started with '-debug adb' option).
35928781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine */
36028781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine
36128781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine/* Delivers a trace message to the emulator via QEMU pipe. */
36228781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkinevoid adb_qemu_trace(const char* fmt, ...);
36328781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine/* Macro to use to send ADB trace messages to the emulator. */
36428781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine#define DQ(...)    adb_qemu_trace(__VA_ARGS__)
36528781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine#else
36628781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine#define DQ(...) ((void)0)
36728781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine#endif  /* !ADB_HOST */
36828781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine
369408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall  extern int     adb_trace_mask;
370408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall  extern unsigned char    adb_trace_output_count;
371dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project  void    adb_trace_init(void);
372dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
373dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#  define ADB_TRACING  ((adb_trace_mask & (1 << TRACE_TAG)) != 0)
374dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
375dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project  /* you must define TRACE_TAG before using this macro */
376408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall#  define  D(...)                                      \
377408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall        do {                                           \
378408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall            if (ADB_TRACING) {                         \
379408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                int save_errno = errno;                \
380408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                adb_mutex_lock(&D_lock);               \
381408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                fprintf(stderr, "%s::%s():",           \
382408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                        __FILE__, __FUNCTION__);       \
383408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                errno = save_errno;                    \
384408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                fprintf(stderr, __VA_ARGS__ );         \
385408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                fflush(stderr);                        \
386408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                adb_mutex_unlock(&D_lock);             \
387408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                errno = save_errno;                    \
388408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall           }                                           \
389408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall        } while (0)
390408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall#  define  DR(...)                                     \
391dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        do {                                           \
392408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall            if (ADB_TRACING) {                         \
393408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                int save_errno = errno;                \
394408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                adb_mutex_lock(&D_lock);               \
395408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                errno = save_errno;                    \
396dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project                fprintf(stderr, __VA_ARGS__ );         \
397408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                fflush(stderr);                        \
398408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                adb_mutex_unlock(&D_lock);             \
399408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                errno = save_errno;                    \
400408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall           }                                           \
401dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        } while (0)
402dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#else
403dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#  define  D(...)          ((void)0)
404408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall#  define  DR(...)         ((void)0)
405dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#  define  ADB_TRACING     0
406dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
407dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
408dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
409dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#if !TRACE_PACKETS
410dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define print_packet(tag,p) do {} while (0)
411dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
412dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
413c318833b359164f25d7a93f6395c0cad787bacd7John Michelau#if ADB_HOST_ON_TARGET
414c318833b359164f25d7a93f6395c0cad787bacd7John Michelau/* adb and adbd are coexisting on the target, so use 5038 for adb
415c318833b359164f25d7a93f6395c0cad787bacd7John Michelau * to avoid conflicting with adbd's usage of 5037
416c318833b359164f25d7a93f6395c0cad787bacd7John Michelau */
417c318833b359164f25d7a93f6395c0cad787bacd7John Michelau#  define DEFAULT_ADB_PORT 5038
418c318833b359164f25d7a93f6395c0cad787bacd7John Michelau#else
419c318833b359164f25d7a93f6395c0cad787bacd7John Michelau#  define DEFAULT_ADB_PORT 5037
420c318833b359164f25d7a93f6395c0cad787bacd7John Michelau#endif
421c318833b359164f25d7a93f6395c0cad787bacd7John Michelau
422a84a42eb20d43ffa2695a69d583a6e09532b49d9Stefan Hilzinger#define DEFAULT_ADB_LOCAL_TRANSPORT_PORT 5555
423dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
424a481d096feba7cf6e61d54e416a68e2d46498df1Xavier Ducrohet#define ADB_CLASS              0xff
425a481d096feba7cf6e61d54e416a68e2d46498df1Xavier Ducrohet#define ADB_SUBCLASS           0x42
426a481d096feba7cf6e61d54e416a68e2d46498df1Xavier Ducrohet#define ADB_PROTOCOL           0x1
4273fd82b8861aa410fab7785074941b459d92220c1Dima Zavin
428dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
429cef31a02544d91b85481a5fa032b6126dbb32365Mike Lockwoodvoid local_init(int port);
430dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint  local_connect(int  port);
431d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzingerint  local_connect_arbitrary_ports(int console_port, int adb_port);
432dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
433dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* usb host/client interface */
434dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid usb_init();
435dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid usb_cleanup();
436dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint usb_write(usb_handle *h, const void *data, int len);
437dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint usb_read(usb_handle *h, void *data, int len);
438dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint usb_close(usb_handle *h);
439dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid usb_kick(usb_handle *h);
440dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
441dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* used for USB device detection */
442a09fbd164d2e088bc5433d310e25640ae048d47dXavier Ducrohet#if ADB_HOST
443dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint is_adb_interface(int vid, int pid, int usb_class, int usb_subclass, int usb_protocol);
444a09fbd164d2e088bc5433d310e25640ae048d47dXavier Ducrohet#endif
445dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
446dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectunsigned host_to_le32(unsigned n);
447dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint adb_commandline(int argc, char **argv);
448dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
449dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint connection_state(atransport *t);
450dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
451dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_ANY       -1
452dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_OFFLINE    0
453dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_BOOTLOADER 1
454dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_DEVICE     2
455dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_HOST       3
456dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_RECOVERY   4
45795b837d38b730353af79f8669b5166007e038ac3Mike Lockwood#define CS_NOPERM     5 /* Insufficient permissions to communicate with the device */
458447f061da19fe46bae35f1cdd93eeb16bc225463Doug Zongker#define CS_SIDELOAD   6
459dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
460dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectextern int HOST;
461408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrallextern int SHELL_EXIT_NOTIFY_FD;
462dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
463dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CHUNK_SIZE (64*1024)
464dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
465fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#if !ADB_HOST
466fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_ADB_PATH     "/dev/android_adb"
467fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz
468fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_FFS_ADB_PATH  "/dev/usb-ffs/adb/"
469fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_FFS_ADB_EP(x) USB_FFS_ADB_PATH#x
470fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz
471fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_FFS_ADB_EP0   USB_FFS_ADB_EP(ep0)
472fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_FFS_ADB_OUT   USB_FFS_ADB_EP(ep1)
473fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_FFS_ADB_IN    USB_FFS_ADB_EP(ep2)
474fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#endif
475fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz
476dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint sendfailmsg(int fd, const char *reason);
477dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint handle_host_request(char *service, transport_type ttype, char* serial, int reply_fd, asocket *s);
478dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
479dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
480