diff options
| author | 2020-12-16 02:07:06 +0000 | |
|---|---|---|
| committer | 2020-12-16 02:07:06 +0000 | |
| commit | 928109c95d4f16e89a6ab687b607c0c42cb45064 (patch) | |
| tree | aa099af30cc01ebed679e8d50b291c209acb8079 | |
| parent | 63458f3e6adac258d3652f8fc0d813754aea3e94 (diff) | |
| parent | e0410f77eef89599b0c5a603c5b931c36ac88549 (diff) | |
Merge "Don't throw RuntimeException on supplicant start/stop failure"
| -rw-r--r-- | services/wifi/java/com/android/server/wifi/SupplicantManager.java | 21 |
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); + } } } |