This commit is contained in:
Andrei Vereha 2021-04-02 16:31:27 +02:00
parent 20179781ef
commit c4291113a6
7 changed files with 38 additions and 14 deletions

View file

@ -108,7 +108,14 @@ class OmnipodDashBleManagerImpl @Inject constructor(
?: Connection(podDevice, aapsLogger, context) ?: Connection(podDevice, aapsLogger, context)
connection = conn connection = conn
if (conn.connectionState() is Connected) { if (conn.connectionState() is Connected) {
emitter.onNext(PodEvent.Connected) if (conn.session == null) {
emitter.onNext(PodEvent.EstablishingSession)
establishSession(1.toByte())
emitter.onNext(PodEvent.Connected)
} else {
emitter.onNext(PodEvent.AlreadyConnected(podAddress))
}
emitter.onComplete() emitter.onComplete()
return@create return@create
} }

View file

@ -22,7 +22,7 @@ class BleCommCallbacks(
) : BluetoothGattCallback() { ) : BluetoothGattCallback() {
private val serviceDiscoveryComplete: CountDownLatch = CountDownLatch(1) private val serviceDiscoveryComplete: CountDownLatch = CountDownLatch(1)
private val connected: CountDownLatch = CountDownLatch(1) private var connected: CountDownLatch = CountDownLatch(1)
private val writeQueue: BlockingQueue<WriteConfirmation> = LinkedBlockingQueue(1) private val writeQueue: BlockingQueue<WriteConfirmation> = LinkedBlockingQueue(1)
override fun onConnectionStateChange(gatt: BluetoothGatt, status: Int, newState: Int) { override fun onConnectionStateChange(gatt: BluetoothGatt, status: Int, newState: Int) {
@ -98,7 +98,10 @@ class BleCommCallbacks(
payload.toHex() payload.toHex()
) )
incomingPackets.byCharacteristicType(characteristicType).add(payload) val insertResult = incomingPackets.byCharacteristicType(characteristicType).add(payload)
if (!insertResult) {
aapsLogger.warn(LTag.PUMPBTCOMM, "Could not insert read data to the incoming queue: ${characteristicType}")
}
} }
override fun onDescriptorWrite(gatt: BluetoothGatt, descriptor: BluetoothGattDescriptor, status: Int) { override fun onDescriptorWrite(gatt: BluetoothGatt, descriptor: BluetoothGattDescriptor, status: Int) {
@ -148,6 +151,11 @@ class BleCommCallbacks(
} }
} }
fun resetConnection() {
connected = CountDownLatch(1)
flushConfirmationQueue()
}
companion object { companion object {
private const val WRITE_CONFIRM_TIMEOUT_MS = 10 // the confirmation queue should be empty anyway private const val WRITE_CONFIRM_TIMEOUT_MS = 10 // the confirmation queue should be empty anyway

View file

@ -54,7 +54,7 @@ open class BleIO(
* @param payload the data to send * @param payload the data to send
*/ */
fun sendAndConfirmPacket(payload: ByteArray): BleSendResult { fun sendAndConfirmPacket(payload: ByteArray): BleSendResult {
aapsLogger.debug(LTag.PUMPBTCOMM, "BleIO: Sending data on ${payload.toHex()}") aapsLogger.debug(LTag.PUMPBTCOMM, "BleIO: Sending on ${type.name}: ${payload.toHex()}")
val set = characteristic.setValue(payload) val set = characteristic.setValue(payload)
if (!set) { if (!set) {
return BleSendErrorSending("Could set setValue on ${type.name}") return BleSendErrorSending("Could set setValue on ${type.name}")

View file

@ -10,8 +10,8 @@ class IncomingPackets {
fun byCharacteristicType(char: CharacteristicType): BlockingQueue<ByteArray> { fun byCharacteristicType(char: CharacteristicType): BlockingQueue<ByteArray> {
return when (char) { return when (char) {
CharacteristicType.DATA -> cmdQueue CharacteristicType.DATA -> dataQueue
CharacteristicType.CMD -> dataQueue CharacteristicType.CMD -> cmdQueue
} }
} }
} }

View file

@ -103,7 +103,8 @@ class MessageIO(
maxMessageReadTries = joiner.fullFragments * 2 + 2 maxMessageReadTries = joiner.fullFragments * 2 + 2
for (i in 1 until joiner.fullFragments + 1) { for (i in 1 until joiner.fullFragments + 1) {
expected++ expected++
val packet = expectBlePacket(expected) val nackOnTimeout = !joiner.oneExtraPacket && i==joiner.fullFragments // last packet
val packet = expectBlePacket(expected, nackOnTimeout)
if (packet !is PacketReceiveSuccess) { if (packet !is PacketReceiveSuccess) {
aapsLogger.warn(LTag.PUMPBTCOMM, "Error reading packet:$packet") aapsLogger.warn(LTag.PUMPBTCOMM, "Error reading packet:$packet")
return null return null
@ -112,7 +113,7 @@ class MessageIO(
} }
if (joiner.oneExtraPacket) { if (joiner.oneExtraPacket) {
expected++ expected++
val packet = expectBlePacket(expected) val packet = expectBlePacket(expected, true)
if (packet !is PacketReceiveSuccess) { if (packet !is PacketReceiveSuccess) {
aapsLogger.warn(LTag.PUMPBTCOMM, "Error reading packet:$packet") aapsLogger.warn(LTag.PUMPBTCOMM, "Error reading packet:$packet")
return null return null
@ -186,7 +187,8 @@ class MessageIO(
if (received == null || received.isEmpty()) { if (received == null || received.isEmpty()) {
if (nackOnTimeout) if (nackOnTimeout)
cmdBleIO.sendAndConfirmPacket(BleCommandNack(index).data) cmdBleIO.sendAndConfirmPacket(BleCommandNack(index).data)
aapsLogger.info(LTag.PUMPBTCOMM, "Error reading index: $index. Received: $received") aapsLogger.info(LTag.PUMPBTCOMM, "Error reading index: $index. Received: $received. NackOnTimeout: " +
"$nackOnTimeout")
continue continue
} }
if (received[0] == index) { if (received[0] == index) {

View file

@ -26,7 +26,7 @@ sealed class ConnectionState
object Connected : ConnectionState() object Connected : ConnectionState()
object NotConnected : ConnectionState() object NotConnected : ConnectionState()
class Connection(val podDevice: BluetoothDevice, private val aapsLogger: AAPSLogger, private val context: Context) { class Connection(val podDevice: BluetoothDevice, private val aapsLogger: AAPSLogger, context: Context) {
private val incomingPackets = IncomingPackets() private val incomingPackets = IncomingPackets()
private val bleCommCallbacks = BleCommCallbacks(aapsLogger, incomingPackets) private val bleCommCallbacks = BleCommCallbacks(aapsLogger, incomingPackets)
@ -77,6 +77,9 @@ class Connection(val podDevice: BluetoothDevice, private val aapsLogger: AAPSLog
} }
fun connect() { fun connect() {
// forces reconnection
disconnect()
if (!gattConnection.connect()) { if (!gattConnection.connect()) {
throw FailedToConnectException("connect() returned false") throw FailedToConnectException("connect() returned false")
} }
@ -86,10 +89,14 @@ class Connection(val podDevice: BluetoothDevice, private val aapsLogger: AAPSLog
} }
cmdBleIO.hello() cmdBleIO.hello()
cmdBleIO.readyToRead()
dataBleIO.readyToRead()
} }
fun disconnect() { fun disconnect() {
bleCommCallbacks.resetConnection()
gattConnection.disconnect() gattConnection.disconnect()
session = null
} }
private fun waitForConnection(): ConnectionState { private fun waitForConnection(): ConnectionState {

View file

@ -73,11 +73,11 @@ class Session(
var responseMsgPacket: MessagePacket? = null var responseMsgPacket: MessagePacket? = null
for (i in 0..MAX_TRIES) { for (i in 0..MAX_TRIES) {
val responseMsg = msgIO.receiveMessage() val responseMsg = msgIO.receiveMessage()
if (responseMsg == null) { if (responseMsg != null) {
aapsLogger.debug(LTag.PUMPBTCOMM, "Error receiving response: $responseMsg") responseMsgPacket = responseMsg
continue break
} }
responseMsgPacket = responseMsg aapsLogger.debug(LTag.PUMPBTCOMM, "Error receiving response: $responseMsg")
} }
responseMsgPacket responseMsgPacket