--- ./src/plugins/bearer/generic/qgenericengine.cpp.orig 2019-01-28 19:11:52.000000000 +0200 +++ ./src/plugins/bearer/generic/qgenericengine.cpp 2019-03-17 19:22:28.529272000 +0200 @@ -82,7 +82,7 @@ // needed as interface is used as parameter name in qGetInterfaceType #undef interface -#ifdef Q_OS_LINUX +#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD) #include #include #include @@ -139,6 +139,23 @@ if (result >= 0 && request.ifr_hwaddr.sa_family == ARPHRD_ETHER) return QNetworkConfiguration::BearerEthernet; + +#elif defined(Q_OS_FREEBSD) + int sock = socket(AF_LOCAL, SOCK_DGRAM, 0); + + ifreq request; + memset(&request, 0, sizeof(struct ifreq)); + strncpy(request.ifr_name, interface.toLocal8Bit().data(), sizeof(request.ifr_name) - 1); + request.ifr_name[sizeof(request.ifr_name) - 1] = '\0'; + + if (sock >= 0) { + int result = ioctl(sock, SIOCGHWADDR, &request); + close(sock); + + if (result >= 0) + return QNetworkConfiguration::BearerEthernet; + } + #elif defined(Q_OS_WINRT) ComPtr networkInfoStatics; HRESULT hr = GetActivationFactory(HString::MakeReference(RuntimeClass_Windows_Networking_Connectivity_NetworkInformation).Get(), &networkInfoStatics); @@ -231,9 +248,11 @@ QGenericEngine::QGenericEngine(QObject *parent) : QBearerEngineImpl(parent) { +#ifndef QT_NO_NETWORKINTERFACE //workaround for deadlock in __cxa_guard_acquire with webkit on macos x //initialise the Q_GLOBAL_STATIC in same thread as the AtomicallyInitializedStatic (void)QNetworkInterface::interfaceFromIndex(0); +#endif } QGenericEngine::~QGenericEngine()