diff options
author | Irfan Sheriff <isheriff@google.com> | 2013-02-12 18:31:37 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2013-02-12 18:31:37 +0000 |
commit | 702b42dd7415a88e876d4bacb1b543579548c607 (patch) | |
tree | 1a6ce7766327d2858a4d383a746fca1d65393f75 /wifi/java/android | |
parent | 0ef4397125995c30718f404cee76c0dbbdbf7ef6 (diff) | |
parent | 9dab7d670537eb6a954d8e933c1deade87dfd981 (diff) | |
download | frameworks_base-702b42dd7415a88e876d4bacb1b543579548c607.zip frameworks_base-702b42dd7415a88e876d4bacb1b543579548c607.tar.gz frameworks_base-702b42dd7415a88e876d4bacb1b543579548c607.tar.bz2 |
Merge "Fix NPE"
Diffstat (limited to 'wifi/java/android')
-rw-r--r-- | wifi/java/android/net/wifi/p2p/WifiP2pService.java | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/wifi/java/android/net/wifi/p2p/WifiP2pService.java b/wifi/java/android/net/wifi/p2p/WifiP2pService.java index 77604a4..1589fec 100644 --- a/wifi/java/android/net/wifi/p2p/WifiP2pService.java +++ b/wifi/java/android/net/wifi/p2p/WifiP2pService.java @@ -1332,10 +1332,19 @@ public class WifiP2pService extends IWifiP2pManager.Stub { P2pStateMachine.this, mGroup.getInterface()); mDhcpStateMachine.sendMessage(DhcpStateMachine.CMD_START_DHCP); WifiP2pDevice groupOwner = mGroup.getOwner(); - /* update group owner details with the ones found at discovery */ - groupOwner.updateSupplicantDetails(mPeers.get(groupOwner.deviceAddress)); - mPeers.updateStatus(groupOwner.deviceAddress, WifiP2pDevice.CONNECTED); - sendPeersChangedBroadcast(); + WifiP2pDevice peer = mPeers.get(groupOwner.deviceAddress); + if (peer != null) { + // update group owner details with peer details found at discovery + groupOwner.updateSupplicantDetails(peer); + mPeers.updateStatus(groupOwner.deviceAddress, WifiP2pDevice.CONNECTED); + sendPeersChangedBroadcast(); + } else { + // A supplicant bug can lead to reporting an invalid + // group owner address (all zeroes) at times. Avoid a + // crash, but continue group creation since it is not + // essential. + logw("Unknown group owner " + groupOwner); + } } transitionTo(mGroupCreatedState); break; |