diff options
author | Bart De Schuymer <bdschuym@pandora.be> | 2007-02-11 12:47:58 +0000 |
---|---|---|
committer | Bart De Schuymer <bdschuym@pandora.be> | 2007-02-11 12:47:58 +0000 |
commit | 8ed0cbb74bf6b07367c47832fdc3c585dc5dd5e3 (patch) | |
tree | ec3e935fdd98b7ae6d372b95a1c1c55d42b67947 /userspace/ebtables2/ebtables.c | |
parent | 8907b0f337c5d14e299f514432ddc22382f71666 (diff) |
speedup checking for loops
Diffstat (limited to 'userspace/ebtables2/ebtables.c')
-rw-r--r-- | userspace/ebtables2/ebtables.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/userspace/ebtables2/ebtables.c b/userspace/ebtables2/ebtables.c index 1b819cd..6de714f 100644 --- a/userspace/ebtables2/ebtables.c +++ b/userspace/ebtables2/ebtables.c @@ -1170,9 +1170,14 @@ check_extension: rule_nr--; rule_nr_end = rule_nr; - ebt_check_for_loops(replace); - if (ebt_errormsg[0] != '\0') - goto delete_the_rule; + /* a jump to a udc requires checking for loops */ + if (!strcmp(new_entry->t->u.name, EBT_STANDARD_TARGET) && + ((struct ebt_standard_target *)(new_entry->t))->verdict >= 0) { + /* FIXME: this can be done faster */ + ebt_check_for_loops(replace); + if (ebt_errormsg[0] != '\0') + goto delete_the_rule; + } /* Do the final_check(), for all entries. * This is needed when adding a rule that has a chain target */ |