adb.h revision 64b3103017cb9038c5fb7e3601f51c6a458bed06
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
32d5fcafaf41f8ec90986c813f75ec78402096af2dBenoit Goby#define A_AUTH 0x48545541
33dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
34dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define A_VERSION 0x01000000        // ADB protocol version
35dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
36dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define ADB_VERSION_MAJOR 1         // Used for help/version information
37dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define ADB_VERSION_MINOR 0         // Used for help/version information
38dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
3964b3103017cb9038c5fb7e3601f51c6a458bed06Benoit Goby#define ADB_SERVER_VERSION    31    // Increment this when we want to force users to start a new adb server
40dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
41dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct amessage amessage;
42dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct apacket apacket;
43dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct asocket asocket;
44dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct alistener alistener;
45dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct aservice aservice;
46dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct atransport atransport;
47dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct adisconnect  adisconnect;
48dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef struct usb_handle usb_handle;
49dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
50dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct amessage {
51dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned command;       /* command identifier constant      */
52dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned arg0;          /* first argument                   */
53dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned arg1;          /* second argument                  */
54dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned data_length;   /* length of payload (0 is allowed) */
55dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned data_check;    /* checksum of data payload         */
56dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned magic;         /* command ^ 0xffffffff             */
57dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
58dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
59dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct apacket
60dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project{
61dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    apacket *next;
62dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
63dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned len;
64dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned char *ptr;
65dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
66dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    amessage msg;
67dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned char data[MAX_PAYLOAD];
68dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
69dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
70dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* An asocket represents one half of a connection between a local and
71dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** remote entity.  A local asocket is bound to a file descriptor.  A
72dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** remote asocket is bound to the protocol engine.
73dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
74dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct asocket {
75dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* chain pointers for the local/remote list of
76dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** asockets that this asocket lives in
77dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
78dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    asocket *next;
79dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    asocket *prev;
80dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
81dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* the unique identifier for this asocket
82dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
83dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned id;
84dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
85dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* flag: set when the socket's peer has closed
86dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** but packets are still queued for delivery
87dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
88dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int    closing;
89dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
90f366b3698b409405e1ee88476d1186f29fe14b06Benoit Goby        /* flag: quit adbd when both ends close the
91f366b3698b409405e1ee88476d1186f29fe14b06Benoit Goby        ** local service socket
92f366b3698b409405e1ee88476d1186f29fe14b06Benoit Goby        */
93f366b3698b409405e1ee88476d1186f29fe14b06Benoit Goby    int    exit_on_close;
94f366b3698b409405e1ee88476d1186f29fe14b06Benoit Goby
95dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* the asocket we are connected to
96dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
97dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
98dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    asocket *peer;
99dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
100dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* For local asockets, the fde is used to bind
101dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** us to our fd event system.  For remote asockets
102dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** these fields are not used.
103dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
104dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    fdevent fde;
105dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int fd;
106dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
107dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* queue of apackets waiting to be written
108dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
109dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    apacket *pkt_first;
110dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    apacket *pkt_last;
111dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
112dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* enqueue is called by our peer when it has data
113dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** for us.  It should return 0 if we can accept more
114dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** data or 1 if not.  If we return 1, we must call
115dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** peer->ready() when we once again are ready to
116dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** receive data.
117dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
118dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int (*enqueue)(asocket *s, apacket *pkt);
119dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
120dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* ready is called by the peer when it is ready for
121dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** us to send data via enqueue again
122dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
123dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void (*ready)(asocket *s);
124dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
125dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* close is called by the peer when it has gone away.
126dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** we are not allowed to make any further calls on the
127dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        ** peer once our close method is called.
128dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        */
129dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void (*close)(asocket *s);
130dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
131dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* socket-type-specific extradata */
132dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void *extra;
133dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
1340e7c4274c687446dbe30a814278d7a6b99da8c4eJP Abgrall    	/* A socket is bound to atransport */
135dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    atransport *transport;
136dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
137dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
138dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
139dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* the adisconnect structure is used to record a callback that
140dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** will be called whenever a transport is disconnected (e.g. by the user)
141dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** this should be used to cleanup objects that depend on the
142dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** transport (e.g. remote sockets, listeners, etc...)
143dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
144dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct  adisconnect
145dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project{
146dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void        (*func)(void*  opaque, atransport*  t);
147dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void*         opaque;
148dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    adisconnect*  next;
149dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    adisconnect*  prev;
150dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
151dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
152dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
153dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* a transport object models the connection to a remote device or emulator
154dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** there is one transport per connected device/emulator. a "local transport"
155dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** connects through TCP (for the emulator), while a "usb transport" through
156dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** USB (for real devices)
157dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project**
158dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** note that kTransportHost doesn't really correspond to a real transport
159dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** object, it's a special value used to indicate that a client wants to
160dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** connect to a service implemented within the ADB server itself.
161dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
162dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef enum transport_type {
163dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        kTransportUsb,
164dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        kTransportLocal,
165dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        kTransportAny,
166dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        kTransportHost,
167dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project} transport_type;
168dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
169d5fcafaf41f8ec90986c813f75ec78402096af2dBenoit Goby#define TOKEN_SIZE 20
170d5fcafaf41f8ec90986c813f75ec78402096af2dBenoit Goby
171dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct atransport
172dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project{
173dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    atransport *next;
174dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    atransport *prev;
175dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
176dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int (*read_from_remote)(apacket *p, atransport *t);
177dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int (*write_to_remote)(apacket *p, atransport *t);
178dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void (*close)(atransport *t);
179dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    void (*kick)(atransport *t);
180dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
181dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int fd;
182dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int transport_socket;
183dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    fdevent transport_fde;
184dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int ref_count;
185dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    unsigned sync_token;
186dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int connection_state;
187d5fcafaf41f8ec90986c813f75ec78402096af2dBenoit Goby    int online;
188dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    transport_type type;
189dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
190dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* usb handle or socket fd as needed */
191dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    usb_handle *usb;
192dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int sfd;
193dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
194dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* used to identify transports for clients */
195dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    char *serial;
196dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    char *product;
197e82c2db05cae70a0490a1f84b7211ef42c329671Scott Anderson    char *model;
198e82c2db05cae70a0490a1f84b7211ef42c329671Scott Anderson    char *device;
199e109d266c12c5f537d429ca4b892f2719e02c2daScott Anderson    char *devpath;
200d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzinger    int adb_port; // Use for emulators (local transport)
201dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
202dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        /* a list of adisconnect callbacks called when the transport is kicked */
203dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int          kicked;
204dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    adisconnect  disconnects;
205d5fcafaf41f8ec90986c813f75ec78402096af2dBenoit Goby
206d5fcafaf41f8ec90986c813f75ec78402096af2dBenoit Goby    void *key;
207d5fcafaf41f8ec90986c813f75ec78402096af2dBenoit Goby    unsigned char token[TOKEN_SIZE];
208d5fcafaf41f8ec90986c813f75ec78402096af2dBenoit Goby    fdevent auth_fde;
209d5fcafaf41f8ec90986c813f75ec78402096af2dBenoit Goby    unsigned failed_auth_attempts;
210dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
211dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
212dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
213dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* A listener is an entity which binds to a local port
214dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** and, upon receiving a connection on that port, creates
215dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** an asocket to connect the new local connection to a
216dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** specific remote service.
217dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project**
218dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** TODO: some listeners read from the new connection to
219dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** determine what exact service to connect to on the far
220dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** side.
221dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
222dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectstruct alistener
223dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project{
224dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    alistener *next;
225dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    alistener *prev;
226dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
227dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    fdevent fde;
228dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    int fd;
229dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
230dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    const char *local_name;
231dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    const char *connect_to;
232dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    atransport *transport;
233dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    adisconnect  disconnect;
234dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project};
235dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
236dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
237dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid print_packet(const char *label, apacket *p);
238dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
239dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket *find_local_socket(unsigned id);
240dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid install_local_socket(asocket *s);
241dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid remove_socket(asocket *s);
242dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid close_all_sockets(atransport *t);
243dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
244dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define  LOCAL_CLIENT_PREFIX  "emulator-"
245dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
246dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket *create_local_socket(int fd);
247dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket *create_local_service_socket(const char *destination);
248dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
249dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket *create_remote_socket(unsigned id, atransport *t);
250dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid connect_to_remote(asocket *s, const char *destination);
251dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid connect_to_smartsocket(asocket *s);
252dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
253dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid fatal(const char *fmt, ...);
254dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid fatal_errno(const char *fmt, ...);
255dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
256dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid handle_packet(apacket *p, atransport *t);
257dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid send_packet(apacket *p, atransport *t);
258dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
2593166410a82f43d39201be98a8d35c51baa86cb53Alexey Tarasovvoid get_my_path(char *s, size_t maxLen);
260a84a42eb20d43ffa2695a69d583a6e09532b49d9Stefan Hilzingerint launch_server(int server_port);
261a84a42eb20d43ffa2695a69d583a6e09532b49d9Stefan Hilzingerint adb_main(int is_daemon, int server_port);
262dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
263dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
264dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* transports are ref-counted
265dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** get_device_transport does an acquire on your behalf before returning
266dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
267dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid init_transport_registration(void);
2682ca3e6b35f79136418ebc32fef57580698dbd045Scott Andersonint  list_transports(char *buf, size_t  bufsize, int long_listing);
269dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid update_transports(void);
270dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
271dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket*  create_device_tracker(void);
272dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
273dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* Obtain a transport from the available transports.
274dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** If state is != CS_ANY, only transports in that state are considered.
275dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** If serial is non-NULL then only the device with that serial will be chosen.
276dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project** If no suitable transport is found, error is set.
277dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project*/
278dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectatransport *acquire_one_transport(int state, transport_type ttype, const char* serial, char **error_out);
279dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid   add_transport_disconnect( atransport*  t, adisconnect*  dis );
280dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid   remove_transport_disconnect( atransport*  t, adisconnect*  dis );
281dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid   run_transport_disconnects( atransport*  t );
282dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid   kick_transport( atransport*  t );
283dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
284dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* initialize a transport object's func pointers and state */
285d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzinger#if ADB_HOST
286d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzingerint get_available_local_transport_index();
287d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzinger#endif
2882f38b699713dc2587a771bd5d4c6a47329728f5eMike Lockwoodint  init_socket_transport(atransport *t, int s, int port, int local);
28995b837d38b730353af79f8669b5166007e038ac3Mike Lockwoodvoid init_usb_transport(atransport *t, usb_handle *usb, int state);
290dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
291dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* for MacOS X cleanup */
292dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid close_usb_devices();
293dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
294dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* cause new transports to be init'd and added to the list */
2952f38b699713dc2587a771bd5d4c6a47329728f5eMike Lockwoodvoid register_socket_transport(int s, const char *serial, int port, int local);
29674d7ff8cfd490852d3df1c4b9d8a21beed619caaMike Lockwood
297cbbe79add1410b53ec65936cfb1b74cac68467f0Mike Lockwood/* these should only be used for the "adb disconnect" command */
29874d7ff8cfd490852d3df1c4b9d8a21beed619caaMike Lockwoodvoid unregister_transport(atransport *t);
299cbbe79add1410b53ec65936cfb1b74cac68467f0Mike Lockwoodvoid unregister_all_tcp_transports();
30074d7ff8cfd490852d3df1c4b9d8a21beed619caaMike Lockwood
301e109d266c12c5f537d429ca4b892f2719e02c2daScott Andersonvoid register_usb_transport(usb_handle *h, const char *serial, const char *devpath, unsigned writeable);
30295b837d38b730353af79f8669b5166007e038ac3Mike Lockwood
30395b837d38b730353af79f8669b5166007e038ac3Mike Lockwood/* this should only be used for transports with connection_state == CS_NOPERM */
30495b837d38b730353af79f8669b5166007e038ac3Mike Lockwoodvoid unregister_usb_transport(usb_handle *usb);
305dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
30674d7ff8cfd490852d3df1c4b9d8a21beed619caaMike Lockwoodatransport *find_transport(const char *serial);
307d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzinger#if ADB_HOST
308d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzingeratransport* find_emulator_transport_by_adb_port(int adb_port);
309d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzinger#endif
31074d7ff8cfd490852d3df1c4b9d8a21beed619caaMike Lockwood
311dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint service_to_fd(const char *name);
312dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#if ADB_HOST
313dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket *host_service_to_socket(const char*  name, const char *serial);
314dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
315dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
316dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#if !ADB_HOST
317dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint       init_jdwp(void);
318dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket*  create_jdwp_service_socket();
319dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectasocket*  create_jdwp_tracker_service_socket();
320dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint       create_jdwp_connection_fd(int  jdwp_pid);
321dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
322dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
323dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#if !ADB_HOST
324702967afb1bebc97c0b8a23c075d4932820ef7a3Christopher Tatetypedef enum {
325702967afb1bebc97c0b8a23c075d4932820ef7a3Christopher Tate    BACKUP,
326702967afb1bebc97c0b8a23c075d4932820ef7a3Christopher Tate    RESTORE
327702967afb1bebc97c0b8a23c075d4932820ef7a3Christopher Tate} BackupOperation;
328702967afb1bebc97c0b8a23c075d4932820ef7a3Christopher Tateint backup_service(BackupOperation operation, char* args);
329dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid framebuffer_service(int fd, void *cookie);
330dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid log_service(int fd, void *cookie);
331dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid remount_service(int fd, void *cookie);
332dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectchar * get_log_file_path(const char * log_name);
333dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
334dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
335dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* packet allocator */
336dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectapacket *get_apacket(void);
337dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid put_apacket(apacket *p);
338dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
339dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint check_header(apacket *p);
340dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint check_data(apacket *p);
341dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
342dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* define ADB_TRACE to 1 to enable tracing support, or 0 to disable it */
343dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
344dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define  ADB_TRACE    1
345dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
346dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* IMPORTANT: if you change the following list, don't
347dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * forget to update the corresponding 'tags' table in
348dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project * the adb_trace_init() function implemented in adb.c
349dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project */
350dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projecttypedef enum {
351408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall    TRACE_ADB = 0,   /* 0x001 */
352dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_SOCKETS,
353dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_PACKETS,
354dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_TRANSPORT,
355408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall    TRACE_RWX,       /* 0x010 */
356dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_USB,
357dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_SYNC,
358dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project    TRACE_SYSDEPS,
359408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall    TRACE_JDWP,      /* 0x100 */
360408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall    TRACE_SERVICES,
361d5fcafaf41f8ec90986c813f75ec78402096af2dBenoit Goby    TRACE_AUTH,
362dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project} AdbTrace;
363dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
364dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#if ADB_TRACE
365dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
36628781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine#if !ADB_HOST
36728781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine/*
36828781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine * When running inside the emulator, guest's adbd can connect to 'adb-debug'
36928781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine * qemud service that can display adb trace messages (on condition that emulator
37028781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine * has been started with '-debug adb' option).
37128781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine */
37228781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine
37328781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine/* Delivers a trace message to the emulator via QEMU pipe. */
37428781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkinevoid adb_qemu_trace(const char* fmt, ...);
37528781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine/* Macro to use to send ADB trace messages to the emulator. */
37628781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine#define DQ(...)    adb_qemu_trace(__VA_ARGS__)
37728781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine#else
37828781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine#define DQ(...) ((void)0)
37928781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine#endif  /* !ADB_HOST */
38028781b0a52dfb5ad19121afcc6aef56918992b30Vladimir Chtchetkine
381408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall  extern int     adb_trace_mask;
382408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall  extern unsigned char    adb_trace_output_count;
383dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project  void    adb_trace_init(void);
384dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
385dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#  define ADB_TRACING  ((adb_trace_mask & (1 << TRACE_TAG)) != 0)
386dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
387dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project  /* you must define TRACE_TAG before using this macro */
388408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall#  define  D(...)                                      \
389408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall        do {                                           \
390408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall            if (ADB_TRACING) {                         \
391408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                int save_errno = errno;                \
392408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                adb_mutex_lock(&D_lock);               \
393408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                fprintf(stderr, "%s::%s():",           \
394408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                        __FILE__, __FUNCTION__);       \
395408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                errno = save_errno;                    \
396408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                fprintf(stderr, __VA_ARGS__ );         \
397408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                fflush(stderr);                        \
398408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                adb_mutex_unlock(&D_lock);             \
399408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                errno = save_errno;                    \
400408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall           }                                           \
401408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall        } while (0)
402408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall#  define  DR(...)                                     \
403dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        do {                                           \
404408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall            if (ADB_TRACING) {                         \
405408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                int save_errno = errno;                \
406408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                adb_mutex_lock(&D_lock);               \
407408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                errno = save_errno;                    \
408dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project                fprintf(stderr, __VA_ARGS__ );         \
409408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                fflush(stderr);                        \
410408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                adb_mutex_unlock(&D_lock);             \
411408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall                errno = save_errno;                    \
412408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall           }                                           \
413dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project        } while (0)
414dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#else
415dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#  define  D(...)          ((void)0)
416408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrall#  define  DR(...)         ((void)0)
417dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#  define  ADB_TRACING     0
418dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
419dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
420dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
421d5fcafaf41f8ec90986c813f75ec78402096af2dBenoit Goby#if !DEBUG_PACKETS
422dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define print_packet(tag,p) do {} while (0)
423dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
424dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
425c318833b359164f25d7a93f6395c0cad787bacd7John Michelau#if ADB_HOST_ON_TARGET
426c318833b359164f25d7a93f6395c0cad787bacd7John Michelau/* adb and adbd are coexisting on the target, so use 5038 for adb
427c318833b359164f25d7a93f6395c0cad787bacd7John Michelau * to avoid conflicting with adbd's usage of 5037
428c318833b359164f25d7a93f6395c0cad787bacd7John Michelau */
429c318833b359164f25d7a93f6395c0cad787bacd7John Michelau#  define DEFAULT_ADB_PORT 5038
430c318833b359164f25d7a93f6395c0cad787bacd7John Michelau#else
431c318833b359164f25d7a93f6395c0cad787bacd7John Michelau#  define DEFAULT_ADB_PORT 5037
432c318833b359164f25d7a93f6395c0cad787bacd7John Michelau#endif
433c318833b359164f25d7a93f6395c0cad787bacd7John Michelau
434a84a42eb20d43ffa2695a69d583a6e09532b49d9Stefan Hilzinger#define DEFAULT_ADB_LOCAL_TRANSPORT_PORT 5555
435dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
436a481d096feba7cf6e61d54e416a68e2d46498df1Xavier Ducrohet#define ADB_CLASS              0xff
437a481d096feba7cf6e61d54e416a68e2d46498df1Xavier Ducrohet#define ADB_SUBCLASS           0x42
438a481d096feba7cf6e61d54e416a68e2d46498df1Xavier Ducrohet#define ADB_PROTOCOL           0x1
4393fd82b8861aa410fab7785074941b459d92220c1Dima Zavin
440dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
441cef31a02544d91b85481a5fa032b6126dbb32365Mike Lockwoodvoid local_init(int port);
442dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint  local_connect(int  port);
443d9d1ca47802395e9e42e7deb05b2683d9d306598Stefan Hilzingerint  local_connect_arbitrary_ports(int console_port, int adb_port);
444dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
445dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* usb host/client interface */
446dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid usb_init();
447dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid usb_cleanup();
448dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint usb_write(usb_handle *h, const void *data, int len);
449dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint usb_read(usb_handle *h, void *data, int len);
450dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint usb_close(usb_handle *h);
451dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectvoid usb_kick(usb_handle *h);
452dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
453dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project/* used for USB device detection */
454a09fbd164d2e088bc5433d310e25640ae048d47dXavier Ducrohet#if ADB_HOST
455dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint is_adb_interface(int vid, int pid, int usb_class, int usb_subclass, int usb_protocol);
456a09fbd164d2e088bc5433d310e25640ae048d47dXavier Ducrohet#endif
457dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
458dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectunsigned host_to_le32(unsigned n);
459dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint adb_commandline(int argc, char **argv);
460dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
461dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint connection_state(atransport *t);
462dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
463dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_ANY       -1
464dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_OFFLINE    0
465dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_BOOTLOADER 1
466dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_DEVICE     2
467dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_HOST       3
468dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CS_RECOVERY   4
46995b837d38b730353af79f8669b5166007e038ac3Mike Lockwood#define CS_NOPERM     5 /* Insufficient permissions to communicate with the device */
470447f061da19fe46bae35f1cdd93eeb16bc225463Doug Zongker#define CS_SIDELOAD   6
471dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
472dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectextern int HOST;
473408fa57864c01113deaa213e5c1848a9c594ae92JP Abgrallextern int SHELL_EXIT_NOTIFY_FD;
474dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
475dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#define CHUNK_SIZE (64*1024)
476dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
477fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#if !ADB_HOST
478fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_ADB_PATH     "/dev/android_adb"
479fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz
480fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_FFS_ADB_PATH  "/dev/usb-ffs/adb/"
481fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_FFS_ADB_EP(x) USB_FFS_ADB_PATH#x
482fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz
483fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_FFS_ADB_EP0   USB_FFS_ADB_EP(ep0)
484fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_FFS_ADB_OUT   USB_FFS_ADB_EP(ep1)
485fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#define USB_FFS_ADB_IN    USB_FFS_ADB_EP(ep2)
486fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz#endif
487fd96db17b7f07eb6615af01fd1908b74383bf04bAndrzej Pietrasiewicz
488dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint sendfailmsg(int fd, const char *reason);
489dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Projectint handle_host_request(char *service, transport_type ttype, char* serial, int reply_fd, asocket *s);
490dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project
491dd7bc3319deb2b77c5d07a51b7d6cd7e11b5beb0The Android Open Source Project#endif
492