Thomas Graf | 63d886c | 2005-07-05 15:29:16 -0700 | [diff] [blame] | 1 | /* |
| 2 | * net/sched/sch_blackhole.c Black hole queue |
| 3 | * |
| 4 | * This program is free software; you can redistribute it and/or |
| 5 | * modify it under the terms of the GNU General Public License |
| 6 | * as published by the Free Software Foundation; either version |
| 7 | * 2 of the License, or (at your option) any later version. |
| 8 | * |
| 9 | * Authors: Thomas Graf <tgraf@suug.ch> |
| 10 | * |
| 11 | * Note: Quantum tunneling is not supported. |
| 12 | */ |
| 13 | |
Paul Gortmaker | 075640e | 2015-10-07 17:27:45 -0400 | [diff] [blame] | 14 | #include <linux/init.h> |
Thomas Graf | 63d886c | 2005-07-05 15:29:16 -0700 | [diff] [blame] | 15 | #include <linux/types.h> |
| 16 | #include <linux/kernel.h> |
Thomas Graf | 63d886c | 2005-07-05 15:29:16 -0700 | [diff] [blame] | 17 | #include <linux/skbuff.h> |
| 18 | #include <net/pkt_sched.h> |
| 19 | |
Eric Dumazet | 520ac30 | 2016-06-21 23:16:49 -0700 | [diff] [blame] | 20 | static int blackhole_enqueue(struct sk_buff *skb, struct Qdisc *sch, |
| 21 | struct sk_buff **to_free) |
Thomas Graf | 63d886c | 2005-07-05 15:29:16 -0700 | [diff] [blame] | 22 | { |
Eric Dumazet | 520ac30 | 2016-06-21 23:16:49 -0700 | [diff] [blame] | 23 | qdisc_drop(skb, sch, to_free); |
Konstantin Khlebnikov | 7e85dc8 | 2018-06-15 13:27:31 +0300 | [diff] [blame] | 24 | return NET_XMIT_SUCCESS | __NET_XMIT_BYPASS; |
Thomas Graf | 63d886c | 2005-07-05 15:29:16 -0700 | [diff] [blame] | 25 | } |
| 26 | |
| 27 | static struct sk_buff *blackhole_dequeue(struct Qdisc *sch) |
| 28 | { |
| 29 | return NULL; |
| 30 | } |
| 31 | |
Eric Dumazet | 20fea08 | 2007-11-14 01:44:41 -0800 | [diff] [blame] | 32 | static struct Qdisc_ops blackhole_qdisc_ops __read_mostly = { |
Thomas Graf | 63d886c | 2005-07-05 15:29:16 -0700 | [diff] [blame] | 33 | .id = "blackhole", |
| 34 | .priv_size = 0, |
| 35 | .enqueue = blackhole_enqueue, |
| 36 | .dequeue = blackhole_dequeue, |
Jarek Poplawski | 8e3af97 | 2008-10-31 00:45:55 -0700 | [diff] [blame] | 37 | .peek = blackhole_dequeue, |
Thomas Graf | 63d886c | 2005-07-05 15:29:16 -0700 | [diff] [blame] | 38 | .owner = THIS_MODULE, |
| 39 | }; |
| 40 | |
Paul Gortmaker | 075640e | 2015-10-07 17:27:45 -0400 | [diff] [blame] | 41 | static int __init blackhole_init(void) |
Thomas Graf | 63d886c | 2005-07-05 15:29:16 -0700 | [diff] [blame] | 42 | { |
| 43 | return register_qdisc(&blackhole_qdisc_ops); |
| 44 | } |
Paul Gortmaker | 075640e | 2015-10-07 17:27:45 -0400 | [diff] [blame] | 45 | device_initcall(blackhole_init) |