Check for existence of interface prior to setting terminate flag

https://bugzilla.redhat.com/show_bug.cgi?id=903480

During domain destruction it's possible that the learnIPAddressThread has
already removed the interface prior to the teardown filter path being run.
The teardown code would only be telling the thread to terminate.

(cherry picked from commit 64919d978e4cc910a4475f77c0f04b866051935d)
This commit is contained in:
John Ferlan 2013-05-31 07:26:30 -04:00 committed by Cole Robinson
parent b14ced3932
commit e01eedf9bf

View File

@ -250,6 +250,14 @@ virNWFilterTerminateLearnReq(const char *ifname) {
int ifindex; int ifindex;
virNWFilterIPAddrLearnReqPtr req; virNWFilterIPAddrLearnReqPtr req;
/* It's possible that it's already been removed as a result of
* virNWFilterDeregisterLearnReq during learnIPAddressThread() exit
*/
if (virNetDevExists(ifname) != 1) {
virResetLastError();
return 0;
}
if (virNetDevGetIndex(ifname, &ifindex) < 0) { if (virNetDevGetIndex(ifname, &ifindex) < 0) {
virResetLastError(); virResetLastError();
return rc; return rc;