diff options
Diffstat (limited to 'sbin/ipfw')
-rw-r--r-- | sbin/ipfw/ipfw2.c | 7 | ||||
-rw-r--r-- | sbin/ipfw/tables.c | 37 |
2 files changed, 27 insertions, 17 deletions
diff --git a/sbin/ipfw/ipfw2.c b/sbin/ipfw/ipfw2.c index fba03cb..d90ac1a 100644 --- a/sbin/ipfw/ipfw2.c +++ b/sbin/ipfw/ipfw2.c @@ -2659,7 +2659,7 @@ ipfw_get_config(struct cmdline_opts *co, struct format_opts *fo, sz = 4096; cfg = NULL; - for (i = 0; i < 10; i++) { + for (i = 0; i < 16; i++) { if (cfg != NULL) free(cfg); if ((cfg = calloc(1, sz)) == NULL) @@ -2676,9 +2676,10 @@ ipfw_get_config(struct cmdline_opts *co, struct format_opts *fo, } /* Buffer size is not enough. Try to increase */ - sz = sz * 2 + 200; + sz = sz * 2; if (sz < cfg->size) - sz = cfg->size + 200; + sz = cfg->size; + continue; } *pcfg = cfg; diff --git a/sbin/ipfw/tables.c b/sbin/ipfw/tables.c index 9167137..b78bbeb 100644 --- a/sbin/ipfw/tables.c +++ b/sbin/ipfw/tables.c @@ -67,7 +67,7 @@ static void table_fill_ntlv(ipfw_obj_ntlv *ntlv, char *name, uint32_t set, static int table_flush_one(ipfw_xtable_info *i, void *arg); static int table_show_one(ipfw_xtable_info *i, void *arg); -static int table_get_list(ipfw_xtable_info *i, ipfw_obj_header *oh); +static int table_do_get_list(ipfw_xtable_info *i, ipfw_obj_header **poh); static void table_show_list(ipfw_obj_header *oh, int need_header); static void table_show_entry(ipfw_xtable_info *i, ipfw_obj_tentry *tent); @@ -760,10 +760,7 @@ table_show_one(ipfw_xtable_info *i, void *arg) ipfw_obj_header *oh; int error; - if ((oh = calloc(1, i->size)) == NULL) - return (ENOMEM); - - if ((error = table_get_list(i, oh)) != 0) { + if ((error = table_do_get_list(i, &oh)) != 0) { err(EX_OSERR, "Error requesting table %s list", i->tablename); return (error); } @@ -1304,31 +1301,43 @@ tables_foreach(table_cb_t *f, void *arg, int sort) /* * Retrieves all entries for given table @i in - * eXtended format. Assumes buffer of size - * @i->size has already been allocated by caller. + * eXtended format. Allocate buffer large enough + * to store result. Called needs to free it later. * * Returns 0 on success. */ static int -table_get_list(ipfw_xtable_info *i, ipfw_obj_header *oh) +table_do_get_list(ipfw_xtable_info *i, ipfw_obj_header **poh) { + ipfw_obj_header *oh; size_t sz; int error, c; sz = 0; - for (c = 0; c < 3; c++) { - table_fill_objheader(oh, i); + oh = NULL; + error = 0; + for (c = 0; c < 8; c++) { if (sz < i->size) - sz = i->size; - + sz = i->size + 44; + if (oh != NULL) + free(oh); + if ((oh = calloc(1, sz)) == NULL) + continue; + table_fill_objheader(oh, i); oh->opheader.version = 1; /* Current version */ error = do_get3(IP_FW_TABLE_XLIST, &oh->opheader, &sz); + if (error == 0) { + *poh = oh; + return (0); + } + if (error != ENOMEM) - return (errno); + break; } + free(oh); - return (ENOMEM); + return (error); } /* |