2019-05-27 14:55:01 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2005-07-06 06:29:16 +08:00
|
|
|
/*
|
|
|
|
* net/sched/sch_blackhole.c Black hole queue
|
|
|
|
*
|
|
|
|
* Authors: Thomas Graf <tgraf@suug.ch>
|
|
|
|
*
|
|
|
|
* Note: Quantum tunneling is not supported.
|
|
|
|
*/
|
|
|
|
|
2015-10-08 05:27:45 +08:00
|
|
|
#include <linux/init.h>
|
2005-07-06 06:29:16 +08:00
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/kernel.h>
|
|
|
|
#include <linux/skbuff.h>
|
|
|
|
#include <net/pkt_sched.h>
|
|
|
|
|
2020-06-27 06:45:25 +08:00
|
|
|
static int blackhole_enqueue(struct sk_buff *skb, struct Qdisc *sch, spinlock_t *root_lock,
|
2016-06-22 14:16:49 +08:00
|
|
|
struct sk_buff **to_free)
|
2005-07-06 06:29:16 +08:00
|
|
|
{
|
2016-06-22 14:16:49 +08:00
|
|
|
qdisc_drop(skb, sch, to_free);
|
2018-06-15 18:27:31 +08:00
|
|
|
return NET_XMIT_SUCCESS | __NET_XMIT_BYPASS;
|
2005-07-06 06:29:16 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static struct sk_buff *blackhole_dequeue(struct Qdisc *sch)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2007-11-14 17:44:41 +08:00
|
|
|
static struct Qdisc_ops blackhole_qdisc_ops __read_mostly = {
|
2005-07-06 06:29:16 +08:00
|
|
|
.id = "blackhole",
|
|
|
|
.priv_size = 0,
|
|
|
|
.enqueue = blackhole_enqueue,
|
|
|
|
.dequeue = blackhole_dequeue,
|
2008-10-31 15:45:55 +08:00
|
|
|
.peek = blackhole_dequeue,
|
2005-07-06 06:29:16 +08:00
|
|
|
.owner = THIS_MODULE,
|
|
|
|
};
|
|
|
|
|
2015-10-08 05:27:45 +08:00
|
|
|
static int __init blackhole_init(void)
|
2005-07-06 06:29:16 +08:00
|
|
|
{
|
|
|
|
return register_qdisc(&blackhole_qdisc_ops);
|
|
|
|
}
|
2015-10-08 05:27:45 +08:00
|
|
|
device_initcall(blackhole_init)
|