Loading core/java/android/hardware/display/WifiDisplayStatus.java +48 −37 Original line number Diff line number Diff line Loading @@ -32,18 +32,27 @@ import java.util.Arrays; */ public final class WifiDisplayStatus implements Parcelable { private final boolean mEnabled; private final WifiDisplay mConnectedDisplay; private final int mScanState; private final int mActiveDisplayState; private final WifiDisplay mActiveDisplay; private final WifiDisplay[] mKnownDisplays; private final boolean mScanInProgress; private final boolean mConnectionInProgress; public static final int SCAN_STATE_NOT_SCANNING = 0; public static final int SCAN_STATE_SCANNING = 1; public static final int DISPLAY_STATE_NOT_CONNECTED = 0; public static final int DISPLAY_STATE_CONNECTING = 1; public static final int DISPLAY_STATE_CONNECTED = 2; public static final Creator<WifiDisplayStatus> CREATOR = new Creator<WifiDisplayStatus>() { public WifiDisplayStatus createFromParcel(Parcel in) { boolean enabled = (in.readInt() != 0); int scanState = in.readInt(); int activeDisplayState= in.readInt(); WifiDisplay connectedDisplay = null; WifiDisplay activeDisplay = null; if (in.readInt() != 0) { connectedDisplay = WifiDisplay.CREATOR.createFromParcel(in); activeDisplay = WifiDisplay.CREATOR.createFromParcel(in); } WifiDisplay[] knownDisplays = WifiDisplay.CREATOR.newArray(in.readInt()); Loading @@ -51,11 +60,8 @@ public final class WifiDisplayStatus implements Parcelable { knownDisplays[i] = WifiDisplay.CREATOR.createFromParcel(in); } boolean scanInProgress = (in.readInt() != 0); boolean connectionInProgress = (in.readInt() != 0); return new WifiDisplayStatus(enabled, connectedDisplay, knownDisplays, scanInProgress, connectionInProgress); return new WifiDisplayStatus(enabled, scanState, activeDisplayState, activeDisplay, knownDisplays); } public WifiDisplayStatus[] newArray(int size) { Loading @@ -64,21 +70,21 @@ public final class WifiDisplayStatus implements Parcelable { }; public WifiDisplayStatus() { this(false, null, WifiDisplay.EMPTY_ARRAY, false, false); this(false, SCAN_STATE_NOT_SCANNING, DISPLAY_STATE_NOT_CONNECTED, null, WifiDisplay.EMPTY_ARRAY); } public WifiDisplayStatus(boolean enabled, WifiDisplay connectedDisplay, WifiDisplay[] knownDisplays, boolean scanInProgress, boolean connectionInProgress) { public WifiDisplayStatus(boolean enabled, int scanState, int activeDisplayState, WifiDisplay activeDisplay, WifiDisplay[] knownDisplays) { if (knownDisplays == null) { throw new IllegalArgumentException("knownDisplays must not be null"); } mEnabled = enabled; mConnectedDisplay = connectedDisplay; mScanState = scanState; mActiveDisplayState = activeDisplayState; mActiveDisplay = activeDisplay; mKnownDisplays = knownDisplays; mScanInProgress = scanInProgress; mConnectionInProgress = connectionInProgress; } /** Loading @@ -94,40 +100,48 @@ public final class WifiDisplayStatus implements Parcelable { } /** * Gets the currently connected Wifi display or null if none. * Returns the current state of the Wifi display scan. * * @return One of: {@link #SCAN_STATE_NOT_SCANNING} or {@link #SCAN_STATE_SCANNING}. */ public WifiDisplay getConnectedDisplay() { return mConnectedDisplay; public int getScanState() { return mScanState; } /** * Gets the list of all known Wifi displays, never null. * Get the state of the currently active display. * * @return One of: {@link #DISPLAY_STATE_NOT_CONNECTED}, {@link #DISPLAY_STATE_CONNECTING}, * or {@link #DISPLAY_STATE_CONNECTED}. */ public WifiDisplay[] getKnownDisplays() { return mKnownDisplays; public int getActiveDisplayState() { return mActiveDisplayState; } /** * Returns true if there is currently a Wifi display scan in progress. * Gets the Wifi display that is currently active. It may be connecting or * connected. */ public boolean isScanInProgress() { return mScanInProgress; public WifiDisplay getActiveDisplay() { return mActiveDisplay; } /** * Returns true if there is currently a Wifi display connection in progress. * Gets the list of all known Wifi displays, never null. */ public boolean isConnectionInProgress() { return mConnectionInProgress; public WifiDisplay[] getKnownDisplays() { return mKnownDisplays; } @Override public void writeToParcel(Parcel dest, int flags) { dest.writeInt(mEnabled ? 1 : 0); dest.writeInt(mScanState); dest.writeInt(mActiveDisplayState); if (mConnectedDisplay != null) { if (mActiveDisplay != null) { dest.writeInt(1); mConnectedDisplay.writeToParcel(dest, flags); mActiveDisplay.writeToParcel(dest, flags); } else { dest.writeInt(0); } Loading @@ -136,9 +150,6 @@ public final class WifiDisplayStatus implements Parcelable { for (WifiDisplay display : mKnownDisplays) { display.writeToParcel(dest, flags); } dest.writeInt(mScanInProgress ? 1 : 0); dest.writeInt(mConnectionInProgress ? 1 : 0); } @Override Loading @@ -150,10 +161,10 @@ public final class WifiDisplayStatus implements Parcelable { @Override public String toString() { return "WifiDisplayStatus{enabled=" + mEnabled + ", connectedDisplay=" + mConnectedDisplay + ", scanState=" + mScanState + ", activeDisplayState=" + mActiveDisplayState + ", activeDisplay=" + mActiveDisplay + ", knownDisplays=" + Arrays.toString(mKnownDisplays) + ", scanInProgress=" + mScanInProgress + ", connectionInProgress=" + mConnectionInProgress + "}"; } } services/java/com/android/server/display/WifiDisplayAdapter.java +31 −24 Original line number Diff line number Diff line Loading @@ -55,10 +55,10 @@ final class WifiDisplayAdapter extends DisplayAdapter { private WifiDisplayStatus mCurrentStatus; private boolean mEnabled; private WifiDisplay mConnectedDisplay; private int mScanState; private int mActiveDisplayState; private WifiDisplay mActiveDisplay; private WifiDisplay[] mKnownDisplays = WifiDisplay.EMPTY_ARRAY; private boolean mScanInProgress; private boolean mConnectionInProgress; private boolean mPendingStatusChangeBroadcast; Loading @@ -80,10 +80,10 @@ final class WifiDisplayAdapter extends DisplayAdapter { pw.println("mCurrentStatus=" + getWifiDisplayStatusLocked()); pw.println("mEnabled=" + mEnabled); pw.println("mConnectedDisplay=" + mConnectedDisplay); pw.println("mScanState=" + mScanState); pw.println("mActiveDisplayState=" + mActiveDisplayState); pw.println("mActiveDisplay=" + mActiveDisplay); pw.println("mKnownDisplays=" + Arrays.toString(mKnownDisplays)); pw.println("mScanInProgress=" + mScanInProgress); pw.println("mConnectionInProgress=" + mConnectionInProgress); pw.println("mPendingStatusChangeBroadcast=" + mPendingStatusChangeBroadcast); // Try to dump the controller state. Loading Loading @@ -145,9 +145,8 @@ final class WifiDisplayAdapter extends DisplayAdapter { public WifiDisplayStatus getWifiDisplayStatusLocked() { if (mCurrentStatus == null) { mCurrentStatus = new WifiDisplayStatus(mEnabled, mConnectedDisplay, mKnownDisplays, mScanInProgress, mConnectionInProgress); mCurrentStatus = new WifiDisplayStatus(mEnabled, mScanState, mActiveDisplayState, mActiveDisplay, mKnownDisplays); } return mCurrentStatus; } Loading Loading @@ -211,9 +210,9 @@ final class WifiDisplayAdapter extends DisplayAdapter { @Override public void onScanStarted() { synchronized (getSyncRoot()) { if (!mScanInProgress) { if (mScanState != WifiDisplayStatus.SCAN_STATE_SCANNING) { mCurrentStatus = null; mScanInProgress = true; mScanState = WifiDisplayStatus.SCAN_STATE_SCANNING; scheduleStatusChangedBroadcastLocked(); } } Loading @@ -221,10 +220,11 @@ final class WifiDisplayAdapter extends DisplayAdapter { public void onScanFinished(WifiDisplay[] knownDisplays) { synchronized (getSyncRoot()) { if (!Arrays.equals(mKnownDisplays, knownDisplays) || mScanInProgress) { if (mScanState != WifiDisplayStatus.SCAN_STATE_NOT_SCANNING || !Arrays.equals(mKnownDisplays, knownDisplays)) { mCurrentStatus = null; mScanState = WifiDisplayStatus.SCAN_STATE_NOT_SCANNING; mKnownDisplays = knownDisplays; mScanInProgress = false; scheduleStatusChangedBroadcastLocked(); } } Loading @@ -233,9 +233,12 @@ final class WifiDisplayAdapter extends DisplayAdapter { @Override public void onDisplayConnecting(WifiDisplay display) { synchronized (getSyncRoot()) { if (!mConnectionInProgress) { if (mActiveDisplayState != WifiDisplayStatus.DISPLAY_STATE_CONNECTING || mActiveDisplay == null || !mActiveDisplay.equals(display)) { mCurrentStatus = null; mConnectionInProgress = true; mActiveDisplayState = WifiDisplayStatus.DISPLAY_STATE_CONNECTING; mActiveDisplay = display; scheduleStatusChangedBroadcastLocked(); } } Loading @@ -244,9 +247,11 @@ final class WifiDisplayAdapter extends DisplayAdapter { @Override public void onDisplayConnectionFailed() { synchronized (getSyncRoot()) { if (mConnectionInProgress) { if (mActiveDisplayState != WifiDisplayStatus.DISPLAY_STATE_NOT_CONNECTED || mActiveDisplay != null) { mCurrentStatus = null; mConnectionInProgress = false; mActiveDisplayState = WifiDisplayStatus.DISPLAY_STATE_NOT_CONNECTED; mActiveDisplay = null; scheduleStatusChangedBroadcastLocked(); } } Loading @@ -257,11 +262,12 @@ final class WifiDisplayAdapter extends DisplayAdapter { synchronized (getSyncRoot()) { handleConnectLocked(display, iface); if (mConnectedDisplay == null || !mConnectedDisplay.equals(display) || mConnectionInProgress) { if (mActiveDisplayState != WifiDisplayStatus.DISPLAY_STATE_CONNECTED || mActiveDisplay == null || !mActiveDisplay.equals(display)) { mCurrentStatus = null; mConnectedDisplay = display; mConnectionInProgress = false; mActiveDisplayState = WifiDisplayStatus.DISPLAY_STATE_CONNECTED; mActiveDisplay = display; scheduleStatusChangedBroadcastLocked(); } } Loading @@ -273,10 +279,11 @@ final class WifiDisplayAdapter extends DisplayAdapter { synchronized (getSyncRoot()) { handleDisconnectLocked(); if (mConnectedDisplay != null || mConnectionInProgress) { if (mActiveDisplayState != WifiDisplayStatus.DISPLAY_STATE_NOT_CONNECTED || mActiveDisplay != null) { mCurrentStatus = null; mConnectedDisplay = null; mConnectionInProgress = false; mActiveDisplayState = WifiDisplayStatus.DISPLAY_STATE_NOT_CONNECTED; mActiveDisplay = null; scheduleStatusChangedBroadcastLocked(); } } Loading services/java/com/android/server/display/WifiDisplayController.java +8 −1 Original line number Diff line number Diff line Loading @@ -536,7 +536,7 @@ final class WifiDisplayController implements DumpUtils.Dump { private void handleConnectionChanged(NetworkInfo networkInfo) { mNetworkInfo = networkInfo; if (mWifiP2pEnabled && mWfdEnabled && networkInfo.isConnected()) { if (mWfdEnabled && networkInfo.isConnected()) { if (mDesiredDevice != null) { mWifiP2pManager.requestGroupInfo(mWifiP2pChannel, new GroupInfoListener() { @Override Loading Loading @@ -573,6 +573,13 @@ final class WifiDisplayController implements DumpUtils.Dump { } } else { disconnect(); // After disconnection for a group, for some reason we have a tendency // to get a peer change notification with an empty list of peers. // Perform a fresh scan. if (mWfdEnabled) { requestPeers(); } } } Loading Loading
core/java/android/hardware/display/WifiDisplayStatus.java +48 −37 Original line number Diff line number Diff line Loading @@ -32,18 +32,27 @@ import java.util.Arrays; */ public final class WifiDisplayStatus implements Parcelable { private final boolean mEnabled; private final WifiDisplay mConnectedDisplay; private final int mScanState; private final int mActiveDisplayState; private final WifiDisplay mActiveDisplay; private final WifiDisplay[] mKnownDisplays; private final boolean mScanInProgress; private final boolean mConnectionInProgress; public static final int SCAN_STATE_NOT_SCANNING = 0; public static final int SCAN_STATE_SCANNING = 1; public static final int DISPLAY_STATE_NOT_CONNECTED = 0; public static final int DISPLAY_STATE_CONNECTING = 1; public static final int DISPLAY_STATE_CONNECTED = 2; public static final Creator<WifiDisplayStatus> CREATOR = new Creator<WifiDisplayStatus>() { public WifiDisplayStatus createFromParcel(Parcel in) { boolean enabled = (in.readInt() != 0); int scanState = in.readInt(); int activeDisplayState= in.readInt(); WifiDisplay connectedDisplay = null; WifiDisplay activeDisplay = null; if (in.readInt() != 0) { connectedDisplay = WifiDisplay.CREATOR.createFromParcel(in); activeDisplay = WifiDisplay.CREATOR.createFromParcel(in); } WifiDisplay[] knownDisplays = WifiDisplay.CREATOR.newArray(in.readInt()); Loading @@ -51,11 +60,8 @@ public final class WifiDisplayStatus implements Parcelable { knownDisplays[i] = WifiDisplay.CREATOR.createFromParcel(in); } boolean scanInProgress = (in.readInt() != 0); boolean connectionInProgress = (in.readInt() != 0); return new WifiDisplayStatus(enabled, connectedDisplay, knownDisplays, scanInProgress, connectionInProgress); return new WifiDisplayStatus(enabled, scanState, activeDisplayState, activeDisplay, knownDisplays); } public WifiDisplayStatus[] newArray(int size) { Loading @@ -64,21 +70,21 @@ public final class WifiDisplayStatus implements Parcelable { }; public WifiDisplayStatus() { this(false, null, WifiDisplay.EMPTY_ARRAY, false, false); this(false, SCAN_STATE_NOT_SCANNING, DISPLAY_STATE_NOT_CONNECTED, null, WifiDisplay.EMPTY_ARRAY); } public WifiDisplayStatus(boolean enabled, WifiDisplay connectedDisplay, WifiDisplay[] knownDisplays, boolean scanInProgress, boolean connectionInProgress) { public WifiDisplayStatus(boolean enabled, int scanState, int activeDisplayState, WifiDisplay activeDisplay, WifiDisplay[] knownDisplays) { if (knownDisplays == null) { throw new IllegalArgumentException("knownDisplays must not be null"); } mEnabled = enabled; mConnectedDisplay = connectedDisplay; mScanState = scanState; mActiveDisplayState = activeDisplayState; mActiveDisplay = activeDisplay; mKnownDisplays = knownDisplays; mScanInProgress = scanInProgress; mConnectionInProgress = connectionInProgress; } /** Loading @@ -94,40 +100,48 @@ public final class WifiDisplayStatus implements Parcelable { } /** * Gets the currently connected Wifi display or null if none. * Returns the current state of the Wifi display scan. * * @return One of: {@link #SCAN_STATE_NOT_SCANNING} or {@link #SCAN_STATE_SCANNING}. */ public WifiDisplay getConnectedDisplay() { return mConnectedDisplay; public int getScanState() { return mScanState; } /** * Gets the list of all known Wifi displays, never null. * Get the state of the currently active display. * * @return One of: {@link #DISPLAY_STATE_NOT_CONNECTED}, {@link #DISPLAY_STATE_CONNECTING}, * or {@link #DISPLAY_STATE_CONNECTED}. */ public WifiDisplay[] getKnownDisplays() { return mKnownDisplays; public int getActiveDisplayState() { return mActiveDisplayState; } /** * Returns true if there is currently a Wifi display scan in progress. * Gets the Wifi display that is currently active. It may be connecting or * connected. */ public boolean isScanInProgress() { return mScanInProgress; public WifiDisplay getActiveDisplay() { return mActiveDisplay; } /** * Returns true if there is currently a Wifi display connection in progress. * Gets the list of all known Wifi displays, never null. */ public boolean isConnectionInProgress() { return mConnectionInProgress; public WifiDisplay[] getKnownDisplays() { return mKnownDisplays; } @Override public void writeToParcel(Parcel dest, int flags) { dest.writeInt(mEnabled ? 1 : 0); dest.writeInt(mScanState); dest.writeInt(mActiveDisplayState); if (mConnectedDisplay != null) { if (mActiveDisplay != null) { dest.writeInt(1); mConnectedDisplay.writeToParcel(dest, flags); mActiveDisplay.writeToParcel(dest, flags); } else { dest.writeInt(0); } Loading @@ -136,9 +150,6 @@ public final class WifiDisplayStatus implements Parcelable { for (WifiDisplay display : mKnownDisplays) { display.writeToParcel(dest, flags); } dest.writeInt(mScanInProgress ? 1 : 0); dest.writeInt(mConnectionInProgress ? 1 : 0); } @Override Loading @@ -150,10 +161,10 @@ public final class WifiDisplayStatus implements Parcelable { @Override public String toString() { return "WifiDisplayStatus{enabled=" + mEnabled + ", connectedDisplay=" + mConnectedDisplay + ", scanState=" + mScanState + ", activeDisplayState=" + mActiveDisplayState + ", activeDisplay=" + mActiveDisplay + ", knownDisplays=" + Arrays.toString(mKnownDisplays) + ", scanInProgress=" + mScanInProgress + ", connectionInProgress=" + mConnectionInProgress + "}"; } }
services/java/com/android/server/display/WifiDisplayAdapter.java +31 −24 Original line number Diff line number Diff line Loading @@ -55,10 +55,10 @@ final class WifiDisplayAdapter extends DisplayAdapter { private WifiDisplayStatus mCurrentStatus; private boolean mEnabled; private WifiDisplay mConnectedDisplay; private int mScanState; private int mActiveDisplayState; private WifiDisplay mActiveDisplay; private WifiDisplay[] mKnownDisplays = WifiDisplay.EMPTY_ARRAY; private boolean mScanInProgress; private boolean mConnectionInProgress; private boolean mPendingStatusChangeBroadcast; Loading @@ -80,10 +80,10 @@ final class WifiDisplayAdapter extends DisplayAdapter { pw.println("mCurrentStatus=" + getWifiDisplayStatusLocked()); pw.println("mEnabled=" + mEnabled); pw.println("mConnectedDisplay=" + mConnectedDisplay); pw.println("mScanState=" + mScanState); pw.println("mActiveDisplayState=" + mActiveDisplayState); pw.println("mActiveDisplay=" + mActiveDisplay); pw.println("mKnownDisplays=" + Arrays.toString(mKnownDisplays)); pw.println("mScanInProgress=" + mScanInProgress); pw.println("mConnectionInProgress=" + mConnectionInProgress); pw.println("mPendingStatusChangeBroadcast=" + mPendingStatusChangeBroadcast); // Try to dump the controller state. Loading Loading @@ -145,9 +145,8 @@ final class WifiDisplayAdapter extends DisplayAdapter { public WifiDisplayStatus getWifiDisplayStatusLocked() { if (mCurrentStatus == null) { mCurrentStatus = new WifiDisplayStatus(mEnabled, mConnectedDisplay, mKnownDisplays, mScanInProgress, mConnectionInProgress); mCurrentStatus = new WifiDisplayStatus(mEnabled, mScanState, mActiveDisplayState, mActiveDisplay, mKnownDisplays); } return mCurrentStatus; } Loading Loading @@ -211,9 +210,9 @@ final class WifiDisplayAdapter extends DisplayAdapter { @Override public void onScanStarted() { synchronized (getSyncRoot()) { if (!mScanInProgress) { if (mScanState != WifiDisplayStatus.SCAN_STATE_SCANNING) { mCurrentStatus = null; mScanInProgress = true; mScanState = WifiDisplayStatus.SCAN_STATE_SCANNING; scheduleStatusChangedBroadcastLocked(); } } Loading @@ -221,10 +220,11 @@ final class WifiDisplayAdapter extends DisplayAdapter { public void onScanFinished(WifiDisplay[] knownDisplays) { synchronized (getSyncRoot()) { if (!Arrays.equals(mKnownDisplays, knownDisplays) || mScanInProgress) { if (mScanState != WifiDisplayStatus.SCAN_STATE_NOT_SCANNING || !Arrays.equals(mKnownDisplays, knownDisplays)) { mCurrentStatus = null; mScanState = WifiDisplayStatus.SCAN_STATE_NOT_SCANNING; mKnownDisplays = knownDisplays; mScanInProgress = false; scheduleStatusChangedBroadcastLocked(); } } Loading @@ -233,9 +233,12 @@ final class WifiDisplayAdapter extends DisplayAdapter { @Override public void onDisplayConnecting(WifiDisplay display) { synchronized (getSyncRoot()) { if (!mConnectionInProgress) { if (mActiveDisplayState != WifiDisplayStatus.DISPLAY_STATE_CONNECTING || mActiveDisplay == null || !mActiveDisplay.equals(display)) { mCurrentStatus = null; mConnectionInProgress = true; mActiveDisplayState = WifiDisplayStatus.DISPLAY_STATE_CONNECTING; mActiveDisplay = display; scheduleStatusChangedBroadcastLocked(); } } Loading @@ -244,9 +247,11 @@ final class WifiDisplayAdapter extends DisplayAdapter { @Override public void onDisplayConnectionFailed() { synchronized (getSyncRoot()) { if (mConnectionInProgress) { if (mActiveDisplayState != WifiDisplayStatus.DISPLAY_STATE_NOT_CONNECTED || mActiveDisplay != null) { mCurrentStatus = null; mConnectionInProgress = false; mActiveDisplayState = WifiDisplayStatus.DISPLAY_STATE_NOT_CONNECTED; mActiveDisplay = null; scheduleStatusChangedBroadcastLocked(); } } Loading @@ -257,11 +262,12 @@ final class WifiDisplayAdapter extends DisplayAdapter { synchronized (getSyncRoot()) { handleConnectLocked(display, iface); if (mConnectedDisplay == null || !mConnectedDisplay.equals(display) || mConnectionInProgress) { if (mActiveDisplayState != WifiDisplayStatus.DISPLAY_STATE_CONNECTED || mActiveDisplay == null || !mActiveDisplay.equals(display)) { mCurrentStatus = null; mConnectedDisplay = display; mConnectionInProgress = false; mActiveDisplayState = WifiDisplayStatus.DISPLAY_STATE_CONNECTED; mActiveDisplay = display; scheduleStatusChangedBroadcastLocked(); } } Loading @@ -273,10 +279,11 @@ final class WifiDisplayAdapter extends DisplayAdapter { synchronized (getSyncRoot()) { handleDisconnectLocked(); if (mConnectedDisplay != null || mConnectionInProgress) { if (mActiveDisplayState != WifiDisplayStatus.DISPLAY_STATE_NOT_CONNECTED || mActiveDisplay != null) { mCurrentStatus = null; mConnectedDisplay = null; mConnectionInProgress = false; mActiveDisplayState = WifiDisplayStatus.DISPLAY_STATE_NOT_CONNECTED; mActiveDisplay = null; scheduleStatusChangedBroadcastLocked(); } } Loading
services/java/com/android/server/display/WifiDisplayController.java +8 −1 Original line number Diff line number Diff line Loading @@ -536,7 +536,7 @@ final class WifiDisplayController implements DumpUtils.Dump { private void handleConnectionChanged(NetworkInfo networkInfo) { mNetworkInfo = networkInfo; if (mWifiP2pEnabled && mWfdEnabled && networkInfo.isConnected()) { if (mWfdEnabled && networkInfo.isConnected()) { if (mDesiredDevice != null) { mWifiP2pManager.requestGroupInfo(mWifiP2pChannel, new GroupInfoListener() { @Override Loading Loading @@ -573,6 +573,13 @@ final class WifiDisplayController implements DumpUtils.Dump { } } else { disconnect(); // After disconnection for a group, for some reason we have a tendency // to get a peer change notification with an empty list of peers. // Perform a fresh scan. if (mWfdEnabled) { requestPeers(); } } } Loading