#ifndef PERF_UTIL_PERF_HOOKS_H #define PERF_UTIL_PERF_HOOKS_H #ifdef __cplusplus extern "C" { #endif typedef void (*perf_hook_func_t)(void *ctx); struct perf_hook_desc { const char * const hook_name; perf_hook_func_t * const p_hook_func; void *hook_ctx; }; extern void perf_hooks__invoke(const struct perf_hook_desc *); extern void perf_hooks__recover(void); #define PERF_HOOK(name) \ extern struct perf_hook_desc __perf_hook_desc_##name; \ static inline void perf_hooks__invoke_##name(void) \ { \ perf_hooks__invoke(&__perf_hook_desc_##name); \ } #include "perf-hooks-list.h" #undef PERF_HOOK extern int perf_hooks__set_hook(const char *hook_name, perf_hook_func_t hook_func, void *hook_ctx); extern perf_hook_func_t perf_hooks__get_hook(const char *hook_name); #ifdef __cplusplus } #endif #endif /linux/net-next.git/'>net-next.git
net-next plumbingsTobias Klauser
summaryrefslogtreecommitdiff
path: root/net/sched/act_simple.c
diff options
context:
space:
mode:
authorFeng <fgao@ikuai8.com>2017-01-20 21:40:43 +0800
committerPablo Neira Ayuso <pablo@netfilter.org>2017-02-02 14:30:19 +0100
commit10435c1192d06bdb0bac7666452d8219d7e7c477 (patch)
tree93b76419142fe17b1d162d062c663297a3e8a965 /net/sched/act_simple.c
parent1a28ad74ebd8f9d3c7eae0d781f72a6d30545e17 (diff)
netfilter: nf_tables: Eliminate duplicated code in nf_tables_table_enable()
If something fails in nf_tables_table_enable(), it unregisters the chains. But the rollback code is the same as nf_tables_table_disable() almostly, except there is one counter check. Now create one wrapper function to eliminate the duplicated codes. Signed-off-by: Feng <fgao@ikuai8.com> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'net/sched/act_simple.c')