18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * net/sched/act_meta_prio.c IFE skb->priority 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 skbprio_check(struct sk_buff *skb, struct tcf_meta_info *e) 228c2ecf20Sopenharmony_ci{ 238c2ecf20Sopenharmony_ci return ife_check_meta_u32(skb->priority, e); 248c2ecf20Sopenharmony_ci} 258c2ecf20Sopenharmony_ci 268c2ecf20Sopenharmony_cistatic int skbprio_encode(struct sk_buff *skb, void *skbdata, 278c2ecf20Sopenharmony_ci struct tcf_meta_info *e) 288c2ecf20Sopenharmony_ci{ 298c2ecf20Sopenharmony_ci u32 ifeprio = skb->priority; /* avoid having to cast skb->priority*/ 308c2ecf20Sopenharmony_ci 318c2ecf20Sopenharmony_ci return ife_encode_meta_u32(ifeprio, skbdata, e); 328c2ecf20Sopenharmony_ci} 338c2ecf20Sopenharmony_ci 348c2ecf20Sopenharmony_cistatic int skbprio_decode(struct sk_buff *skb, void *data, u16 len) 358c2ecf20Sopenharmony_ci{ 368c2ecf20Sopenharmony_ci u32 ifeprio = *(u32 *)data; 378c2ecf20Sopenharmony_ci 388c2ecf20Sopenharmony_ci skb->priority = ntohl(ifeprio); 398c2ecf20Sopenharmony_ci return 0; 408c2ecf20Sopenharmony_ci} 418c2ecf20Sopenharmony_ci 428c2ecf20Sopenharmony_cistatic struct tcf_meta_ops ife_prio_ops = { 438c2ecf20Sopenharmony_ci .metaid = IFE_META_PRIO, 448c2ecf20Sopenharmony_ci .metatype = NLA_U32, 458c2ecf20Sopenharmony_ci .name = "skbprio", 468c2ecf20Sopenharmony_ci .synopsis = "skb prio metadata", 478c2ecf20Sopenharmony_ci .check_presence = skbprio_check, 488c2ecf20Sopenharmony_ci .encode = skbprio_encode, 498c2ecf20Sopenharmony_ci .decode = skbprio_decode, 508c2ecf20Sopenharmony_ci .get = ife_get_meta_u32, 518c2ecf20Sopenharmony_ci .alloc = ife_alloc_meta_u32, 528c2ecf20Sopenharmony_ci .owner = THIS_MODULE, 538c2ecf20Sopenharmony_ci}; 548c2ecf20Sopenharmony_ci 558c2ecf20Sopenharmony_cistatic int __init ifeprio_init_module(void) 568c2ecf20Sopenharmony_ci{ 578c2ecf20Sopenharmony_ci return register_ife_op(&ife_prio_ops); 588c2ecf20Sopenharmony_ci} 598c2ecf20Sopenharmony_ci 608c2ecf20Sopenharmony_cistatic void __exit ifeprio_cleanup_module(void) 618c2ecf20Sopenharmony_ci{ 628c2ecf20Sopenharmony_ci unregister_ife_op(&ife_prio_ops); 638c2ecf20Sopenharmony_ci} 648c2ecf20Sopenharmony_ci 658c2ecf20Sopenharmony_cimodule_init(ifeprio_init_module); 668c2ecf20Sopenharmony_cimodule_exit(ifeprio_cleanup_module); 678c2ecf20Sopenharmony_ci 688c2ecf20Sopenharmony_ciMODULE_AUTHOR("Jamal Hadi Salim(2015)"); 698c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("Inter-FE skb prio metadata action"); 708c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL"); 718c2ecf20Sopenharmony_ciMODULE_ALIAS_IFE_META("skbprio"); 72