Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 21 Jul 2017 11:14:01 +0000 (UTC)
From:      "Carlos J. Puga Medina" <cpm@FreeBSD.org>
To:        ports-committers@freebsd.org, svn-ports-all@freebsd.org, svn-ports-head@freebsd.org
Subject:   svn commit: r446307 - in head/www/chromium: . files
Message-ID:  <201707211114.v6LBE15W078624@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: cpm
Date: Fri Jul 21 11:14:01 2017
New Revision: 446307
URL: https://svnweb.freebsd.org/changeset/ports/446307

Log:
  - Add network interface implementation for FreeBSD [1]
  - Backport a patch from upstream to fix DPI settings
  - Bump PORTREVISION
  
  PR:		211036 [1]
  MFH:		2017Q3

Added:
  head/www/chromium/files/patch-chrome_browser_ui_libgtkui_gtk_ui.cc   (contents, props changed)
  head/www/chromium/files/patch-net_base_network__interfaces__freebsd.cc   (contents, props changed)
  head/www/chromium/files/patch-net_base_network__interfaces__freebsd.h   (contents, props changed)
  head/www/chromium/files/patch-net_base_network__interfaces__posix.h   (contents, props changed)
  head/www/chromium/files/patch-v8_src_log-utils.h   (contents, props changed)
Deleted:
  head/www/chromium/files/patch-net_base_network__interfaces__posix.cc
Modified:
  head/www/chromium/Makefile
  head/www/chromium/files/patch-net_BUILD.gn

Modified: head/www/chromium/Makefile
==============================================================================
--- head/www/chromium/Makefile	Fri Jul 21 10:56:16 2017	(r446306)
+++ head/www/chromium/Makefile	Fri Jul 21 11:14:01 2017	(r446307)
@@ -3,7 +3,7 @@
 
 PORTNAME=	chromium
 PORTVERSION=	59.0.3071.115
-PORTREVISION=	1
+PORTREVISION=	2
 CATEGORIES=	www
 MASTER_SITES=	https://commondatastorage.googleapis.com/chromium-browser-official/:source1 \
 		LOCAL/cpm:source2

Added: head/www/chromium/files/patch-chrome_browser_ui_libgtkui_gtk_ui.cc
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/www/chromium/files/patch-chrome_browser_ui_libgtkui_gtk_ui.cc	Fri Jul 21 11:14:01 2017	(r446307)
@@ -0,0 +1,60 @@
+--- chrome/browser/ui/libgtkui/gtk_ui.cc.orig	2017-07-21 03:22:08.117746000 +0200
++++ chrome/browser/ui/libgtkui/gtk_ui.cc	2017-07-21 03:25:59.536126000 +0200
+@@ -315,52 +315,15 @@
+   return params;
+ }
+ 
+-float GtkDpiToScaleFactor(int dpi) {
+-  // GTK multiplies the DPI by 1024 before storing it.
+-  return dpi / (1024 * kDefaultDPI);
+-}
+-
+-gint GetGdkScreenSettingInt(const char* setting_name) {
+-  GValue value = G_VALUE_INIT;
+-  g_value_init(&value, G_TYPE_INT);
+-  if (!gdk_screen_get_setting(gdk_screen_get_default(), setting_name, &value))
+-    return -1;
+-  return g_value_get_int(&value);
+-}
+-
+-float GetScaleFromGdkScreenSettings() {
+-  gint window_scale = GetGdkScreenSettingInt("gdk-window-scaling-factor");
+-  if (window_scale <= 0)
+-    return -1;
+-  gint font_dpi = GetGdkScreenSettingInt("gdk-unscaled-dpi");
+-  if (font_dpi <= 0)
+-    return -1;
+-  return window_scale * GtkDpiToScaleFactor(font_dpi);
+-}
+-
+-float GetScaleFromXftDPI() {
+-  GtkSettings* gtk_settings = gtk_settings_get_default();
+-  CHECK(gtk_settings);
+-  gint gtk_dpi = -1;
+-  g_object_get(gtk_settings, "gtk-xft-dpi", &gtk_dpi, nullptr);
+-  if (gtk_dpi <= 0)
+-    return -1;
+-  return GtkDpiToScaleFactor(gtk_dpi);
+-}
+-
+ float GetRawDeviceScaleFactor() {
+   if (display::Display::HasForceDeviceScaleFactor())
+     return display::Display::GetForcedDeviceScaleFactor();
+ 
+-  float scale = GetScaleFromGdkScreenSettings();
+-  if (scale > 0)
+-    return scale;
+-
+-  scale = GetScaleFromXftDPI();
+-  if (scale > 0)
+-    return scale;
+-
+-  return 1;
++  GdkScreen* screen = gdk_screen_get_default();
++  gint scale = gdk_screen_get_monitor_scale_factor(
++      screen, gdk_screen_get_primary_monitor(screen));
++  gdouble resolution = gdk_screen_get_resolution(screen);
++  return resolution <= 0? scale : resolution * scale / kDefaultDPI;
+ }
+ 
+ views::LinuxUI::NonClientMiddleClickAction GetDefaultMiddleClickAction() {

Modified: head/www/chromium/files/patch-net_BUILD.gn
==============================================================================
--- head/www/chromium/files/patch-net_BUILD.gn	Fri Jul 21 10:56:16 2017	(r446306)
+++ head/www/chromium/files/patch-net_BUILD.gn	Fri Jul 21 11:14:01 2017	(r446307)
@@ -1,6 +1,6 @@
---- net/BUILD.gn.orig	2017-06-05 19:03:09 UTC
-+++ net/BUILD.gn
-@@ -86,7 +86,7 @@ if (use_glib && use_gconf && !is_chromeos) {
+--- net/BUILD.gn.orig	2017-06-26 21:03:20.000000000 +0200
++++ net/BUILD.gn	2017-07-04 23:12:52.376233000 +0200
+@@ -86,7 +86,7 @@
    net_configs += [ "//build/config/linux/gconf" ]
  }
  
@@ -9,7 +9,7 @@
    net_configs += [ "//build/config/linux:libresolv" ]
  }
  
-@@ -1900,6 +1900,16 @@ component("net") {
+@@ -1900,6 +1900,17 @@
        sources -= [ "disk_cache/blockfile/file_posix.cc" ]
      }
  
@@ -21,12 +21,13 @@
 +         "base/network_change_notifier_linux.h",
 +         "base/network_interfaces_linux.cc",
 +      ]
++      sources += [ "base/network_interfaces_freebsd.cc" ]
 +    }
 +
      if (is_ios || is_mac) {
        sources += [
          "base/mac/url_conversions.h",
-@@ -2854,7 +2864,7 @@ if (!is_ios && !is_android) {
+@@ -2854,7 +2865,7 @@
    }
  }
  
@@ -35,7 +36,7 @@
    executable("cachetool") {
      testonly = true
      sources = [
-@@ -2883,7 +2893,7 @@ if (is_linux || is_mac) {
+@@ -2883,7 +2894,7 @@
    }
  }
  
@@ -44,7 +45,7 @@
    static_library("epoll_server") {
      sources = [
        "tools/epoll_server/epoll_server.cc",
-@@ -2987,7 +2997,7 @@ if (is_android) {
+@@ -2987,7 +2998,7 @@
    }
  }
  
@@ -53,7 +54,7 @@
    executable("disk_cache_memory_test") {
      testonly = true
      sources = [
-@@ -4874,7 +4884,7 @@ test("net_unittests") {
+@@ -4874,7 +4885,7 @@
      "third_party/nist-pkits/",
    ]
  
@@ -62,7 +63,7 @@
      deps += [
        "//third_party/pyftpdlib/",
        "//third_party/pywebsocket/",
-@@ -4897,7 +4907,7 @@ test("net_unittests") {
+@@ -4897,7 +4908,7 @@
    if (is_desktop_linux) {
      deps += [ ":epoll_quic_tools" ]
    }
@@ -71,7 +72,7 @@
      sources += [
        "tools/quic/chlo_extractor_test.cc",
        "tools/quic/end_to_end_test.cc",
-@@ -4957,6 +4967,10 @@ test("net_unittests") {
+@@ -4957,6 +4968,10 @@
  
    if (is_chromeos) {
      sources -= [ "proxy/proxy_config_service_linux_unittest.cc" ]

Added: head/www/chromium/files/patch-net_base_network__interfaces__freebsd.cc
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/www/chromium/files/patch-net_base_network__interfaces__freebsd.cc	Fri Jul 21 11:14:01 2017	(r446307)
@@ -0,0 +1,243 @@
+--- net/base/network_interfaces_freebsd.cc.orig	2017-07-05 18:08:44.779023000 +0200
++++ net/base/network_interfaces_freebsd.cc	2017-07-05 22:03:18.679624000 +0200
+@@ -0,0 +1,240 @@
++// Copyright (c) 2014 The Chromium Authors. All rights reserved.
++// Use of this source code is governed by a BSD-style license that can be
++// found in the LICENSE file.
++
++#include "net/base/network_interfaces_freebsd.h"
++
++#include <ifaddrs.h>
++#include <net/if.h>
++#include <netinet/in.h>
++#include <sys/types.h>
++#include <net/if_media.h>
++#include <net/if_var.h>
++#include <netinet/in_var.h>
++#include <netinet6/in6_var.h>
++#include <sys/ioctl.h>
++
++#include <memory>
++#include <set>
++
++#include "base/files/file_path.h"
++#include "base/logging.h"
++#include "base/strings/string_number_conversions.h"
++#include "base/strings/string_tokenizer.h"
++#include "base/strings/string_util.h"
++#include "base/threading/thread_restrictions.h"
++#include "net/base/escape.h"
++#include "net/base/ip_endpoint.h"
++#include "net/base/net_errors.h"
++#include "net/base/network_interfaces_posix.h"
++#include "url/gurl.h"
++
++namespace net {
++
++namespace {
++
++// FreeBSD implementation of IPAttributesGetterFreeBSD which calls ioctl on socket to
++// retrieve IP attributes.
++class IPAttributesGetterFreeBSDImpl : public internal::IPAttributesGetterFreeBSD {
++ public:
++  IPAttributesGetterFreeBSDImpl();
++  ~IPAttributesGetterFreeBSDImpl() override;
++  bool IsInitialized() const override;
++  bool GetIPAttributes(const char* ifname,
++                       const sockaddr* sock_addr,
++                       int* native_attributes) override;
++
++ private:
++  int ioctl_socket_;
++};
++
++IPAttributesGetterFreeBSDImpl::IPAttributesGetterFreeBSDImpl()
++    : ioctl_socket_(socket(AF_INET6, SOCK_DGRAM, 0)) {
++  DCHECK_GE(ioctl_socket_, 0);
++}
++
++bool IPAttributesGetterFreeBSDImpl::IsInitialized() const {
++  return ioctl_socket_ >= 0;
++}
++
++IPAttributesGetterFreeBSDImpl::~IPAttributesGetterFreeBSDImpl() {
++  if (ioctl_socket_ >= 0) {
++    close(ioctl_socket_);
++  }
++}
++
++bool IPAttributesGetterFreeBSDImpl::GetIPAttributes(const char* ifname,
++                                                const sockaddr* sock_addr,
++                                                int* native_attributes) {
++  struct in6_ifreq ifr = {};
++  strncpy(ifr.ifr_name, ifname, sizeof(ifr.ifr_name) - 1);
++  memcpy(&ifr.ifr_ifru.ifru_addr, sock_addr, sock_addr->sa_len);
++  int rv = ioctl(ioctl_socket_, SIOCGIFAFLAG_IN6, &ifr);
++  if (rv >= 0) {
++    *native_attributes = ifr.ifr_ifru.ifru_flags;
++  }
++  return (rv >= 0);
++}
++
++// When returning true, the platform native IPv6 address attributes were
++// successfully converted to net IP address attributes. Otherwise, returning
++// false and the caller should drop the IP address which can't be used by the
++// application layer.
++bool TryConvertNativeToNetIPAttributes(int native_attributes,
++                                       int* net_attributes) {
++  // For FreeBSD, we disallow addresses with attributes IN6_IFF_ANYCASE,
++  // IN6_IFF_DUPLICATED, IN6_IFF_TENTATIVE, and IN6_IFF_DETACHED as these are
++  // still progressing through duplicated address detection (DAD) or are not
++  // suitable to be used in an one-to-one communication and shouldn't be used
++  // by the application layer.
++  if (native_attributes & (IN6_IFF_ANYCAST | IN6_IFF_DUPLICATED |
++                           IN6_IFF_TENTATIVE | IN6_IFF_DETACHED)) {
++    return false;
++  }
++
++  if (native_attributes & IN6_IFF_DEPRECATED) {
++    *net_attributes |= IP_ADDRESS_ATTRIBUTE_DEPRECATED;
++  }
++
++  return true;
++}
++
++NetworkChangeNotifier::ConnectionType GetNetworkInterfaceType(
++    int addr_family,
++    const std::string& interface_name) {
++  NetworkChangeNotifier::ConnectionType type =
++      NetworkChangeNotifier::CONNECTION_UNKNOWN;
++
++  struct ifmediareq ifmr = {};
++  strncpy(ifmr.ifm_name, interface_name.c_str(), sizeof(ifmr.ifm_name) - 1);
++
++  int s = socket(addr_family, SOCK_DGRAM, 0);
++  if (s == -1) {
++    return type;
++  }
++
++  if (ioctl(s, SIOCGIFMEDIA, &ifmr) != -1) {
++    if (ifmr.ifm_current & IFM_IEEE80211) {
++      type = NetworkChangeNotifier::CONNECTION_WIFI;
++    } else if (ifmr.ifm_current & IFM_ETHER) {
++      type = NetworkChangeNotifier::CONNECTION_ETHERNET;
++    }
++  }
++  close(s);
++  return type;
++}
++
++}  // namespace
++
++namespace internal {
++
++bool GetNetworkListImpl(NetworkInterfaceList* networks,
++                        int policy,
++                        const ifaddrs* interfaces,
++                        IPAttributesGetterFreeBSD* ip_attributes_getter) {
++  // Enumerate the addresses assigned to network interfaces which are up.
++  for (const ifaddrs* interface = interfaces; interface != NULL;
++       interface = interface->ifa_next) {
++    // Skip loopback interfaces, and ones which are down.
++    if (!(IFF_RUNNING & interface->ifa_flags))
++      continue;
++    if (IFF_LOOPBACK & interface->ifa_flags)
++      continue;
++    // Skip interfaces with no address configured.
++    struct sockaddr* addr = interface->ifa_addr;
++    if (!addr)
++      continue;
++
++    // Skip unspecified addresses (i.e. made of zeroes) and loopback addresses
++    // configured on non-loopback interfaces.
++    if (IsLoopbackOrUnspecifiedAddress(addr))
++      continue;
++
++    const std::string& name = interface->ifa_name;
++    // Filter out VMware interfaces, typically named vmnet1 and vmnet8.
++    if (ShouldIgnoreInterface(name, policy)) {
++      continue;
++    }
++
++    NetworkChangeNotifier::ConnectionType connection_type =
++        NetworkChangeNotifier::CONNECTION_UNKNOWN;
++
++    int ip_attributes = IP_ADDRESS_ATTRIBUTE_NONE;
++
++    // Retrieve native ip attributes and convert to net version if a getter is
++    // given.
++    if (ip_attributes_getter && ip_attributes_getter->IsInitialized()) {
++      int native_attributes = 0;
++      if (addr->sa_family == AF_INET6 &&
++          ip_attributes_getter->GetIPAttributes(
++              interface->ifa_name, interface->ifa_addr, &native_attributes)) {
++        if (!TryConvertNativeToNetIPAttributes(native_attributes,
++                                               &ip_attributes)) {
++          continue;
++        }
++      }
++    }
++
++    connection_type = GetNetworkInterfaceType(addr->sa_family, name);
++
++    IPEndPoint address;
++
++    int addr_size = 0;
++    if (addr->sa_family == AF_INET6) {
++      addr_size = sizeof(sockaddr_in6);
++    } else if (addr->sa_family == AF_INET) {
++      addr_size = sizeof(sockaddr_in);
++    }
++
++    if (address.FromSockAddr(addr, addr_size)) {
++      uint8_t prefix_length = 0;
++      if (interface->ifa_netmask) {
++        // If not otherwise set, assume the same sa_family as ifa_addr.
++        if (interface->ifa_netmask->sa_family == 0) {
++          interface->ifa_netmask->sa_family = addr->sa_family;
++        }
++        IPEndPoint netmask;
++        if (netmask.FromSockAddr(interface->ifa_netmask, addr_size)) {
++          prefix_length = MaskPrefixLength(netmask.address());
++        }
++      }
++      networks->push_back(NetworkInterface(
++          name, name, if_nametoindex(name.c_str()), connection_type,
++          address.address(), prefix_length, ip_attributes));
++    }
++  }
++
++  return true;
++}
++
++}  // namespace internal
++
++bool GetNetworkList(NetworkInterfaceList* networks, int policy) {
++  if (networks == NULL)
++    return false;
++
++  // getifaddrs() may require IO operations.
++  base::ThreadRestrictions::AssertIOAllowed();
++
++  ifaddrs* interfaces;
++  if (getifaddrs(&interfaces) < 0) {
++    PLOG(ERROR) << "getifaddrs";
++    return false;
++  }
++
++  std::unique_ptr<internal::IPAttributesGetterFreeBSD> ip_attributes_getter;
++
++  ip_attributes_getter.reset(new IPAttributesGetterFreeBSDImpl());
++
++  bool result = internal::GetNetworkListImpl(networks, policy, interfaces,
++                                             ip_attributes_getter.get());
++  freeifaddrs(interfaces);
++  return result;
++}
++
++std::string GetWifiSSID() {
++  NOTIMPLEMENTED();
++  return "";
++}
++
++}  // namespace net

Added: head/www/chromium/files/patch-net_base_network__interfaces__freebsd.h
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/www/chromium/files/patch-net_base_network__interfaces__freebsd.h	Fri Jul 21 11:14:01 2017	(r446307)
@@ -0,0 +1,47 @@
+--- net/base/network_interfaces_freebsd.h.orig	2017-07-04 23:05:05.313339000 +0200
++++ net/base/network_interfaces_freebsd.h	2017-07-04 23:04:51.039635000 +0200
+@@ -0,0 +1,44 @@
++// Copyright (c) 2014 The Chromium Authors. All rights reserved.
++// Use of this source code is governed by a BSD-style license that can be
++// found in the LICENSE file.
++
++#ifndef NET_BASE_NETWORK_INTERFACES_FREEBSD_H_
++#define NET_BASE_NETWORK_INTERFACES_FREEBSD_H_
++
++// This file is only used to expose some of the internals
++// of network_interfaces_mac.cc to tests.
++
++#include <sys/socket.h>
++
++#include "base/macros.h"
++#include "net/base/net_export.h"
++#include "net/base/network_interfaces.h"
++
++struct ifaddrs;
++struct sockaddr;
++
++namespace net {
++namespace internal {
++
++class NET_EXPORT IPAttributesGetterFreeBSD {
++ public:
++  IPAttributesGetterFreeBSD() {}
++  virtual ~IPAttributesGetterFreeBSD() {}
++  virtual bool IsInitialized() const = 0;
++  virtual bool GetIPAttributes(const char* ifname,
++                               const sockaddr* sock_addr,
++                               int* native_attributes) = 0;
++
++ private:
++  DISALLOW_COPY_AND_ASSIGN(IPAttributesGetterFreeBSD);
++};
++
++NET_EXPORT bool GetNetworkListImpl(NetworkInterfaceList* networks,
++                                   int policy,
++                                   const ifaddrs* interfaces,
++                                   IPAttributesGetterFreeBSD* ip_attributes_getter);
++
++}  // namespace internal
++}  // namespace net
++
++#endif  // NET_BASE_NETWORK_INTERFACES_FREEBSD_H_

Added: head/www/chromium/files/patch-net_base_network__interfaces__posix.h
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/www/chromium/files/patch-net_base_network__interfaces__posix.h	Fri Jul 21 11:14:01 2017	(r446307)
@@ -0,0 +1,11 @@
+--- net/base/network_interfaces_posix.h.orig	2017-07-04 22:49:41.402276000 +0200
++++ net/base/network_interfaces_posix.h	2017-07-04 22:49:59.456467000 +0200
+@@ -8,6 +8,8 @@
+ // This file is only used to expose some of the internals of
+ // network_interfaces_posix.cc to network_interfaces_linux.cc and network_interfaces_mac.cc.
+ 
++#include <sys/socket.h>
++
+ #include <string>
+ 
+ struct sockaddr;

Added: head/www/chromium/files/patch-v8_src_log-utils.h
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/www/chromium/files/patch-v8_src_log-utils.h	Fri Jul 21 11:14:01 2017	(r446307)
@@ -0,0 +1,11 @@
+--- v8/src/log-utils.h.orig	2017-07-04 22:40:30.657540000 +0200
++++ v8/src/log-utils.h	2017-07-04 22:40:59.090730000 +0200
+@@ -14,6 +14,8 @@
+ #include "src/base/platform/mutex.h"
+ #include "src/flags.h"
+ 
++#include <stdarg.h>
++
+ namespace v8 {
+ namespace internal {
+ 



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201707211114.v6LBE15W078624>