diff options
| author | Paul Stewart <pstew@google.com> | 2016-03-22 22:23:46 +0000 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2016-03-22 22:23:48 +0000 |
| commit | 68ffbba158579dd8b6f32aa628ec91228786e864 (patch) | |
| tree | a7de982a3ecccd4d71db038faaa5ef6f5a8d0017 /core/java | |
| parent | db9fba373450e01d52f14e8380646e631dee1713 (diff) | |
| parent | bf8cbb05e085c4504685883f3dd564f200405bea (diff) | |
Merge changes Iddeebeb8,Idd1e37a3 into nyc-dev
* changes:
WifiManager: Use ConnectivityThread
Create ConnectivityThread
Diffstat (limited to 'core/java')
| -rw-r--r-- | core/java/android/app/SystemServiceRegistry.java | 4 | ||||
| -rw-r--r-- | core/java/android/net/ConnectivityThread.java | 51 |
2 files changed, 54 insertions, 1 deletions
diff --git a/core/java/android/app/SystemServiceRegistry.java b/core/java/android/app/SystemServiceRegistry.java index 9d7f7246a25d..2987fbc4f33d 100644 --- a/core/java/android/app/SystemServiceRegistry.java +++ b/core/java/android/app/SystemServiceRegistry.java @@ -69,6 +69,7 @@ import android.media.soundtrigger.SoundTriggerManager; import android.media.tv.ITvInputManager; import android.media.tv.TvInputManager; import android.net.ConnectivityManager; +import android.net.ConnectivityThread; import android.net.EthernetManager; import android.net.IConnectivityManager; import android.net.IEthernetManager; @@ -500,7 +501,8 @@ final class SystemServiceRegistry { public WifiManager createService(ContextImpl ctx) { IBinder b = ServiceManager.getService(Context.WIFI_SERVICE); IWifiManager service = IWifiManager.Stub.asInterface(b); - return new WifiManager(ctx.getOuterContext(), service); + return new WifiManager(ctx.getOuterContext(), service, + ConnectivityThread.getInstanceLooper()); }}); registerService(Context.WIFI_P2P_SERVICE, WifiP2pManager.class, diff --git a/core/java/android/net/ConnectivityThread.java b/core/java/android/net/ConnectivityThread.java new file mode 100644 index 000000000000..55c3402bf39d --- /dev/null +++ b/core/java/android/net/ConnectivityThread.java @@ -0,0 +1,51 @@ +/* + * Copyright (C) 2016 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package android.net; + +import android.os.HandlerThread; +import android.os.Looper; + +/** + * Shared singleton connectivity thread for the system. This is a thread for + * connectivity operations such as AsyncChannel connections to system services. + * Various connectivity manager objects can use this singleton as a common + * resource for their handlers instead of creating separate threads of their own. + * @hide + */ +public final class ConnectivityThread extends HandlerThread { + private static ConnectivityThread sInstance; + + private ConnectivityThread() { + super("ConnectivityThread"); + } + + private static synchronized ConnectivityThread getInstance() { + if (sInstance == null) { + sInstance = new ConnectivityThread(); + sInstance.start(); + } + return sInstance; + } + + public static ConnectivityThread get() { + return getInstance(); + } + + public static Looper getInstanceLooper() { + return getInstance().getLooper(); + } +} |
