/* * net/sched/act_meta_tc_index.c IFE skb->tc_index metadata module * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version * 2 of the License, or (at your option) any later version. * * copyright Jamal Hadi Salim (2016) * */ #include #include #include #include #include #include #include #include #include #include #include #include #include static int skbtcindex_encode(struct sk_buff *skb, void *skbdata, struct tcf_meta_info *e) { u32 ifetc_index = skb->tc_index; return ife_encode_meta_u16(ifetc_index, skbdata, e); } static int skbtcindex_decode(struct sk_buff *skb, void *data, u16 len) { u16 ifetc_index = *(u16 *)data; skb->tc_index = ntohs(ifetc_index); return 0; } static int skbtcindex_check(struct sk_buff *skb, struct tcf_meta_info *e) { return ife_check_meta_u16(skb->tc_index, e); } static struct tcf_meta_ops ife_skbtcindex_ops = { .metaid = IFE_META_TCINDEX, .metatype = NLA_U16, .name = "tc_index", .synopsis = "skb tc_index 16 bit metadata", .check_presence = skbtcindex_check, .encode = skbtcindex_encode, .decode = skbtcindex_decode, .get = ife_get_meta_u16, .alloc = ife_alloc_meta_u16, .release = ife_release_meta_gen, .validate = ife_validate_meta_u16, .owner = THIS_MODULE, }; static int __init ifetc_index_init_module(void) { return register_ife_op(&ife_skbtcindex_ops); } static void __exit ifetc_index_cleanup_module(void) { unregister_ife_op(&ife_skbtcindex_ops); } module_init(ifetc_index_init_module); module_exit(ifetc_index_cleanup_module); MODULE_AUTHOR("Jamal Hadi Salim(2016)"); MODULE_DESCRIPTION("Inter-FE skb tc_index metadata module"); MODULE_LICENSE("GPL"); MODULE_ALIAS_IFE_META(IFE_META_SKBTCINDEX); xen/interface?id=6989606a7224a2d5a925df22a49e4f7a0bfed0d6'>diff
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2017-01-05 23:06:06 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2017-01-05 23:06:06 -0800
commit6989606a7224a2d5a925df22a49e4f7a0bfed0d6 (patch)
tree2fb686a4dea9a7f4beec97fde510f2840c8e06f9 /include/xen/interface
parented40875dd4b4c7b5c991db9e06c984180ab0b3ce (diff)
parentbe29d20f3f5db1f0b4e49a4f6eeedf840e2bf9b1 (diff)
Merge branch 'stable-4.10' of git://git.infradead.org/users/pcmoore/audit
Pull audit fixes from Paul Moore: "Two small fixes relating to audit's use of fsnotify. The first patch plugs a leak and the second fixes some lock shenanigans. The patches are small and I banged on this for an afternoon with our testsuite and didn't see anything odd" * 'stable-4.10' of git://git.infradead.org/users/pcmoore/audit: audit: Fix sleep in atomic fsnotify: Remove fsnotify_duplicate_mark()
Diffstat (limited to 'include/xen/interface')