Android 7.0 自带EthernetService,默认开机就会启动,默认ip获取方式是动态分配(DHCP),有时候公司路由器DNS设置有问题,导致无法上网(能ping通局域网,无法上外网),手动设置静态IP就派上用场了。
废话不多说了,上图
修改记录:
alps/device/xxxxx/xxx6737t_35g_n/device.mk
alps/frameworks/base/core/java/android/net/EthernetManager.java
alps/frameworks/base/core/java/android/net/IEthernetManager.aidl
alps/frameworks/base/core/java/android/provider/Settings.java
alps/frameworks/base/core/res/res/values/config.xml
alps/frameworks/base/packages/SettingsProvider/res/values/defaults.xml
alps/frameworks/base/packages/SettingsProvider/src/com/android/providers/settings/DatabaseHelper.java
alps/frameworks/base/proto/src/metrics_constants.proto
alps/frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetNetworkFactory.java
alps/frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetServiceImpl.java
alps/packages/apps/Settings/AndroidManifest.xml
alps/packages/apps/Settings/res/drawable-hdpi/ic_settings_ethernet.png
alps/packages/apps/Settings/res/layout/ethernet_configure.xml
alps/packages/apps/Settings/res/values-zh-rCN/strings.xml
alps/packages/apps/Settings/res/values/strings.xml
alps/packages/apps/Settings/res/xml/ethernet_settings.xml
alps/packages/apps/Settings/src/com/android/settings/Settings.java
alps/packages/apps/Settings/src/com/android/settings/SettingsActivity.java
alps/packages/apps/Settings/src/com/android/settings/ethernet/EthernetDialog.java
alps/packages/apps/Settings/src/com/android/settings/ethernet/EthernetEnabler.java
alps/packages/apps/Settings/src/com/android/settings/ethernet/EthernetSettings.java
alps/packages/apps/Settings/src/com/android/settings/ethernet/ip/AbsEditText.java
alps/packages/apps/Settings/src/com/android/settings/ethernet/ip/AbsEditTextGroup.java
alps/packages/apps/Settings/src/com/android/settings/ethernet/ip/IPEditText.java
alps/packages/apps/Settings/src/com/android/settings/ethernet/ip/IPView.java
1. device/xxxxx/xxx6737t_35g_n/device.mk
diff --git a/alps/device/xxxxx/xxx6737t_35g_n/device.mk b/alps/device/xxxxx/xxx6737t_35g_n/device.mk
index 71f1a5c..8ce0e36 100755 (executable)
--- a/alps/device/xxxxx/xxx6737t_35g_n/device.mk
+++ b/alps/device/xxxxx/xxx6737t_35g_n/device.mk
@@ -141,6 +141,9 @@ endif
# USB OTG
PRODUCT_COPY_FILES += frameworks/native/data/etc/android.hardware.usb.host.xml:system/etc/permissions/android.hardware.usb.host.xml
+# Ethernet
+PRODUCT_COPY_FILES += frameworks/native/data/etc/android.hardware.ethernet.xml:system/etc/permissions/android.hardware.ethernet.xml
+
# GPS relative file
ifeq ($(MTK_GPS_SUPPORT),yes)
2. frameworks/base/core/java/android/net/EthernetManager.java
diff --git a/alps/frameworks/base/core/java/android/net/EthernetManager.java b/alps/frameworks/base/core/java/android/net/EthernetManager.java
index 664b7b4..44592be 100755 (executable)
--- a/alps/frameworks/base/core/java/android/net/EthernetManager.java
+++ b/alps/frameworks/base/core/java/android/net/EthernetManager.java
@@ -35,6 +35,10 @@ public class EthernetManager {
private static final String TAG = "EthernetManager";
private static final int MSG_AVAILABILITY_CHANGED = 1000;
+ public static final int ETHERNET_STATE_UNKNOWN = 0;
+ public static final int ETHERNET_STATE_DISABLED = 1;
+ public static final int ETHERNET_STATE_ENABLED = 2;
+
private final Context mContext;
private final IEthernetManager mService;
private final Handler mHandler = new Handler() {
@@ -152,4 +156,19 @@ public class EthernetManager {
}
}
}
+
+ public void start() {
+ try {
+ mService.trackStart();
+ } catch (NullPointerException | RemoteException e) {
+ }
+ }
+
+ public void stop() {
+ try {
+ mService.trackStop();
+ } catch (NullPointerException | RemoteException e) {
+ }
+ }
+
}
3. frameworks/base/core/java/android/net/IEthernetManager.aidl
diff --git a/alps/frameworks/base/core/java/android/net/IEthernetManager.aidl b/alps/frameworks/base/core/java/android/net/IEthernetManager.aidl
index 7a92eb9..d2014ad 100755 (executable)
--- a/alps/frameworks/base/core/java/android/net/IEthernetManager.aidl
+++ b/alps/frameworks/base/core/java/android/net/IEthernetManager.aidl
@@ -31,4 +31,6 @@ interface IEthernetManager
boolean isAvailable();
void addListener(in IEthernetServiceListener listener);
void removeListener(in IEthernetServiceListener listener);
+ void trackStart();
+ void trackStop();
}
4. frameworks/base/core/java/android/provider/Settings.java
diff --git a/alps/frameworks/base/core/java/android/provider/Settings.java b/alps/frameworks/base/core/java/android/provider/Settings.java
index 1e0a53a..817b008 100755 (executable)
--- a/alps/frameworks/base/core/java/android/provider/Settings.java
+++ b/alps/frameworks/base/core/java/android/provider/Settings.java
@@ -9832,6 +9832,48 @@ public final class Settings {
public static final String CURRENT_NETWORK_CALL = "current_network_call";
/// MTK ADD END. @}
+ /**
+ * ethernet setting is enabled or disable.
+ *
+ * @hide
+ */
+ public static final String ETHERNET_ON = "ethernet_on";
+
+ /**
+ * ethernet_static_ip setting
+ *
+ * @hide
+ */
+ public static final String ETHERNET_STATIC_IP = "ethernet_static_ip";
+
+ /**
+ * ethernet_static_mask setting
+ *
+ * @hide
+ */
+ public static final String ETHERNET_STATIC_MASK = "ethernet_static_mask";
+
+ /**
+ * ethernet_static_gateway setting
+ *
+ * @hide
+ */
+ public static final String ETHERNET_STATIC_GATEWAY = "ethernet_static_gateway";
+
+ /**
+ * ethernet_static_dns1 setting
+ *
+ * @hide
+ */
+ public static final String ETHERNET_STATIC_DNS1 = "ethernet_static_dns1";
+
+ /**
+ * ethernet_static_dns2 setting
+ *
+ * @hide
+ */
+ public static final String ETHERNET_STATIC_DNS2 = "ethernet_static_dns2";
+
}
/**
5. frameworks/base/core/res/res/values/config.xml
diff --git a/alps/frameworks/base/core/res/res/values/config.xml b/alps/frameworks/base/core/res/res/values/config.xml
index 9aac18e..d790573 100755 (executable)
--- a/alps/frameworks/base/core/res/res/values/config.xml
+++ b/alps/frameworks/base/core/res/res/values/config.xml
@@ -232,6 +232,7 @@
does not require auto-restore. -->
+
6. frameworks/base/packages/SettingsProvider/res/values/defaults.xml
diff --git a/alps/frameworks/base/packages/SettingsProvider/res/values/defaults.xml b/alps/frameworks/base/packages/SettingsProvider/res/values/defaults.xml
index f50436b..72298cc 100755 (executable)
--- a/alps/frameworks/base/packages/SettingsProvider/res/values/defaults.xml
+++ b/alps/frameworks/base/packages/SettingsProvider/res/values/defaults.xml
@@ -219,4 +219,17 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
7. frameworks/base/packages/SettingsProvider/src/com/android/providers/settings/DatabaseHelper.java
diff --git a/alps/frameworks/base/packages/SettingsProvider/src/com/android/providers/settings/DatabaseHelper.java b/alps/frameworks/base/packages/SettingsProvider/src/com/android/providers/settings/DatabaseHelper.java
index 3ad22dd..3eb3fe7 100755 (executable)
--- a/alps/frameworks/base/packages/SettingsProvider/src/com/android/providers/settings/DatabaseHelper.java
+++ b/alps/frameworks/base/packages/SettingsProvider/src/com/android/providers/settings/DatabaseHelper.java
@@ -2755,6 +2755,19 @@ class DatabaseHelper extends SQLiteOpenHelper {
loadSetting(stmt, Settings.Global.ENHANCED_4G_MODE_ENABLED,
ImsConfig.FeatureValueConstants.ON);
+ loadIntegerSetting(stmt, Settings.Global.ETHERNET_ON,
+ R.integer.def_ethernet_on);
+ loadStringSetting(stmt, Settings.Global.ETHERNET_STATIC_IP,
+ R.string.def_ethernet_static_ip);
+ loadStringSetting(stmt, Settings.Global.ETHERNET_STATIC_MASK,
+ R.string.def_ethernet_static_mask);
+ loadStringSetting(stmt, Settings.Global.ETHERNET_STATIC_GATEWAY,
+ R.string.def_ethernet_static_gateway);
+ loadStringSetting(stmt, Settings.Global.ETHERNET_STATIC_DNS1,
+ R.string.def_ethernet_static_dns1);
+ loadStringSetting(stmt, Settings.Global.ETHERNET_STATIC_DNS2,
+ R.string.def_ethernet_static_dns2);
+
/// M: Load MTK added Global providers before Android M.
mUtils.loadCustomGlobalSettings(stmt);
8. frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetNetworkFactory.java
diff --git a/alps/frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetNetworkFactory.java b/alps/frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetNetworkFactory.java
index 0b091f2..5a268ab 100755 (executable)
--- a/alps/frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetNetworkFactory.java
+++ b/alps/frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetNetworkFactory.java
@@ -105,6 +105,8 @@ class EthernetNetworkFactory {
private IpManager mIpManager;
private Thread mIpProvisioningThread;
+ private Handler mHandler;
+
EthernetNetworkFactory(RemoteCallbackList
mNetworkInfo = new NetworkInfo(ConnectivityManager.TYPE_ETHERNET, 0, NETWORK_TYPE, "");
mLinkProperties = new LinkProperties();
@@ -298,6 +300,12 @@ class EthernetNetworkFactory {
if (config.getIpAssignment() == IpAssignment.STATIC) {
if (!setStaticIpAddress(config.getStaticIpConfiguration())) {
// We've already logged an error.
+ //if error then stop and restart
+ if((mContext != null) && (mHandler != null)) {
+ Log.d(TAG, "Setting static ip failed now restart");
+ stop();
+ start(mContext,mHandler);
+ }
return;
}
linkProperties = config.getStaticIpConfiguration().toLinkProperties(mIface);
@@ -426,6 +434,7 @@ class EthernetNetworkFactory {
mFactory.register();
mContext = context;
+ mHandler = target;
// Start tracking interface change events.
mInterfaceObserver = new InterfaceObserver();
@@ -449,6 +458,9 @@ class EthernetNetworkFactory {
// configuring it. Since we're already holding the lock,
// any real link up/down notification will only arrive
// after we've done this.
+ if(!iface.equals("eth0")) {
+ continue;
+ }
if (mNMService.getInterfaceConfig(iface).hasFlag("running")) {
updateInterfaceState(iface, true);
}
9. frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetServiceImpl.java
diff --git a/alps/frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetServiceImpl.java b/alps/frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetServiceImpl.java
index 42996d6..9508b79 100755 (executable)
--- a/alps/frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetServiceImpl.java
+++ b/alps/frameworks/opt/net/ethernet/java/com/android/server/ethernet/EthernetServiceImpl.java
@@ -18,6 +18,7 @@ package com.android.server.ethernet;
import android.content.Context;
import android.content.pm.PackageManager;
+import android.net.EthernetManager;
import android.net.IEthernetManager;
import android.net.IEthernetServiceListener;
import android.net.IpConfiguration;
@@ -26,6 +27,7 @@ import android.net.IpConfiguration.ProxySettings;
import android.os.Binder;
import android.os.Handler;
import android.os.HandlerThread;
+import android.os.Looper;
import android.os.RemoteCallbackList;
import android.os.RemoteException;
import android.provider.Settings;
@@ -38,6 +40,12 @@ import java.io.FileDescriptor;
import java.io.PrintWriter;
import java.util.concurrent.atomic.AtomicBoolean;
+import android.net.Uri;
+import android.provider.Settings.System;
+import android.net.StaticIpConfiguration;
+import android.net.LinkAddress;
+import java.net.InetAddress;
+
/**
* EthernetServiceImpl handles remote Ethernet operation requests by implementing
* the IEthernetManager interface.
@@ -87,11 +95,42 @@ public class EthernetServiceImpl extends IEthernetManager.Stub {
handlerThread.start();
mHandler = new Handler(handlerThread.getLooper());
+ int enable = Settings.Global.getInt(mContext.getContentResolver(),
+ Settings.Global.ETHERNET_ON, 0);
+ if(enable != EthernetManager.ETHERNET_STATE_ENABLED) {
+ Log.i(TAG, "Ethernet is not enable");
+ return;
+ }
+
mTracker.start(mContext, mHandler);
mStarted.set(true);
}
+ public void trackStart() {
+ Log.i(TAG, "Statr ethernet service");
+ new Thread(new Runnable() {
+ public void run() {
+ Looper.prepare();
+ mTracker.start(mContext, mHandler);
+ mStarted.set(true);
+ Looper.loop();
+ }
+ }).start();;
+ }
+
+ public void trackStop() {
+ Log.i(TAG, "Stop ethernet service");
+ new Thread(new Runnable() {
+ public void run() {
+ Looper.prepare();
+ mTracker.stop();
+ mStarted.set(false);
+ Looper.loop();
+ }
+ }).start();;
+ }
+
/**
* Get Ethernet configuration
* @return the Ethernet Configuration, contained in {@link IpConfiguration}.
10. packages/apps/Settings/AndroidManifest.xml
diff --git a/alps/packages/apps/Settings/AndroidManifest.xml b/alps/packages/apps/Settings/AndroidManifest.xml
index 8f1cfc1..9a02ea3 100644 (file)
--- a/alps/packages/apps/Settings/AndroidManifest.xml
+++ b/alps/packages/apps/Settings/AndroidManifest.xml
@@ -465,6 +465,46 @@
+
+ android:label="@string/ethernet_settings"
+ android:icon="@drawable/ic_settings_ethernet"
+ android:taskAffinity="" >
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ android:value="com.android.settings.category.wireless" />
+
+ android:value="com.android.settings.ethernet.EthernetSettings" />
+
+ android:value="true" />
+
+
+
+
+ android:targetActivity="Settings$EthernetSettingsActivity"
+ android:exported="true"
+ android:clearTaskOnLaunch="true">
+
+ android:value="com.android.settings.ethernet.EthernetSettings" />
+
+
android:permission="android.permission.TETHER_PRIVILEGED" />
@@ -2404,11 +2444,11 @@
android:label="@string/crypt_keeper_encrypt_title">
11. packages/apps/Settings/res/drawable-hdpi/ic_settings_ethernet.png
12. packages/apps/Settings/res/layout/ethernet_configure.xml
13. packages/apps/Settings/res/values-zh-rCN/strings.xml
diff --git a/alps/packages/apps/Settings/res/values-zh-rCN/strings.xml b/alps/packages/apps/Settings/res/values-zh-rCN/strings.xml
index 47cbe80..5fd7ba5 100755 (executable)
--- a/alps/packages/apps/Settings/res/values-zh-rCN/strings.xml
+++ b/alps/packages/apps/Settings/res/values-zh-rCN/strings.xml
@@ -3099,4 +3099,31 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
14. packages/apps/Settings/res/values/strings.xml
diff --git a/alps/packages/apps/Settings/res/values/strings.xml b/alps/packages/apps/Settings/res/values/strings.xml
index 38bc124..c3798fd 100755 (executable)
--- a/alps/packages/apps/Settings/res/values/strings.xml
+++ b/alps/packages/apps/Settings/res/values/strings.xml
@@ -7500,4 +7500,32 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
15. packages/apps/Settings/res/xml/ethernet_settings.xml
16. packages/apps/Settings/src/com/android/settings/Settings.java
diff --git a/alps/packages/apps/Settings/src/com/android/settings/Settings.java b/alps/packages/apps/Settings/src/com/android/settings/Settings.java
index 3508406..f423077 100644 (file)
--- a/alps/packages/apps/Settings/src/com/android/settings/Settings.java
+++ b/alps/packages/apps/Settings/src/com/android/settings/Settings.java
@@ -29,6 +29,7 @@ public class Settings extends SettingsActivity {
* Settings subclasses for launching independently.
*/
public static class BluetoothSettingsActivity extends SettingsActivity { /* empty */ }
+ public static class EthernetSettingsActivity extends SettingsActivity { /* empty */ }
public static class WirelessSettingsActivity extends SettingsActivity { /* empty */ }
public static class SimSettingsActivity extends SettingsActivity { /* empty */ }
public static class TetherSettingsActivity extends SettingsActivity { /* empty */ }
17. packages/apps/Settings/src/com/android/settings/SettingsActivity.java
diff --git a/alps/packages/apps/Settings/src/com/android/settings/SettingsActivity.java b/alps/packages/apps/Settings/src/com/android/settings/SettingsActivity.java
index 9b82a5f..efa99a1 100644 (file)
--- a/alps/packages/apps/Settings/src/com/android/settings/SettingsActivity.java
+++ b/alps/packages/apps/Settings/src/com/android/settings/SettingsActivity.java
@@ -81,6 +81,7 @@ import com.android.settings.deviceinfo.PublicVolumeSettings;
import com.android.settings.deviceinfo.SimStatus;
import com.android.settings.deviceinfo.Status;
import com.android.settings.deviceinfo.StorageSettings;
+import com.android.settings.ethernet.EthernetSettings;
import com.android.settings.fuelgauge.BatterySaverSettings;
import com.android.settings.fuelgauge.PowerUsageDetail;
import com.android.settings.fuelgauge.PowerUsageSummary;
@@ -239,6 +240,7 @@ public class SettingsActivity extends SettingsDrawerActivity
//wireless_section
WifiSettingsActivity.class.getName(),
Settings.BluetoothSettingsActivity.class.getName(),
+ Settings.EthernetSettingsActivity.class.getName(),
Settings.DataUsageSummaryActivity.class.getName(),
Settings.SimSettingsActivity.class.getName(),
Settings.WirelessSettingsActivity.class.getName(),
@@ -278,6 +280,7 @@ public class SettingsActivity extends SettingsDrawerActivity
AdvancedWifiSettings.class.getName(),
SavedAccessPointsWifiSettings.class.getName(),
BluetoothSettings.class.getName(),
+ EthernetSettings.class.getName(),
SimSettings.class.getName(),
TetherSettings.class.getName(),
WifiP2pSettings.class.getName(),
@@ -1085,6 +1088,10 @@ public class SettingsActivity extends SettingsDrawerActivity
pm.hasSystemFeature(PackageManager.FEATURE_BLUETOOTH), isAdmin, pm);
setTileEnabled(new ComponentName(packageName,
+ Settings.EthernetSettingsActivity.class.getName()),
+ pm.hasSystemFeature(PackageManager.FEATURE_ETHERNET), isAdmin, pm);
+
+ setTileEnabled(new ComponentName(packageName,
Settings.DataUsageSummaryActivity.class.getName()),
Utils.isBandwidthControlEnabled(), isAdmin, pm);
18. packages/apps/Settings/src/com/android/settings/ethernet/EthernetDialog.java
19. packages/apps/Settings/src/com/android/settings/ethernet/EthernetEnabler.java
20. packages/apps/Settings/src/com/android/settings/ethernet/EthernetSettings.java
21. packages/apps/Settings/src/com/android/settings/ethernet/ip/AbsEditText.java
22. packages/apps/Settings/src/com/android/settings/ethernet/ip/AbsEditTextGroup.java
23. packages/apps/Settings/src/com/android/settings/ethernet/ip/IPEditText.java
24. packages/apps/Settings/src/com/android/settings/ethernet/ip/IPView.java
标红文件见 Android 7.0 增加Ethernet设置(DHCP与Static ip)
感谢
http://blog.csdn.net/hclydao/article/details/50972932
https://github.com/lanyan520/Idea-EditText