diff options
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/netfilter_ipv4/ip_tables.h | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/include/linux/netfilter_ipv4/ip_tables.h b/include/linux/netfilter_ipv4/ip_tables.h index 2f46dd728ee1..e992cd6b28f5 100644 --- a/include/linux/netfilter_ipv4/ip_tables.h +++ b/include/linux/netfilter_ipv4/ip_tables.h | |||
| @@ -264,6 +264,26 @@ ipt_get_target(struct ipt_entry *e) | |||
| 264 | __ret; \ | 264 | __ret; \ |
| 265 | }) | 265 | }) |
| 266 | 266 | ||
| 267 | /* fn returns 0 to continue iteration */ | ||
| 268 | #define IPT_ENTRY_ITERATE_CONTINUE(entries, size, n, fn, args...) \ | ||
| 269 | ({ \ | ||
| 270 | unsigned int __i, __n; \ | ||
| 271 | int __ret = 0; \ | ||
| 272 | struct ipt_entry *__entry; \ | ||
| 273 | \ | ||
| 274 | for (__i = 0, __n = 0; __i < (size); \ | ||
| 275 | __i += __entry->next_offset, __n++) { \ | ||
| 276 | __entry = (void *)(entries) + __i; \ | ||
| 277 | if (__n < n) \ | ||
| 278 | continue; \ | ||
| 279 | \ | ||
| 280 | __ret = fn(__entry , ## args); \ | ||
| 281 | if (__ret != 0) \ | ||
| 282 | break; \ | ||
| 283 | } \ | ||
| 284 | __ret; \ | ||
| 285 | }) | ||
| 286 | |||
| 267 | /* | 287 | /* |
| 268 | * Main firewall chains definitions and global var's definitions. | 288 | * Main firewall chains definitions and global var's definitions. |
| 269 | */ | 289 | */ |
