Add Solaris support in cmake build
Add SOLARIS cmake platform definition. Add settings for QT_DEFAULT_MKSPEC so that qplatformdefs.h can be found. Solaris has its gssapi symbols in libgss. Solaris supports @ORIGIN. Solaris ld does not support --dynamic-list needed for reduce relocations. Make solaris fail the reduce relocation test. getauxval is specific to GNU libc and some other libc implementations on Linux but sys/auxv.h is not. The bootstrap uses sys/aux.h as the only indication for getauxval. This breaks builds on Solaris, so only make sys/auxv.h an indicator for getauxval on linux or glibc based systems. Solaris uses X11 so add it to the X11_SUPPORTED list. Solaris network libraries for sockets etc are in socket and nsl. ifreq does not have a member ifr_ifindex on Solaris, it uses ifr_index. Add test to check if ifr_index is a member of ifreq. The first struct in the in_addr union on solaris is defined as four uint8_t, therefore four arguments are needed for its initializer list. Change-Id: Ieed4c1bbac8559a7ae1db9c4e1e91f609f150270 Reviewed-by: Edward Welbourne <edward.welbourne@qt.io> Reviewed-by: Joerg Bornemann <joerg.bornemann@qt.io>
This commit is contained in:
parent
284d4e7125
commit
fadd87ed15
@ -9,6 +9,7 @@ find_path(GSSAPI_INCLUDE_DIRS
|
|||||||
find_library(GSSAPI_LIBRARIES
|
find_library(GSSAPI_LIBRARIES
|
||||||
NAMES
|
NAMES
|
||||||
GSS # framework
|
GSS # framework
|
||||||
|
gss # solaris
|
||||||
gssapi_krb5
|
gssapi_krb5
|
||||||
HINTS ${PC_GSSAPILIBDIR}
|
HINTS ${PC_GSSAPILIBDIR}
|
||||||
)
|
)
|
||||||
|
@ -329,6 +329,20 @@ elseif(NETBSD)
|
|||||||
set(QT_DEFAULT_MKSPEC netbsd-g++)
|
set(QT_DEFAULT_MKSPEC netbsd-g++)
|
||||||
elseif(OPENBSD)
|
elseif(OPENBSD)
|
||||||
set(QT_DEFAULT_MKSPEC openbsd-g++)
|
set(QT_DEFAULT_MKSPEC openbsd-g++)
|
||||||
|
elseif(SOLARIS)
|
||||||
|
if(GCC)
|
||||||
|
if(QT_64BIT)
|
||||||
|
set(QT_DEFAULT_MKSPEC solaris-g++-64)
|
||||||
|
else()
|
||||||
|
set(QT_DEFAULT_MKSPEC solaris-g++)
|
||||||
|
endif()
|
||||||
|
else()
|
||||||
|
if(QT_64BIT)
|
||||||
|
set(QT_DEFAULT_MKSPEC solaris-cc-64)
|
||||||
|
else()
|
||||||
|
set(QT_DEFAULT_MKSPEC solaris-cc)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(NOT QT_QMAKE_TARGET_MKSPEC)
|
if(NOT QT_QMAKE_TARGET_MKSPEC)
|
||||||
|
@ -17,6 +17,7 @@ qt_set01(OPENBSD CMAKE_SYSTEM_NAME STREQUAL "OpenBSD") # FIXME: How to identify
|
|||||||
qt_set01(FREEBSD CMAKE_SYSTEM_NAME STREQUAL "FreeBSD") # FIXME: How to identify this?
|
qt_set01(FREEBSD CMAKE_SYSTEM_NAME STREQUAL "FreeBSD") # FIXME: How to identify this?
|
||||||
qt_set01(NETBSD CMAKE_SYSTEM_NAME STREQUAL "NetBSD") # FIXME: How to identify this?
|
qt_set01(NETBSD CMAKE_SYSTEM_NAME STREQUAL "NetBSD") # FIXME: How to identify this?
|
||||||
qt_set01(WASM CMAKE_SYSTEM_NAME STREQUAL "Emscripten" OR EMSCRIPTEN)
|
qt_set01(WASM CMAKE_SYSTEM_NAME STREQUAL "Emscripten" OR EMSCRIPTEN)
|
||||||
|
qt_set01(SOLARIS CMAKE_SYSTEM_NAME STREQUAL "SunOS")
|
||||||
|
|
||||||
qt_set01(BSD APPLE OR OPENBSD OR FREEBSD OR NETBSD)
|
qt_set01(BSD APPLE OR OPENBSD OR FREEBSD OR NETBSD)
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ function(qt_compute_relative_rpath_base rpath install_location out_var)
|
|||||||
# needed in the .prf files, but for CMake we need to prepend them ourselves.
|
# needed in the .prf files, but for CMake we need to prepend them ourselves.
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
set(rpath_rel_base "@loader_path")
|
set(rpath_rel_base "@loader_path")
|
||||||
elseif(LINUX)
|
elseif(LINUX OR SOLARIS)
|
||||||
set(rpath_rel_base "$ORIGIN")
|
set(rpath_rel_base "$ORIGIN")
|
||||||
else()
|
else()
|
||||||
message(WARNING "No known RPATH_REL_BASE for target platform.")
|
message(WARNING "No known RPATH_REL_BASE for target platform.")
|
||||||
|
@ -143,7 +143,7 @@ qt_config_linker_supports_flag_test(gdb_index
|
|||||||
qt_config_compile_test(reduce_relocations
|
qt_config_compile_test(reduce_relocations
|
||||||
LABEL "-Bsymbolic-functions support"
|
LABEL "-Bsymbolic-functions support"
|
||||||
CODE
|
CODE
|
||||||
"#if !(defined(__i386) || defined(__i386__) || defined(__x86_64) || defined(__x86_64__) || defined(__amd64))
|
"#if !(defined(__i386) || defined(__i386__) || defined(__x86_64) || defined(__x86_64__) || defined(__amd64)) || defined (__sun)
|
||||||
# error Symbolic function binding on this architecture may be broken, disabling it (see QTBUG-36129).
|
# error Symbolic function binding on this architecture may be broken, disabling it (see QTBUG-36129).
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -451,7 +451,7 @@
|
|||||||
"type": "compile",
|
"type": "compile",
|
||||||
"test": {
|
"test": {
|
||||||
"head": [
|
"head": [
|
||||||
"#if !(defined(__i386) || defined(__i386__) || defined(__x86_64) || defined(__x86_64__) || defined(__amd64))",
|
"#if !(defined(__i386) || defined(__i386__) || defined(__x86_64) || defined(__x86_64__) || defined(__amd64)) || defined(__sun)",
|
||||||
"# error Symbolic function binding on this architecture may be broken, disabling it (see QTBUG-36129).",
|
"# error Symbolic function binding on this architecture may be broken, disabling it (see QTBUG-36129).",
|
||||||
"#endif"
|
"#endif"
|
||||||
],
|
],
|
||||||
|
@ -84,7 +84,11 @@
|
|||||||
#define QT_FEATURE_datetimeparser -1
|
#define QT_FEATURE_datetimeparser -1
|
||||||
#define QT_FEATURE_easingcurve -1
|
#define QT_FEATURE_easingcurve -1
|
||||||
#define QT_FEATURE_etw -1
|
#define QT_FEATURE_etw -1
|
||||||
|
#if defined(__linux__) || defined(__GLIBC__)
|
||||||
#define QT_FEATURE_getauxval (__has_include(<sys/auxv.h>) ? 1 : -1)
|
#define QT_FEATURE_getauxval (__has_include(<sys/auxv.h>) ? 1 : -1)
|
||||||
|
#else
|
||||||
|
#define QT_FEATURE_getauxval -1
|
||||||
|
#endif
|
||||||
#define QT_FEATURE_getentropy -1
|
#define QT_FEATURE_getentropy -1
|
||||||
#define QT_NO_GEOM_VARIANT
|
#define QT_NO_GEOM_VARIANT
|
||||||
#define QT_FEATURE_hijricalendar -1
|
#define QT_FEATURE_hijricalendar -1
|
||||||
|
@ -25,7 +25,7 @@ set_property(CACHE INPUT_libpng PROPERTY STRINGS undefined no qt system)
|
|||||||
|
|
||||||
|
|
||||||
#### Libraries
|
#### Libraries
|
||||||
qt_set01(X11_SUPPORTED LINUX OR HPUX OR FREEBSD OR NETBSD OR OPENBSD) # special case
|
qt_set01(X11_SUPPORTED LINUX OR HPUX OR FREEBSD OR NETBSD OR OPENBSD OR SOLARIS) # special case
|
||||||
qt_find_package(ATSPI2 PROVIDED_TARGETS PkgConfig::ATSPI2 MODULE_NAME gui QMAKE_LIB atspi)
|
qt_find_package(ATSPI2 PROVIDED_TARGETS PkgConfig::ATSPI2 MODULE_NAME gui QMAKE_LIB atspi)
|
||||||
qt_find_package(DirectFB PROVIDED_TARGETS PkgConfig::DirectFB MODULE_NAME gui QMAKE_LIB directfb)
|
qt_find_package(DirectFB PROVIDED_TARGETS PkgConfig::DirectFB MODULE_NAME gui QMAKE_LIB directfb)
|
||||||
qt_find_package(Libdrm PROVIDED_TARGETS Libdrm::Libdrm MODULE_NAME gui QMAKE_LIB drm)
|
qt_find_package(Libdrm PROVIDED_TARGETS Libdrm::Libdrm MODULE_NAME gui QMAKE_LIB drm)
|
||||||
|
@ -427,6 +427,8 @@ qt_internal_extend_target(Network CONDITION WIN32 PUBLIC_LIBRARIES ws2_32) # spe
|
|||||||
|
|
||||||
qt_internal_extend_target(Network CONDITION QNX PUBLIC_LIBRARIES socket) # special case: mkspecs/common/qcc-base-qnx.conf
|
qt_internal_extend_target(Network CONDITION QNX PUBLIC_LIBRARIES socket) # special case: mkspecs/common/qcc-base-qnx.conf
|
||||||
|
|
||||||
|
qt_internal_extend_target(Network CONDITION SOLARIS PUBLIC_LIBRARIES socket nsl) # special case
|
||||||
|
|
||||||
# include the snippet projects for developer-builds
|
# include the snippet projects for developer-builds
|
||||||
if(QT_FEATURE_private_tests)
|
if(QT_FEATURE_private_tests)
|
||||||
add_subdirectory(doc/snippets/network)
|
add_subdirectory(doc/snippets/network)
|
||||||
|
@ -81,6 +81,22 @@ freeifaddrs(list);
|
|||||||
"# FIXME: use: unmapped library: network
|
"# FIXME: use: unmapped library: network
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# ifr_index
|
||||||
|
qt_config_compile_test(ifr_index
|
||||||
|
LABEL "ifr_index"
|
||||||
|
CODE
|
||||||
|
"#include <net/if.h>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
/* BEGIN TEST: */
|
||||||
|
struct ifreq req;
|
||||||
|
req.ifr_index = 0;
|
||||||
|
/* END TEST: */
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
")
|
||||||
|
|
||||||
# ipv6ifname
|
# ipv6ifname
|
||||||
qt_config_compile_test(ipv6ifname
|
qt_config_compile_test(ipv6ifname
|
||||||
LABEL "IPv6 ifname"
|
LABEL "IPv6 ifname"
|
||||||
@ -220,6 +236,10 @@ qt_feature("getifaddrs" PUBLIC
|
|||||||
CONDITION TEST_getifaddrs
|
CONDITION TEST_getifaddrs
|
||||||
)
|
)
|
||||||
qt_feature_definition("getifaddrs" "QT_NO_GETIFADDRS" NEGATE VALUE "1")
|
qt_feature_definition("getifaddrs" "QT_NO_GETIFADDRS" NEGATE VALUE "1")
|
||||||
|
qt_feature("ifr_index" PRIVATE
|
||||||
|
LABEL "ifr_index"
|
||||||
|
CONDITION TEST_ifr_index
|
||||||
|
)
|
||||||
qt_feature("ipv6ifname" PUBLIC
|
qt_feature("ipv6ifname" PUBLIC
|
||||||
LABEL "IPv6 ifname"
|
LABEL "IPv6 ifname"
|
||||||
CONDITION TEST_ipv6ifname
|
CONDITION TEST_ipv6ifname
|
||||||
|
@ -142,6 +142,17 @@
|
|||||||
},
|
},
|
||||||
"use": "network"
|
"use": "network"
|
||||||
},
|
},
|
||||||
|
"ifr_index": {
|
||||||
|
"label": "ifr_index",
|
||||||
|
"type": "compile",
|
||||||
|
"test": {
|
||||||
|
"include": "net/if.h",
|
||||||
|
"main": [
|
||||||
|
"struct ifreq req;",
|
||||||
|
"req.ifr_index = 0;"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
"ipv6ifname": {
|
"ipv6ifname": {
|
||||||
"label": "IPv6 ifname",
|
"label": "IPv6 ifname",
|
||||||
"type": "compile",
|
"type": "compile",
|
||||||
@ -238,6 +249,11 @@
|
|||||||
"condition": "tests.getifaddrs",
|
"condition": "tests.getifaddrs",
|
||||||
"output": [ "feature" ]
|
"output": [ "feature" ]
|
||||||
},
|
},
|
||||||
|
"ifr_index": {
|
||||||
|
"label": "ifr_index",
|
||||||
|
"condition": "tests.ifr_index",
|
||||||
|
"output": [ "privateFeature" ]
|
||||||
|
},
|
||||||
"ipv6ifname": {
|
"ipv6ifname": {
|
||||||
"label": "IPv6 ifname",
|
"label": "IPv6 ifname",
|
||||||
"condition": "tests.ipv6ifname",
|
"condition": "tests.ipv6ifname",
|
||||||
|
@ -111,7 +111,11 @@ uint QNetworkInterfaceManager::interfaceIndexFromName(const QString &name)
|
|||||||
|
|
||||||
uint id = 0;
|
uint id = 0;
|
||||||
if (qt_safe_ioctl(socket, SIOCGIFINDEX, &req) >= 0)
|
if (qt_safe_ioctl(socket, SIOCGIFINDEX, &req) >= 0)
|
||||||
|
# if QT_CONFIG(ifr_index)
|
||||||
|
id = req.ifr_index;
|
||||||
|
# else
|
||||||
id = req.ifr_ifindex;
|
id = req.ifr_ifindex;
|
||||||
|
# endif
|
||||||
qt_safe_close(socket);
|
qt_safe_close(socket);
|
||||||
return id;
|
return id;
|
||||||
#else
|
#else
|
||||||
@ -130,7 +134,11 @@ QString QNetworkInterfaceManager::interfaceNameFromIndex(uint index)
|
|||||||
int socket = qt_safe_socket(AF_INET, SOCK_STREAM, 0);
|
int socket = qt_safe_socket(AF_INET, SOCK_STREAM, 0);
|
||||||
if (socket >= 0) {
|
if (socket >= 0) {
|
||||||
memset(&req, 0, sizeof(ifreq));
|
memset(&req, 0, sizeof(ifreq));
|
||||||
|
# if QT_CONFIG(ifr_index)
|
||||||
|
req.ifr_index = index;
|
||||||
|
# else
|
||||||
req.ifr_ifindex = index;
|
req.ifr_ifindex = index;
|
||||||
|
# endif
|
||||||
|
|
||||||
if (qt_safe_ioctl(socket, SIOCGIFNAME, &req) >= 0) {
|
if (qt_safe_ioctl(socket, SIOCGIFNAME, &req) >= 0) {
|
||||||
qt_safe_close(socket);
|
qt_safe_close(socket);
|
||||||
@ -216,7 +224,7 @@ static QNetworkInterfacePrivate *findInterface(int socket, QList<QNetworkInterfa
|
|||||||
// Get the interface index
|
// Get the interface index
|
||||||
# ifdef SIOCGIFINDEX
|
# ifdef SIOCGIFINDEX
|
||||||
if (qt_safe_ioctl(socket, SIOCGIFINDEX, &req) >= 0)
|
if (qt_safe_ioctl(socket, SIOCGIFINDEX, &req) >= 0)
|
||||||
# if defined(Q_OS_HAIKU)
|
# if QT_CONFIG(ifr_index)
|
||||||
ifindex = req.ifr_index;
|
ifindex = req.ifr_index;
|
||||||
# else
|
# else
|
||||||
ifindex = req.ifr_ifindex;
|
ifindex = req.ifr_ifindex;
|
||||||
|
@ -783,7 +783,11 @@ QNetworkInterface QNativeSocketEnginePrivate::nativeMulticastInterface() const
|
|||||||
return QNetworkInterface::interfaceFromIndex(v);
|
return QNetworkInterface::interfaceFromIndex(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(Q_OS_SOLARIS)
|
||||||
|
struct in_addr v = { 0, 0, 0, 0};
|
||||||
|
#else
|
||||||
struct in_addr v = { 0 };
|
struct in_addr v = { 0 };
|
||||||
|
#endif
|
||||||
QT_SOCKOPTLEN_T sizeofv = sizeof(v);
|
QT_SOCKOPTLEN_T sizeofv = sizeof(v);
|
||||||
if (::getsockopt(socketDescriptor, IPPROTO_IP, IP_MULTICAST_IF, &v, &sizeofv) == -1)
|
if (::getsockopt(socketDescriptor, IPPROTO_IP, IP_MULTICAST_IF, &v, &sizeofv) == -1)
|
||||||
return QNetworkInterface();
|
return QNetworkInterface();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user