18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * net/sched/act_meta_tc_index.c IFE skb->tc_index metadata module 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * copyright Jamal Hadi Salim (2016) 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 skbtcindex_encode(struct sk_buff *skb, void *skbdata, 228c2ecf20Sopenharmony_ci struct tcf_meta_info *e) 238c2ecf20Sopenharmony_ci{ 248c2ecf20Sopenharmony_ci u32 ifetc_index = skb->tc_index; 258c2ecf20Sopenharmony_ci 268c2ecf20Sopenharmony_ci return ife_encode_meta_u16(ifetc_index, skbdata, e); 278c2ecf20Sopenharmony_ci} 288c2ecf20Sopenharmony_ci 298c2ecf20Sopenharmony_cistatic int skbtcindex_decode(struct sk_buff *skb, void *data, u16 len) 308c2ecf20Sopenharmony_ci{ 318c2ecf20Sopenharmony_ci u16 ifetc_index = *(u16 *)data; 328c2ecf20Sopenharmony_ci 338c2ecf20Sopenharmony_ci skb->tc_index = ntohs(ifetc_index); 348c2ecf20Sopenharmony_ci return 0; 358c2ecf20Sopenharmony_ci} 368c2ecf20Sopenharmony_ci 378c2ecf20Sopenharmony_cistatic int skbtcindex_check(struct sk_buff *skb, struct tcf_meta_info *e) 388c2ecf20Sopenharmony_ci{ 398c2ecf20Sopenharmony_ci return ife_check_meta_u16(skb->tc_index, e); 408c2ecf20Sopenharmony_ci} 418c2ecf20Sopenharmony_ci 428c2ecf20Sopenharmony_cistatic struct tcf_meta_ops ife_skbtcindex_ops = { 438c2ecf20Sopenharmony_ci .metaid = IFE_META_TCINDEX, 448c2ecf20Sopenharmony_ci .metatype = NLA_U16, 458c2ecf20Sopenharmony_ci .name = "tc_index", 468c2ecf20Sopenharmony_ci .synopsis = "skb tc_index 16 bit metadata", 478c2ecf20Sopenharmony_ci .check_presence = skbtcindex_check, 488c2ecf20Sopenharmony_ci .encode = skbtcindex_encode, 498c2ecf20Sopenharmony_ci .decode = skbtcindex_decode, 508c2ecf20Sopenharmony_ci .get = ife_get_meta_u16, 518c2ecf20Sopenharmony_ci .alloc = ife_alloc_meta_u16, 528c2ecf20Sopenharmony_ci .release = ife_release_meta_gen, 538c2ecf20Sopenharmony_ci .validate = ife_validate_meta_u16, 548c2ecf20Sopenharmony_ci .owner = THIS_MODULE, 558c2ecf20Sopenharmony_ci}; 568c2ecf20Sopenharmony_ci 578c2ecf20Sopenharmony_cistatic int __init ifetc_index_init_module(void) 588c2ecf20Sopenharmony_ci{ 598c2ecf20Sopenharmony_ci return register_ife_op(&ife_skbtcindex_ops); 608c2ecf20Sopenharmony_ci} 618c2ecf20Sopenharmony_ci 628c2ecf20Sopenharmony_cistatic void __exit ifetc_index_cleanup_module(void) 638c2ecf20Sopenharmony_ci{ 648c2ecf20Sopenharmony_ci unregister_ife_op(&ife_skbtcindex_ops); 658c2ecf20Sopenharmony_ci} 668c2ecf20Sopenharmony_ci 678c2ecf20Sopenharmony_cimodule_init(ifetc_index_init_module); 688c2ecf20Sopenharmony_cimodule_exit(ifetc_index_cleanup_module); 698c2ecf20Sopenharmony_ci 708c2ecf20Sopenharmony_ciMODULE_AUTHOR("Jamal Hadi Salim(2016)"); 718c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("Inter-FE skb tc_index metadata module"); 728c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL"); 738c2ecf20Sopenharmony_ciMODULE_ALIAS_IFE_META("tcindex"); 74