18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * net/sched/act_meta_mark.c IFE skb->mark metadata module 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * copyright Jamal Hadi Salim (2015) 68c2ecf20Sopenharmony_ci*/ 78c2ecf20Sopenharmony_ci 88c2ecf20Sopenharmony_ci#include <linux/types.h> 98c2ecf20Sopenharmony_ci#include <linux/kernel.h> 108c2ecf20Sopenharmony_ci#include <linux/string.h> 118c2ecf20Sopenharmony_ci#include <linux/errno.h> 128c2ecf20Sopenharmony_ci#include <linux/skbuff.h> 138c2ecf20Sopenharmony_ci#include <linux/rtnetlink.h> 148c2ecf20Sopenharmony_ci#include <linux/module.h> 158c2ecf20Sopenharmony_ci#include <linux/init.h> 168c2ecf20Sopenharmony_ci#include <net/netlink.h> 178c2ecf20Sopenharmony_ci#include <net/pkt_sched.h> 188c2ecf20Sopenharmony_ci#include <uapi/linux/tc_act/tc_ife.h> 198c2ecf20Sopenharmony_ci#include <net/tc_act/tc_ife.h> 208c2ecf20Sopenharmony_ci 218c2ecf20Sopenharmony_cistatic int skbmark_encode(struct sk_buff *skb, void *skbdata, 228c2ecf20Sopenharmony_ci struct tcf_meta_info *e) 238c2ecf20Sopenharmony_ci{ 248c2ecf20Sopenharmony_ci u32 ifemark = skb->mark; 258c2ecf20Sopenharmony_ci 268c2ecf20Sopenharmony_ci return ife_encode_meta_u32(ifemark, skbdata, e); 278c2ecf20Sopenharmony_ci} 288c2ecf20Sopenharmony_ci 298c2ecf20Sopenharmony_cistatic int skbmark_decode(struct sk_buff *skb, void *data, u16 len) 308c2ecf20Sopenharmony_ci{ 318c2ecf20Sopenharmony_ci u32 ifemark = *(u32 *)data; 328c2ecf20Sopenharmony_ci 338c2ecf20Sopenharmony_ci skb->mark = ntohl(ifemark); 348c2ecf20Sopenharmony_ci return 0; 358c2ecf20Sopenharmony_ci} 368c2ecf20Sopenharmony_ci 378c2ecf20Sopenharmony_cistatic int skbmark_check(struct sk_buff *skb, struct tcf_meta_info *e) 388c2ecf20Sopenharmony_ci{ 398c2ecf20Sopenharmony_ci return ife_check_meta_u32(skb->mark, e); 408c2ecf20Sopenharmony_ci} 418c2ecf20Sopenharmony_ci 428c2ecf20Sopenharmony_cistatic struct tcf_meta_ops ife_skbmark_ops = { 438c2ecf20Sopenharmony_ci .metaid = IFE_META_SKBMARK, 448c2ecf20Sopenharmony_ci .metatype = NLA_U32, 458c2ecf20Sopenharmony_ci .name = "skbmark", 468c2ecf20Sopenharmony_ci .synopsis = "skb mark 32 bit metadata", 478c2ecf20Sopenharmony_ci .check_presence = skbmark_check, 488c2ecf20Sopenharmony_ci .encode = skbmark_encode, 498c2ecf20Sopenharmony_ci .decode = skbmark_decode, 508c2ecf20Sopenharmony_ci .get = ife_get_meta_u32, 518c2ecf20Sopenharmony_ci .alloc = ife_alloc_meta_u32, 528c2ecf20Sopenharmony_ci .release = ife_release_meta_gen, 538c2ecf20Sopenharmony_ci .validate = ife_validate_meta_u32, 548c2ecf20Sopenharmony_ci .owner = THIS_MODULE, 558c2ecf20Sopenharmony_ci}; 568c2ecf20Sopenharmony_ci 578c2ecf20Sopenharmony_cistatic int __init ifemark_init_module(void) 588c2ecf20Sopenharmony_ci{ 598c2ecf20Sopenharmony_ci return register_ife_op(&ife_skbmark_ops); 608c2ecf20Sopenharmony_ci} 618c2ecf20Sopenharmony_ci 628c2ecf20Sopenharmony_cistatic void __exit ifemark_cleanup_module(void) 638c2ecf20Sopenharmony_ci{ 648c2ecf20Sopenharmony_ci unregister_ife_op(&ife_skbmark_ops); 658c2ecf20Sopenharmony_ci} 668c2ecf20Sopenharmony_ci 678c2ecf20Sopenharmony_cimodule_init(ifemark_init_module); 688c2ecf20Sopenharmony_cimodule_exit(ifemark_cleanup_module); 698c2ecf20Sopenharmony_ci 708c2ecf20Sopenharmony_ciMODULE_AUTHOR("Jamal Hadi Salim(2015)"); 718c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("Inter-FE skb mark metadata module"); 728c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL"); 738c2ecf20Sopenharmony_ciMODULE_ALIAS_IFE_META("skbmark"); 74