From 44b330dfb0aeecb4e2ac97ff72a5abfb341c74fb Mon Sep 17 00:00:00 2001 From: Irfan Sheriff Date: Wed, 28 Dec 2011 13:00:28 -0800 Subject: Add multi-interface support to native calls Add the initial support for supporting seperate socket connections on the p2p interface. This is the initial change making primary interface connections work alongside native support for p2p socket connection Change-Id: I7619715ca75b10afd29af852279fe713331f75e0 --- wifi/java/android/net/wifi/WifiNative.java | 43 ++++++++++++++++++++---- wifi/java/android/net/wifi/WifiStateMachine.java | 3 ++ 2 files changed, 40 insertions(+), 6 deletions(-) (limited to 'wifi/java') diff --git a/wifi/java/android/net/wifi/WifiNative.java b/wifi/java/android/net/wifi/WifiNative.java index b599054..f8eafde 100644 --- a/wifi/java/android/net/wifi/WifiNative.java +++ b/wifi/java/android/net/wifi/WifiNative.java @@ -19,6 +19,7 @@ package android.net.wifi; import android.net.wifi.p2p.WifiP2pConfig; import android.net.wifi.p2p.WifiP2pGroup; import android.net.wifi.p2p.WifiP2pDevice; +import android.os.SystemProperties; import android.text.TextUtils; import android.util.Log; @@ -42,6 +43,8 @@ public class WifiNative { static final int BLUETOOTH_COEXISTENCE_MODE_DISABLED = 1; static final int BLUETOOTH_COEXISTENCE_MODE_SENSE = 2; + static String sDefaultInterface; + public native static boolean loadDriver(); public native static boolean isDriverLoaded(); @@ -56,21 +59,49 @@ public class WifiNative { or when the supplicant is hung */ public native static boolean killSupplicant(); - public native static boolean connectToSupplicant(); + public native static boolean connectToSupplicant(String iface); - public native static void closeSupplicantConnection(); + public native static void closeSupplicantConnection(String iface); /** * Wait for the supplicant to send an event, returning the event string. * @return the event string sent by the supplicant. */ - public native static String waitForEvent(); + public native static String waitForEvent(String iface); + + private native static boolean doBooleanCommand(String iface, String command); + + private native static int doIntCommand(String iface, String command); + + private native static String doStringCommand(String iface, String command); - private native static boolean doBooleanCommand(String command); + public static void setDefaultInterface(String iface) { + sDefaultInterface = iface; + } + + public static boolean connectToSupplicant() { + return connectToSupplicant(sDefaultInterface); + } - private native static int doIntCommand(String command); + public static void closeSupplicantConnection() { + closeSupplicantConnection(sDefaultInterface); + } - private native static String doStringCommand(String command); + public static String waitForEvent() { + return waitForEvent(sDefaultInterface); + } + + private static boolean doBooleanCommand(String command) { + return doBooleanCommand(sDefaultInterface, command); + } + + private static int doIntCommand(String command) { + return doIntCommand(sDefaultInterface, command); + } + + private static String doStringCommand(String command) { + return doStringCommand(sDefaultInterface, command); + } public static boolean ping() { String pong = doStringCommand("PING"); diff --git a/wifi/java/android/net/wifi/WifiStateMachine.java b/wifi/java/android/net/wifi/WifiStateMachine.java index 25bd8f7..1a85529 100644 --- a/wifi/java/android/net/wifi/WifiStateMachine.java +++ b/wifi/java/android/net/wifi/WifiStateMachine.java @@ -572,6 +572,9 @@ public class WifiStateMachine extends StateMachine { mLastNetworkId = WifiConfiguration.INVALID_NETWORK_ID; mLastSignalLevel = -1; + /* Set default interface for all primary socket communication */ + WifiNative.setDefaultInterface(mInterfaceName); + mAlarmManager = (AlarmManager)mContext.getSystemService(Context.ALARM_SERVICE); Intent scanIntent = new Intent(ACTION_START_SCAN, null); mScanIntent = PendingIntent.getBroadcast(mContext, SCAN_REQUEST, scanIntent, 0); -- cgit v1.1