summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAleksandar Sasha Babic <aleksandar.babic@nokia.com>2009-07-08 15:20:00 (GMT)
committerAleksandar Sasha Babic <aleksandar.babic@nokia.com>2009-07-24 09:18:59 (GMT)
commit1401d0a8b232278f5f07c9c34ed537885e7f17e2 (patch)
tree43ab65592b965797ea8a5be6502df48f80bd64a0
parentcf66c667a97c0079141eb3f2d9e997b7378ae792 (diff)
downloadQt-1401d0a8b232278f5f07c9c34ed537885e7f17e2.zip
Qt-1401d0a8b232278f5f07c9c34ed537885e7f17e2.tar.gz
Qt-1401d0a8b232278f5f07c9c34ed537885e7f17e2.tar.bz2
For some reason interface info on Symbian will not
give neither correct netmask nor broadcast address. But, experiments show that route info can be used to obtain netmask. Then is easy to calculate broadcast address. Idea is to match interface and destination address from routeinfo entry, and then to use given netmask. "Machines take me by surprise with great frequency." Alan Turing(1912 - 1954)
-rw-r--r--src/network/kernel/qnetworkinterface_symbian.cpp61
1 files changed, 59 insertions, 2 deletions
diff --git a/src/network/kernel/qnetworkinterface_symbian.cpp b/src/network/kernel/qnetworkinterface_symbian.cpp
index 59f1c02..e3a282f 100644
--- a/src/network/kernel/qnetworkinterface_symbian.cpp
+++ b/src/network/kernel/qnetworkinterface_symbian.cpp
@@ -175,7 +175,7 @@ static QList<QNetworkInterfacePrivate *> interfaceListing()
iface->addressEntries << entry;
#if defined(QNETWORKINTERFACE_DEBUG)
- qDebug("\n Found network interface %s, interface flags:\n\
+ printf("\n Found network interface %s, interface flags:\n\
IsUp = %d, IsRunning = %d, CanBroadcast = %d,\n\
IsLoopBack = %d, IsPointToPoint = %d, CanMulticast = %d, \n\
ip = %s, netmask = %s, broadcast = %s,\n\
@@ -188,8 +188,65 @@ static QList<QNetworkInterfacePrivate *> interfaceListing()
#endif
}
}
+
+ // we will try to use routing info to detect more precisely
+ // netmask and then ::postProcess() should calculate
+ // broadcast addresses
+
+ // use dummy socket to start enumerating routes
+ err = socket.SetOpt(KSoInetEnumRoutes, KSolInetRtCtrl);
+ if( err )
+ {
+ socket.Close();
+ socketServ.Close();
+ // return what we have
+ // up to this moment
+ return interfaces;
+ }
+
+ TSoInetRouteInfo routeInfo;
+ TPckg<TSoInetRouteInfo> routeInfoPkg(routeInfo);
+ while(socket.GetOpt(KSoInetNextRoute, KSolInetRtCtrl, routeInfoPkg) == KErrNone)
+ {
+ TName address;
+
+ // get interface address
+ routeInfo.iIfAddr.Output(address);
+ QHostAddress ifAddr(qstringFromDesc(address));
+ if(ifAddr.isNull())
+ continue;
+
+ routeInfo.iDstAddr.Output(address);
+ QHostAddress destination(qstringFromDesc(address));
+ if(destination.isNull() || destination != ifAddr)
+ continue;
+
+ // search interfaces
+ for(int ifindex = 0; ifindex < interfaces.size(); ++ifindex) {
+ QNetworkInterfacePrivate *iface = interfaces.at(ifindex);
+ for(int eindex = 0; eindex < iface->addressEntries.size(); ++eindex) {
+ QNetworkAddressEntry entry = iface->addressEntries.at(eindex);
+ if(entry.ip() != ifAddr) {
+ continue;
+ } else {
+ routeInfo.iNetMask.Output(address);
+ QHostAddress netmask(qstringFromDesc(address));
+ entry.setNetmask(netmask);
+ // NULL boradcast address for
+ // ::postProcess to have effect
+ entry.setBroadcast(QHostAddress());
+ iface->addressEntries.replace(eindex, entry);
+// printf("for %s netmask = %s and destination = %s ; type = %d; state = %d; metric = %d \n",
+// ifAddr.toString().toLatin1().constData(), netmask.toString().toLatin1().constData(), destination.toString().toLatin1().constData(),
+// routeInfo.iType, routeInfo.iState, routeInfo.iMetric);
+ }
+ }
+ }
+ }
+
socket.Close();
- socketServ.Close();
+ socketServ.Close();
+
return interfaces;
}