1*2874c5fdSThomas Gleixner // SPDX-License-Identifier: GPL-2.0-or-later
2084e2f65SJamal Hadi Salim /*
3084e2f65SJamal Hadi Salim * net/sched/act_meta_mark.c IFE skb->mark metadata module
4084e2f65SJamal Hadi Salim *
5084e2f65SJamal Hadi Salim * copyright Jamal Hadi Salim (2015)
6084e2f65SJamal Hadi Salim */
7084e2f65SJamal Hadi Salim
8084e2f65SJamal Hadi Salim #include <linux/types.h>
9084e2f65SJamal Hadi Salim #include <linux/kernel.h>
10084e2f65SJamal Hadi Salim #include <linux/string.h>
11084e2f65SJamal Hadi Salim #include <linux/errno.h>
12084e2f65SJamal Hadi Salim #include <linux/skbuff.h>
13084e2f65SJamal Hadi Salim #include <linux/rtnetlink.h>
14084e2f65SJamal Hadi Salim #include <linux/module.h>
15084e2f65SJamal Hadi Salim #include <linux/init.h>
16084e2f65SJamal Hadi Salim #include <net/netlink.h>
17084e2f65SJamal Hadi Salim #include <net/pkt_sched.h>
18084e2f65SJamal Hadi Salim #include <uapi/linux/tc_act/tc_ife.h>
19084e2f65SJamal Hadi Salim #include <net/tc_act/tc_ife.h>
20084e2f65SJamal Hadi Salim
skbmark_encode(struct sk_buff * skb,void * skbdata,struct tcf_meta_info * e)21084e2f65SJamal Hadi Salim static int skbmark_encode(struct sk_buff *skb, void *skbdata,
22084e2f65SJamal Hadi Salim struct tcf_meta_info *e)
23084e2f65SJamal Hadi Salim {
24084e2f65SJamal Hadi Salim u32 ifemark = skb->mark;
25084e2f65SJamal Hadi Salim
26084e2f65SJamal Hadi Salim return ife_encode_meta_u32(ifemark, skbdata, e);
27084e2f65SJamal Hadi Salim }
28084e2f65SJamal Hadi Salim
skbmark_decode(struct sk_buff * skb,void * data,u16 len)29084e2f65SJamal Hadi Salim static int skbmark_decode(struct sk_buff *skb, void *data, u16 len)
30084e2f65SJamal Hadi Salim {
31084e2f65SJamal Hadi Salim u32 ifemark = *(u32 *)data;
32084e2f65SJamal Hadi Salim
33084e2f65SJamal Hadi Salim skb->mark = ntohl(ifemark);
34084e2f65SJamal Hadi Salim return 0;
35084e2f65SJamal Hadi Salim }
36084e2f65SJamal Hadi Salim
skbmark_check(struct sk_buff * skb,struct tcf_meta_info * e)37084e2f65SJamal Hadi Salim static int skbmark_check(struct sk_buff *skb, struct tcf_meta_info *e)
38084e2f65SJamal Hadi Salim {
39084e2f65SJamal Hadi Salim return ife_check_meta_u32(skb->mark, e);
40084e2f65SJamal Hadi Salim }
41084e2f65SJamal Hadi Salim
42084e2f65SJamal Hadi Salim static struct tcf_meta_ops ife_skbmark_ops = {
43084e2f65SJamal Hadi Salim .metaid = IFE_META_SKBMARK,
44084e2f65SJamal Hadi Salim .metatype = NLA_U32,
45084e2f65SJamal Hadi Salim .name = "skbmark",
46084e2f65SJamal Hadi Salim .synopsis = "skb mark 32 bit metadata",
47084e2f65SJamal Hadi Salim .check_presence = skbmark_check,
48084e2f65SJamal Hadi Salim .encode = skbmark_encode,
49084e2f65SJamal Hadi Salim .decode = skbmark_decode,
50084e2f65SJamal Hadi Salim .get = ife_get_meta_u32,
51084e2f65SJamal Hadi Salim .alloc = ife_alloc_meta_u32,
52084e2f65SJamal Hadi Salim .release = ife_release_meta_gen,
53084e2f65SJamal Hadi Salim .validate = ife_validate_meta_u32,
54084e2f65SJamal Hadi Salim .owner = THIS_MODULE,
55084e2f65SJamal Hadi Salim };
56084e2f65SJamal Hadi Salim
ifemark_init_module(void)57084e2f65SJamal Hadi Salim static int __init ifemark_init_module(void)
58084e2f65SJamal Hadi Salim {
59084e2f65SJamal Hadi Salim return register_ife_op(&ife_skbmark_ops);
60084e2f65SJamal Hadi Salim }
61084e2f65SJamal Hadi Salim
ifemark_cleanup_module(void)62084e2f65SJamal Hadi Salim static void __exit ifemark_cleanup_module(void)
63084e2f65SJamal Hadi Salim {
64084e2f65SJamal Hadi Salim unregister_ife_op(&ife_skbmark_ops);
65084e2f65SJamal Hadi Salim }
66084e2f65SJamal Hadi Salim
67084e2f65SJamal Hadi Salim module_init(ifemark_init_module);
68084e2f65SJamal Hadi Salim module_exit(ifemark_cleanup_module);
69084e2f65SJamal Hadi Salim
70084e2f65SJamal Hadi Salim MODULE_AUTHOR("Jamal Hadi Salim(2015)");
71084e2f65SJamal Hadi Salim MODULE_DESCRIPTION("Inter-FE skb mark metadata module");
72084e2f65SJamal Hadi Salim MODULE_LICENSE("GPL");
738f047480SRoman Mashak MODULE_ALIAS_IFE_META("skbmark");
74