BaseDfuImpl.smali
.class abstract Lno/nordicsemi/android/dfu/BaseDfuImpl;
.super Ljava/lang/Object;
.source "BaseDfuImpl.java"
# interfaces
.implements Lno/nordicsemi/android/dfu/DfuService;
# static fields
.field protected static final CLIENT_CHARACTERISTIC_CONFIG:Ljava/util/UUID;
.field protected static final GENERIC_ATTRIBUTE_SERVICE_UUID:Ljava/util/UUID;
.field protected static final HEX_ARRAY:[C
.field protected static final INDICATIONS:I = 0x2
.field protected static final MAX_PACKET_SIZE_DEFAULT:I = 0x14
.field protected static final NOTIFICATIONS:I = 0x1
.field protected static final SERVICE_CHANGED_UUID:Ljava/util/UUID;
.field private static final TAG:Ljava/lang/String; = "DfuImpl"
# instance fields
.field protected mAborted:Z
.field protected mBuffer:[B
.field protected mConnected:Z
.field protected mError:I
.field protected mFileType:I
.field protected mFirmwareStream:Ljava/io/InputStream;
.field protected mGatt:Landroid/bluetooth/BluetoothGatt;
.field protected mImageSizeInBytes:I
.field protected mInitPacketSizeInBytes:I
.field protected mInitPacketStream:Ljava/io/InputStream;
.field protected final mLock:Ljava/lang/Object;
.field protected mPaused:Z
.field protected mProgressInfo:Lno/nordicsemi/android/dfu/DfuProgressInfo;
.field protected mReceivedData:[B
.field protected mRequestCompleted:Z
.field protected mResetRequestSent:Z
.field protected mService:Lno/nordicsemi/android/dfu/DfuBaseService;
# direct methods
.method static constructor <clinit>()V
.registers 6
.prologue
const-wide v4, -0x7fffff7fa064cb05L # -2.724079460785E-312
.line 49
new-instance v0, Ljava/util/UUID;
const-wide v2, 0x180100001000L
invoke-direct {v0, v2, v3, v4, v5}, Ljava/util/UUID;-><init>(JJ)V
sput-object v0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->GENERIC_ATTRIBUTE_SERVICE_UUID:Ljava/util/UUID;
.line 50
new-instance v0, Ljava/util/UUID;
const-wide v2, 0x2a0500001000L
invoke-direct {v0, v2, v3, v4, v5}, Ljava/util/UUID;-><init>(JJ)V
sput-object v0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->SERVICE_CHANGED_UUID:Ljava/util/UUID;
.line 51
new-instance v0, Ljava/util/UUID;
const-wide v2, 0x290200001000L
invoke-direct {v0, v2, v3, v4, v5}, Ljava/util/UUID;-><init>(JJ)V
sput-object v0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->CLIENT_CHARACTERISTIC_CONFIG:Ljava/util/UUID;
.line 55
const-string v0, "0123456789ABCDEF"
invoke-virtual {v0}, Ljava/lang/String;->toCharArray()[C
move-result-object v0
sput-object v0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->HEX_ARRAY:[C
return-void
.end method
.method constructor <init>(Landroid/content/Intent;Lno/nordicsemi/android/dfu/DfuBaseService;)V
.registers 4
.prologue
.line 206
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 61
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
.line 92
const/4 v0, 0x0
iput-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mReceivedData:[B
.line 93
const/16 v0, 0x14
new-array v0, v0, [B
iput-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mBuffer:[B
.line 207
iput-object p2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
.line 208
iget-object v0, p2, Lno/nordicsemi/android/dfu/DfuBaseService;->mProgressInfo:Lno/nordicsemi/android/dfu/DfuProgressInfo;
iput-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mProgressInfo:Lno/nordicsemi/android/dfu/DfuProgressInfo;
.line 209
const/4 v0, 0x1
iput-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
.line 210
return-void
.end method
.method private createBondApi18(Landroid/bluetooth/BluetoothDevice;)Z
.registers 7
.prologue
const/4 v1, 0x0
.line 532
:try_start_1
invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
const-string v2, "createBond"
const/4 v3, 0x0
new-array v3, v3, [Ljava/lang/Class;
invoke-virtual {v0, v2, v3}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v0
.line 533
if-eqz v0, :cond_27
.line 534
iget-object v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const/4 v3, 0x0
const-string v4, "gatt.getDevice().createBond() (hidden)"
invoke-virtual {v2, v3, v4}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 535
const/4 v2, 0x0
new-array v2, v2, [Ljava/lang/Object;
invoke-virtual {v0, p1, v2}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Boolean;
invoke-virtual {v0}, Ljava/lang/Boolean;->booleanValue()Z
:try_end_24
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_24} :catch_26
move-result v0
.line 540
:goto_25
return v0
:catch_26
move-exception v0
:cond_27
move v0, v1
goto :goto_25
.end method
.method private isServiceChangedCCCDEnabled()Z
.registers 8
.prologue
const/4 v1, 0x1
const/4 v0, 0x0
.line 394
iget-boolean v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-nez v2, :cond_e
.line 395
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;
const-string v1, "Unable to read Service Changed CCCD: device disconnected"
invoke-direct {v0, v1}, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;-><init>(Ljava/lang/String;)V
throw v0
.line 396
:cond_e
iget-boolean v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mAborted:Z
if-eqz v2, :cond_18
.line 397
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/UploadAbortedException;
invoke-direct {v0}, Lno/nordicsemi/android/dfu/internal/exception/UploadAbortedException;-><init>()V
throw v0
.line 400
:cond_18
iget-object v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mGatt:Landroid/bluetooth/BluetoothGatt;
.line 401
sget-object v3, Lno/nordicsemi/android/dfu/BaseDfuImpl;->GENERIC_ATTRIBUTE_SERVICE_UUID:Ljava/util/UUID;
invoke-virtual {v2, v3}, Landroid/bluetooth/BluetoothGatt;->getService(Ljava/util/UUID;)Landroid/bluetooth/BluetoothGattService;
move-result-object v3
.line 402
if-nez v3, :cond_23
.line 438
:cond_22
:goto_22
return v0
.line 405
:cond_23
sget-object v4, Lno/nordicsemi/android/dfu/BaseDfuImpl;->SERVICE_CHANGED_UUID:Ljava/util/UUID;
invoke-virtual {v3, v4}, Landroid/bluetooth/BluetoothGattService;->getCharacteristic(Ljava/util/UUID;)Landroid/bluetooth/BluetoothGattCharacteristic;
move-result-object v3
.line 406
if-eqz v3, :cond_22
.line 409
sget-object v4, Lno/nordicsemi/android/dfu/BaseDfuImpl;->CLIENT_CHARACTERISTIC_CONFIG:Ljava/util/UUID;
invoke-virtual {v3, v4}, Landroid/bluetooth/BluetoothGattCharacteristic;->getDescriptor(Ljava/util/UUID;)Landroid/bluetooth/BluetoothGattDescriptor;
move-result-object v3
.line 410
if-eqz v3, :cond_22
.line 413
iput-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mRequestCompleted:Z
.line 414
iput v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
.line 416
const-string v4, "Reading Service Changed CCCD value..."
invoke-virtual {p0, v4}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->logi(Ljava/lang/String;)V
.line 417
iget-object v4, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const-string v5, "Reading Service Changed CCCD value..."
invoke-virtual {v4, v1, v5}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 418
iget-object v4, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
new-instance v5, Ljava/lang/StringBuilder;
const-string v6, "gatt.readDescriptor("
invoke-direct {v5, v6}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3}, Landroid/bluetooth/BluetoothGattDescriptor;->getUuid()Ljava/util/UUID;
move-result-object v6
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v5
const-string v6, ")"
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v5
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-virtual {v4, v0, v5}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 419
invoke-virtual {v2, v3}, Landroid/bluetooth/BluetoothGatt;->readDescriptor(Landroid/bluetooth/BluetoothGattDescriptor;)Z
.line 423
:try_start_64
iget-object v4, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
monitor-enter v4
:try_end_67
.catch Ljava/lang/InterruptedException; {:try_start_64 .. :try_end_67} :catch_80
.line 424
:goto_67
:try_start_67
iget-boolean v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mRequestCompleted:Z
if-nez v2, :cond_73
iget-boolean v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-eqz v2, :cond_73
iget v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
if-eqz v2, :cond_77
:cond_73
iget-boolean v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mPaused:Z
if-eqz v2, :cond_94
.line 425
:cond_77
iget-object v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
invoke-virtual {v2}, Ljava/lang/Object;->wait()V
goto :goto_67
.line 426
:catchall_7d
move-exception v2
monitor-exit v4
:try_end_7f
.catchall {:try_start_67 .. :try_end_7f} :catchall_7d
:try_start_7f
throw v2
:try_end_80
.catch Ljava/lang/InterruptedException; {:try_start_7f .. :try_end_80} :catch_80
.line 427
:catch_80
move-exception v2
.line 428
const-string v4, "Sleeping interrupted"
invoke-virtual {p0, v4, v2}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->loge(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 430
:goto_86
iget v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
if-eqz v2, :cond_96
.line 431
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/DfuException;
const-string v1, "Unable to read Service Changed CCCD"
iget v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
invoke-direct {v0, v1, v2}, Lno/nordicsemi/android/dfu/internal/exception/DfuException;-><init>(Ljava/lang/String;I)V
throw v0
.line 426
:cond_94
:try_start_94
monitor-exit v4
:try_end_95
.catchall {:try_start_94 .. :try_end_95} :catchall_7d
goto :goto_86
.line 432
:cond_96
iget-boolean v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-nez v2, :cond_a2
.line 433
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;
const-string v1, "Unable to read Service Changed CCCD: device disconnected"
invoke-direct {v0, v1}, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;-><init>(Ljava/lang/String;)V
throw v0
.line 436
:cond_a2
invoke-virtual {v3}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v2
if-eqz v2, :cond_22
invoke-virtual {v3}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v2
array-length v2, v2
const/4 v4, 0x2
if-ne v2, v4, :cond_22
.line 437
invoke-virtual {v3}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v2
aget-byte v2, v2, v0
sget-object v4, Landroid/bluetooth/BluetoothGattDescriptor;->ENABLE_INDICATION_VALUE:[B
aget-byte v4, v4, v0
if-ne v2, v4, :cond_22
.line 438
invoke-virtual {v3}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v2
aget-byte v2, v2, v1
sget-object v3, Landroid/bluetooth/BluetoothGattDescriptor;->ENABLE_INDICATION_VALUE:[B
aget-byte v3, v3, v1
if-ne v2, v3, :cond_22
move v0, v1
goto/16 :goto_22
.end method
# virtual methods
.method public abort()V
.registers 2
.prologue
.line 230
const/4 v0, 0x0
iput-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mPaused:Z
.line 231
const/4 v0, 0x1
iput-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mAborted:Z
.line 232
invoke-virtual {p0}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->notifyLock()V
.line 233
return-void
.end method
.method protected createBond()Z
.registers 6
.annotation build Landroid/annotation/SuppressLint;
value = {
"NewApi"
}
.end annotation
.prologue
const/4 v0, 0x1
const/4 v4, 0x0
.line 494
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mGatt:Landroid/bluetooth/BluetoothGatt;
invoke-virtual {v1}, Landroid/bluetooth/BluetoothGatt;->getDevice()Landroid/bluetooth/BluetoothDevice;
move-result-object v1
.line 495
invoke-virtual {v1}, Landroid/bluetooth/BluetoothDevice;->getBondState()I
move-result v2
const/16 v3, 0xc
if-ne v2, v3, :cond_11
.line 518
:goto_10
return v0
.line 499
:cond_11
iput-boolean v4, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mRequestCompleted:Z
.line 501
iget-object v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const-string v3, "Starting pairing..."
invoke-virtual {v2, v0, v3}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 502
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v2, 0x13
if-lt v0, v2, :cond_46
.line 503
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const-string v2, "gatt.getDevice().createBond()"
invoke-virtual {v0, v4, v2}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 504
invoke-virtual {v1}, Landroid/bluetooth/BluetoothDevice;->createBond()Z
move-result v0
.line 511
:goto_2b
:try_start_2b
iget-object v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
monitor-enter v2
:try_end_2e
.catch Ljava/lang/InterruptedException; {:try_start_2b .. :try_end_2e} :catch_3f
.line 512
:goto_2e
:try_start_2e
iget-boolean v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mRequestCompleted:Z
if-nez v1, :cond_4b
iget-boolean v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mAborted:Z
if-nez v1, :cond_4b
.line 513
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
invoke-virtual {v1}, Ljava/lang/Object;->wait()V
goto :goto_2e
.line 514
:catchall_3c
move-exception v1
monitor-exit v2
:try_end_3e
.catchall {:try_start_2e .. :try_end_3e} :catchall_3c
:try_start_3e
throw v1
:try_end_3f
.catch Ljava/lang/InterruptedException; {:try_start_3e .. :try_end_3f} :catch_3f
.line 515
:catch_3f
move-exception v1
.line 516
const-string v2, "Sleeping interrupted"
invoke-virtual {p0, v2, v1}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->loge(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_10
.line 506
:cond_46
invoke-direct {p0, v1}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->createBondApi18(Landroid/bluetooth/BluetoothDevice;)Z
move-result v0
goto :goto_2b
.line 514
:cond_4b
:try_start_4b
monitor-exit v2
:try_end_4c
.catchall {:try_start_4b .. :try_end_4c} :catchall_3c
goto :goto_10
.end method
.method protected enableCCCD(Landroid/bluetooth/BluetoothGattCharacteristic;I)V
.registers 13
.prologue
const/4 v9, 0x2
const/4 v3, 0x0
const/4 v2, 0x1
.line 341
iget-object v5, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mGatt:Landroid/bluetooth/BluetoothGatt;
.line 342
if-ne p2, v2, :cond_28
const-string v0, "notifications"
.line 343
:goto_9
iget-boolean v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-nez v1, :cond_2b
.line 344
new-instance v1, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Unable to set "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v2, " state: device disconnected"
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;-><init>(Ljava/lang/String;)V
throw v1
.line 342
:cond_28
const-string v0, "indications"
goto :goto_9
.line 345
:cond_2b
iget-boolean v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mAborted:Z
if-eqz v1, :cond_35
.line 346
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/UploadAbortedException;
invoke-direct {v0}, Lno/nordicsemi/android/dfu/internal/exception/UploadAbortedException;-><init>()V
throw v0
.line 348
:cond_35
const/4 v1, 0x0
iput-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mReceivedData:[B
.line 349
iput v3, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
.line 350
sget-object v1, Lno/nordicsemi/android/dfu/BaseDfuImpl;->CLIENT_CHARACTERISTIC_CONFIG:Ljava/util/UUID;
invoke-virtual {p1, v1}, Landroid/bluetooth/BluetoothGattCharacteristic;->getDescriptor(Ljava/util/UUID;)Landroid/bluetooth/BluetoothGattDescriptor;
move-result-object v6
.line 351
invoke-virtual {v6}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v1
if-eqz v1, :cond_61
invoke-virtual {v6}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v1
array-length v1, v1
if-ne v1, v9, :cond_61
invoke-virtual {v6}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v1
aget-byte v1, v1, v3
if-lez v1, :cond_61
invoke-virtual {v6}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v1
aget-byte v1, v1, v2
if-nez v1, :cond_61
move v4, v2
.line 352
:goto_5e
if-eqz v4, :cond_63
.line 383
:cond_60
return-void
:cond_61
move v4, v3
.line 351
goto :goto_5e
.line 355
:cond_63
new-instance v1, Ljava/lang/StringBuilder;
const-string v7, "Enabling "
invoke-direct {v1, v7}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v7, "..."
invoke-virtual {v1, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {p0, v1}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->logi(Ljava/lang/String;)V
.line 356
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
new-instance v7, Ljava/lang/StringBuilder;
const-string v8, "Enabling "
invoke-direct {v7, v8}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v7, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
const-string v8, " for "
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {p1}, Landroid/bluetooth/BluetoothGattCharacteristic;->getUuid()Ljava/util/UUID;
move-result-object v8
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
invoke-virtual {v1, v2, v7}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 359
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
new-instance v7, Ljava/lang/StringBuilder;
const-string v8, "gatt.setCharacteristicNotification("
invoke-direct {v7, v8}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Landroid/bluetooth/BluetoothGattCharacteristic;->getUuid()Ljava/util/UUID;
move-result-object v8
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v7
const-string v8, ", true)"
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
invoke-virtual {v1, v3, v7}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 360
invoke-virtual {v5, p1, v2}, Landroid/bluetooth/BluetoothGatt;->setCharacteristicNotification(Landroid/bluetooth/BluetoothGattCharacteristic;Z)Z
.line 363
if-ne p2, v2, :cond_120
sget-object v1, Landroid/bluetooth/BluetoothGattDescriptor;->ENABLE_NOTIFICATION_VALUE:[B
:goto_c2
invoke-virtual {v6, v1}, Landroid/bluetooth/BluetoothGattDescriptor;->setValue([B)Z
.line 364
iget-object v7, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
new-instance v1, Ljava/lang/StringBuilder;
const-string v8, "gatt.writeDescriptor("
invoke-direct {v1, v8}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v6}, Landroid/bluetooth/BluetoothGattDescriptor;->getUuid()Ljava/util/UUID;
move-result-object v8
invoke-virtual {v1, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v8
if-ne p2, v2, :cond_123
const-string v1, ", value=0x01-00)"
:goto_da
invoke-virtual {v8, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v7, v3, v1}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 365
invoke-virtual {v5, v6}, Landroid/bluetooth/BluetoothGatt;->writeDescriptor(Landroid/bluetooth/BluetoothGattDescriptor;)Z
.line 369
:try_start_e8
iget-object v5, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
monitor-enter v5
:try_end_eb
.catch Ljava/lang/InterruptedException; {:try_start_e8 .. :try_end_eb} :catch_14d
move v1, v4
.line 370
:goto_ec
if-nez v1, :cond_f6
:try_start_ee
iget-boolean v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-eqz v1, :cond_f6
iget v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
if-eqz v1, :cond_fa
:cond_f6
iget-boolean v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mPaused:Z
if-eqz v1, :cond_128
.line 371
:cond_fa
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
invoke-virtual {v1}, Ljava/lang/Object;->wait()V
.line 373
invoke-virtual {v6}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v1
if-eqz v1, :cond_126
invoke-virtual {v6}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v1
array-length v1, v1
if-ne v1, v9, :cond_126
invoke-virtual {v6}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v1
const/4 v4, 0x0
aget-byte v1, v1, v4
if-lez v1, :cond_126
invoke-virtual {v6}, Landroid/bluetooth/BluetoothGattDescriptor;->getValue()[B
move-result-object v1
const/4 v4, 0x1
aget-byte v1, v1, v4
:try_end_11c
.catchall {:try_start_ee .. :try_end_11c} :catchall_14a
if-nez v1, :cond_126
move v1, v2
goto :goto_ec
.line 363
:cond_120
sget-object v1, Landroid/bluetooth/BluetoothGattDescriptor;->ENABLE_INDICATION_VALUE:[B
goto :goto_c2
.line 364
:cond_123
const-string v1, ", value=0x02-00)"
goto :goto_da
:cond_126
move v1, v3
.line 373
goto :goto_ec
.line 375
:cond_128
:try_start_128
monitor-exit v5
:try_end_129
.catchall {:try_start_128 .. :try_end_129} :catchall_14a
.line 379
:goto_129
iget v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
if-eqz v1, :cond_154
.line 380
new-instance v1, Lno/nordicsemi/android/dfu/internal/exception/DfuException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Unable to set "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v2, " state"
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
iget v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
invoke-direct {v1, v0, v2}, Lno/nordicsemi/android/dfu/internal/exception/DfuException;-><init>(Ljava/lang/String;I)V
throw v1
.line 375
:catchall_14a
move-exception v1
:try_start_14b
monitor-exit v5
:try_end_14c
.catchall {:try_start_14b .. :try_end_14c} :catchall_14a
:try_start_14c
throw v1
:try_end_14d
.catch Ljava/lang/InterruptedException; {:try_start_14c .. :try_end_14d} :catch_14d
.line 376
:catch_14d
move-exception v1
.line 377
const-string v2, "Sleeping interrupted"
invoke-virtual {p0, v2, v1}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->loge(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_129
.line 381
:cond_154
iget-boolean v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-nez v1, :cond_60
.line 382
new-instance v1, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Unable to set "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v2, " state: device disconnected"
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;-><init>(Ljava/lang/String;)V
throw v1
.end method
.method public initialize(Landroid/content/Intent;Landroid/bluetooth/BluetoothGatt;ILjava/io/InputStream;Ljava/io/InputStream;)Z
.registers 14
.prologue
const/16 v7, 0xf
const/4 v1, 0x0
const/4 v3, 0x2
const/4 v6, 0x1
.line 243
iput-object p2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mGatt:Landroid/bluetooth/BluetoothGatt;
.line 244
iput p3, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mFileType:I
.line 245
iput-object p4, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mFirmwareStream:Ljava/io/InputStream;
.line 246
iput-object p5, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mInitPacketStream:Ljava/io/InputStream;
.line 248
const-string v0, "no.nordicsemi.android.dfu.extra.EXTRA_PART_CURRENT"
invoke-virtual {p1, v0, v6}, Landroid/content/Intent;->getIntExtra(Ljava/lang/String;I)I
move-result v4
.line 249
const-string v0, "no.nordicsemi.android.dfu.extra.EXTRA_PARTS_TOTAL"
invoke-virtual {p1, v0, v6}, Landroid/content/Intent;->getIntExtra(Ljava/lang/String;I)I
move-result v0
.line 252
const/4 v2, 0x4
if-le p3, v2, :cond_8c
.line 253
const-string v0, "DFU target does not support (SD/BL)+App update, splitting into 2 parts"
invoke-virtual {p0, v0}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->logw(Ljava/lang/String;)V
.line 254
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const-string v2, "Sending system components"
invoke-virtual {v0, v7, v2}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 255
iget v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mFileType:I
and-int/lit8 v0, v0, -0x5
iput v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mFileType:I
.line 259
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mFirmwareStream:Ljava/io/InputStream;
check-cast v0, Lno/nordicsemi/android/dfu/internal/ArchiveInputStream;
.line 260
iget v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mFileType:I
invoke-virtual {v0, v2}, Lno/nordicsemi/android/dfu/internal/ArchiveInputStream;->setContentType(I)I
move v2, v3
.line 263
:goto_38
if-ne v4, v3, :cond_41
.line 264
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const-string v5, "Sending application"
invoke-virtual {v0, v7, v5}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 269
:cond_41
:try_start_41
invoke-virtual {p5}, Ljava/io/InputStream;->available()I
:try_end_44
.catch Ljava/lang/Exception; {:try_start_41 .. :try_end_44} :catch_87
move-result v0
.line 273
:goto_45
iput v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mInitPacketSizeInBytes:I
.line 275
:try_start_47
invoke-virtual {p4}, Ljava/io/InputStream;->available()I
:try_end_4a
.catch Ljava/lang/Exception; {:try_start_47 .. :try_end_4a} :catch_8a
move-result v1
.line 280
:goto_4b
iput v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mImageSizeInBytes:I
.line 281
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mProgressInfo:Lno/nordicsemi/android/dfu/DfuProgressInfo;
invoke-virtual {v0, v1, v4, v2}, Lno/nordicsemi/android/dfu/DfuProgressInfo;->init(III)Lno/nordicsemi/android/dfu/DfuProgressInfo;
.line 294
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x17
if-ge v0, v1, :cond_86
invoke-virtual {p2}, Landroid/bluetooth/BluetoothGatt;->getDevice()Landroid/bluetooth/BluetoothDevice;
move-result-object v0
invoke-virtual {v0}, Landroid/bluetooth/BluetoothDevice;->getBondState()I
move-result v0
const/16 v1, 0xc
if-ne v0, v1, :cond_86
.line 295
sget-object v0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->GENERIC_ATTRIBUTE_SERVICE_UUID:Ljava/util/UUID;
invoke-virtual {p2, v0}, Landroid/bluetooth/BluetoothGatt;->getService(Ljava/util/UUID;)Landroid/bluetooth/BluetoothGattService;
move-result-object v0
.line 296
if-eqz v0, :cond_86
.line 297
sget-object v1, Lno/nordicsemi/android/dfu/BaseDfuImpl;->SERVICE_CHANGED_UUID:Ljava/util/UUID;
invoke-virtual {v0, v1}, Landroid/bluetooth/BluetoothGattService;->getCharacteristic(Ljava/util/UUID;)Landroid/bluetooth/BluetoothGattCharacteristic;
move-result-object v0
.line 298
if-eqz v0, :cond_86
.line 300
invoke-direct {p0}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->isServiceChangedCCCDEnabled()Z
move-result v1
.line 302
if-nez v1, :cond_7d
.line 303
invoke-virtual {p0, v0, v3}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->enableCCCD(Landroid/bluetooth/BluetoothGattCharacteristic;I)V
.line 305
:cond_7d
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const/16 v1, 0xa
const-string v2, "Service Changed indications enabled"
invoke-virtual {v0, v1, v2}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 309
:cond_86
return v6
.line 271
:catch_87
move-exception v0
move v0, v1
goto :goto_45
.line 277
:catch_8a
move-exception v0
goto :goto_4b
:cond_8c
move v2, v0
goto :goto_38
.end method
.method protected isBonded()Z
.registers 3
.prologue
.line 587
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mGatt:Landroid/bluetooth/BluetoothGatt;
invoke-virtual {v0}, Landroid/bluetooth/BluetoothGatt;->getDevice()Landroid/bluetooth/BluetoothDevice;
move-result-object v0
.line 588
invoke-virtual {v0}, Landroid/bluetooth/BluetoothDevice;->getBondState()I
move-result v0
const/16 v1, 0xc
if-ne v0, v1, :cond_10
const/4 v0, 0x1
:goto_f
return v0
:cond_10
const/4 v0, 0x0
goto :goto_f
.end method
.method loge(Ljava/lang/String;)V
.registers 2
.prologue
.line 693
return-void
.end method
.method loge(Ljava/lang/String;Ljava/lang/Throwable;)V
.registers 3
.prologue
.line 697
return-void
.end method
.method logi(Ljava/lang/String;)V
.registers 3
.prologue
.line 705
sget-boolean v0, Lno/nordicsemi/android/dfu/DfuBaseService;->DEBUG:Z
.line 707
return-void
.end method
.method logw(Ljava/lang/String;)V
.registers 3
.prologue
.line 700
sget-boolean v0, Lno/nordicsemi/android/dfu/DfuBaseService;->DEBUG:Z
.line 702
return-void
.end method
.method protected notifyLock()V
.registers 3
.prologue
.line 314
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
monitor-enter v1
.line 315
:try_start_3
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
invoke-virtual {v0}, Ljava/lang/Object;->notifyAll()V
.line 316
monitor-exit v1
return-void
:catchall_a
move-exception v0
monitor-exit v1
:try_end_c
.catchall {:try_start_3 .. :try_end_c} :catchall_a
throw v0
.end method
.method public onBondStateChanged(I)V
.registers 3
.prologue
.line 237
const/4 v0, 0x1
iput-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mRequestCompleted:Z
.line 238
invoke-virtual {p0}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->notifyLock()V
.line 239
return-void
.end method
.method protected parse([B)Ljava/lang/String;
.registers 9
.prologue
.line 673
if-nez p1, :cond_5
.line 674
const-string v0, ""
.line 688
:goto_4
return-object v0
.line 676
:cond_5
array-length v1, p1
.line 677
if-nez v1, :cond_b
.line 678
const-string v0, ""
goto :goto_4
.line 680
:cond_b
mul-int/lit8 v0, v1, 0x3
add-int/lit8 v0, v0, -0x1
new-array v2, v0, [C
.line 681
const/4 v0, 0x0
:goto_12
if-ge v0, v1, :cond_3d
.line 682
aget-byte v3, p1, v0
and-int/lit16 v3, v3, 0xff
.line 683
mul-int/lit8 v4, v0, 0x3
sget-object v5, Lno/nordicsemi/android/dfu/BaseDfuImpl;->HEX_ARRAY:[C
ushr-int/lit8 v6, v3, 0x4
aget-char v5, v5, v6
aput-char v5, v2, v4
.line 684
mul-int/lit8 v4, v0, 0x3
add-int/lit8 v4, v4, 0x1
sget-object v5, Lno/nordicsemi/android/dfu/BaseDfuImpl;->HEX_ARRAY:[C
and-int/lit8 v3, v3, 0xf
aget-char v3, v5, v3
aput-char v3, v2, v4
.line 685
add-int/lit8 v3, v1, -0x1
if-eq v0, v3, :cond_3a
.line 686
mul-int/lit8 v3, v0, 0x3
add-int/lit8 v3, v3, 0x2
const/16 v4, 0x2d
aput-char v4, v2, v3
.line 681
:cond_3a
add-int/lit8 v0, v0, 0x1
goto :goto_12
.line 688
:cond_3d
new-instance v0, Ljava/lang/String;
invoke-direct {v0, v2}, Ljava/lang/String;-><init>([C)V
goto :goto_4
.end method
.method public pause()V
.registers 2
.prologue
.line 219
const/4 v0, 0x1
iput-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mPaused:Z
.line 220
return-void
.end method
.method protected readNotificationResponse()[B
.registers 4
.prologue
.line 632
:try_start_0
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
monitor-enter v1
:try_end_3
.catch Ljava/lang/InterruptedException; {:try_start_0 .. :try_end_3} :catch_20
.line 633
:goto_3
:try_start_3
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mReceivedData:[B
if-nez v0, :cond_13
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-eqz v0, :cond_13
iget v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
if-nez v0, :cond_13
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mAborted:Z
if-eqz v0, :cond_17
:cond_13
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mPaused:Z
if-eqz v0, :cond_30
.line 634
:cond_17
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
invoke-virtual {v0}, Ljava/lang/Object;->wait()V
goto :goto_3
.line 635
:catchall_1d
move-exception v0
monitor-exit v1
:try_end_1f
.catchall {:try_start_3 .. :try_end_1f} :catchall_1d
:try_start_1f
throw v0
:try_end_20
.catch Ljava/lang/InterruptedException; {:try_start_1f .. :try_end_20} :catch_20
.line 636
:catch_20
move-exception v0
.line 637
const-string v1, "Sleeping interrupted"
invoke-virtual {p0, v1, v0}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->loge(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 639
:goto_26
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mAborted:Z
if-eqz v0, :cond_32
.line 640
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/UploadAbortedException;
invoke-direct {v0}, Lno/nordicsemi/android/dfu/internal/exception/UploadAbortedException;-><init>()V
throw v0
.line 635
:cond_30
:try_start_30
monitor-exit v1
:try_end_31
.catchall {:try_start_30 .. :try_end_31} :catchall_1d
goto :goto_26
.line 641
:cond_32
iget v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
if-eqz v0, :cond_40
.line 642
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/DfuException;
const-string v1, "Unable to write Op Code"
iget v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
invoke-direct {v0, v1, v2}, Lno/nordicsemi/android/dfu/internal/exception/DfuException;-><init>(Ljava/lang/String;I)V
throw v0
.line 643
:cond_40
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-nez v0, :cond_4c
.line 644
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;
const-string v1, "Unable to write Op Code: device disconnected"
invoke-direct {v0, v1}, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;-><init>(Ljava/lang/String;)V
throw v0
.line 645
:cond_4c
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mReceivedData:[B
return-object v0
.end method
.method public release()V
.registers 2
.prologue
.line 214
const/4 v0, 0x0
iput-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
.line 215
return-void
.end method
.method protected removeBond()Z
.registers 8
.prologue
const/4 v1, 0x1
const/4 v2, 0x0
.line 549
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mGatt:Landroid/bluetooth/BluetoothGatt;
invoke-virtual {v0}, Landroid/bluetooth/BluetoothGatt;->getDevice()Landroid/bluetooth/BluetoothDevice;
move-result-object v0
.line 550
invoke-virtual {v0}, Landroid/bluetooth/BluetoothDevice;->getBondState()I
move-result v3
const/16 v4, 0xa
if-ne v3, v4, :cond_11
.line 579
:goto_10
return v1
.line 553
:cond_11
iget-object v3, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const-string v4, "Removing bond information..."
invoke-virtual {v3, v1, v4}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 559
:try_start_18
invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v3
const-string v4, "removeBond"
const/4 v5, 0x0
new-array v5, v5, [Ljava/lang/Class;
invoke-virtual {v3, v4, v5}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v3
.line 560
if-eqz v3, :cond_59
.line 561
const/4 v4, 0x0
iput-boolean v4, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mRequestCompleted:Z
.line 562
iget-object v4, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const/4 v5, 0x0
const-string v6, "gatt.getDevice().removeBond() (hidden)"
invoke-virtual {v4, v5, v6}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 563
const/4 v4, 0x0
new-array v4, v4, [Ljava/lang/Object;
invoke-virtual {v3, v0, v4}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Boolean;
invoke-virtual {v0}, Ljava/lang/Boolean;->booleanValue()Z
:try_end_3e
.catch Ljava/lang/Exception; {:try_start_18 .. :try_end_3e} :catch_5e
move-result v2
.line 567
:try_start_3f
iget-object v3, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
monitor-enter v3
:try_end_42
.catch Ljava/lang/InterruptedException; {:try_start_3f .. :try_end_42} :catch_53
.catch Ljava/lang/Exception; {:try_start_3f .. :try_end_42} :catch_61
.line 568
:goto_42
:try_start_42
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mRequestCompleted:Z
if-nez v0, :cond_5c
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mAborted:Z
if-nez v0, :cond_5c
.line 569
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
invoke-virtual {v0}, Ljava/lang/Object;->wait()V
goto :goto_42
.line 570
:catchall_50
move-exception v0
monitor-exit v3
:try_end_52
.catchall {:try_start_42 .. :try_end_52} :catchall_50
:try_start_52
throw v0
:try_end_53
.catch Ljava/lang/InterruptedException; {:try_start_52 .. :try_end_53} :catch_53
.catch Ljava/lang/Exception; {:try_start_52 .. :try_end_53} :catch_61
.line 571
:catch_53
move-exception v0
.line 572
:try_start_54
const-string v3, "Sleeping interrupted"
invoke-virtual {p0, v3, v0}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->loge(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_59
.catch Ljava/lang/Exception; {:try_start_54 .. :try_end_59} :catch_61
:cond_59
:goto_59
move v0, v1
:goto_5a
move v1, v0
.line 579
goto :goto_10
.line 570
:cond_5c
:try_start_5c
monitor-exit v3
:try_end_5d
.catchall {:try_start_5c .. :try_end_5d} :catchall_50
goto :goto_59
:catch_5e
move-exception v0
move v0, v2
goto :goto_5a
:catch_61
move-exception v0
move v0, v2
goto :goto_5a
.end method
.method protected requestMtu(I)V
.registers 6
.prologue
const/4 v3, 0x0
.line 598
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mAborted:Z
if-eqz v0, :cond_b
.line 599
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/UploadAbortedException;
invoke-direct {v0}, Lno/nordicsemi/android/dfu/internal/exception/UploadAbortedException;-><init>()V
throw v0
.line 600
:cond_b
iput-boolean v3, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mRequestCompleted:Z
.line 602
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const/4 v1, 0x1
const-string v2, "Requesting new MTU..."
invoke-virtual {v0, v1, v2}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 603
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "gatt.requestMtu("
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, ")"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v3, v1}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 604
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mGatt:Landroid/bluetooth/BluetoothGatt;
invoke-virtual {v0, p1}, Landroid/bluetooth/BluetoothGatt;->requestMtu(I)Z
move-result v0
if-nez v0, :cond_38
.line 618
:cond_37
return-void
.line 609
:cond_38
:try_start_38
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
monitor-enter v1
:try_end_3b
.catch Ljava/lang/InterruptedException; {:try_start_38 .. :try_end_3b} :catch_54
.line 610
:goto_3b
:try_start_3b
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mRequestCompleted:Z
if-nez v0, :cond_47
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-eqz v0, :cond_47
iget v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
if-eqz v0, :cond_4b
:cond_47
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mPaused:Z
if-eqz v0, :cond_66
.line 611
:cond_4b
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
invoke-virtual {v0}, Ljava/lang/Object;->wait()V
goto :goto_3b
.line 612
:catchall_51
move-exception v0
monitor-exit v1
:try_end_53
.catchall {:try_start_3b .. :try_end_53} :catchall_51
:try_start_53
throw v0
:try_end_54
.catch Ljava/lang/InterruptedException; {:try_start_53 .. :try_end_54} :catch_54
.line 613
:catch_54
move-exception v0
.line 614
const-string v1, "Sleeping interrupted"
invoke-virtual {p0, v1, v0}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->loge(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 616
:goto_5a
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-nez v0, :cond_37
.line 617
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;
const-string v1, "Unable to read Service Changed CCCD: device disconnected"
invoke-direct {v0, v1}, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;-><init>(Ljava/lang/String;)V
throw v0
.line 612
:cond_66
:try_start_66
monitor-exit v1
:try_end_67
.catchall {:try_start_66 .. :try_end_67} :catchall_51
goto :goto_5a
.end method
.method protected restartService(Landroid/content/Intent;Z)V
.registers 8
.prologue
const/4 v4, 0x5
.line 655
const/4 v0, 0x0
.line 656
if-eqz p2, :cond_46
.line 657
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const/4 v1, 0x1
const-string v2, "Scanning for the DFU Bootloader..."
invoke-virtual {v0, v1, v2}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 658
invoke-static {}, Lno/nordicsemi/android/dfu/internal/scanner/BootloaderScannerFactory;->getScanner()Lno/nordicsemi/android/dfu/internal/scanner/BootloaderScanner;
move-result-object v0
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mGatt:Landroid/bluetooth/BluetoothGatt;
invoke-virtual {v1}, Landroid/bluetooth/BluetoothGatt;->getDevice()Landroid/bluetooth/BluetoothDevice;
move-result-object v1
invoke-virtual {v1}, Landroid/bluetooth/BluetoothDevice;->getAddress()Ljava/lang/String;
move-result-object v1
invoke-interface {v0, v1}, Lno/nordicsemi/android/dfu/internal/scanner/BootloaderScanner;->searchFor(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 659
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Scanning for new address finished with: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {p0, v1}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->logi(Ljava/lang/String;)V
.line 660
if-eqz v0, :cond_53
.line 661
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "DFU Bootloader found with address "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v4, v2}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 667
:cond_46
:goto_46
if-eqz v0, :cond_4d
.line 668
const-string v1, "no.nordicsemi.android.dfu.extra.EXTRA_DEVICE_ADDRESS"
invoke-virtual {p1, v1, v0}, Landroid/content/Intent;->putExtra(Ljava/lang/String;Ljava/lang/String;)Landroid/content/Intent;
.line 669
:cond_4d
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
invoke-virtual {v0, p1}, Lno/nordicsemi/android/dfu/DfuBaseService;->startService(Landroid/content/Intent;)Landroid/content/ComponentName;
.line 670
return-void
.line 663
:cond_53
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const-string v2, "DFU Bootloader not found. Trying the same address..."
invoke-virtual {v1, v4, v2}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
goto :goto_46
.end method
.method public resume()V
.registers 2
.prologue
.line 224
const/4 v0, 0x0
iput-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mPaused:Z
.line 225
invoke-virtual {p0}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->notifyLock()V
.line 226
return-void
.end method
.method protected waitIfPaused()V
.registers 3
.prologue
.line 321
:try_start_0
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
monitor-enter v1
:try_end_3
.catch Ljava/lang/InterruptedException; {:try_start_0 .. :try_end_3} :catch_10
.line 322
:goto_3
:try_start_3
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mPaused:Z
if-eqz v0, :cond_17
.line 323
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
invoke-virtual {v0}, Ljava/lang/Object;->wait()V
goto :goto_3
.line 324
:catchall_d
move-exception v0
monitor-exit v1
:try_end_f
.catchall {:try_start_3 .. :try_end_f} :catchall_d
:try_start_f
throw v0
:try_end_10
.catch Ljava/lang/InterruptedException; {:try_start_f .. :try_end_10} :catch_10
.line 325
:catch_10
move-exception v0
.line 326
const-string v1, "Sleeping interrupted"
invoke-virtual {p0, v1, v0}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->loge(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 328
:goto_16
return-void
.line 324
:cond_17
:try_start_17
monitor-exit v1
:try_end_18
.catchall {:try_start_17 .. :try_end_18} :catchall_d
goto :goto_16
.end method
.method protected writeOpCode(Landroid/bluetooth/BluetoothGattCharacteristic;[BZ)V
.registers 9
.prologue
const/4 v4, 0x0
.line 455
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mAborted:Z
if-eqz v0, :cond_b
.line 456
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/UploadAbortedException;
invoke-direct {v0}, Lno/nordicsemi/android/dfu/internal/exception/UploadAbortedException;-><init>()V
throw v0
.line 457
:cond_b
const/4 v0, 0x0
iput-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mReceivedData:[B
.line 458
iput v4, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
.line 459
iput-boolean v4, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mRequestCompleted:Z
.line 464
iput-boolean p3, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mResetRequestSent:Z
.line 466
const/4 v0, 0x2
invoke-virtual {p1, v0}, Landroid/bluetooth/BluetoothGattCharacteristic;->setWriteType(I)V
.line 467
invoke-virtual {p1, p2}, Landroid/bluetooth/BluetoothGattCharacteristic;->setValue([B)Z
.line 468
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
const/4 v1, 0x1
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Writing to characteristic "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Landroid/bluetooth/BluetoothGattCharacteristic;->getUuid()Ljava/util/UUID;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v1, v2}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 469
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mService:Lno/nordicsemi/android/dfu/DfuBaseService;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "gatt.writeCharacteristic("
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Landroid/bluetooth/BluetoothGattCharacteristic;->getUuid()Ljava/util/UUID;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, ")"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v4, v1}, Lno/nordicsemi/android/dfu/DfuBaseService;->sendLogBroadcast(ILjava/lang/String;)V
.line 470
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mGatt:Landroid/bluetooth/BluetoothGatt;
invoke-virtual {v0, p1}, Landroid/bluetooth/BluetoothGatt;->writeCharacteristic(Landroid/bluetooth/BluetoothGattCharacteristic;)Z
.line 474
:try_start_57
iget-object v1, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
monitor-enter v1
:try_end_5a
.catch Ljava/lang/InterruptedException; {:try_start_57 .. :try_end_5a} :catch_73
.line 475
:goto_5a
:try_start_5a
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mRequestCompleted:Z
if-nez v0, :cond_66
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-eqz v0, :cond_66
iget v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
if-eqz v0, :cond_6a
:cond_66
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mPaused:Z
if-eqz v0, :cond_9a
.line 476
:cond_6a
iget-object v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mLock:Ljava/lang/Object;
invoke-virtual {v0}, Ljava/lang/Object;->wait()V
goto :goto_5a
.line 477
:catchall_70
move-exception v0
monitor-exit v1
:try_end_72
.catchall {:try_start_5a .. :try_end_72} :catchall_70
:try_start_72
throw v0
:try_end_73
.catch Ljava/lang/InterruptedException; {:try_start_72 .. :try_end_73} :catch_73
.line 478
:catch_73
move-exception v0
.line 479
const-string v1, "Sleeping interrupted"
invoke-virtual {p0, v1, v0}, Lno/nordicsemi/android/dfu/BaseDfuImpl;->loge(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 481
:goto_79
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mResetRequestSent:Z
if-nez v0, :cond_9c
iget v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
if-eqz v0, :cond_9c
.line 482
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/DfuException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Unable to write Op Code "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
aget-byte v2, p2, v4
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
iget v2, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mError:I
invoke-direct {v0, v1, v2}, Lno/nordicsemi/android/dfu/internal/exception/DfuException;-><init>(Ljava/lang/String;I)V
throw v0
.line 477
:cond_9a
:try_start_9a
monitor-exit v1
:try_end_9b
.catchall {:try_start_9a .. :try_end_9b} :catchall_70
goto :goto_79
.line 483
:cond_9c
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mResetRequestSent:Z
if-nez v0, :cond_c1
iget-boolean v0, p0, Lno/nordicsemi/android/dfu/BaseDfuImpl;->mConnected:Z
if-nez v0, :cond_c1
.line 484
new-instance v0, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Unable to write Op Code "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
aget-byte v2, p2, v4
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, ": device disconnected"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Lno/nordicsemi/android/dfu/internal/exception/DeviceDisconnectedException;-><init>(Ljava/lang/String;)V
throw v0
.line 485
:cond_c1
return-void
.end method