提交 10881fac 编写于 作者: J John Ferlan

network: Use local variables in networkUpdatePortBandwidth

We go through the trouble of checking {old|new}Bandwidth[->in] and
storing the result in local @old_floor and @new_floor, but then
we don't use them. Instead we make derefs to the longer name. This
caused Coverity to note dereferencing newBandwidth->in without first
checking @newBandwidth like was done for new_floor could cause a
NULL dereference.
Signed-off-by: NJohn Ferlan <jferlan@redhat.com>
Reviewed-by: NDaniel Henrique Barboza <danielhb413@gmail.com>
上级 d70024d0
...@@ -5380,19 +5380,18 @@ networkUpdatePortBandwidth(virNetworkObjPtr obj, ...@@ -5380,19 +5380,18 @@ networkUpdatePortBandwidth(virNetworkObjPtr obj,
/* Okay, there are three possible scenarios: */ /* Okay, there are three possible scenarios: */
if (oldBandwidth && oldBandwidth->in && oldBandwidth->in->floor && if (old_floor > 0 && new_floor > 0) {
newBandwidth->in && newBandwidth->in->floor) {
/* Either we just need to update @floor .. */ /* Either we just need to update @floor .. */
if (virNetDevBandwidthUpdateRate(def->bridge, if (virNetDevBandwidthUpdateRate(def->bridge,
*class_id, *class_id,
def->bandwidth, def->bandwidth,
newBandwidth->in->floor) < 0) new_floor) < 0)
return -1; return -1;
tmp_floor_sum = virNetworkObjGetFloorSum(obj); tmp_floor_sum = virNetworkObjGetFloorSum(obj);
tmp_floor_sum -= oldBandwidth->in->floor; tmp_floor_sum -= old_floor;
tmp_floor_sum += newBandwidth->in->floor; tmp_floor_sum += new_floor;
virNetworkObjSetFloorSum(obj, tmp_floor_sum); virNetworkObjSetFloorSum(obj, tmp_floor_sum);
new_rate -= tmp_floor_sum; new_rate -= tmp_floor_sum;
...@@ -5401,17 +5400,17 @@ networkUpdatePortBandwidth(virNetworkObjPtr obj, ...@@ -5401,17 +5400,17 @@ networkUpdatePortBandwidth(virNetworkObjPtr obj,
virNetworkObjSaveStatus(driver->stateDir, virNetworkObjSaveStatus(driver->stateDir,
obj, network_driver->xmlopt) < 0) { obj, network_driver->xmlopt) < 0) {
/* Ouch, rollback */ /* Ouch, rollback */
tmp_floor_sum -= newBandwidth->in->floor; tmp_floor_sum -= new_floor;
tmp_floor_sum += oldBandwidth->in->floor; tmp_floor_sum += old_floor;
virNetworkObjSetFloorSum(obj, tmp_floor_sum); virNetworkObjSetFloorSum(obj, tmp_floor_sum);
ignore_value(virNetDevBandwidthUpdateRate(def->bridge, ignore_value(virNetDevBandwidthUpdateRate(def->bridge,
*class_id, *class_id,
def->bandwidth, def->bandwidth,
oldBandwidth->in->floor)); old_floor));
return -1; return -1;
} }
} else if (newBandwidth->in && newBandwidth->in->floor) { } else if (new_floor > 0) {
/* .. or we need to plug in new .. */ /* .. or we need to plug in new .. */
if (networkPlugBandwidthImpl(obj, mac, newBandwidth, if (networkPlugBandwidthImpl(obj, mac, newBandwidth,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册