From ddfab1cdae7341387fc8a2efde89a6ed12a04305 Mon Sep 17 00:00:00 2001 From: Andreas Shimokawa Date: Fri, 18 Nov 2016 23:45:05 +0100 Subject: [PATCH] Pebble 2: use requestMTU() on Android 5+ instead of characteristics write. This actually fixes MTU problems with older Pebbles (Time, OG) --- .../devices/pebble/ble/PebbleGATTClient.java | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/pebble/ble/PebbleGATTClient.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/pebble/ble/PebbleGATTClient.java index d8fa0a33..8121e0a6 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/pebble/ble/PebbleGATTClient.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/pebble/ble/PebbleGATTClient.java @@ -13,6 +13,7 @@ import org.slf4j.LoggerFactory; import java.lang.reflect.Method; import java.util.UUID; +import nodomain.freeyourgadget.gadgetbridge.GBApplication; import nodomain.freeyourgadget.gadgetbridge.util.GB; import static android.bluetooth.BluetoothGattCharacteristic.FORMAT_UINT16; @@ -211,10 +212,14 @@ class PebbleGATTClient extends BluetoothGattCallback { private void setMTU(BluetoothGatt gatt) { LOG.info("setting MTU"); - BluetoothGattCharacteristic characteristic = gatt.getService(SERVICE_UUID).getCharacteristic(MTU_CHARACTERISTIC); - BluetoothGattDescriptor descriptor = characteristic.getDescriptor(CHARACTERISTIC_CONFIGURATION_DESCRIPTOR); - descriptor.setValue(new byte[]{0x0b, 0x01}); // unknown - gatt.writeCharacteristic(characteristic); + if (GBApplication.isRunningLollipopOrLater()) { + gatt.requestMtu(339); + } else { + BluetoothGattCharacteristic characteristic = gatt.getService(SERVICE_UUID).getCharacteristic(MTU_CHARACTERISTIC); + BluetoothGattDescriptor descriptor = characteristic.getDescriptor(CHARACTERISTIC_CONFIGURATION_DESCRIPTOR); + descriptor.setValue(new byte[]{0x0b, 0x01}); // unknown + gatt.writeCharacteristic(characteristic); + } } public void close() {