summaryrefslogtreecommitdiffstats
path: root/services/java/com/android/server/NsdService.java
diff options
context:
space:
mode:
authorVinit Deshapnde <vinitd@google.com>2013-06-25 19:45:03 -0700
committerVinit Deshapnde <vinitd@google.com>2013-06-25 19:45:03 -0700
commit8ed09e893f6a4b6a4f6503186515b8f6978baa14 (patch)
tree1d5e5b0eecbe6d8eb92a84b3d253bb419fc8a73e /services/java/com/android/server/NsdService.java
parent28dd15b2d48752f8ea86d1fe10e31da3eeba5bb0 (diff)
downloadframeworks_base-8ed09e893f6a4b6a4f6503186515b8f6978baa14.zip
frameworks_base-8ed09e893f6a4b6a4f6503186515b8f6978baa14.tar.gz
frameworks_base-8ed09e893f6a4b6a4f6503186515b8f6978baa14.tar.bz2
Fix an NPE in NsdManager
The NPE happens because NSD Manager doesn't always notify with a 'good' notification for SERVICE_FOUND. It can get in a situation where a SERVICE_FOUND is recevied from MDnsDs demon when processing StopDiscovery on the messaging thread. When that happens, NsdService sends a message to NsdManager with an invalid index of the listener. The fix is twofold. First, we fix NsdService to not generate a message if it doesn't have a good listener index. And second, we also fix NsdManager to watch for invalid index. Change-Id: I3d63af10bded13c72e8e437a1ebf74a666760432
Diffstat (limited to 'services/java/com/android/server/NsdService.java')
-rw-r--r--services/java/com/android/server/NsdService.java8
1 files changed, 8 insertions, 0 deletions
diff --git a/services/java/com/android/server/NsdService.java b/services/java/com/android/server/NsdService.java
index faa72a2..e0f415b 100644
--- a/services/java/com/android/server/NsdService.java
+++ b/services/java/com/android/server/NsdService.java
@@ -417,7 +417,15 @@ public class NsdService extends INsdManager.Stub {
int keyId = clientInfo.mClientIds.indexOfValue(id);
if (keyId != -1) {
clientId = clientInfo.mClientIds.keyAt(keyId);
+ } else {
+ // This can happen because of race conditions. For example,
+ // SERVICE_FOUND may race with STOP_SERVICE_DISCOVERY,
+ // and we may get in this situation.
+ Slog.d(TAG, "Notification for a listener that is no longer active: " + id);
+ handled = false;
+ return handled;
}
+
switch (code) {
case NativeResponseCode.SERVICE_FOUND:
/* NNN uniqueId serviceName regType domain */