MFC 1.127:

- Do not leak read lock in IP_FW_TABLE_GETSIZE case of ipfw_ctl().
  - Acquire read (not write) lock in case of IP_FW_TABLE_LIST.

Approved by:	re (hrs)
This commit is contained in:
glebius 2006-03-09 13:42:44 +00:00
parent a77875cef3
commit 8ddb67d972

View File

@ -1879,8 +1879,6 @@ dump_table(struct ip_fw_chain *ch, ipfw_table *tbl)
{
struct radix_node_head *rnh;
IPFW_WLOCK_ASSERT(ch);
if (tbl->tbl >= IPFW_TABLES_MAX)
return (EINVAL);
rnh = ch->tables[tbl->tbl];
@ -4053,9 +4051,10 @@ ipfw_ctl(struct sockopt *sopt)
sizeof(tbl))))
break;
IPFW_RLOCK(&layer3_chain);
if ((error = count_table(&layer3_chain, tbl, &cnt)))
break;
error = count_table(&layer3_chain, tbl, &cnt);
IPFW_RUNLOCK(&layer3_chain);
if (error)
break;
error = sooptcopyout(sopt, &cnt, sizeof(cnt));
}
break;
@ -4081,14 +4080,13 @@ ipfw_ctl(struct sockopt *sopt)
}
tbl->size = (size - sizeof(*tbl)) /
sizeof(ipfw_table_entry);
IPFW_WLOCK(&layer3_chain);
IPFW_RLOCK(&layer3_chain);
error = dump_table(&layer3_chain, tbl);
IPFW_RUNLOCK(&layer3_chain);
if (error) {
IPFW_WUNLOCK(&layer3_chain);
free(tbl, M_TEMP);
break;
}
IPFW_WUNLOCK(&layer3_chain);
error = sooptcopyout(sopt, tbl, size);
free(tbl, M_TEMP);
}