1
0
mirror of https://gitlab.com/libvirt/libvirt.git synced 2025-01-23 02:04:16 +03:00

nwfilter: use standard label names when reasonable

Rather than having labels named exit, done, exit_snooprequnlock,
skip_rename, etc, use the standard "cleanup" label. And instead of
err_exit, malformed, tear_down_tmpebchains, use "error".

Signed-off-by: Laine Stump <laine@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
This commit is contained in:
Laine Stump 2020-06-24 22:20:56 -04:00
parent 9c5cd04545
commit a082c3d1a1
4 changed files with 52 additions and 52 deletions

View File

@ -456,11 +456,11 @@ virNWFilterSnoopIPLeaseInstallRule(virNWFilterSnoopIPLeasePtr ipl,
virNWFilterSnoopReqLock(req); virNWFilterSnoopReqLock(req);
if (virNWFilterIPAddrMapAddIPAddr(req->binding->portdevname, ipaddr) < 0) if (virNWFilterIPAddrMapAddIPAddr(req->binding->portdevname, ipaddr) < 0)
goto exit_snooprequnlock; goto cleanup;
if (!instantiate) { if (!instantiate) {
rc = 0; rc = 0;
goto exit_snooprequnlock; goto cleanup;
} }
/* instantiate the filters */ /* instantiate the filters */
@ -471,7 +471,7 @@ virNWFilterSnoopIPLeaseInstallRule(virNWFilterSnoopIPLeasePtr ipl,
req->ifindex); req->ifindex);
} }
exit_snooprequnlock: cleanup:
virNWFilterSnoopReqUnlock(req); virNWFilterSnoopReqUnlock(req);
VIR_FREE(ipaddr); VIR_FREE(ipaddr);
@ -732,7 +732,7 @@ virNWFilterSnoopReqLeaseAdd(virNWFilterSnoopReqPtr req,
virNWFilterSnoopReqUnlock(req); virNWFilterSnoopReqUnlock(req);
goto exit; goto cleanup;
} }
virNWFilterSnoopReqUnlock(req); virNWFilterSnoopReqUnlock(req);
@ -757,7 +757,7 @@ virNWFilterSnoopReqLeaseAdd(virNWFilterSnoopReqPtr req,
g_atomic_int_add(&virNWFilterSnoopState.nLeases, 1); g_atomic_int_add(&virNWFilterSnoopState.nLeases, 1);
exit: cleanup:
if (update_leasefile) if (update_leasefile)
virNWFilterSnoopLeaseFileSave(pl); virNWFilterSnoopLeaseFileSave(pl);
@ -902,7 +902,7 @@ virNWFilterSnoopDHCPGetOpt(virNWFilterSnoopDHCPHdrPtr pd, int len,
switch (pd->d_opts[oind]) { switch (pd->d_opts[oind]) {
case DHCPO_LEASE: case DHCPO_LEASE:
if (olen - oind < 6) if (olen - oind < 6)
goto malformed; goto error;
if (*pleasetime) if (*pleasetime)
return -1; /* duplicate lease time */ return -1; /* duplicate lease time */
memcpy(&nwint, (char *)pd->d_opts + oind + 2, sizeof(nwint)); memcpy(&nwint, (char *)pd->d_opts + oind + 2, sizeof(nwint));
@ -910,7 +910,7 @@ virNWFilterSnoopDHCPGetOpt(virNWFilterSnoopDHCPHdrPtr pd, int len,
break; break;
case DHCPO_MTYPE: case DHCPO_MTYPE:
if (olen - oind < 3) if (olen - oind < 3)
goto malformed; goto error;
if (*pmtype) if (*pmtype)
return -1; /* duplicate message type */ return -1; /* duplicate message type */
*pmtype = pd->d_opts[oind + 2]; *pmtype = pd->d_opts[oind + 2];
@ -922,12 +922,12 @@ virNWFilterSnoopDHCPGetOpt(virNWFilterSnoopDHCPHdrPtr pd, int len,
return 0; return 0;
default: default:
if (olen - oind < 2) if (olen - oind < 2)
goto malformed; goto error;
} }
oind += pd->d_opts[oind + 1] + 2; oind += pd->d_opts[oind + 1] + 2;
} }
return 0; return 0;
malformed: error:
VIR_WARN("got lost in the options!"); VIR_WARN("got lost in the options!");
return -1; return -1;
} }
@ -1386,7 +1386,7 @@ virNWFilterDHCPSnoopThread(void *req0)
virNWFilterSnoopReqUnlock(req); virNWFilterSnoopReqUnlock(req);
if (req->threadStatus != THREAD_STATUS_OK) if (req->threadStatus != THREAD_STATUS_OK)
goto exit; goto cleanup;
while (!error) { while (!error) {
if (virNWFilterSnoopAdjustPoll(pcapConf, if (virNWFilterSnoopAdjustPoll(pcapConf,
@ -1414,7 +1414,7 @@ virNWFilterDHCPSnoopThread(void *req0)
*/ */
if (!virNWFilterSnoopIsActive(threadkey) || if (!virNWFilterSnoopIsActive(threadkey) ||
req->jobCompletionStatus != 0) req->jobCompletionStatus != 0)
goto exit; goto cleanup;
for (i = 0; n > 0 && i < G_N_ELEMENTS(fds); i++) { for (i = 0; n > 0 && i < G_N_ELEMENTS(fds); i++) {
if (!fds[i].revents) if (!fds[i].revents)
@ -1531,7 +1531,7 @@ virNWFilterDHCPSnoopThread(void *req0)
virNWFilterSnoopReqUnlock(req); virNWFilterSnoopReqUnlock(req);
virNWFilterSnoopUnlock(); virNWFilterSnoopUnlock();
exit: cleanup:
virThreadPoolFree(worker); virThreadPoolFree(worker);
virNWFilterSnoopReqPut(req); virNWFilterSnoopReqPut(req);
@ -1774,14 +1774,14 @@ virNWFilterSnoopLeaseFileSave(virNWFilterSnoopIPLeasePtr ipl)
virNWFilterSnoopLeaseFileOpen(); virNWFilterSnoopLeaseFileOpen();
if (virNWFilterSnoopLeaseFileWrite(virNWFilterSnoopState.leaseFD, if (virNWFilterSnoopLeaseFileWrite(virNWFilterSnoopState.leaseFD,
req->ifkey, ipl) < 0) req->ifkey, ipl) < 0)
goto err_exit; goto error;
/* keep dead leases at < ~95% of file size */ /* keep dead leases at < ~95% of file size */
if (g_atomic_int_add(&virNWFilterSnoopState.wLeases, 1) >= if (g_atomic_int_add(&virNWFilterSnoopState.wLeases, 1) >=
g_atomic_int_get(&virNWFilterSnoopState.nLeases) * 20) g_atomic_int_get(&virNWFilterSnoopState.nLeases) * 20)
virNWFilterSnoopLeaseFileLoad(); /* load & refresh lease file */ virNWFilterSnoopLeaseFileLoad(); /* load & refresh lease file */
err_exit: error:
virNWFilterSnoopUnlock(); virNWFilterSnoopUnlock();
} }
@ -1876,7 +1876,7 @@ virNWFilterSnoopLeaseFileRefresh(void)
if (VIR_CLOSE(tfd) < 0) { if (VIR_CLOSE(tfd) < 0) {
virReportSystemError(errno, _("unable to close %s"), TMPLEASEFILE); virReportSystemError(errno, _("unable to close %s"), TMPLEASEFILE);
/* assuming the old lease file is still better, skip the renaming */ /* assuming the old lease file is still better, skip the renaming */
goto skip_rename; goto cleanup;
} }
if (rename(TMPLEASEFILE, LEASEFILE) < 0) { if (rename(TMPLEASEFILE, LEASEFILE) < 0) {
@ -1886,7 +1886,7 @@ virNWFilterSnoopLeaseFileRefresh(void)
} }
g_atomic_int_set(&virNWFilterSnoopState.wLeases, 0); g_atomic_int_set(&virNWFilterSnoopState.wLeases, 0);
skip_rename: cleanup:
virNWFilterSnoopLeaseFileOpen(); virNWFilterSnoopLeaseFileOpen();
} }
@ -2051,14 +2051,14 @@ virNWFilterDHCPSnoopInit(void)
if (!virNWFilterSnoopState.ifnameToKey || if (!virNWFilterSnoopState.ifnameToKey ||
!virNWFilterSnoopState.snoopReqs || !virNWFilterSnoopState.snoopReqs ||
!virNWFilterSnoopState.active) !virNWFilterSnoopState.active)
goto err_exit; goto error;
virNWFilterSnoopLeaseFileLoad(); virNWFilterSnoopLeaseFileLoad();
virNWFilterSnoopLeaseFileOpen(); virNWFilterSnoopLeaseFileOpen();
return 0; return 0;
err_exit: error:
virHashFree(virNWFilterSnoopState.ifnameToKey); virHashFree(virNWFilterSnoopState.ifnameToKey);
virNWFilterSnoopState.ifnameToKey = NULL; virNWFilterSnoopState.ifnameToKey = NULL;

View File

@ -2893,11 +2893,11 @@ ebtablesApplyBasicRules(const char *ifname,
ebtablesRenameTmpRootChainFW(fw, true, ifname); ebtablesRenameTmpRootChainFW(fw, true, ifname);
if (virFirewallApply(fw) < 0) if (virFirewallApply(fw) < 0)
goto tear_down_tmpebchains; goto error;
return 0; return 0;
tear_down_tmpebchains: error:
ebtablesCleanAll(ifname); ebtablesCleanAll(ifname);
return -1; return -1;
} }
@ -3009,11 +3009,11 @@ ebtablesApplyDHCPOnlyRules(const char *ifname,
} }
if (virFirewallApply(fw) < 0) if (virFirewallApply(fw) < 0)
goto tear_down_tmpebchains; goto error;
return 0; return 0;
tear_down_tmpebchains: error:
ebtablesCleanAll(ifname); ebtablesCleanAll(ifname);
return -1; return -1;
} }
@ -3060,11 +3060,11 @@ ebtablesApplyDropAllRules(const char *ifname)
ebtablesRenameTmpRootChainFW(fw, false, ifname); ebtablesRenameTmpRootChainFW(fw, false, ifname);
if (virFirewallApply(fw) < 0) if (virFirewallApply(fw) < 0)
goto tear_down_tmpebchains; goto error;
return 0; return 0;
tear_down_tmpebchains: error:
ebtablesCleanAll(ifname); ebtablesCleanAll(ifname);
return -1; return -1;
} }

View File

@ -204,14 +204,14 @@ virNWFilterCreateVarsFrom(virHashTablePtr vars1,
return NULL; return NULL;
if (virNWFilterHashTablePutAll(vars1, res) < 0) if (virNWFilterHashTablePutAll(vars1, res) < 0)
goto err_exit; goto error;
if (virNWFilterHashTablePutAll(vars2, res) < 0) if (virNWFilterHashTablePutAll(vars2, res) < 0)
goto err_exit; goto error;
return res; return res;
err_exit: error:
virHashFree(res); virHashFree(res);
return NULL; return NULL;
} }
@ -527,7 +527,7 @@ virNWFilterDoInstantiate(virNWFilterTechDriverPtr techdriver,
if (!missing_vars) { if (!missing_vars) {
rc = -1; rc = -1;
goto err_exit; goto error;
} }
rc = virNWFilterDetermineMissingVarsRec(filter, rc = virNWFilterDetermineMissingVarsRec(filter,
@ -536,7 +536,7 @@ virNWFilterDoInstantiate(virNWFilterTechDriverPtr techdriver,
useNewFilter, useNewFilter,
driver); driver);
if (rc < 0) if (rc < 0)
goto err_exit; goto error;
lv = virHashLookup(binding->filterparams, NWFILTER_VARNAME_CTRL_IP_LEARNING); lv = virHashLookup(binding->filterparams, NWFILTER_VARNAME_CTRL_IP_LEARNING);
if (lv) if (lv)
@ -558,7 +558,7 @@ virNWFilterDoInstantiate(virNWFilterTechDriverPtr techdriver,
rc = virNWFilterDHCPSnoopReq(techdriver, rc = virNWFilterDHCPSnoopReq(techdriver,
binding, binding,
driver); driver);
goto err_exit; goto error;
} else if (STRCASEEQ(learning, "any")) { } else if (STRCASEEQ(learning, "any")) {
if (!virNWFilterHasLearnReq(ifindex)) { if (!virNWFilterHasLearnReq(ifindex)) {
rc = virNWFilterLearnIPAddress(techdriver, rc = virNWFilterLearnIPAddress(techdriver,
@ -567,14 +567,14 @@ virNWFilterDoInstantiate(virNWFilterTechDriverPtr techdriver,
driver, driver,
DETECT_DHCP|DETECT_STATIC); DETECT_DHCP|DETECT_STATIC);
} }
goto err_exit; goto error;
} else { } else {
rc = -1; rc = -1;
virReportError(VIR_ERR_PARSE_FAILED, virReportError(VIR_ERR_PARSE_FAILED,
_("filter '%s' " _("filter '%s' "
"learning value '%s' invalid."), "learning value '%s' invalid."),
filter->name, learning); filter->name, learning);
goto err_exit; goto error;
} }
} else { } else {
goto err_unresolvable_vars; goto err_unresolvable_vars;
@ -583,7 +583,7 @@ virNWFilterDoInstantiate(virNWFilterTechDriverPtr techdriver,
goto err_unresolvable_vars; goto err_unresolvable_vars;
} else if (!forceWithPendingReq && } else if (!forceWithPendingReq &&
virNWFilterHasLearnReq(ifindex)) { virNWFilterHasLearnReq(ifindex)) {
goto err_exit; goto error;
} }
rc = virNWFilterDefToInst(driver, rc = virNWFilterDefToInst(driver,
@ -593,7 +593,7 @@ virNWFilterDoInstantiate(virNWFilterTechDriverPtr techdriver,
&inst); &inst);
if (rc < 0) if (rc < 0)
goto err_exit; goto error;
switch (useNewFilter) { switch (useNewFilter) {
case INSTANTIATE_FOLLOW_NEWFILTER: case INSTANTIATE_FOLLOW_NEWFILTER:
@ -606,7 +606,7 @@ virNWFilterDoInstantiate(virNWFilterTechDriverPtr techdriver,
if (instantiate) { if (instantiate) {
if (virNWFilterLockIface(binding->portdevname) < 0) if (virNWFilterLockIface(binding->portdevname) < 0)
goto err_exit; goto error;
rc = techdriver->applyNewRules(binding->portdevname, inst.rules, inst.nrules); rc = techdriver->applyNewRules(binding->portdevname, inst.rules, inst.nrules);
@ -623,7 +623,7 @@ virNWFilterDoInstantiate(virNWFilterTechDriverPtr techdriver,
virNWFilterUnlockIface(binding->portdevname); virNWFilterUnlockIface(binding->portdevname);
} }
err_exit: error:
virNWFilterInstReset(&inst); virNWFilterInstReset(&inst);
virHashFree(missing_vars); virHashFree(missing_vars);
@ -640,7 +640,7 @@ virNWFilterDoInstantiate(virNWFilterTechDriverPtr techdriver,
} }
rc = -1; rc = -1;
goto err_exit; goto error;
} }
@ -707,14 +707,14 @@ virNWFilterInstantiateFilterUpdate(virNWFilterDriverStatePtr driver,
if (virNWFilterVarHashmapAddStdValue(binding->filterparams, if (virNWFilterVarHashmapAddStdValue(binding->filterparams,
NWFILTER_STD_VAR_MAC, NWFILTER_STD_VAR_MAC,
vmmacaddr) < 0) vmmacaddr) < 0)
goto err_exit; goto error;
ipaddr = virNWFilterIPAddrMapGetIPAddr(binding->portdevname); ipaddr = virNWFilterIPAddrMapGetIPAddr(binding->portdevname);
if (ipaddr && if (ipaddr &&
virNWFilterVarHashmapAddStdValue(binding->filterparams, virNWFilterVarHashmapAddStdValue(binding->filterparams,
NWFILTER_STD_VAR_IP, NWFILTER_STD_VAR_IP,
virNWFilterVarValueGetSimple(ipaddr)) < 0) virNWFilterVarValueGetSimple(ipaddr)) < 0)
goto err_exit; goto error;
filter = virNWFilterObjGetDef(obj); filter = virNWFilterObjGetDef(obj);
@ -737,7 +737,7 @@ virNWFilterInstantiateFilterUpdate(virNWFilterDriverStatePtr driver,
teardownOld, driver, teardownOld, driver,
forceWithPendingReq); forceWithPendingReq);
err_exit: error:
virNWFilterObjUnlock(obj); virNWFilterObjUnlock(obj);
return rc; return rc;

View File

@ -152,13 +152,13 @@ virNWFilterLockIface(const char *ifname)
ifaceLock = virHashLookup(ifaceLockMap, ifname); ifaceLock = virHashLookup(ifaceLockMap, ifname);
if (!ifaceLock) { if (!ifaceLock) {
if (VIR_ALLOC(ifaceLock) < 0) if (VIR_ALLOC(ifaceLock) < 0)
goto err_exit; goto error;
if (virMutexInitRecursive(&ifaceLock->lock) < 0) { if (virMutexInitRecursive(&ifaceLock->lock) < 0) {
virReportError(VIR_ERR_INTERNAL_ERROR, "%s", virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
_("mutex initialization failed")); _("mutex initialization failed"));
VIR_FREE(ifaceLock); VIR_FREE(ifaceLock);
goto err_exit; goto error;
} }
if (virStrcpyStatic(ifaceLock->ifname, ifname) < 0) { if (virStrcpyStatic(ifaceLock->ifname, ifname) < 0) {
@ -167,12 +167,12 @@ virNWFilterLockIface(const char *ifname)
"buffer "), "buffer "),
ifaceLock->ifname); ifaceLock->ifname);
VIR_FREE(ifaceLock); VIR_FREE(ifaceLock);
goto err_exit; goto error;
} }
while (virHashAddEntry(ifaceLockMap, ifname, ifaceLock)) { while (virHashAddEntry(ifaceLockMap, ifname, ifaceLock)) {
VIR_FREE(ifaceLock); VIR_FREE(ifaceLock);
goto err_exit; goto error;
} }
ifaceLock->refctr = 0; ifaceLock->refctr = 0;
@ -186,7 +186,7 @@ virNWFilterLockIface(const char *ifname)
return 0; return 0;
err_exit: error:
virMutexUnlock(&ifaceMapLock); virMutexUnlock(&ifaceMapLock);
return -1; return -1;
@ -414,7 +414,7 @@ learnIPAddressThread(void *arg)
if (virNetDevValidateConfig(req->binding->portdevname, NULL, req->ifindex) <= 0) { if (virNetDevValidateConfig(req->binding->portdevname, NULL, req->ifindex) <= 0) {
virResetLastError(); virResetLastError();
req->status = ENODEV; req->status = ENODEV;
goto done; goto cleanup;
} }
handle = pcap_open_live(listen_if, BUFSIZ, 0, PKT_TIMEOUT_MS, errbuf); handle = pcap_open_live(listen_if, BUFSIZ, 0, PKT_TIMEOUT_MS, errbuf);
@ -422,7 +422,7 @@ learnIPAddressThread(void *arg)
if (handle == NULL) { if (handle == NULL) {
VIR_DEBUG("Couldn't open device %s: %s", listen_if, errbuf); VIR_DEBUG("Couldn't open device %s: %s", listen_if, errbuf);
req->status = ENODEV; req->status = ENODEV;
goto done; goto cleanup;
} }
fds[0].fd = pcap_fileno(handle); fds[0].fd = pcap_fileno(handle);
@ -436,7 +436,7 @@ learnIPAddressThread(void *arg)
NULL, false) < 0) { NULL, false) < 0) {
VIR_DEBUG("Unable to apply DHCP only rules"); VIR_DEBUG("Unable to apply DHCP only rules");
req->status = EINVAL; req->status = EINVAL;
goto done; goto cleanup;
} }
virBufferAddLit(&buf, "src port 67 and dst port 68"); virBufferAddLit(&buf, "src port 67 and dst port 68");
} else { } else {
@ -444,7 +444,7 @@ learnIPAddressThread(void *arg)
&req->binding->mac) < 0) { &req->binding->mac) < 0) {
VIR_DEBUG("Unable to apply basic rules"); VIR_DEBUG("Unable to apply basic rules");
req->status = EINVAL; req->status = EINVAL;
goto done; goto cleanup;
} }
virBufferAsprintf(&buf, "ether host %s or ether dst ff:ff:ff:ff:ff:ff", virBufferAsprintf(&buf, "ether host %s or ether dst ff:ff:ff:ff:ff:ff",
macaddr); macaddr);
@ -455,14 +455,14 @@ learnIPAddressThread(void *arg)
if (pcap_compile(handle, &fp, filter, 1, 0) != 0) { if (pcap_compile(handle, &fp, filter, 1, 0) != 0) {
VIR_DEBUG("Couldn't compile filter '%s'", filter); VIR_DEBUG("Couldn't compile filter '%s'", filter);
req->status = EINVAL; req->status = EINVAL;
goto done; goto cleanup;
} }
if (pcap_setfilter(handle, &fp) != 0) { if (pcap_setfilter(handle, &fp) != 0) {
VIR_DEBUG("Couldn't set filter '%s'", filter); VIR_DEBUG("Couldn't set filter '%s'", filter);
req->status = EINVAL; req->status = EINVAL;
pcap_freecode(&fp); pcap_freecode(&fp);
goto done; goto cleanup;
} }
pcap_freecode(&fp); pcap_freecode(&fp);
@ -622,7 +622,7 @@ learnIPAddressThread(void *arg)
} }
} /* while */ } /* while */
done: cleanup:
VIR_FREE(filter); VIR_FREE(filter);
if (handle) if (handle)