| Index: content/renderer/p2p/ipc_network_manager.cc | 
| diff --git a/content/renderer/p2p/ipc_network_manager.cc b/content/renderer/p2p/ipc_network_manager.cc | 
| index d1ea5ca5d26560fda2b0802e6b689c77c168d0bd..906f960eab4627f7823cefd8eb3fc10c69a102e0 100644 | 
| --- a/content/renderer/p2p/ipc_network_manager.cc | 
| +++ b/content/renderer/p2p/ipc_network_manager.cc | 
| @@ -13,10 +13,12 @@ | 
| #include "base/sys_byteorder.h" | 
| #include "base/thread_task_runner_handle.h" | 
| #include "content/public/common/content_switches.h" | 
| +#include "jingle/glue/utils.h" | 
| #include "net/base/ip_address_number.h" | 
| #include "net/base/net_util.h" | 
| #include "net/base/network_change_notifier.h" | 
| #include "net/base/network_interfaces.h" | 
| +#include "third_party/webrtc/base/socketaddress.h" | 
|  | 
| namespace content { | 
|  | 
| @@ -71,12 +73,21 @@ void IpcNetworkManager::StopUpdating() { | 
| } | 
|  | 
| void IpcNetworkManager::OnNetworkListChanged( | 
| -    const net::NetworkInterfaceList& list) { | 
| - | 
| +    const net::NetworkInterfaceList& list, | 
| +    const net::IPEndPoint& default_ipv4_local_address, | 
| +    const net::IPEndPoint& default_ipv6_local_address) { | 
| // Update flag if network list received for the first time. | 
| if (!network_list_received_) | 
| network_list_received_ = true; | 
|  | 
| +  // Update the default private interface. | 
| +  rtc::SocketAddress sock_addr_v4, sock_addr_v6; | 
| +  jingle_glue::IPEndPointToSocketAddress(default_ipv4_local_address, | 
| +                                         &sock_addr_v4); | 
| +  jingle_glue::IPEndPointToSocketAddress(default_ipv6_local_address, | 
| +                                         &sock_addr_v6); | 
| +  set_default_local_addresses(sock_addr_v4.ipaddr(), sock_addr_v6.ipaddr()); | 
| + | 
| // rtc::Network uses these prefix_length to compare network | 
| // interfaces discovered. | 
| std::vector<rtc::Network*> networks; | 
| @@ -91,6 +102,7 @@ void IpcNetworkManager::OnNetworkListChanged( | 
| rtc::Network* network = | 
| new rtc::Network(it->name, it->name, prefix, it->prefix_length, | 
| ConvertConnectionTypeToAdapterType(it->type)); | 
| +      network->set_default_address_provider(this); | 
| network->AddIP(rtc::IPAddress(address)); | 
| networks.push_back(network); | 
| } else if (it->address.size() == net::kIPv6AddressSize) { | 
| @@ -110,6 +122,7 @@ void IpcNetworkManager::OnNetworkListChanged( | 
| rtc::Network* network = | 
| new rtc::Network(it->name, it->name, prefix, it->prefix_length, | 
| ConvertConnectionTypeToAdapterType(it->type)); | 
| +        network->set_default_address_provider(this); | 
| network->AddIP(ip6_addr); | 
| networks.push_back(network); | 
| } | 
| @@ -122,6 +135,7 @@ void IpcNetworkManager::OnNetworkListChanged( | 
| rtc::IPAddress ip_address_v4(INADDR_LOOPBACK); | 
| rtc::Network* network_v4 = new rtc::Network( | 
| name_v4, name_v4, ip_address_v4, 32, rtc::ADAPTER_TYPE_UNKNOWN); | 
| +    network_v4->set_default_address_provider(this); | 
| network_v4->AddIP(ip_address_v4); | 
| networks.push_back(network_v4); | 
|  | 
| @@ -129,6 +143,7 @@ void IpcNetworkManager::OnNetworkListChanged( | 
| rtc::IPAddress ip_address_v6(in6addr_loopback); | 
| rtc::Network* network_v6 = new rtc::Network( | 
| name_v6, name_v6, ip_address_v6, 64, rtc::ADAPTER_TYPE_UNKNOWN); | 
| +    network_v6->set_default_address_provider(this); | 
| network_v6->AddIP(ip_address_v6); | 
| networks.push_back(network_v6); | 
| } | 
|  |