Merge change 2282 into donut
* changes: Support for 3rd party USB Vendor IDs in adb.
This commit is contained in:
commit
0469d2c37a
7 changed files with 116 additions and 32 deletions
|
|
@ -919,9 +919,6 @@ int adb_main(int is_daemon)
|
||||||
fdevent_loop();
|
fdevent_loop();
|
||||||
|
|
||||||
usb_cleanup();
|
usb_cleanup();
|
||||||
#if ADB_HOST
|
|
||||||
usb_vendors_cleanup();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -357,11 +357,10 @@ typedef enum {
|
||||||
#define ADB_PORT 5037
|
#define ADB_PORT 5037
|
||||||
#define ADB_LOCAL_TRANSPORT_PORT 5555
|
#define ADB_LOCAL_TRANSPORT_PORT 5555
|
||||||
|
|
||||||
// Google's USB Vendor ID
|
#define ADB_CLASS 0xff
|
||||||
#define VENDOR_ID_GOOGLE 0x18d1
|
#define ADB_SUBCLASS 0x42
|
||||||
|
#define ADB_PROTOCOL 0x1
|
||||||
|
|
||||||
// HTC's USB Vendor ID
|
|
||||||
#define VENDOR_ID_HTC 0x0bb4
|
|
||||||
|
|
||||||
void local_init();
|
void local_init();
|
||||||
int local_connect(int port);
|
int local_connect(int port);
|
||||||
|
|
|
||||||
|
|
@ -213,7 +213,7 @@ int adb_connect(const char *service)
|
||||||
fprintf(stdout,"* daemon started successfully *\n");
|
fprintf(stdout,"* daemon started successfully *\n");
|
||||||
}
|
}
|
||||||
/* give the server some time to start properly and detect devices */
|
/* give the server some time to start properly and detect devices */
|
||||||
adb_sleep_ms(2000);
|
adb_sleep_ms(3000);
|
||||||
// fall through to _adb_connect
|
// fall through to _adb_connect
|
||||||
} else {
|
} else {
|
||||||
// if server was running, check its version to make sure it is not out of date
|
// if server was running, check its version to make sure it is not out of date
|
||||||
|
|
|
||||||
|
|
@ -135,11 +135,9 @@ int is_adb_interface(int vid, int pid, int usb_class, int usb_subclass, int usb_
|
||||||
unsigned i;
|
unsigned i;
|
||||||
for (i = 0; i < vendorIdCount; i++) {
|
for (i = 0; i < vendorIdCount; i++) {
|
||||||
if (vid == vendorIds[i]) {
|
if (vid == vendorIds[i]) {
|
||||||
/* class:vendor (0xff) subclass:android (0x42) proto:adb (0x01) */
|
if (usb_class == ADB_CLASS && usb_subclass == ADB_SUBCLASS &&
|
||||||
if(usb_class == 0xff) {
|
usb_protocol == ADB_PROTOCOL) {
|
||||||
if((usb_subclass == 0x42) && (usb_protocol == 0x01)) {
|
return 1;
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
||||||
|
|
@ -32,9 +32,6 @@
|
||||||
|
|
||||||
#define DBG D
|
#define DBG D
|
||||||
|
|
||||||
#define ADB_SUBCLASS 0x42
|
|
||||||
#define ADB_PROTOCOL 0x1
|
|
||||||
|
|
||||||
static IONotificationPortRef notificationPort = 0;
|
static IONotificationPortRef notificationPort = 0;
|
||||||
static io_iterator_t* notificationIterators;
|
static io_iterator_t* notificationIterators;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -16,25 +16,119 @@
|
||||||
|
|
||||||
#include "usb_vendors.h"
|
#include "usb_vendors.h"
|
||||||
|
|
||||||
#include "sysdeps.h"
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
# define WIN32_LEAN_AND_MEAN
|
||||||
|
# include "windows.h"
|
||||||
|
# include "shlobj.h"
|
||||||
|
#else
|
||||||
|
# include <unistd.h>
|
||||||
|
# include <sys/stat.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "sysdeps.h"
|
||||||
#include "adb.h"
|
#include "adb.h"
|
||||||
|
|
||||||
int* vendorIds = NULL;
|
#define ANDROID_PATH ".android"
|
||||||
|
#define ANDROID_ADB_INI "adb_usb.ini"
|
||||||
|
|
||||||
|
#define TRACE_TAG TRACE_USB
|
||||||
|
|
||||||
|
// Google's USB Vendor ID
|
||||||
|
#define VENDOR_ID_GOOGLE 0x18d1
|
||||||
|
// HTC's USB Vendor ID
|
||||||
|
#define VENDOR_ID_HTC 0x0bb4
|
||||||
|
|
||||||
|
/** built-in vendor list */
|
||||||
|
int builtInVendorIds[] = {
|
||||||
|
VENDOR_ID_GOOGLE,
|
||||||
|
VENDOR_ID_HTC,
|
||||||
|
};
|
||||||
|
|
||||||
|
#define BUILT_IN_VENDOR_COUNT (sizeof(builtInVendorIds)/sizeof(builtInVendorIds[0]))
|
||||||
|
|
||||||
|
/* max number of supported vendor ids (built-in + 3rd party). increase as needed */
|
||||||
|
#define VENDOR_COUNT_MAX 128
|
||||||
|
|
||||||
|
int vendorIds[VENDOR_COUNT_MAX];
|
||||||
unsigned vendorIdCount = 0;
|
unsigned vendorIdCount = 0;
|
||||||
|
|
||||||
void usb_vendors_init(void) {
|
int get_adb_usb_ini(char* buff, size_t len);
|
||||||
/* for now, only put the built-in VENDOR_ID_* */
|
|
||||||
vendorIdCount = 2;
|
|
||||||
vendorIds = (int*)malloc(vendorIdCount * sizeof(int));
|
|
||||||
vendorIds[0] = VENDOR_ID_GOOGLE;
|
|
||||||
vendorIds[1] = VENDOR_ID_HTC;
|
|
||||||
}
|
|
||||||
|
|
||||||
void usb_vendors_cleanup(void) {
|
void usb_vendors_init(void)
|
||||||
if (vendorIds != NULL) {
|
{
|
||||||
free(vendorIds);
|
if (VENDOR_COUNT_MAX < BUILT_IN_VENDOR_COUNT) {
|
||||||
vendorIds = NULL;
|
fprintf(stderr, "VENDOR_COUNT_MAX not big enough for built-in vendor list.\n");
|
||||||
vendorIdCount = 0;
|
exit(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* add the built-in vendors at the beginning of the array */
|
||||||
|
memcpy(vendorIds, builtInVendorIds, sizeof(builtInVendorIds));
|
||||||
|
|
||||||
|
/* default array size is the number of built-in vendors */
|
||||||
|
vendorIdCount = BUILT_IN_VENDOR_COUNT;
|
||||||
|
|
||||||
|
if (VENDOR_COUNT_MAX == BUILT_IN_VENDOR_COUNT)
|
||||||
|
return;
|
||||||
|
|
||||||
|
char temp[PATH_MAX];
|
||||||
|
if (get_adb_usb_ini(temp, sizeof(temp)) == 0) {
|
||||||
|
FILE * f = fopen(temp, "rt");
|
||||||
|
|
||||||
|
if (f != NULL) {
|
||||||
|
/* The vendor id file is pretty basic. 1 vendor id per line.
|
||||||
|
Lines starting with # are comments */
|
||||||
|
while (fgets(temp, sizeof(temp), f) != NULL) {
|
||||||
|
if (temp[0] == '#')
|
||||||
|
continue;
|
||||||
|
|
||||||
|
long value = strtol(temp, NULL, 0);
|
||||||
|
if (errno == EINVAL || errno == ERANGE || value > INT_MAX || value < 0) {
|
||||||
|
fprintf(stderr, "Invalid content in %s. Quitting.\n", ANDROID_ADB_INI);
|
||||||
|
exit(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
vendorIds[vendorIdCount++] = (int)value;
|
||||||
|
|
||||||
|
/* make sure we don't go beyond the array */
|
||||||
|
if (vendorIdCount == VENDOR_COUNT_MAX) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Utils methods */
|
||||||
|
|
||||||
|
/* builds the path to the adb vendor id file. returns 0 if success */
|
||||||
|
int build_path(char* buff, size_t len, const char* format, const char* home)
|
||||||
|
{
|
||||||
|
if (snprintf(buff, len, format, home, ANDROID_PATH, ANDROID_ADB_INI) >= len) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* fills buff with the path to the adb vendor id file. returns 0 if success */
|
||||||
|
int get_adb_usb_ini(char* buff, size_t len)
|
||||||
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
|
const char* home = getenv("ANDROID_SDK_HOME");
|
||||||
|
if (home != NULL) {
|
||||||
|
return build_path(buff, len, "%s\\%s\\%s", home);
|
||||||
|
} else {
|
||||||
|
char path[MAX_PATH];
|
||||||
|
SHGetFolderPath( NULL, CSIDL_PROFILE, NULL, 0, path);
|
||||||
|
return build_path(buff, len, "%s\\%s\\%s", path);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
const char* home = getenv("HOME");
|
||||||
|
if (home == NULL)
|
||||||
|
home = "/tmp";
|
||||||
|
|
||||||
|
return build_path(buff, len, "%s/%s/%s", home);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -17,10 +17,9 @@
|
||||||
#ifndef __USB_VENDORS_H
|
#ifndef __USB_VENDORS_H
|
||||||
#define __USB_VENDORS_H
|
#define __USB_VENDORS_H
|
||||||
|
|
||||||
extern int* vendorIds;
|
extern int vendorIds[];
|
||||||
extern unsigned vendorIdCount;
|
extern unsigned vendorIdCount;
|
||||||
|
|
||||||
void usb_vendors_init(void);
|
void usb_vendors_init(void);
|
||||||
void usb_vendors_cleanup(void);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
Loading…
Add table
Reference in a new issue