Commit 6eb563a4 authored by Stephen Hemminger's avatar Stephen Hemminger

[BRIDGE]: Missing unlocks in ioctl error paths.

parent 83e410b8
...@@ -138,8 +138,10 @@ static int br_ioctl_device(struct net_bridge *br, ...@@ -138,8 +138,10 @@ static int br_ioctl_device(struct net_bridge *br,
struct net_bridge_port *pt; struct net_bridge_port *pt;
read_lock(&br->lock); read_lock(&br->lock);
if ((pt = br_get_port(br, arg1)) == NULL) if ((pt = br_get_port(br, arg1)) == NULL) {
read_unlock(&br->lock);
return -EINVAL; return -EINVAL;
}
memset(&p, 0, sizeof(struct __port_info)); memset(&p, 0, sizeof(struct __port_info));
memcpy(&p.designated_root, &pt->designated_root, 8); memcpy(&p.designated_root, &pt->designated_root, 8);
...@@ -176,25 +178,29 @@ static int br_ioctl_device(struct net_bridge *br, ...@@ -176,25 +178,29 @@ static int br_ioctl_device(struct net_bridge *br,
case BRCTL_SET_PORT_PRIORITY: case BRCTL_SET_PORT_PRIORITY:
{ {
struct net_bridge_port *p; struct net_bridge_port *p;
int ret = 0;
write_lock(&br->lock); write_lock(&br->lock);
if ((p = br_get_port(br, arg0)) == NULL) if ((p = br_get_port(br, arg0)) == NULL)
return -EINVAL; ret = -EINVAL;
else
br_stp_set_port_priority(p, arg1); br_stp_set_port_priority(p, arg1);
write_unlock(&br->lock); write_unlock(&br->lock);
return 0; return ret;
} }
case BRCTL_SET_PATH_COST: case BRCTL_SET_PATH_COST:
{ {
struct net_bridge_port *p; struct net_bridge_port *p;
int ret = 0;
write_lock(&br->lock); write_lock(&br->lock);
if ((p = br_get_port(br, arg0)) == NULL) if ((p = br_get_port(br, arg0)) == NULL)
return -EINVAL; ret = -EINVAL;
else
br_stp_set_path_cost(p, arg1); br_stp_set_path_cost(p, arg1);
write_unlock(&br->lock); write_unlock(&br->lock);
return 0; return ret;
} }
case BRCTL_GET_FDB_ENTRIES: case BRCTL_GET_FDB_ENTRIES:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment