diff options
| author | Lorenzo Colitti <lorenzo@google.com> | 2014-10-28 00:15:07 +0900 |
|---|---|---|
| committer | Lorenzo Colitti <lorenzo@google.com> | 2014-10-30 21:51:57 +0900 |
| commit | 0ea8ff87012f6bda41b6d2b4629d4fd0fd6f4794 (patch) | |
| tree | 429378ba3ce857c28d579e3cb20f7ebcf848723b /server/InterfaceController.cpp | |
| parent | ac7fefcf3d90cf856b0f1664207d056ed1dd4725 (diff) | |
Add a netd interface command to disable ND offload.
This will be used to support 464xlat on wifi and IPv6 tethering.
Bug: 12111730
Change-Id: I3b97f4dfb787b2c5d5021811c6da51850bdc70d1
Diffstat (limited to 'server/InterfaceController.cpp')
| -rw-r--r-- | server/InterfaceController.cpp | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/server/InterfaceController.cpp b/server/InterfaceController.cpp index 061060f8..b38c137a 100644 --- a/server/InterfaceController.cpp +++ b/server/InterfaceController.cpp @@ -18,6 +18,7 @@ #define LOG_TAG "InterfaceController" #include <cutils/log.h> +#include <logwrap/logwrap.h> #include "InterfaceController.h" #include "RouteController.h" @@ -26,6 +27,8 @@ const char ipv6_proc_path[] = "/proc/sys/net/ipv6/conf"; const char sys_net_path[] = "/sys/class/net"; +const char wl_util_path[] = "/system/xbin/wlutil"; + InterfaceController::InterfaceController() { // Initial IPv6 settings. // By default, accept_ra is set to 1 (accept RAs unless forwarding is on) on all interfaces. @@ -66,6 +69,29 @@ int InterfaceController::setIPv6PrivacyExtensions(const char *interface, const i return writeIPv6ProcPath(interface, "use_tempaddr", on ? "2" : "0"); } +// Enables or disables IPv6 ND offload. This is useful for 464xlat on wifi, IPv6 tethering, and +// generally implementing IPv6 neighbour discovery and duplicate address detection properly. +// TODO: This should be implemented in wpa_supplicant via driver commands instead. +int InterfaceController::setIPv6NdOffload(char* interface, const int on) { + // Only supported on Broadcom chipsets via wlutil for now. + if (access(wl_util_path, X_OK) == 0) { + const char *argv[] = { + wl_util_path, + "-a", + interface, + "ndoe", + on ? "1" : "0" + }; + int ret = android_fork_execvp(ARRAY_SIZE(argv), const_cast<char**>(argv), NULL, + false, false); + ALOGD("%s ND offload on %s: %d (%s)", + (on ? "enabling" : "disabling"), interface, ret, strerror(errno)); + return ret; + } else { + return 0; + } +} + int InterfaceController::isInterfaceName(const char *name) { return strcmp(name, ".") && strcmp(name, "..") && |
