mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
usb-serial-for-android: More fields in device descriptor
As discussed in issue #2657, there are now more fields about the usb device information in android_usb_serial_device_descriptor. Additionally, the user-facing string now makes more sense: "vendor [<bus# as integer>:<dev# as integer>]" Where vendor is as reported by android, but shortened to 16 characters. Examples: FTDI [1:2] Silicon Labs [1:4] Signed-off-by: Christof Arnosti <charno@charno.ch> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
344f7861b4
commit
ce7d4d1ca6
2 changed files with 88 additions and 14 deletions
|
@ -7,6 +7,7 @@
|
||||||
#include <QAndroidJniObject>
|
#include <QAndroidJniObject>
|
||||||
#include <QAndroidJniEnvironment>
|
#include <QAndroidJniEnvironment>
|
||||||
#include <QtAndroid>
|
#include <QtAndroid>
|
||||||
|
#include <QRegularExpression>
|
||||||
|
|
||||||
#include <thread>
|
#include <thread>
|
||||||
|
|
||||||
|
@ -203,7 +204,56 @@ dc_status_t serial_usb_android_open(dc_iostream_t **iostream, dc_context_t *cont
|
||||||
return dc_custom_open(iostream, context, DC_TRANSPORT_SERIAL, &callbacks, device);
|
return dc_custom_open(iostream, context, DC_TRANSPORT_SERIAL, &callbacks, device);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices(bool driverSelection)
|
android_usb_serial_device_descriptor getDescriptor(QAndroidJniObject usbDevice)
|
||||||
|
{
|
||||||
|
QAndroidJniEnvironment env;
|
||||||
|
|
||||||
|
android_usb_serial_device_descriptor descriptor;
|
||||||
|
|
||||||
|
descriptor.usbDevice = usbDevice;
|
||||||
|
descriptor.pid = usbDevice.callMethod<jint>("getProductId");
|
||||||
|
descriptor.vid = usbDevice.callMethod<jint>("getVendorId");
|
||||||
|
|
||||||
|
// descriptor.manufacturer = UsbDevice.getManufacturerName();
|
||||||
|
QAndroidJniObject usbManufacturerName = usbDevice.callObjectMethod<jstring>("getManufacturerName");
|
||||||
|
if (usbManufacturerName.isValid()) {
|
||||||
|
const char *charArray = env->GetStringUTFChars(usbManufacturerName.object<jstring>(), nullptr);
|
||||||
|
descriptor.manufacturer = std::string(charArray);
|
||||||
|
env->ReleaseStringUTFChars(usbManufacturerName.object<jstring>(), charArray);
|
||||||
|
}
|
||||||
|
|
||||||
|
// descriptor.product = UsbDevice.getProductName();
|
||||||
|
QAndroidJniObject usbProductName = usbDevice.callObjectMethod<jstring>("getProductName");
|
||||||
|
if (usbManufacturerName.isValid()) {
|
||||||
|
const char *charArray = env->GetStringUTFChars(usbProductName.object<jstring>(), nullptr);
|
||||||
|
descriptor.product = std::string(charArray);
|
||||||
|
env->ReleaseStringUTFChars(usbProductName.object<jstring>(), charArray);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get busnum and portnum
|
||||||
|
QAndroidJniObject usbDeviceNameString = usbDevice.callObjectMethod<jstring>("getDeviceName");
|
||||||
|
const char *charArray = env->GetStringUTFChars(usbDeviceNameString.object<jstring>(), nullptr);
|
||||||
|
QRegularExpression reg("/dev/bus/usb/(\\d*)/(\\d*)");
|
||||||
|
QRegularExpressionMatch match = reg.match(charArray);
|
||||||
|
int busnum = match.captured(1).toInt();
|
||||||
|
int portnum = match.captured(2).toInt();
|
||||||
|
env->ReleaseStringUTFChars(usbDeviceNameString.object<jstring>(), charArray);
|
||||||
|
|
||||||
|
// The ui representation
|
||||||
|
char buffer[128];
|
||||||
|
if (descriptor.manufacturer.empty()) {
|
||||||
|
sprintf(buffer, "USB Device [%i:%i]", busnum, portnum);
|
||||||
|
} else if (descriptor.manufacturer.size() <= 16) {
|
||||||
|
sprintf(buffer, "%s [%i:%i]", descriptor.manufacturer.c_str(), busnum, portnum);
|
||||||
|
} else {
|
||||||
|
sprintf(buffer, "%.16s… [%i:%i]", descriptor.manufacturer.c_str(), busnum, portnum);
|
||||||
|
}
|
||||||
|
descriptor.uiRepresentation = buffer;
|
||||||
|
|
||||||
|
return descriptor;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices(book driverSelection)
|
||||||
{
|
{
|
||||||
std::vector<std::string> driverNames;
|
std::vector<std::string> driverNames;
|
||||||
if (driverSelection)
|
if (driverSelection)
|
||||||
|
@ -230,7 +280,10 @@ std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices
|
||||||
// UsbDevice usbDevice = arrayOfDevices[0]
|
// UsbDevice usbDevice = arrayOfDevices[0]
|
||||||
jobject value = env->GetObjectArrayElement(arrayOfDevices.object<jobjectArray>(), 0);
|
jobject value = env->GetObjectArrayElement(arrayOfDevices.object<jobjectArray>(), 0);
|
||||||
QAndroidJniObject usbDevice(value);
|
QAndroidJniObject usbDevice(value);
|
||||||
return std::vector<android_usb_serial_device_descriptor> { {QAndroidJniObject(usbDevice), "", "USB Connection"} };
|
android_usb_serial_device_descriptor descriptor = getDescriptor(usbDevice);
|
||||||
|
descriptor.uiRepresentation = "USB Connection";
|
||||||
|
|
||||||
|
return {descriptor};
|
||||||
} else {
|
} else {
|
||||||
std::vector<android_usb_serial_device_descriptor> retval;
|
std::vector<android_usb_serial_device_descriptor> retval;
|
||||||
for (int i = 0; i < numDevices ; i++) {
|
for (int i = 0; i < numDevices ; i++) {
|
||||||
|
@ -238,21 +291,15 @@ std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices
|
||||||
jobject value = env->GetObjectArrayElement(arrayOfDevices.object<jobjectArray>(), i);
|
jobject value = env->GetObjectArrayElement(arrayOfDevices.object<jobjectArray>(), i);
|
||||||
QAndroidJniObject usbDevice(value);
|
QAndroidJniObject usbDevice(value);
|
||||||
|
|
||||||
// std::string deviceName = usbDevice.getDeviceName()
|
|
||||||
QAndroidJniObject usbDeviceNameString = usbDevice.callObjectMethod<jstring>("getDeviceName");
|
|
||||||
const char *charArray = env->GetStringUTFChars(usbDeviceNameString.object<jstring>(), nullptr);
|
|
||||||
std::string deviceName(charArray);
|
|
||||||
env->ReleaseStringUTFChars(usbDeviceNameString.object<jstring>(), charArray);
|
|
||||||
|
|
||||||
// TODO the deviceName should probably be something better... Currently it's the /dev-filename.
|
|
||||||
|
|
||||||
for (std::string driverName : driverNames) {
|
for (std::string driverName : driverNames) {
|
||||||
std::string uiDeviceName;
|
android_usb_serial_device_descriptor descriptor = getDescriptor(usbDevice);
|
||||||
|
|
||||||
|
descriptor.className = driverName;
|
||||||
if (driverName != "")
|
if (driverName != "")
|
||||||
uiDeviceName = deviceName + " (" + driverName + ")";
|
descriptor.uiRepresentation += " (" + driverName + ")";
|
||||||
else
|
else
|
||||||
uiDeviceName = deviceName + " (autoselect driver)";
|
descriptor.uiRepresentation += " (autoselect driver)";
|
||||||
retval.push_back({QAndroidJniObject(usbDevice), driverName, uiDeviceName});
|
retval.push_back(descriptor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return retval;
|
return retval;
|
||||||
|
@ -265,6 +312,27 @@ std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices
|
||||||
*/
|
*/
|
||||||
dc_status_t serial_usb_android_open(dc_iostream_t **iostream, dc_context_t *context)
|
dc_status_t serial_usb_android_open(dc_iostream_t **iostream, dc_context_t *context)
|
||||||
{
|
{
|
||||||
|
// Testing of the method only!
|
||||||
|
{
|
||||||
|
TRACE(device->contxt, "List of devices with specific drivers:");
|
||||||
|
std::vector<android_usb_serial_device_descriptor> devices = serial_usb_android_get_devices(true);
|
||||||
|
for (auto device : devices) {
|
||||||
|
TRACE(device->contxt,
|
||||||
|
"USB Device: uiRepresentation=%s, className=%s, manufacturer=%s, product=%s, pid=%i, vid=%i",
|
||||||
|
device.uiRepresentation.c_str(), device.className.c_str(), device.manufacturer.c_str(),
|
||||||
|
device.product.c_str(), device.pid, device.vid);
|
||||||
|
}
|
||||||
|
|
||||||
|
TRACE(device->contxt, "List of devices simple:");
|
||||||
|
devices = serial_usb_android_get_devices(false);
|
||||||
|
for (auto device : devices) {
|
||||||
|
TRACE(device->contxt,
|
||||||
|
"USB Device: uiRepresentation=%s, className=%s, manufacturer=%s, product=%s, pid=%i, vid=%i",
|
||||||
|
device.uiRepresentation.c_str(), device.className.c_str(), device.manufacturer.c_str(),
|
||||||
|
device.product.c_str(), device.pid, device.vid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
std::vector<android_usb_serial_device_descriptor> devices = serial_usb_android_get_devices(false);
|
std::vector<android_usb_serial_device_descriptor> devices = serial_usb_android_get_devices(false);
|
||||||
|
|
||||||
if(devices.empty())
|
if(devices.empty())
|
||||||
|
|
|
@ -9,6 +9,12 @@ struct android_usb_serial_device_descriptor {
|
||||||
QAndroidJniObject usbDevice; /* the UsbDevice */
|
QAndroidJniObject usbDevice; /* the UsbDevice */
|
||||||
std::string className; /* the driver class name. If empty, then "autodetect" */
|
std::string className; /* the driver class name. If empty, then "autodetect" */
|
||||||
std::string uiRepresentation; /* The string that can be used for the user interface. */
|
std::string uiRepresentation; /* The string that can be used for the user interface. */
|
||||||
|
|
||||||
|
// Device information
|
||||||
|
std::string manufacturer;
|
||||||
|
std::string product;
|
||||||
|
uint16_t pid;
|
||||||
|
uint16_t vid;
|
||||||
};
|
};
|
||||||
|
|
||||||
std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices(bool driverSelection);
|
std::vector<android_usb_serial_device_descriptor> serial_usb_android_get_devices(bool driverSelection);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue