diff options
author | Elliott Hughes <enh@google.com> | 2015-04-30 17:32:03 -0700 |
---|---|---|
committer | Elliott Hughes <enh@google.com> | 2015-05-01 17:09:34 -0700 |
commit | 92af733ee202caa3b5475fe27fcc81582f11e7c8 (patch) | |
tree | 0e5d4bc49cc6299f80a0cccd4ba205d5dfcbb3cb /adb/test_track_devices.cpp | |
parent | 5cffd971997ace97ebfd2ecb7d43a64c03cf3169 (diff) | |
download | system_core-92af733ee202caa3b5475fe27fcc81582f11e7c8.zip system_core-92af733ee202caa3b5475fe27fcc81582f11e7c8.tar.gz system_core-92af733ee202caa3b5475fe27fcc81582f11e7c8.tar.bz2 |
More adb buffer fixes.
This patch factors out a lot of the basic protocol code: sending OKAY,
sending FAIL, and sending a length-prefixed string.
ADB_TRACE has been non-optional for a long time, so let's just remove
the #ifs.
Also actually build the device tracker test tool (and remove its duplicate).
Bug: http://b/20666660
Change-Id: I6c7d59f18707bdc62ca69dea45547617f9f31fc6
(cherry picked from commit e67f1f87d9b1188ec8617035db7006c37ee7b21e)
Diffstat (limited to 'adb/test_track_devices.cpp')
-rw-r--r-- | adb/test_track_devices.cpp | 65 |
1 files changed, 18 insertions, 47 deletions
diff --git a/adb/test_track_devices.cpp b/adb/test_track_devices.cpp index 77b3ad9..3e823e9 100644 --- a/adb/test_track_devices.cpp +++ b/adb/test_track_devices.cpp @@ -1,3 +1,5 @@ +// TODO: replace this with a shell/python script. + /* a simple test program, connects to ADB server, and opens a track-devices session */ #include <netdb.h> #include <sys/socket.h> @@ -6,6 +8,8 @@ #include <errno.h> #include <memory.h> +#include <base/file.h> + static void panic( const char* msg ) { @@ -13,82 +17,49 @@ panic( const char* msg ) exit(1); } -static int -unix_write( int fd, const char* buf, int len ) -{ - int result = 0; - while (len > 0) { - int len2 = write(fd, buf, len); - if (len2 < 0) { - if (errno == EINTR || errno == EAGAIN) - continue; - return -1; - } - result += len2; - len -= len2; - buf += len2; - } - return result; -} +int main(int argc, char* argv[]) { + const char* request = "host:track-devices"; -static int -unix_read( int fd, char* buf, int len ) -{ - int result = 0; - while (len > 0) { - int len2 = read(fd, buf, len); - if (len2 < 0) { - if (errno == EINTR || errno == EAGAIN) - continue; - return -1; - } - result += len2; - len -= len2; - buf += len2; + if (argv[1] && strcmp(argv[1], "--jdwp") == 0) { + request = "track-jdwp"; } - return result; -} - -int main( void ) -{ - int ret, s; + int ret; struct sockaddr_in server; char buffer[1024]; - const char* request = "host:track-devices"; - int len; memset( &server, 0, sizeof(server) ); server.sin_family = AF_INET; server.sin_port = htons(5037); server.sin_addr.s_addr = htonl(INADDR_LOOPBACK); - s = socket( PF_INET, SOCK_STREAM, 0 ); + int s = socket( PF_INET, SOCK_STREAM, 0 ); ret = connect( s, (struct sockaddr*) &server, sizeof(server) ); if (ret < 0) panic( "could not connect to server" ); /* send the request */ - len = snprintf( buffer, sizeof buffer, "%04x%s", strlen(request), request ); - if (unix_write(s, buffer, len) < 0) + int len = snprintf(buffer, sizeof(buffer), "%04zx%s", strlen(request), request); + if (!android::base::WriteFully(s, buffer, len)) panic( "could not send request" ); /* read the OKAY answer */ - if (unix_read(s, buffer, 4) != 4) + if (!android::base::ReadFully(s, buffer, 4)) panic( "could not read request" ); printf( "server answer: %.*s\n", 4, buffer ); /* now loop */ - for (;;) { + while (true) { char head[5] = "0000"; - if (unix_read(s, head, 4) < 0) + if (!android::base::ReadFully(s, head, 4)) panic("could not read length"); - if ( sscanf( head, "%04x", &len ) != 1 ) + int len; + if (sscanf(head, "%04x", &len) != 1 ) panic("could not decode length"); - if (unix_read(s, buffer, len) != len) + if (!android::base::ReadFully(s, buffer, len)) panic("could not read data"); printf( "received header %.*s (%d bytes):\n%.*s", 4, head, len, len, buffer ); |