Qdisc performance suffers when packets are dropped at enqueue() time because drops (kfree_skb()) are done while qdisc lock is held, delaying a dequeue() draining the queue. Nominal throughput can be reduced by 50 % when this happens, at a time we would like the dequeue() to proceed as fast as possible. Even FQ is vulnerable to this problem, while one of FQ goals was to provide some flow isolation. This patch adds a 'struct sk_buff **to_free' parameter to all qdisc->enqueue(), and in qdisc_drop() helper. I measured a performance increase of up to 12 %, but this patch is a prereq so that future batches in enqueue() can fly. Signed-off-by: Eric Dumazet <edumazet@google.com> Acked-by: Jesper Dangaard Brouer <brouer@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * net/sched/sch_blackhole.c	Black hole queue
 | |
|  *
 | |
|  *		This program is free software; you can redistribute it and/or
 | |
|  *		modify it under the terms of the GNU General Public License
 | |
|  *		as published by the Free Software Foundation; either version
 | |
|  *		2 of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * Authors:	Thomas Graf <tgraf@suug.ch>
 | |
|  *
 | |
|  * Note: Quantum tunneling is not supported.
 | |
|  */
 | |
| 
 | |
| #include <linux/init.h>
 | |
| #include <linux/types.h>
 | |
| #include <linux/kernel.h>
 | |
| #include <linux/skbuff.h>
 | |
| #include <net/pkt_sched.h>
 | |
| 
 | |
| static int blackhole_enqueue(struct sk_buff *skb, struct Qdisc *sch,
 | |
| 			     struct sk_buff **to_free)
 | |
| {
 | |
| 	qdisc_drop(skb, sch, to_free);
 | |
| 	return NET_XMIT_SUCCESS;
 | |
| }
 | |
| 
 | |
| static struct sk_buff *blackhole_dequeue(struct Qdisc *sch)
 | |
| {
 | |
| 	return NULL;
 | |
| }
 | |
| 
 | |
| static struct Qdisc_ops blackhole_qdisc_ops __read_mostly = {
 | |
| 	.id		= "blackhole",
 | |
| 	.priv_size	= 0,
 | |
| 	.enqueue	= blackhole_enqueue,
 | |
| 	.dequeue	= blackhole_dequeue,
 | |
| 	.peek		= blackhole_dequeue,
 | |
| 	.owner		= THIS_MODULE,
 | |
| };
 | |
| 
 | |
| static int __init blackhole_init(void)
 | |
| {
 | |
| 	return register_qdisc(&blackhole_qdisc_ops);
 | |
| }
 | |
| device_initcall(blackhole_init)
 |