mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	net sched actions: Complete the JUMPX opcode
per discussion at netconf/netdev: When we have an action that is capable of branching (example a policer), we can achieve a continuation of the action graph by programming a "continue" where we find an exact replica of the same filter rule with a lower priority and the remainder of the action graph. When you have 100s of thousands of filters which require such a feature it gets very inefficient to do two lookups. This patch completes a leftover feature of action codes. Its time has come. Example below where a user labels packets with a different skbmark on ingress of a port depending on whether they have/not exceeded the configured rate. This mark is then used to make further decisions on some egress port. #rate control, very low so we can easily see the effect sudo $TC actions add action police rate 1kbit burst 90k \ conform-exceed pipe/jump 2 index 10 # skbedit index 11 will be used if the user conforms sudo $TC actions add action skbedit mark 11 ok index 11 # skbedit index 12 will be used if the user does not conform sudo $TC actions add action skbedit mark 12 ok index 12 #lets bind the user .. sudo $TC filter add dev $ETH parent ffff: protocol ip prio 8 u32 \ match ip dst 127.0.0.8/32 flowid 1:10 \ action police index 10 \ action skbedit index 11 \ action skbedit index 12 #run a ping -f and see what happens.. # jhs@foobar:~$ sudo $TC -s filter ls dev $ETH parent ffff: protocol ip filter pref 8 u32 filter pref 8 u32 fh 800: ht divisor 1 filter pref 8 u32 fh 800::800 order 2048 key ht 800 bkt 0 flowid 1:10 (rule hit 2800 success 1005) match 7f000008/ffffffff at 16 (success 1005 ) action order 1: police 0xa rate 1Kbit burst 23440b mtu 2Kb action pipe/jump 2 overhead 0b ref 2 bind 1 installed 207 sec used 122 sec Action statistics: Sent 84420 bytes 1005 pkt (dropped 0, overlimits 721 requeues 0) backlog 0b 0p requeues 0 action order 2: skbedit mark 11 pass index 11 ref 2 bind 1 installed 204 sec used 122 sec Action statistics: Sent 60564 bytes 721 pkt (dropped 0, overlimits 0 requeues 0) backlog 0b 0p requeues 0 action order 3: skbedit mark 12 pass index 12 ref 2 bind 1 installed 201 sec used 122 sec Action statistics: Sent 23856 bytes 284 pkt (dropped 0, overlimits 0 requeues 0) backlog 0b 0p requeues 0 Not bad, about 28% non-conforming packets.. Signed-off-by: Jamal Hadi Salim <jhs@mojatatu.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									45a6f3bca6
								
							
						
					
					
						commit
						e0ee84ded7
					
				
					 1 changed files with 25 additions and 0 deletions
				
			
		| 
						 | 
				
			
			@ -428,24 +428,49 @@ static struct tc_action_ops *tc_lookup_action(struct nlattr *kind)
 | 
			
		|||
	return res;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/*TCA_ACT_MAX_PRIO is 32, there count upto 32 */
 | 
			
		||||
#define TCA_ACT_MAX_PRIO_MASK 0x1FF
 | 
			
		||||
int tcf_action_exec(struct sk_buff *skb, struct tc_action **actions,
 | 
			
		||||
		    int nr_actions, struct tcf_result *res)
 | 
			
		||||
{
 | 
			
		||||
	int ret = -1, i;
 | 
			
		||||
	u32 jmp_prgcnt = 0;
 | 
			
		||||
	u32 jmp_ttl = TCA_ACT_MAX_PRIO; /*matches actions per filter */
 | 
			
		||||
 | 
			
		||||
	if (skb_skip_tc_classify(skb))
 | 
			
		||||
		return TC_ACT_OK;
 | 
			
		||||
 | 
			
		||||
restart_act_graph:
 | 
			
		||||
	for (i = 0; i < nr_actions; i++) {
 | 
			
		||||
		const struct tc_action *a = actions[i];
 | 
			
		||||
 | 
			
		||||
		if (jmp_prgcnt > 0) {
 | 
			
		||||
			jmp_prgcnt -= 1;
 | 
			
		||||
			continue;
 | 
			
		||||
		}
 | 
			
		||||
repeat:
 | 
			
		||||
		ret = a->ops->act(skb, a, res);
 | 
			
		||||
		if (ret == TC_ACT_REPEAT)
 | 
			
		||||
			goto repeat;	/* we need a ttl - JHS */
 | 
			
		||||
 | 
			
		||||
		if (ret & TC_ACT_JUMP) {
 | 
			
		||||
			jmp_prgcnt = ret & TCA_ACT_MAX_PRIO_MASK;
 | 
			
		||||
			if (!jmp_prgcnt || (jmp_prgcnt > nr_actions)) {
 | 
			
		||||
				/* faulty opcode, stop pipeline */
 | 
			
		||||
				return TC_ACT_OK;
 | 
			
		||||
			} else {
 | 
			
		||||
				jmp_ttl -= 1;
 | 
			
		||||
				if (jmp_ttl > 0)
 | 
			
		||||
					goto restart_act_graph;
 | 
			
		||||
				else /* faulty graph, stop pipeline */
 | 
			
		||||
					return TC_ACT_OK;
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		if (ret != TC_ACT_PIPE)
 | 
			
		||||
			break;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return ret;
 | 
			
		||||
}
 | 
			
		||||
EXPORT_SYMBOL(tcf_action_exec);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue