summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author TreeHugger Robot <treehugger-gerrit@google.com> 2020-12-16 02:07:06 +0000
committer Android (Google) Code Review <android-gerrit@google.com> 2020-12-16 02:07:06 +0000
commit928109c95d4f16e89a6ab687b607c0c42cb45064 (patch)
treeaa099af30cc01ebed679e8d50b291c209acb8079
parent63458f3e6adac258d3652f8fc0d813754aea3e94 (diff)
parente0410f77eef89599b0c5a603c5b931c36ac88549 (diff)
Merge "Don't throw RuntimeException on supplicant start/stop failure"
-rw-r--r--services/wifi/java/com/android/server/wifi/SupplicantManager.java21
1 files changed, 19 insertions, 2 deletions
diff --git a/services/wifi/java/com/android/server/wifi/SupplicantManager.java b/services/wifi/java/com/android/server/wifi/SupplicantManager.java
index 5ed1ab3198e2..e2e5b2b3ac2d 100644
--- a/services/wifi/java/com/android/server/wifi/SupplicantManager.java
+++ b/services/wifi/java/com/android/server/wifi/SupplicantManager.java
@@ -18,6 +18,9 @@ package com.android.server.wifi;
import android.annotation.SystemApi;
import android.os.SystemService;
+import android.util.Log;
+
+import java.util.NoSuchElementException;
/**
* Wrapper to start/stop supplicant daemon using init system.
@@ -25,6 +28,8 @@ import android.os.SystemService;
*/
@SystemApi(client = SystemApi.Client.SYSTEM_SERVER)
public class SupplicantManager {
+ private static final String TAG = "SupplicantManager";
+
private static final String WPA_SUPPLICANT_DAEMON_NAME = "wpa_supplicant";
private SupplicantManager() {}
@@ -32,9 +37,16 @@ public class SupplicantManager {
/**
* Start the wpa_supplicant daemon.
* Note: This uses the init system to start the "wpa_supplicant" service.
+ *
+ * @throws NoSuchElementException if supplicant daemon failed to start
*/
public static void start() {
- SystemService.start(WPA_SUPPLICANT_DAEMON_NAME);
+ try {
+ SystemService.start(WPA_SUPPLICANT_DAEMON_NAME);
+ } catch (RuntimeException e) {
+ // likely a "failed to set system property" runtime exception
+ throw new NoSuchElementException("Failed to start Supplicant");
+ }
}
/**
@@ -42,6 +54,11 @@ public class SupplicantManager {
* Note: This uses the init system to stop the "wpa_supplicant" service.
*/
public static void stop() {
- SystemService.stop(WPA_SUPPLICANT_DAEMON_NAME);
+ try {
+ SystemService.stop(WPA_SUPPLICANT_DAEMON_NAME);
+ } catch (RuntimeException e) {
+ // likely a "failed to set system property" runtime exception
+ Log.w(TAG, "Failed to stop Supplicant", e);
+ }
}
}