Server IP : 172.67.216.182 / Your IP : 104.23.175.231 Web Server : Apache System : Linux krdc-ubuntu-s-2vcpu-4gb-amd-blr1-01.localdomain 5.15.0-142-generic #152-Ubuntu SMP Mon May 19 10:54:31 UTC 2025 x86_64 User : www ( 1000) PHP Version : 7.4.33 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /usr/src/linux-headers-5.15.0-142/include/net/tc_act/ |
Upload File : |
/* SPDX-License-Identifier: GPL-2.0-or-later */ /* Copyright 2020 NXP */ #ifndef __NET_TC_GATE_H #define __NET_TC_GATE_H #include <net/act_api.h> #include <linux/tc_act/tc_gate.h> struct action_gate_entry { u8 gate_state; u32 interval; s32 ipv; s32 maxoctets; }; struct tcfg_gate_entry { int index; u8 gate_state; u32 interval; s32 ipv; s32 maxoctets; struct list_head list; }; struct tcf_gate_params { s32 tcfg_priority; u64 tcfg_basetime; u64 tcfg_cycletime; u64 tcfg_cycletime_ext; u32 tcfg_flags; s32 tcfg_clockid; size_t num_entries; struct list_head entries; }; #define GATE_ACT_GATE_OPEN BIT(0) #define GATE_ACT_PENDING BIT(1) struct tcf_gate { struct tc_action common; struct tcf_gate_params param; u8 current_gate_status; ktime_t current_close_time; u32 current_entry_octets; s32 current_max_octets; struct tcfg_gate_entry *next_entry; struct hrtimer hitimer; enum tk_offsets tk_offset; }; #define to_gate(a) ((struct tcf_gate *)a) static inline bool is_tcf_gate(const struct tc_action *a) { #ifdef CONFIG_NET_CLS_ACT if (a->ops && a->ops->id == TCA_ID_GATE) return true; #endif return false; } static inline u32 tcf_gate_index(const struct tc_action *a) { return a->tcfa_index; } static inline s32 tcf_gate_prio(const struct tc_action *a) { s32 tcfg_prio; tcfg_prio = to_gate(a)->param.tcfg_priority; return tcfg_prio; } static inline u64 tcf_gate_basetime(const struct tc_action *a) { u64 tcfg_basetime; tcfg_basetime = to_gate(a)->param.tcfg_basetime; return tcfg_basetime; } static inline u64 tcf_gate_cycletime(const struct tc_action *a) { u64 tcfg_cycletime; tcfg_cycletime = to_gate(a)->param.tcfg_cycletime; return tcfg_cycletime; } static inline u64 tcf_gate_cycletimeext(const struct tc_action *a) { u64 tcfg_cycletimeext; tcfg_cycletimeext = to_gate(a)->param.tcfg_cycletime_ext; return tcfg_cycletimeext; } static inline u32 tcf_gate_num_entries(const struct tc_action *a) { u32 num_entries; num_entries = to_gate(a)->param.num_entries; return num_entries; } static inline struct action_gate_entry *tcf_gate_get_list(const struct tc_action *a) { struct action_gate_entry *oe; struct tcf_gate_params *p; struct tcfg_gate_entry *entry; u32 num_entries; int i = 0; p = &to_gate(a)->param; num_entries = p->num_entries; list_for_each_entry(entry, &p->entries, list) i++; if (i != num_entries) return NULL; oe = kcalloc(num_entries, sizeof(*oe), GFP_ATOMIC); if (!oe) return NULL; i = 0; list_for_each_entry(entry, &p->entries, list) { oe[i].gate_state = entry->gate_state; oe[i].interval = entry->interval; oe[i].ipv = entry->ipv; oe[i].maxoctets = entry->maxoctets; i++; } return oe; } #endif