OTG: Fix connection issues

This commit is contained in:
Nikita Mikhailov 2016-04-15 00:13:33 +06:00
parent 784bf2322c
commit 263799ec96
3 changed files with 17 additions and 24 deletions

View file

@ -66,7 +66,7 @@ public class UsbTransport implements Transport {
* @param on true to turn ICC on, false to turn it off * @param on true to turn ICC on, false to turn it off
* @throws UsbTransportException * @throws UsbTransportException
*/ */
private void iccPowerSet(boolean on) throws UsbTransportException { private void setIccPower(boolean on) throws UsbTransportException {
final byte[] iccPowerCommand = { final byte[] iccPowerCommand = {
(byte) (on ? 0x62 : 0x63), (byte) (on ? 0x62 : 0x63),
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
@ -145,7 +145,8 @@ public class UsbTransport implements Transport {
*/ */
@Override @Override
public boolean isConnected() { public boolean isConnected() {
return mConnection != null && mUsbManager.getDeviceList().containsValue(mUsbDevice); return mConnection != null && mUsbManager.getDeviceList().containsValue(mUsbDevice) &&
mConnection.getSerial() != null;
} }
/** /**
@ -188,7 +189,7 @@ public class UsbTransport implements Transport {
throw new UsbTransportException("USB error - failed to claim interface"); throw new UsbTransportException("USB error - failed to claim interface");
} }
iccPowerSet(true); setIccPower(true);
Log.d(Constants.TAG, "Usb transport connected"); Log.d(Constants.TAG, "Usb transport connected");
} }

View file

@ -22,8 +22,11 @@
package org.sufficientlysecure.keychain.ui.base; package org.sufficientlysecure.keychain.ui.base;
import android.app.Activity; import android.app.Activity;
import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.content.pm.PackageManager; import android.content.pm.PackageManager;
import android.hardware.usb.UsbDevice;
import android.hardware.usb.UsbManager;
import android.nfc.NfcAdapter; import android.nfc.NfcAdapter;
import android.nfc.Tag; import android.nfc.Tag;
import android.nfc.TagLostException; import android.nfc.TagLostException;
@ -142,12 +145,13 @@ public abstract class BaseSecurityTokenNfcActivity extends BaseActivity
securityTokenDiscovered(new NfcTransport(tag)); securityTokenDiscovered(new NfcTransport(tag));
} }
public void usbDeviceDiscovered(final UsbTransport transport) { public void usbDeviceDiscovered(final UsbDevice usbDevice) {
// Actual USB operations are executed in doInBackground to not block the UI thread // Actual USB operations are executed in doInBackground to not block the UI thread
if (!mTagHandlingEnabled) if (!mTagHandlingEnabled)
return; return;
securityTokenDiscovered(transport); UsbManager usbManager = (UsbManager) getSystemService(Context.USB_SERVICE);
securityTokenDiscovered(new UsbTransport(usbDevice, usbManager));
} }
public void securityTokenDiscovered(final Transport transport) { public void securityTokenDiscovered(final Transport transport) {
@ -401,7 +405,8 @@ public abstract class BaseSecurityTokenNfcActivity extends BaseActivity
protected void handleSmartcard(Transport transport) throws IOException { protected void handleSmartcard(Transport transport) throws IOException {
// Don't reconnect if device was already connected // Don't reconnect if device was already connected
if (!(mSecurityTokenHelper.isConnected() if (!(mSecurityTokenHelper.isPersistentConnectionAllowed()
&& mSecurityTokenHelper.isConnected()
&& mSecurityTokenHelper.getTransport().equals(transport))) { && mSecurityTokenHelper.getTransport().equals(transport))) {
mSecurityTokenHelper.setTransport(transport); mSecurityTokenHelper.setTransport(transport);
mSecurityTokenHelper.connectToDevice(); mSecurityTokenHelper.connectToDevice();
@ -477,7 +482,7 @@ public abstract class BaseSecurityTokenNfcActivity extends BaseActivity
* Run smartcard routines if last used token is connected and supports * Run smartcard routines if last used token is connected and supports
* persistent connections * persistent connections
*/ */
protected void checkDeviceConnection() { public void checkDeviceConnection() {
mUsbDispatcher.rescanDevices(); mUsbDispatcher.rescanDevices();
} }
} }

View file

@ -33,7 +33,6 @@ public class UsbConnectionDispatcher {
private Activity mActivity; private Activity mActivity;
private OnDiscoveredUsbDeviceListener mListener; private OnDiscoveredUsbDeviceListener mListener;
private UsbTransport mLastUsedUsbTransport;
private UsbManager mUsbManager; private UsbManager mUsbManager;
/** /**
* Receives broadcast when a supported USB device get permission. * Receives broadcast when a supported USB device get permission.
@ -45,23 +44,12 @@ public class UsbConnectionDispatcher {
switch (action) { switch (action) {
case UsbEventReceiverActivity.ACTION_USB_PERMISSION: { case UsbEventReceiverActivity.ACTION_USB_PERMISSION: {
UsbDevice usbDevice = intent.getParcelableExtra(UsbManager.EXTRA_DEVICE); android.hardware.usb.UsbDevice usbDevice = intent.getParcelableExtra(UsbManager.EXTRA_DEVICE);
boolean permission = intent.getBooleanExtra(UsbManager.EXTRA_PERMISSION_GRANTED, boolean permission = intent.getBooleanExtra(UsbManager.EXTRA_PERMISSION_GRANTED,
false); false);
if (permission) { if (permission) {
Log.d(Constants.TAG, "Got permission for " + usbDevice.getDeviceName()); Log.d(Constants.TAG, "Got permission for " + usbDevice.getDeviceName());
mListener.usbDeviceDiscovered(usbDevice);
mLastUsedUsbTransport = new UsbTransport(usbDevice, mUsbManager);
mListener.usbDeviceDiscovered(mLastUsedUsbTransport);
}
break;
}
case UsbManager.ACTION_USB_DEVICE_DETACHED: {
UsbDevice usbDevice = intent.getParcelableExtra(UsbManager.EXTRA_DEVICE);
if (mLastUsedUsbTransport != null && mLastUsedUsbTransport.getUsbDevice().equals(usbDevice)) {
mLastUsedUsbTransport.release();
mLastUsedUsbTransport = null;
} }
break; break;
} }
@ -78,7 +66,6 @@ public class UsbConnectionDispatcher {
public void onStart() { public void onStart() {
final IntentFilter intentFilter = new IntentFilter(); final IntentFilter intentFilter = new IntentFilter();
intentFilter.addAction(UsbEventReceiverActivity.ACTION_USB_PERMISSION); intentFilter.addAction(UsbEventReceiverActivity.ACTION_USB_PERMISSION);
intentFilter.addAction(UsbManager.ACTION_USB_DEVICE_DETACHED);
mActivity.registerReceiver(mUsbReceiver, intentFilter); mActivity.registerReceiver(mUsbReceiver, intentFilter);
} }
@ -97,7 +84,7 @@ public class UsbConnectionDispatcher {
for (UsbDevice device : mUsbManager.getDeviceList().values()) { for (UsbDevice device : mUsbManager.getDeviceList().values()) {
if (mUsbManager.hasPermission(device)) { if (mUsbManager.hasPermission(device)) {
if (mListener != null) { if (mListener != null) {
mListener.usbDeviceDiscovered(new UsbTransport(device, mUsbManager)); mListener.usbDeviceDiscovered(device);
} }
break; break;
} }
@ -105,6 +92,6 @@ public class UsbConnectionDispatcher {
} }
public interface OnDiscoveredUsbDeviceListener { public interface OnDiscoveredUsbDeviceListener {
void usbDeviceDiscovered(UsbTransport usbTransport); void usbDeviceDiscovered(UsbDevice usbDevice);
} }
} }