Always assume IPv6 support
It's 2011 baby! And until Qt5 is released probably 2012 :-) Change-Id: I397aabf25e93c8afb5f562636710985cf0c7acfa Reviewed-on: http://codereview.qt.nokia.com/1008 Reviewed-by: Qt Sanity Bot <qt_sanity_bot@ovi.com> Reviewed-by: Shane Kearns <shane.kearns@accenture.com> Reviewed-by: Martin Petersson <Martin.Petersson@nokia.com> Reviewed-by: Markus Goetz
This commit is contained in:
parent
3d5d8b6c4f
commit
85869920bb
30
configure
vendored
30
configure
vendored
@ -778,7 +778,6 @@ CFG_SSE4_1=auto
|
|||||||
CFG_SSE4_2=auto
|
CFG_SSE4_2=auto
|
||||||
CFG_AVX=auto
|
CFG_AVX=auto
|
||||||
CFG_REDUCE_RELOCATIONS=no
|
CFG_REDUCE_RELOCATIONS=no
|
||||||
CFG_IPV6=auto
|
|
||||||
CFG_NAS=no
|
CFG_NAS=no
|
||||||
CFG_QWS_DEPTHS=all
|
CFG_QWS_DEPTHS=all
|
||||||
CFG_USER_BUILD_KEY=
|
CFG_USER_BUILD_KEY=
|
||||||
@ -3691,10 +3690,6 @@ if [ "$OPT_HELP" = "yes" ]; then
|
|||||||
SHY=" "
|
SHY=" "
|
||||||
SHN="*"
|
SHN="*"
|
||||||
fi
|
fi
|
||||||
if [ "$CFG_IPV6" = "auto" ]; then
|
|
||||||
I6Y="*"
|
|
||||||
I6N=" "
|
|
||||||
fi
|
|
||||||
if [ "$CFG_PRECOMPILE" = "auto" ] || [ "$CFG_PRECOMPILE" = "no" ]; then
|
if [ "$CFG_PRECOMPILE" = "auto" ] || [ "$CFG_PRECOMPILE" = "no" ]; then
|
||||||
PHY=" "
|
PHY=" "
|
||||||
PHN="*"
|
PHN="*"
|
||||||
@ -6598,26 +6593,6 @@ if [ "$CFG_STL" != "no" ]; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# find if the platform supports IPv6
|
|
||||||
if [ "$CFG_IPV6" != "no" ]; then
|
|
||||||
if [ "$XPLATFORM_SYMBIAN" = "yes" ]; then
|
|
||||||
#IPV6 should always be enabled for Symbian release
|
|
||||||
CFG_IPV6=yes
|
|
||||||
elif "$unixtests/compile.test" "$XQMAKESPEC" "$QMAKE_CONFIG" $OPT_VERBOSE "$relpath" "$outpath" config.tests/unix/ipv6 "IPv6" $L_FLAGS $I_FLAGS $l_FLAGS $MAC_CONFIG_TEST_COMMANDLINE; then
|
|
||||||
CFG_IPV6=yes
|
|
||||||
else
|
|
||||||
if [ "$CFG_IPV6" = "yes" ] && [ "$CFG_CONFIGURE_EXIT_ON_ERROR" = "yes" ]; then
|
|
||||||
echo "IPv6 support cannot be enabled due to functionality tests!"
|
|
||||||
echo " Turn on verbose messaging (-v) to $0 to see the final report."
|
|
||||||
echo " If you believe this message is in error you may use the continue"
|
|
||||||
echo " switch (-continue) to $0 to continue."
|
|
||||||
exit 101
|
|
||||||
else
|
|
||||||
CFG_IPV6=no
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# detect POSIX clock_gettime()
|
# detect POSIX clock_gettime()
|
||||||
if [ "$CFG_CLOCK_GETTIME" = "auto" ]; then
|
if [ "$CFG_CLOCK_GETTIME" = "auto" ]; then
|
||||||
if "$unixtests/compile.test" "$XQMAKESPEC" "$QMAKE_CONFIG" $OPT_VERBOSE "$relpath" "$outpath" config.tests/unix/clock-gettime "POSIX clock_gettime()" $L_FLAGS $I_FLAGS $l_FLAGS; then
|
if "$unixtests/compile.test" "$XQMAKESPEC" "$QMAKE_CONFIG" $OPT_VERBOSE "$relpath" "$outpath" config.tests/unix/clock-gettime "POSIX clock_gettime()" $L_FLAGS $I_FLAGS $l_FLAGS; then
|
||||||
@ -7155,9 +7130,6 @@ fi
|
|||||||
[ "$CFG_IWMMXT" = "yes" ] && QMAKE_CONFIG="$QMAKE_CONFIG iwmmxt"
|
[ "$CFG_IWMMXT" = "yes" ] && QMAKE_CONFIG="$QMAKE_CONFIG iwmmxt"
|
||||||
[ "$CFG_NEON" = "yes" ] && QMAKE_CONFIG="$QMAKE_CONFIG neon"
|
[ "$CFG_NEON" = "yes" ] && QMAKE_CONFIG="$QMAKE_CONFIG neon"
|
||||||
[ "$PLATFORM_MAC" = "yes" ] && QMAKE_CONFIG="$QMAKE_CONFIG $CFG_MAC_ARCHS"
|
[ "$PLATFORM_MAC" = "yes" ] && QMAKE_CONFIG="$QMAKE_CONFIG $CFG_MAC_ARCHS"
|
||||||
if [ "$CFG_IPV6" = "yes" ]; then
|
|
||||||
QT_CONFIG="$QT_CONFIG ipv6"
|
|
||||||
fi
|
|
||||||
if [ "$CFG_CLOCK_GETTIME" = "yes" ]; then
|
if [ "$CFG_CLOCK_GETTIME" = "yes" ]; then
|
||||||
QT_CONFIG="$QT_CONFIG clock-gettime"
|
QT_CONFIG="$QT_CONFIG clock-gettime"
|
||||||
fi
|
fi
|
||||||
@ -8203,7 +8175,6 @@ QMakeVar set sql-plugins "$SQL_PLUGINS"
|
|||||||
[ "$CFG_ZLIB" != "yes" ] && QCONFIG_FLAGS="$QCONFIG_FLAGS QT_NO_ZLIB"
|
[ "$CFG_ZLIB" != "yes" ] && QCONFIG_FLAGS="$QCONFIG_FLAGS QT_NO_ZLIB"
|
||||||
[ "$CFG_S60" != "yes" ] && QCONFIG_FLAGS="$QCONFIG_FLAGS QT_NO_S60"
|
[ "$CFG_S60" != "yes" ] && QCONFIG_FLAGS="$QCONFIG_FLAGS QT_NO_S60"
|
||||||
[ "$CFG_EXCEPTIONS" = "no" ] && QCONFIG_FLAGS="$QCONFIG_FLAGS QT_NO_EXCEPTIONS"
|
[ "$CFG_EXCEPTIONS" = "no" ] && QCONFIG_FLAGS="$QCONFIG_FLAGS QT_NO_EXCEPTIONS"
|
||||||
[ "$CFG_IPV6" = "no" ] && QCONFIG_FLAGS="$QCONFIG_FLAGS QT_NO_IPV6"
|
|
||||||
[ "$CFG_SXE" = "no" ] && QCONFIG_FLAGS="$QCONFIG_FLAGS QT_NO_SXE"
|
[ "$CFG_SXE" = "no" ] && QCONFIG_FLAGS="$QCONFIG_FLAGS QT_NO_SXE"
|
||||||
[ "$CFG_DBUS" = "no" ] && QCONFIG_FLAGS="$QCONFIG_FLAGS QT_NO_DBUS"
|
[ "$CFG_DBUS" = "no" ] && QCONFIG_FLAGS="$QCONFIG_FLAGS QT_NO_DBUS"
|
||||||
|
|
||||||
@ -8716,7 +8687,6 @@ if [ "$CFG_ARCH" = "arm" ] || [ "$CFG_ARCH" = "armv6" ]; then
|
|||||||
echo "NEON support ........... ${CFG_NEON}"
|
echo "NEON support ........... ${CFG_NEON}"
|
||||||
fi
|
fi
|
||||||
[ "${PLATFORM_QWS}" != "yes" -a "${PLATFORM_QPA}" != "yes" ] && echo "Graphics System ........ $CFG_GRAPHICS_SYSTEM"
|
[ "${PLATFORM_QWS}" != "yes" -a "${PLATFORM_QPA}" != "yes" ] && echo "Graphics System ........ $CFG_GRAPHICS_SYSTEM"
|
||||||
echo "IPv6 support ........... $CFG_IPV6"
|
|
||||||
echo "IPv6 ifname support .... $CFG_IPV6IFNAME"
|
echo "IPv6 ifname support .... $CFG_IPV6IFNAME"
|
||||||
echo "getaddrinfo support .... $CFG_GETADDRINFO"
|
echo "getaddrinfo support .... $CFG_GETADDRINFO"
|
||||||
echo "getifaddrs support ..... $CFG_GETIFADDRS"
|
echo "getifaddrs support ..... $CFG_GETIFADDRS"
|
||||||
|
@ -65,7 +65,6 @@ QT_BEGIN_NAMESPACE
|
|||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
# if !defined (QT_NO_IPV6)
|
|
||||||
// sockaddr_in6 size changed between old and new SDK
|
// sockaddr_in6 size changed between old and new SDK
|
||||||
// Only the new version is the correct one, so always
|
// Only the new version is the correct one, so always
|
||||||
// use this structure.
|
// use this structure.
|
||||||
@ -91,12 +90,6 @@ typedef struct {
|
|||||||
u_long sin6_scope_id; /* set of interfaces for a scope */
|
u_long sin6_scope_id; /* set of interfaces for a scope */
|
||||||
} qt_sockaddr_in6;
|
} qt_sockaddr_in6;
|
||||||
#else
|
#else
|
||||||
typedef void * qt_sockaddr_in6 ;
|
|
||||||
# endif
|
|
||||||
# ifndef AF_INET6
|
|
||||||
# define AF_INET6 23 /* Internetwork Version 6 */
|
|
||||||
# endif
|
|
||||||
#else
|
|
||||||
#define qt_sockaddr_in6 sockaddr_in6
|
#define qt_sockaddr_in6 sockaddr_in6
|
||||||
#define qt_s6_addr s6_addr
|
#define qt_s6_addr s6_addr
|
||||||
#endif
|
#endif
|
||||||
@ -545,10 +538,8 @@ QHostAddress::QHostAddress(const struct sockaddr *sockaddr)
|
|||||||
{
|
{
|
||||||
if (sockaddr->sa_family == AF_INET)
|
if (sockaddr->sa_family == AF_INET)
|
||||||
setAddress(htonl(((sockaddr_in *)sockaddr)->sin_addr.s_addr));
|
setAddress(htonl(((sockaddr_in *)sockaddr)->sin_addr.s_addr));
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
else if (sockaddr->sa_family == AF_INET6)
|
else if (sockaddr->sa_family == AF_INET6)
|
||||||
setAddress(((qt_sockaddr_in6 *)sockaddr)->sin6_addr.qt_s6_addr);
|
setAddress(((qt_sockaddr_in6 *)sockaddr)->sin6_addr.qt_s6_addr);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -700,10 +691,8 @@ void QHostAddress::setAddress(const struct sockaddr *sockaddr)
|
|||||||
clear();
|
clear();
|
||||||
if (sockaddr->sa_family == AF_INET)
|
if (sockaddr->sa_family == AF_INET)
|
||||||
setAddress(htonl(((sockaddr_in *)sockaddr)->sin_addr.s_addr));
|
setAddress(htonl(((sockaddr_in *)sockaddr)->sin_addr.s_addr));
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
else if (sockaddr->sa_family == AF_INET6)
|
else if (sockaddr->sa_family == AF_INET6)
|
||||||
setAddress(((qt_sockaddr_in6 *)sockaddr)->sin6_addr.qt_s6_addr);
|
setAddress(((qt_sockaddr_in6 *)sockaddr)->sin6_addr.qt_s6_addr);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -149,9 +149,7 @@ QHostInfo QHostInfoAgent::fromName(const QString &hostName)
|
|||||||
// Reverse lookups using getnameinfo are broken on darwin, use gethostbyaddr instead.
|
// Reverse lookups using getnameinfo are broken on darwin, use gethostbyaddr instead.
|
||||||
#if !defined (QT_NO_GETADDRINFO) && !defined (Q_OS_DARWIN)
|
#if !defined (QT_NO_GETADDRINFO) && !defined (Q_OS_DARWIN)
|
||||||
sockaddr_in sa4;
|
sockaddr_in sa4;
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
sockaddr_in6 sa6;
|
sockaddr_in6 sa6;
|
||||||
#endif
|
|
||||||
sockaddr *sa = 0;
|
sockaddr *sa = 0;
|
||||||
QT_SOCKLEN_T saSize = 0;
|
QT_SOCKLEN_T saSize = 0;
|
||||||
if (address.protocol() == QAbstractSocket::IPv4Protocol) {
|
if (address.protocol() == QAbstractSocket::IPv4Protocol) {
|
||||||
@ -161,7 +159,6 @@ QHostInfo QHostInfoAgent::fromName(const QString &hostName)
|
|||||||
sa4.sin_family = AF_INET;
|
sa4.sin_family = AF_INET;
|
||||||
sa4.sin_addr.s_addr = htonl(address.toIPv4Address());
|
sa4.sin_addr.s_addr = htonl(address.toIPv4Address());
|
||||||
}
|
}
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
else {
|
else {
|
||||||
sa = (sockaddr *)&sa6;
|
sa = (sockaddr *)&sa6;
|
||||||
saSize = sizeof(sa6);
|
saSize = sizeof(sa6);
|
||||||
@ -169,7 +166,6 @@ QHostInfo QHostInfoAgent::fromName(const QString &hostName)
|
|||||||
sa6.sin6_family = AF_INET6;
|
sa6.sin6_family = AF_INET6;
|
||||||
memcpy(sa6.sin6_addr.s6_addr, address.toIPv6Address().c, sizeof(sa6.sin6_addr.s6_addr));
|
memcpy(sa6.sin6_addr.s6_addr, address.toIPv6Address().c, sizeof(sa6.sin6_addr.s6_addr));
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
char hbuf[NI_MAXHOST];
|
char hbuf[NI_MAXHOST];
|
||||||
if (sa && getnameinfo(sa, saSize, hbuf, sizeof(hbuf), 0, 0, 0) == 0)
|
if (sa && getnameinfo(sa, saSize, hbuf, sizeof(hbuf), 0, 0, 0) == 0)
|
||||||
@ -231,7 +227,6 @@ QHostInfo QHostInfoAgent::fromName(const QString &hostName)
|
|||||||
if (!addresses.contains(addr))
|
if (!addresses.contains(addr))
|
||||||
addresses.append(addr);
|
addresses.append(addr);
|
||||||
}
|
}
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
else if (node->ai_family == AF_INET6) {
|
else if (node->ai_family == AF_INET6) {
|
||||||
QHostAddress addr;
|
QHostAddress addr;
|
||||||
sockaddr_in6 *sa6 = (sockaddr_in6 *) node->ai_addr;
|
sockaddr_in6 *sa6 = (sockaddr_in6 *) node->ai_addr;
|
||||||
@ -241,7 +236,6 @@ QHostInfo QHostInfoAgent::fromName(const QString &hostName)
|
|||||||
if (!addresses.contains(addr))
|
if (!addresses.contains(addr))
|
||||||
addresses.append(addr);
|
addresses.append(addr);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
node = node->ai_next;
|
node = node->ai_next;
|
||||||
}
|
}
|
||||||
if (addresses.isEmpty() && node == 0) {
|
if (addresses.isEmpty() && node == 0) {
|
||||||
|
@ -80,10 +80,9 @@ static QHostAddress addressFromSockaddr(sockaddr *sa)
|
|||||||
|
|
||||||
if (sa->sa_family == AF_INET)
|
if (sa->sa_family == AF_INET)
|
||||||
address.setAddress(htonl(((sockaddr_in *)sa)->sin_addr.s_addr));
|
address.setAddress(htonl(((sockaddr_in *)sa)->sin_addr.s_addr));
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
else if (sa->sa_family == AF_INET6)
|
else if (sa->sa_family == AF_INET6)
|
||||||
address.setAddress(((sockaddr_in6 *)sa)->sin6_addr.s6_addr);
|
address.setAddress(((sockaddr_in6 *)sa)->sin6_addr.s6_addr);
|
||||||
#endif
|
|
||||||
return address;
|
return address;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1003,17 +1003,6 @@ void QAbstractSocketPrivate::_q_connectToNextAddress()
|
|||||||
host.toString().toLatin1().constData(), port, addresses.count());
|
host.toString().toLatin1().constData(), port, addresses.count());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(QT_NO_IPV6)
|
|
||||||
if (host.protocol() == QAbstractSocket::IPv6Protocol) {
|
|
||||||
// If we have no IPv6 support, then we will not be able to
|
|
||||||
// connect. So we just pretend we didn't see this address.
|
|
||||||
#if defined(QABSTRACTSOCKET_DEBUG)
|
|
||||||
qDebug("QAbstractSocketPrivate::_q_connectToNextAddress(), skipping IPv6 entry");
|
|
||||||
#endif
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (!initSocketLayer(host.protocol())) {
|
if (!initSocketLayer(host.protocol())) {
|
||||||
// hope that the next address is better
|
// hope that the next address is better
|
||||||
#if defined(QABSTRACTSOCKET_DEBUG)
|
#if defined(QABSTRACTSOCKET_DEBUG)
|
||||||
|
@ -203,6 +203,7 @@ void QNativeSocketEnginePrivate::setError(QAbstractSocket::SocketError error, Er
|
|||||||
case BroadcastingInitFailedErrorString:
|
case BroadcastingInitFailedErrorString:
|
||||||
socketErrorString = QNativeSocketEngine::tr("Unable to initialize broadcast socket");
|
socketErrorString = QNativeSocketEngine::tr("Unable to initialize broadcast socket");
|
||||||
break;
|
break;
|
||||||
|
// should not happen anymore
|
||||||
case NoIpV6ErrorString:
|
case NoIpV6ErrorString:
|
||||||
socketErrorString = QNativeSocketEngine::tr("Attempt to use IPv6 socket on a platform with no IPv6 support");
|
socketErrorString = QNativeSocketEngine::tr("Attempt to use IPv6 socket on a platform with no IPv6 support");
|
||||||
break;
|
break;
|
||||||
@ -345,14 +346,6 @@ bool QNativeSocketEngine::initialize(QAbstractSocket::SocketType socketType, QAb
|
|||||||
if (isValid())
|
if (isValid())
|
||||||
close();
|
close();
|
||||||
|
|
||||||
#if defined(QT_NO_IPV6)
|
|
||||||
if (protocol == QAbstractSocket::IPv6Protocol) {
|
|
||||||
d->setError(QAbstractSocket::UnsupportedSocketOperationError,
|
|
||||||
QNativeSocketEnginePrivate::NoIpV6ErrorString);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Create the socket
|
// Create the socket
|
||||||
if (!d->createNewSocket(socketType, protocol)) {
|
if (!d->createNewSocket(socketType, protocol)) {
|
||||||
#if defined (QNATIVESOCKETENGINE_DEBUG)
|
#if defined (QNATIVESOCKETENGINE_DEBUG)
|
||||||
@ -511,13 +504,6 @@ bool QNativeSocketEngine::connectToHost(const QHostAddress &address, quint16 por
|
|||||||
Q_D(QNativeSocketEngine);
|
Q_D(QNativeSocketEngine);
|
||||||
Q_CHECK_VALID_SOCKETLAYER(QNativeSocketEngine::connectToHost(), false);
|
Q_CHECK_VALID_SOCKETLAYER(QNativeSocketEngine::connectToHost(), false);
|
||||||
|
|
||||||
#if defined (QT_NO_IPV6)
|
|
||||||
if (address.protocol() == QAbstractSocket::IPv6Protocol) {
|
|
||||||
d->setError(QAbstractSocket::UnsupportedSocketOperationError,
|
|
||||||
QNativeSocketEnginePrivate::NoIpV6ErrorString);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!d->checkProxy(address))
|
if (!d->checkProxy(address))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
@ -581,13 +567,6 @@ bool QNativeSocketEngine::bind(const QHostAddress &address, quint16 port)
|
|||||||
Q_D(QNativeSocketEngine);
|
Q_D(QNativeSocketEngine);
|
||||||
Q_CHECK_VALID_SOCKETLAYER(QNativeSocketEngine::bind(), false);
|
Q_CHECK_VALID_SOCKETLAYER(QNativeSocketEngine::bind(), false);
|
||||||
|
|
||||||
#if defined (QT_NO_IPV6)
|
|
||||||
if (address.protocol() == QAbstractSocket::IPv6Protocol) {
|
|
||||||
d->setError(QAbstractSocket::UnsupportedSocketOperationError,
|
|
||||||
QNativeSocketEnginePrivate::NoIpV6ErrorString);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!d->checkProxy(address))
|
if (!d->checkProxy(address))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
@ -124,7 +124,6 @@ static void qt_ignore_sigpipe()
|
|||||||
*/
|
*/
|
||||||
static inline void qt_socket_getPortAndAddress(const qt_sockaddr *s, quint16 *port, QHostAddress *addr)
|
static inline void qt_socket_getPortAndAddress(const qt_sockaddr *s, quint16 *port, QHostAddress *addr)
|
||||||
{
|
{
|
||||||
#if !defined(QT_NO_IPV6)
|
|
||||||
if (s->a.sa_family == AF_INET6) {
|
if (s->a.sa_family == AF_INET6) {
|
||||||
Q_IPV6ADDR tmp;
|
Q_IPV6ADDR tmp;
|
||||||
memcpy(&tmp, &s->a6.sin6_addr, sizeof(tmp));
|
memcpy(&tmp, &s->a6.sin6_addr, sizeof(tmp));
|
||||||
@ -144,7 +143,7 @@ static inline void qt_socket_getPortAndAddress(const qt_sockaddr *s, quint16 *po
|
|||||||
*port = ntohs(s->a6.sin6_port);
|
*port = ntohs(s->a6.sin6_port);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
if (port)
|
if (port)
|
||||||
*port = ntohs(s->a4.sin_port);
|
*port = ntohs(s->a4.sin_port);
|
||||||
if (addr) {
|
if (addr) {
|
||||||
@ -162,12 +161,7 @@ static inline void qt_socket_getPortAndAddress(const qt_sockaddr *s, quint16 *po
|
|||||||
bool QNativeSocketEnginePrivate::createNewSocket(QAbstractSocket::SocketType socketType,
|
bool QNativeSocketEnginePrivate::createNewSocket(QAbstractSocket::SocketType socketType,
|
||||||
QAbstractSocket::NetworkLayerProtocol socketProtocol)
|
QAbstractSocket::NetworkLayerProtocol socketProtocol)
|
||||||
{
|
{
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
int protocol = (socketProtocol == QAbstractSocket::IPv6Protocol || socketProtocol == QAbstractSocket::AnyIPProtocol) ? AF_INET6 : AF_INET;
|
int protocol = (socketProtocol == QAbstractSocket::IPv6Protocol || socketProtocol == QAbstractSocket::AnyIPProtocol) ? AF_INET6 : AF_INET;
|
||||||
#else
|
|
||||||
Q_UNUSED(socketProtocol);
|
|
||||||
int protocol = AF_INET;
|
|
||||||
#endif
|
|
||||||
int type = (socketType == QAbstractSocket::UdpSocket) ? SOCK_DGRAM : SOCK_STREAM;
|
int type = (socketType == QAbstractSocket::UdpSocket) ? SOCK_DGRAM : SOCK_STREAM;
|
||||||
|
|
||||||
int socket = qt_safe_socket(protocol, type, 0);
|
int socket = qt_safe_socket(protocol, type, 0);
|
||||||
@ -238,24 +232,20 @@ int QNativeSocketEnginePrivate::option(QNativeSocketEngine::SocketOption opt) co
|
|||||||
n = SO_KEEPALIVE;
|
n = SO_KEEPALIVE;
|
||||||
break;
|
break;
|
||||||
case QNativeSocketEngine::MulticastTtlOption:
|
case QNativeSocketEngine::MulticastTtlOption:
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
level = IPPROTO_IPV6;
|
level = IPPROTO_IPV6;
|
||||||
n = IPV6_MULTICAST_HOPS;
|
n = IPV6_MULTICAST_HOPS;
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
level = IPPROTO_IP;
|
level = IPPROTO_IP;
|
||||||
n = IP_MULTICAST_TTL;
|
n = IP_MULTICAST_TTL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case QNativeSocketEngine::MulticastLoopbackOption:
|
case QNativeSocketEngine::MulticastLoopbackOption:
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
level = IPPROTO_IPV6;
|
level = IPPROTO_IPV6;
|
||||||
n = IPV6_MULTICAST_LOOP;
|
n = IPV6_MULTICAST_LOOP;
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
level = IPPROTO_IP;
|
level = IPPROTO_IP;
|
||||||
n = IP_MULTICAST_LOOP;
|
n = IP_MULTICAST_LOOP;
|
||||||
@ -343,24 +333,20 @@ bool QNativeSocketEnginePrivate::setOption(QNativeSocketEngine::SocketOption opt
|
|||||||
n = SO_KEEPALIVE;
|
n = SO_KEEPALIVE;
|
||||||
break;
|
break;
|
||||||
case QNativeSocketEngine::MulticastTtlOption:
|
case QNativeSocketEngine::MulticastTtlOption:
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
level = IPPROTO_IPV6;
|
level = IPPROTO_IPV6;
|
||||||
n = IPV6_MULTICAST_HOPS;
|
n = IPV6_MULTICAST_HOPS;
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
level = IPPROTO_IP;
|
level = IPPROTO_IP;
|
||||||
n = IP_MULTICAST_TTL;
|
n = IP_MULTICAST_TTL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case QNativeSocketEngine::MulticastLoopbackOption:
|
case QNativeSocketEngine::MulticastLoopbackOption:
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
level = IPPROTO_IPV6;
|
level = IPPROTO_IPV6;
|
||||||
n = IPV6_MULTICAST_LOOP;
|
n = IPV6_MULTICAST_LOOP;
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
level = IPPROTO_IP;
|
level = IPPROTO_IP;
|
||||||
n = IP_MULTICAST_LOOP;
|
n = IP_MULTICAST_LOOP;
|
||||||
@ -381,7 +367,6 @@ bool QNativeSocketEnginePrivate::nativeConnect(const QHostAddress &addr, quint16
|
|||||||
struct sockaddr *sockAddrPtr = 0;
|
struct sockaddr *sockAddrPtr = 0;
|
||||||
QT_SOCKLEN_T sockAddrSize = 0;
|
QT_SOCKLEN_T sockAddrSize = 0;
|
||||||
|
|
||||||
#if !defined(QT_NO_IPV6)
|
|
||||||
struct sockaddr_in6 sockAddrIPv6;
|
struct sockaddr_in6 sockAddrIPv6;
|
||||||
|
|
||||||
if (addr.protocol() == QAbstractSocket::IPv6Protocol) {
|
if (addr.protocol() == QAbstractSocket::IPv6Protocol) {
|
||||||
@ -402,10 +387,6 @@ bool QNativeSocketEnginePrivate::nativeConnect(const QHostAddress &addr, quint16
|
|||||||
sockAddrSize = sizeof(sockAddrIPv6);
|
sockAddrSize = sizeof(sockAddrIPv6);
|
||||||
sockAddrPtr = (struct sockaddr *) &sockAddrIPv6;
|
sockAddrPtr = (struct sockaddr *) &sockAddrIPv6;
|
||||||
} else
|
} else
|
||||||
#if 0
|
|
||||||
{}
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
if (addr.protocol() == QAbstractSocket::IPv4Protocol) {
|
if (addr.protocol() == QAbstractSocket::IPv4Protocol) {
|
||||||
memset(&sockAddrIPv4, 0, sizeof(sockAddrIPv4));
|
memset(&sockAddrIPv4, 0, sizeof(sockAddrIPv4));
|
||||||
sockAddrIPv4.sin_family = AF_INET;
|
sockAddrIPv4.sin_family = AF_INET;
|
||||||
@ -492,7 +473,7 @@ bool QNativeSocketEnginePrivate::nativeBind(const QHostAddress &address, quint16
|
|||||||
struct sockaddr *sockAddrPtr = 0;
|
struct sockaddr *sockAddrPtr = 0;
|
||||||
QT_SOCKLEN_T sockAddrSize = 0;
|
QT_SOCKLEN_T sockAddrSize = 0;
|
||||||
|
|
||||||
#if !defined(QT_NO_IPV6)
|
|
||||||
struct sockaddr_in6 sockAddrIPv6;
|
struct sockaddr_in6 sockAddrIPv6;
|
||||||
|
|
||||||
if (address.protocol() == QAbstractSocket::IPv6Protocol || address.protocol() == QAbstractSocket::AnyIPProtocol) {
|
if (address.protocol() == QAbstractSocket::IPv6Protocol || address.protocol() == QAbstractSocket::AnyIPProtocol) {
|
||||||
@ -516,7 +497,6 @@ bool QNativeSocketEnginePrivate::nativeBind(const QHostAddress &address, quint16
|
|||||||
sockAddrSize = sizeof(sockAddrIPv6);
|
sockAddrSize = sizeof(sockAddrIPv6);
|
||||||
sockAddrPtr = (struct sockaddr *) &sockAddrIPv6;
|
sockAddrPtr = (struct sockaddr *) &sockAddrIPv6;
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
if (address.protocol() == QAbstractSocket::IPv4Protocol) {
|
if (address.protocol() == QAbstractSocket::IPv4Protocol) {
|
||||||
memset(&sockAddrIPv4, 0, sizeof(sockAddrIPv4));
|
memset(&sockAddrIPv4, 0, sizeof(sockAddrIPv4));
|
||||||
sockAddrIPv4.sin_family = AF_INET;
|
sockAddrIPv4.sin_family = AF_INET;
|
||||||
@ -612,7 +592,6 @@ static bool multicastMembershipHelper(QNativeSocketEnginePrivate *d,
|
|||||||
int sockArgSize;
|
int sockArgSize;
|
||||||
|
|
||||||
ip_mreq mreq4;
|
ip_mreq mreq4;
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
ipv6_mreq mreq6;
|
ipv6_mreq mreq6;
|
||||||
|
|
||||||
if (groupAddress.protocol() == QAbstractSocket::IPv6Protocol) {
|
if (groupAddress.protocol() == QAbstractSocket::IPv6Protocol) {
|
||||||
@ -625,7 +604,6 @@ static bool multicastMembershipHelper(QNativeSocketEnginePrivate *d,
|
|||||||
memcpy(&mreq6.ipv6mr_multiaddr, &ip6, sizeof(ip6));
|
memcpy(&mreq6.ipv6mr_multiaddr, &ip6, sizeof(ip6));
|
||||||
mreq6.ipv6mr_interface = interface.index();
|
mreq6.ipv6mr_interface = interface.index();
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
if (groupAddress.protocol() == QAbstractSocket::IPv4Protocol) {
|
if (groupAddress.protocol() == QAbstractSocket::IPv4Protocol) {
|
||||||
level = IPPROTO_IP;
|
level = IPPROTO_IP;
|
||||||
sockOpt = how4;
|
sockOpt = how4;
|
||||||
@ -679,11 +657,7 @@ bool QNativeSocketEnginePrivate::nativeJoinMulticastGroup(const QHostAddress &gr
|
|||||||
const QNetworkInterface &interface)
|
const QNetworkInterface &interface)
|
||||||
{
|
{
|
||||||
return multicastMembershipHelper(this,
|
return multicastMembershipHelper(this,
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
IPV6_JOIN_GROUP,
|
IPV6_JOIN_GROUP,
|
||||||
#else
|
|
||||||
0,
|
|
||||||
#endif
|
|
||||||
IP_ADD_MEMBERSHIP,
|
IP_ADD_MEMBERSHIP,
|
||||||
groupAddress,
|
groupAddress,
|
||||||
interface);
|
interface);
|
||||||
@ -693,11 +667,7 @@ bool QNativeSocketEnginePrivate::nativeLeaveMulticastGroup(const QHostAddress &g
|
|||||||
const QNetworkInterface &interface)
|
const QNetworkInterface &interface)
|
||||||
{
|
{
|
||||||
return multicastMembershipHelper(this,
|
return multicastMembershipHelper(this,
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
IPV6_LEAVE_GROUP,
|
IPV6_LEAVE_GROUP,
|
||||||
#else
|
|
||||||
0,
|
|
||||||
#endif
|
|
||||||
IP_DROP_MEMBERSHIP,
|
IP_DROP_MEMBERSHIP,
|
||||||
groupAddress,
|
groupAddress,
|
||||||
interface);
|
interface);
|
||||||
@ -705,7 +675,6 @@ bool QNativeSocketEnginePrivate::nativeLeaveMulticastGroup(const QHostAddress &g
|
|||||||
|
|
||||||
QNetworkInterface QNativeSocketEnginePrivate::nativeMulticastInterface() const
|
QNetworkInterface QNativeSocketEnginePrivate::nativeMulticastInterface() const
|
||||||
{
|
{
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
uint v;
|
uint v;
|
||||||
QT_SOCKOPTLEN_T sizeofv = sizeof(v);
|
QT_SOCKOPTLEN_T sizeofv = sizeof(v);
|
||||||
@ -713,7 +682,6 @@ QNetworkInterface QNativeSocketEnginePrivate::nativeMulticastInterface() const
|
|||||||
return QNetworkInterface();
|
return QNetworkInterface();
|
||||||
return QNetworkInterface::interfaceFromIndex(v);
|
return QNetworkInterface::interfaceFromIndex(v);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
struct in_addr v = { 0 };
|
struct in_addr v = { 0 };
|
||||||
QT_SOCKOPTLEN_T sizeofv = sizeof(v);
|
QT_SOCKOPTLEN_T sizeofv = sizeof(v);
|
||||||
@ -737,12 +705,10 @@ QNetworkInterface QNativeSocketEnginePrivate::nativeMulticastInterface() const
|
|||||||
|
|
||||||
bool QNativeSocketEnginePrivate::nativeSetMulticastInterface(const QNetworkInterface &iface)
|
bool QNativeSocketEnginePrivate::nativeSetMulticastInterface(const QNetworkInterface &iface)
|
||||||
{
|
{
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
uint v = iface.index();
|
uint v = iface.index();
|
||||||
return (::setsockopt(socketDescriptor, IPPROTO_IPV6, IPV6_MULTICAST_IF, &v, sizeof(v)) != -1);
|
return (::setsockopt(socketDescriptor, IPPROTO_IPV6, IPV6_MULTICAST_IF, &v, sizeof(v)) != -1);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
struct in_addr v;
|
struct in_addr v;
|
||||||
if (iface.isValid()) {
|
if (iface.isValid()) {
|
||||||
@ -871,7 +837,6 @@ qint64 QNativeSocketEnginePrivate::nativeSendDatagram(const char *data, qint64 l
|
|||||||
struct sockaddr *sockAddrPtr = 0;
|
struct sockaddr *sockAddrPtr = 0;
|
||||||
QT_SOCKLEN_T sockAddrSize = 0;
|
QT_SOCKLEN_T sockAddrSize = 0;
|
||||||
|
|
||||||
#if !defined(QT_NO_IPV6)
|
|
||||||
struct sockaddr_in6 sockAddrIPv6;
|
struct sockaddr_in6 sockAddrIPv6;
|
||||||
if (host.protocol() == QAbstractSocket::IPv6Protocol
|
if (host.protocol() == QAbstractSocket::IPv6Protocol
|
||||||
|| socketProtocol == QAbstractSocket::IPv6Protocol) {
|
|| socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
@ -884,7 +849,7 @@ qint64 QNativeSocketEnginePrivate::nativeSendDatagram(const char *data, qint64 l
|
|||||||
sockAddrSize = sizeof(sockAddrIPv6);
|
sockAddrSize = sizeof(sockAddrIPv6);
|
||||||
sockAddrPtr = (struct sockaddr *)&sockAddrIPv6;
|
sockAddrPtr = (struct sockaddr *)&sockAddrIPv6;
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
if (host.protocol() == QAbstractSocket::IPv4Protocol) {
|
if (host.protocol() == QAbstractSocket::IPv4Protocol) {
|
||||||
memset(&sockAddrIPv4, 0, sizeof(sockAddrIPv4));
|
memset(&sockAddrIPv4, 0, sizeof(sockAddrIPv4));
|
||||||
sockAddrIPv4.sin_family = AF_INET;
|
sockAddrIPv4.sin_family = AF_INET;
|
||||||
@ -941,11 +906,9 @@ bool QNativeSocketEnginePrivate::fetchConnectionParameters()
|
|||||||
case AF_INET:
|
case AF_INET:
|
||||||
socketProtocol = QAbstractSocket::IPv4Protocol;
|
socketProtocol = QAbstractSocket::IPv4Protocol;
|
||||||
break;
|
break;
|
||||||
#if !defined (QT_NO_IPV6)
|
|
||||||
case AF_INET6:
|
case AF_INET6:
|
||||||
socketProtocol = QAbstractSocket::IPv6Protocol;
|
socketProtocol = QAbstractSocket::IPv6Protocol;
|
||||||
break;
|
break;
|
||||||
#endif
|
|
||||||
default:
|
default:
|
||||||
socketProtocol = QAbstractSocket::UnknownNetworkLayerProtocol;
|
socketProtocol = QAbstractSocket::UnknownNetworkLayerProtocol;
|
||||||
break;
|
break;
|
||||||
|
@ -165,7 +165,6 @@ static QByteArray qt_prettyDebug(const char *data, int len, int maxLength)
|
|||||||
*/
|
*/
|
||||||
static inline void qt_socket_getPortAndAddress(SOCKET socketDescriptor, const qt_sockaddr *sa, quint16 *port, QHostAddress *address)
|
static inline void qt_socket_getPortAndAddress(SOCKET socketDescriptor, const qt_sockaddr *sa, quint16 *port, QHostAddress *address)
|
||||||
{
|
{
|
||||||
#if !defined (QT_NO_IPV6)
|
|
||||||
if (sa->a.sa_family == AF_INET6) {
|
if (sa->a.sa_family == AF_INET6) {
|
||||||
const qt_sockaddr_in6 *sa6 = &sa->a6;
|
const qt_sockaddr_in6 *sa6 = &sa->a6;
|
||||||
Q_IPV6ADDR tmp;
|
Q_IPV6ADDR tmp;
|
||||||
@ -178,7 +177,7 @@ static inline void qt_socket_getPortAndAddress(SOCKET socketDescriptor, const qt
|
|||||||
if (port)
|
if (port)
|
||||||
WSANtohs(socketDescriptor, sa6->sin6_port, port);
|
WSANtohs(socketDescriptor, sa6->sin6_port, port);
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
if (sa->a.sa_family == AF_INET) {
|
if (sa->a.sa_family == AF_INET) {
|
||||||
const sockaddr_in *sa4 = &sa->a4;
|
const sockaddr_in *sa4 = &sa->a4;
|
||||||
unsigned long addr;
|
unsigned long addr;
|
||||||
@ -200,7 +199,7 @@ static inline void qt_socket_getPortAndAddress(SOCKET socketDescriptor, const qt
|
|||||||
void QNativeSocketEnginePrivate::setPortAndAddress(sockaddr_in * sockAddrIPv4, qt_sockaddr_in6 * sockAddrIPv6,
|
void QNativeSocketEnginePrivate::setPortAndAddress(sockaddr_in * sockAddrIPv4, qt_sockaddr_in6 * sockAddrIPv6,
|
||||||
quint16 port, const QHostAddress & address, sockaddr ** sockAddrPtr, QT_SOCKLEN_T *sockAddrSize)
|
quint16 port, const QHostAddress & address, sockaddr ** sockAddrPtr, QT_SOCKLEN_T *sockAddrSize)
|
||||||
{
|
{
|
||||||
#if !defined(QT_NO_IPV6)
|
|
||||||
if (address.protocol() == QAbstractSocket::IPv6Protocol
|
if (address.protocol() == QAbstractSocket::IPv6Protocol
|
||||||
|| address.protocol() == QAbstractSocket::AnyIPProtocol
|
|| address.protocol() == QAbstractSocket::AnyIPProtocol
|
||||||
|| socketProtocol == QAbstractSocket::IPv6Protocol) {
|
|| socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
@ -213,7 +212,7 @@ void QNativeSocketEnginePrivate::setPortAndAddress(sockaddr_in * sockAddrIPv4, q
|
|||||||
*sockAddrSize = sizeof(qt_sockaddr_in6);
|
*sockAddrSize = sizeof(qt_sockaddr_in6);
|
||||||
*sockAddrPtr = (struct sockaddr *) sockAddrIPv6;
|
*sockAddrPtr = (struct sockaddr *) sockAddrIPv6;
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
if (address.protocol() == QAbstractSocket::IPv4Protocol
|
if (address.protocol() == QAbstractSocket::IPv4Protocol
|
||||||
|| address.protocol() == QAbstractSocket::UnknownNetworkLayerProtocol) {
|
|| address.protocol() == QAbstractSocket::UnknownNetworkLayerProtocol) {
|
||||||
memset(sockAddrIPv4, 0, sizeof(sockaddr_in));
|
memset(sockAddrIPv4, 0, sizeof(sockaddr_in));
|
||||||
@ -403,24 +402,21 @@ int QNativeSocketEnginePrivate::option(QNativeSocketEngine::SocketOption opt) co
|
|||||||
n = SO_KEEPALIVE;
|
n = SO_KEEPALIVE;
|
||||||
break;
|
break;
|
||||||
case QNativeSocketEngine::MulticastTtlOption:
|
case QNativeSocketEngine::MulticastTtlOption:
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
level = IPPROTO_IPV6;
|
level = IPPROTO_IPV6;
|
||||||
n = IPV6_MULTICAST_HOPS;
|
n = IPV6_MULTICAST_HOPS;
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
level = IPPROTO_IP;
|
level = IPPROTO_IP;
|
||||||
n = IP_MULTICAST_TTL;
|
n = IP_MULTICAST_TTL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case QNativeSocketEngine::MulticastLoopbackOption:
|
case QNativeSocketEngine::MulticastLoopbackOption:
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
level = IPPROTO_IPV6;
|
level = IPPROTO_IPV6;
|
||||||
n = IPV6_MULTICAST_LOOP;
|
n = IPV6_MULTICAST_LOOP;
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
level = IPPROTO_IP;
|
level = IPPROTO_IP;
|
||||||
n = IP_MULTICAST_LOOP;
|
n = IP_MULTICAST_LOOP;
|
||||||
@ -487,24 +483,20 @@ bool QNativeSocketEnginePrivate::setOption(QNativeSocketEngine::SocketOption opt
|
|||||||
n = SO_KEEPALIVE;
|
n = SO_KEEPALIVE;
|
||||||
break;
|
break;
|
||||||
case QNativeSocketEngine::MulticastTtlOption:
|
case QNativeSocketEngine::MulticastTtlOption:
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
level = IPPROTO_IPV6;
|
level = IPPROTO_IPV6;
|
||||||
n = IPV6_MULTICAST_HOPS;
|
n = IPV6_MULTICAST_HOPS;
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
level = IPPROTO_IP;
|
level = IPPROTO_IP;
|
||||||
n = IP_MULTICAST_TTL;
|
n = IP_MULTICAST_TTL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case QNativeSocketEngine::MulticastLoopbackOption:
|
case QNativeSocketEngine::MulticastLoopbackOption:
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
level = IPPROTO_IPV6;
|
level = IPPROTO_IPV6;
|
||||||
n = IPV6_MULTICAST_LOOP;
|
n = IPV6_MULTICAST_LOOP;
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
level = IPPROTO_IP;
|
level = IPPROTO_IP;
|
||||||
n = IP_MULTICAST_LOOP;
|
n = IP_MULTICAST_LOOP;
|
||||||
@ -545,11 +537,9 @@ bool QNativeSocketEnginePrivate::fetchConnectionParameters()
|
|||||||
case AF_INET:
|
case AF_INET:
|
||||||
socketProtocol = QAbstractSocket::IPv4Protocol;
|
socketProtocol = QAbstractSocket::IPv4Protocol;
|
||||||
break;
|
break;
|
||||||
#if !defined (QT_NO_IPV6)
|
|
||||||
case AF_INET6:
|
case AF_INET6:
|
||||||
socketProtocol = QAbstractSocket::IPv6Protocol;
|
socketProtocol = QAbstractSocket::IPv6Protocol;
|
||||||
break;
|
break;
|
||||||
#endif
|
|
||||||
default:
|
default:
|
||||||
socketProtocol = QAbstractSocket::UnknownNetworkLayerProtocol;
|
socketProtocol = QAbstractSocket::UnknownNetworkLayerProtocol;
|
||||||
break;
|
break;
|
||||||
@ -714,7 +704,7 @@ bool QNativeSocketEnginePrivate::nativeBind(const QHostAddress &a, quint16 port)
|
|||||||
// binding to a multicast address
|
// binding to a multicast address
|
||||||
address = QHostAddress(QHostAddress::AnyIPv6);
|
address = QHostAddress(QHostAddress::AnyIPv6);
|
||||||
}
|
}
|
||||||
#if !defined (QT_NO_IPV6) && defined (IPV6_V6ONLY)
|
#if defined (IPV6_V6ONLY)
|
||||||
//This is default in current windows versions, it may change in future so set it explicitly
|
//This is default in current windows versions, it may change in future so set it explicitly
|
||||||
if (QSysInfo::windowsVersion() >= QSysInfo::WV_6_0) {
|
if (QSysInfo::windowsVersion() >= QSysInfo::WV_6_0) {
|
||||||
ipv6only = 1;
|
ipv6only = 1;
|
||||||
@ -729,7 +719,7 @@ bool QNativeSocketEnginePrivate::nativeBind(const QHostAddress &a, quint16 port)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case QAbstractSocket::AnyIPProtocol:
|
case QAbstractSocket::AnyIPProtocol:
|
||||||
#if !defined (QT_NO_IPV6) && defined (IPV6_V6ONLY)
|
#if defined (IPV6_V6ONLY)
|
||||||
if (QSysInfo::windowsVersion() >= QSysInfo::WV_6_0)
|
if (QSysInfo::windowsVersion() >= QSysInfo::WV_6_0)
|
||||||
ipv6only = ::setsockopt(socketDescriptor, IPPROTO_IPV6, IPV6_V6ONLY, (char*)&ipv6only, sizeof(ipv6only) );
|
ipv6only = ::setsockopt(socketDescriptor, IPPROTO_IPV6, IPV6_V6ONLY, (char*)&ipv6only, sizeof(ipv6only) );
|
||||||
else
|
else
|
||||||
@ -849,7 +839,6 @@ static bool multicastMembershipHelper(QNativeSocketEnginePrivate *d,
|
|||||||
int sockArgSize;
|
int sockArgSize;
|
||||||
|
|
||||||
struct ip_mreq mreq4;
|
struct ip_mreq mreq4;
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
struct ipv6_mreq mreq6;
|
struct ipv6_mreq mreq6;
|
||||||
|
|
||||||
if (groupAddress.protocol() == QAbstractSocket::IPv6Protocol) {
|
if (groupAddress.protocol() == QAbstractSocket::IPv6Protocol) {
|
||||||
@ -862,7 +851,7 @@ static bool multicastMembershipHelper(QNativeSocketEnginePrivate *d,
|
|||||||
memcpy(&mreq6.ipv6mr_multiaddr, &ip6, sizeof(ip6));
|
memcpy(&mreq6.ipv6mr_multiaddr, &ip6, sizeof(ip6));
|
||||||
mreq6.ipv6mr_interface = iface.index();
|
mreq6.ipv6mr_interface = iface.index();
|
||||||
} else
|
} else
|
||||||
#endif
|
|
||||||
if (groupAddress.protocol() == QAbstractSocket::IPv4Protocol) {
|
if (groupAddress.protocol() == QAbstractSocket::IPv4Protocol) {
|
||||||
level = IPPROTO_IP;
|
level = IPPROTO_IP;
|
||||||
sockOpt = how4;
|
sockOpt = how4;
|
||||||
@ -904,11 +893,7 @@ bool QNativeSocketEnginePrivate::nativeJoinMulticastGroup(const QHostAddress &gr
|
|||||||
const QNetworkInterface &iface)
|
const QNetworkInterface &iface)
|
||||||
{
|
{
|
||||||
return multicastMembershipHelper(this,
|
return multicastMembershipHelper(this,
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
IPV6_JOIN_GROUP,
|
IPV6_JOIN_GROUP,
|
||||||
#else
|
|
||||||
0,
|
|
||||||
#endif
|
|
||||||
IP_ADD_MEMBERSHIP,
|
IP_ADD_MEMBERSHIP,
|
||||||
groupAddress,
|
groupAddress,
|
||||||
iface);
|
iface);
|
||||||
@ -918,11 +903,7 @@ bool QNativeSocketEnginePrivate::nativeLeaveMulticastGroup(const QHostAddress &g
|
|||||||
const QNetworkInterface &iface)
|
const QNetworkInterface &iface)
|
||||||
{
|
{
|
||||||
return multicastMembershipHelper(this,
|
return multicastMembershipHelper(this,
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
IPV6_LEAVE_GROUP,
|
IPV6_LEAVE_GROUP,
|
||||||
#else
|
|
||||||
0,
|
|
||||||
#endif
|
|
||||||
IP_DROP_MEMBERSHIP,
|
IP_DROP_MEMBERSHIP,
|
||||||
groupAddress,
|
groupAddress,
|
||||||
iface);
|
iface);
|
||||||
@ -930,7 +911,6 @@ bool QNativeSocketEnginePrivate::nativeLeaveMulticastGroup(const QHostAddress &g
|
|||||||
|
|
||||||
QNetworkInterface QNativeSocketEnginePrivate::nativeMulticastInterface() const
|
QNetworkInterface QNativeSocketEnginePrivate::nativeMulticastInterface() const
|
||||||
{
|
{
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
uint v;
|
uint v;
|
||||||
QT_SOCKOPTLEN_T sizeofv = sizeof(v);
|
QT_SOCKOPTLEN_T sizeofv = sizeof(v);
|
||||||
@ -938,7 +918,6 @@ QNetworkInterface QNativeSocketEnginePrivate::nativeMulticastInterface() const
|
|||||||
return QNetworkInterface();
|
return QNetworkInterface();
|
||||||
return QNetworkInterface::interfaceFromIndex(v);
|
return QNetworkInterface::interfaceFromIndex(v);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
struct in_addr v;
|
struct in_addr v;
|
||||||
v.s_addr = 0;
|
v.s_addr = 0;
|
||||||
@ -965,12 +944,11 @@ QNetworkInterface QNativeSocketEnginePrivate::nativeMulticastInterface() const
|
|||||||
|
|
||||||
bool QNativeSocketEnginePrivate::nativeSetMulticastInterface(const QNetworkInterface &iface)
|
bool QNativeSocketEnginePrivate::nativeSetMulticastInterface(const QNetworkInterface &iface)
|
||||||
{
|
{
|
||||||
#ifndef QT_NO_IPV6
|
|
||||||
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
if (socketProtocol == QAbstractSocket::IPv6Protocol) {
|
||||||
uint v = iface.isValid() ? iface.index() : 0;
|
uint v = iface.isValid() ? iface.index() : 0;
|
||||||
return (::setsockopt(socketDescriptor, IPPROTO_IPV6, IPV6_MULTICAST_IF, (char *) &v, sizeof(v)) != -1);
|
return (::setsockopt(socketDescriptor, IPPROTO_IPV6, IPV6_MULTICAST_IF, (char *) &v, sizeof(v)) != -1);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
struct in_addr v;
|
struct in_addr v;
|
||||||
if (iface.isValid()) {
|
if (iface.isValid()) {
|
||||||
|
@ -192,15 +192,6 @@ bool QUdpSocketPrivate::doEnsureInitialized(const QHostAddress &bindAddress, qui
|
|||||||
proto = address->protocol();
|
proto = address->protocol();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(QT_NO_IPV6)
|
|
||||||
Q_Q(QUdpSocket);
|
|
||||||
if (proto == QUdpSocket::IPv6Protocol) {
|
|
||||||
socketError = QUdpSocket::UnsupportedSocketOperationError;
|
|
||||||
q->setErrorString(QUdpSocket::tr("This platform does not support IPv6"));
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// now check if the socket engine is initialized and to the right type
|
// now check if the socket engine is initialized and to the right type
|
||||||
if (!socketEngine || !socketEngine->isValid()) {
|
if (!socketEngine || !socketEngine->isValid()) {
|
||||||
resolveProxy(remoteAddress.toString(), bindPort);
|
resolveProxy(remoteAddress.toString(), bindPort);
|
||||||
|
@ -281,9 +281,6 @@ void tst_QTcpServer::dualStack_data()
|
|||||||
|
|
||||||
void tst_QTcpServer::dualStack()
|
void tst_QTcpServer::dualStack()
|
||||||
{
|
{
|
||||||
#ifdef QT_NO_IPV6
|
|
||||||
QSKIP("test requires IPv6 support", SkipAll);
|
|
||||||
#else
|
|
||||||
QFETCH_GLOBAL(bool, setProxy);
|
QFETCH_GLOBAL(bool, setProxy);
|
||||||
if (setProxy)
|
if (setProxy)
|
||||||
QSKIP("test server proxy doesn't support ipv6", SkipSingle);
|
QSKIP("test server proxy doesn't support ipv6", SkipSingle);
|
||||||
@ -302,7 +299,6 @@ void tst_QTcpServer::dualStack()
|
|||||||
|
|
||||||
QCOMPARE(v4client.waitForConnected(5000), v4ok);
|
QCOMPARE(v4client.waitForConnected(5000), v4ok);
|
||||||
QCOMPARE(v6client.waitForConnected(5000), v6ok);
|
QCOMPARE(v6client.waitForConnected(5000), v6ok);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------
|
||||||
|
@ -380,9 +380,6 @@ void tst_QUdpSocket::ipv6Loop_data()
|
|||||||
|
|
||||||
void tst_QUdpSocket::ipv6Loop()
|
void tst_QUdpSocket::ipv6Loop()
|
||||||
{
|
{
|
||||||
#if defined(QT_NO_IPV6)
|
|
||||||
QSKIP("IPv6 is not yet supported", SkipAll);
|
|
||||||
#endif
|
|
||||||
QFETCH(QByteArray, peterMessage);
|
QFETCH(QByteArray, peterMessage);
|
||||||
QFETCH(QByteArray, paulMessage);
|
QFETCH(QByteArray, paulMessage);
|
||||||
QFETCH(bool, success);
|
QFETCH(bool, success);
|
||||||
|
@ -47,9 +47,7 @@
|
|||||||
# undef _POSIX_ /* Don't polute */
|
# undef _POSIX_ /* Don't polute */
|
||||||
|
|
||||||
/* Make sure IP v6 is defined first of all, before windows.h */
|
/* Make sure IP v6 is defined first of all, before windows.h */
|
||||||
# ifndef QT_NO_IPV6
|
|
||||||
# include <winsock2.h>
|
# include <winsock2.h>
|
||||||
# endif
|
|
||||||
# include <stdlib.h>
|
# include <stdlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -341,7 +341,6 @@ Configure::Configure(int& argc, char** argv)
|
|||||||
dictionary[ "ACCESSIBILITY" ] = "yes";
|
dictionary[ "ACCESSIBILITY" ] = "yes";
|
||||||
dictionary[ "OPENGL" ] = "yes";
|
dictionary[ "OPENGL" ] = "yes";
|
||||||
dictionary[ "OPENVG" ] = "no";
|
dictionary[ "OPENVG" ] = "no";
|
||||||
dictionary[ "IPV6" ] = "yes"; // Always, dynamically loaded
|
|
||||||
dictionary[ "OPENSSL" ] = "auto";
|
dictionary[ "OPENSSL" ] = "auto";
|
||||||
dictionary[ "DBUS" ] = "auto";
|
dictionary[ "DBUS" ] = "auto";
|
||||||
dictionary[ "S60" ] = "yes";
|
dictionary[ "S60" ] = "yes";
|
||||||
@ -1555,8 +1554,6 @@ void Configure::applySpecSpecifics()
|
|||||||
dictionary[ "QT3SUPPORT" ] = "no";
|
dictionary[ "QT3SUPPORT" ] = "no";
|
||||||
dictionary[ "OPENGL" ] = "no";
|
dictionary[ "OPENGL" ] = "no";
|
||||||
dictionary[ "OPENSSL" ] = "yes";
|
dictionary[ "OPENSSL" ] = "yes";
|
||||||
// On Symbian we now always will have IPv6 with no chance to disable it
|
|
||||||
dictionary[ "IPV6" ] = "yes";
|
|
||||||
dictionary[ "STL" ] = "yes";
|
dictionary[ "STL" ] = "yes";
|
||||||
dictionary[ "EXCEPTIONS" ] = "yes";
|
dictionary[ "EXCEPTIONS" ] = "yes";
|
||||||
dictionary[ "RTTI" ] = "yes";
|
dictionary[ "RTTI" ] = "yes";
|
||||||
@ -2435,7 +2432,6 @@ bool Configure::verifyConfiguration()
|
|||||||
nis
|
nis
|
||||||
nas
|
nas
|
||||||
tablet
|
tablet
|
||||||
ipv6
|
|
||||||
|
|
||||||
X11 : x11sm xinerama xcursor xfixes xrandr xrender fontconfig xkb
|
X11 : x11sm xinerama xcursor xfixes xrandr xrender fontconfig xkb
|
||||||
Embedded: embedded freetype
|
Embedded: embedded freetype
|
||||||
@ -2710,11 +2706,6 @@ void Configure::generateOutputVars()
|
|||||||
else if (dictionary[ "DBUS" ] == "linked")
|
else if (dictionary[ "DBUS" ] == "linked")
|
||||||
qtConfig += "dbus dbus-linked";
|
qtConfig += "dbus dbus-linked";
|
||||||
|
|
||||||
if (dictionary["IPV6"] == "yes")
|
|
||||||
qtConfig += "ipv6";
|
|
||||||
else if (dictionary["IPV6"] == "no")
|
|
||||||
qtConfig += "no-ipv6";
|
|
||||||
|
|
||||||
if (dictionary[ "CETEST" ] == "yes")
|
if (dictionary[ "CETEST" ] == "yes")
|
||||||
qtConfig += "cetest";
|
qtConfig += "cetest";
|
||||||
|
|
||||||
@ -3188,7 +3179,6 @@ void Configure::generateConfigfiles()
|
|||||||
if (dictionary["OPENSSL"] == "no") qconfigList += "QT_NO_OPENSSL";
|
if (dictionary["OPENSSL"] == "no") qconfigList += "QT_NO_OPENSSL";
|
||||||
if (dictionary["OPENSSL"] == "linked") qconfigList += "QT_LINKED_OPENSSL";
|
if (dictionary["OPENSSL"] == "linked") qconfigList += "QT_LINKED_OPENSSL";
|
||||||
if (dictionary["DBUS"] == "no") qconfigList += "QT_NO_DBUS";
|
if (dictionary["DBUS"] == "no") qconfigList += "QT_NO_DBUS";
|
||||||
if (dictionary["IPV6"] == "no") qconfigList += "QT_NO_IPV6";
|
|
||||||
if (dictionary["WEBKIT"] == "no") qconfigList += "QT_NO_WEBKIT";
|
if (dictionary["WEBKIT"] == "no") qconfigList += "QT_NO_WEBKIT";
|
||||||
if (dictionary["DECLARATIVE"] == "no") qconfigList += "QT_NO_DECLARATIVE";
|
if (dictionary["DECLARATIVE"] == "no") qconfigList += "QT_NO_DECLARATIVE";
|
||||||
if (dictionary["DECLARATIVE_DEBUG"] == "no") qconfigList += "QDECLARATIVE_NO_DEBUG_PROTOCOL";
|
if (dictionary["DECLARATIVE_DEBUG"] == "no") qconfigList += "QDECLARATIVE_NO_DEBUG_PROTOCOL";
|
||||||
|
Loading…
Reference in New Issue
Block a user