blob: 1e8ab4749c6c3cd81501bd0109469f7aecf945aa [file] [log] [blame]
Thomas Gleixnerec8f24b2019-05-19 13:07:45 +01001# SPDX-License-Identifier: GPL-2.0-only
Linus Torvalds1da177e2005-04-16 15:20:36 -07002#
3# Traffic control configuration.
Stephen Hemminger50f699b2018-07-24 12:29:01 -07004#
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -07005
Randy Dunlap85ef3e52007-10-18 21:56:38 -07006menuconfig NET_SCHED
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -07007 bool "QoS and/or fair queueing"
David Kimdon3c62f752006-11-09 16:16:21 -08008 select NET_SCH_FIFO
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +09009 help
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -070010 When the kernel has several packets to send out over a network
11 device, it has to decide which ones to send first, which ones to
Thomas Graf52ab4ac2005-11-01 15:13:02 +010012 delay, and which ones to drop. This is the job of the queueing
13 disciplines, several different algorithms for how to do this
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -070014 "fairly" have been proposed.
15
16 If you say N here, you will get the standard packet scheduler, which
17 is a FIFO (first come, first served). If you say Y here, you will be
18 able to choose from among several alternative algorithms which can
19 then be attached to different network devices. This is useful for
20 example if some of your network devices are real time devices that
21 need a certain minimum data flow rate, or if you need to limit the
22 maximum data flow rate for traffic which matches specified criteria.
23 This code is considered to be experimental.
24
25 To administer these schedulers, you'll need the user-level utilities
Andrew Shewmaker5d330cd2014-12-03 14:07:31 -080026 from the package iproute2+tc at
27 <https://www.kernel.org/pub/linux/utils/net/iproute2/>. That package
28 also contains some documentation; for more, check out
Michael Wittenc996d8b2010-11-15 19:55:34 +000029 <http://www.linuxfoundation.org/collaborate/workgroups/networking/iproute2>.
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -070030
31 This Quality of Service (QoS) support will enable you to use
32 Differentiated Services (diffserv) and Resource Reservation Protocol
Thomas Graf52ab4ac2005-11-01 15:13:02 +010033 (RSVP) on your Linux router if you also say Y to the corresponding
34 classifiers below. Documentation and software is at
35 <http://diffserv.sourceforge.net/>.
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -070036
37 If you say Y here and to "/proc file system" below, you will be able
38 to read status information about packet schedulers from the file
39 /proc/net/psched.
40
41 The available schedulers are listed in the following questions; you
42 can say Y to as many as you like. If unsure, say N now.
43
Roman Zippel05b8b0f2005-11-17 15:22:39 -080044if NET_SCHED
45
Thomas Graf52ab4ac2005-11-01 15:13:02 +010046comment "Queueing/Scheduling"
Thomas Graf52ab4ac2005-11-01 15:13:02 +010047
Linus Torvalds1da177e2005-04-16 15:20:36 -070048config NET_SCH_CBQ
Thomas Graf52ab4ac2005-11-01 15:13:02 +010049 tristate "Class Based Queueing (CBQ)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +090050 help
Linus Torvalds1da177e2005-04-16 15:20:36 -070051 Say Y here if you want to use the Class-Based Queueing (CBQ) packet
Thomas Graf52ab4ac2005-11-01 15:13:02 +010052 scheduling algorithm. This algorithm classifies the waiting packets
53 into a tree-like hierarchy of classes; the leaves of this tree are
54 in turn scheduled by separate algorithms.
Linus Torvalds1da177e2005-04-16 15:20:36 -070055
Thomas Graf52ab4ac2005-11-01 15:13:02 +010056 See the top of <file:net/sched/sch_cbq.c> for more details.
Linus Torvalds1da177e2005-04-16 15:20:36 -070057
58 CBQ is a commonly used scheduler, so if you're unsure, you should
59 say Y here. Then say Y to all the queueing algorithms below that you
Thomas Graf52ab4ac2005-11-01 15:13:02 +010060 want to use as leaf disciplines.
Linus Torvalds1da177e2005-04-16 15:20:36 -070061
62 To compile this code as a module, choose M here: the
63 module will be called sch_cbq.
64
65config NET_SCH_HTB
Thomas Graf52ab4ac2005-11-01 15:13:02 +010066 tristate "Hierarchical Token Bucket (HTB)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +090067 help
Linus Torvalds1da177e2005-04-16 15:20:36 -070068 Say Y here if you want to use the Hierarchical Token Buckets (HTB)
Thomas Graf52ab4ac2005-11-01 15:13:02 +010069 packet scheduling algorithm. See
Linus Torvalds1da177e2005-04-16 15:20:36 -070070 <http://luxik.cdi.cz/~devik/qos/htb/> for complete manual and
71 in-depth articles.
72
Thomas Graf52ab4ac2005-11-01 15:13:02 +010073 HTB is very similar to CBQ regarding its goals however is has
Linus Torvalds1da177e2005-04-16 15:20:36 -070074 different properties and different algorithm.
75
76 To compile this code as a module, choose M here: the
77 module will be called sch_htb.
78
79config NET_SCH_HFSC
Thomas Graf52ab4ac2005-11-01 15:13:02 +010080 tristate "Hierarchical Fair Service Curve (HFSC)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +090081 help
Linus Torvalds1da177e2005-04-16 15:20:36 -070082 Say Y here if you want to use the Hierarchical Fair Service Curve
Thomas Graf52ab4ac2005-11-01 15:13:02 +010083 (HFSC) packet scheduling algorithm.
Linus Torvalds1da177e2005-04-16 15:20:36 -070084
85 To compile this code as a module, choose M here: the
86 module will be called sch_hfsc.
87
Linus Torvalds1da177e2005-04-16 15:20:36 -070088config NET_SCH_ATM
Thomas Graf52ab4ac2005-11-01 15:13:02 +010089 tristate "ATM Virtual Circuits (ATM)"
Roman Zippel05b8b0f2005-11-17 15:22:39 -080090 depends on ATM
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +090091 help
Linus Torvalds1da177e2005-04-16 15:20:36 -070092 Say Y here if you want to use the ATM pseudo-scheduler. This
Thomas Graf52ab4ac2005-11-01 15:13:02 +010093 provides a framework for invoking classifiers, which in turn
94 select classes of this queuing discipline. Each class maps
95 the flow(s) it is handling to a given virtual circuit.
96
Gabriel Craciunescu99acaeb2007-07-18 02:00:04 -070097 See the top of <file:net/sched/sch_atm.c> for more details.
Linus Torvalds1da177e2005-04-16 15:20:36 -070098
99 To compile this code as a module, choose M here: the
100 module will be called sch_atm.
101
102config NET_SCH_PRIO
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100103 tristate "Multi Band Priority Queueing (PRIO)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900104 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700105 Say Y here if you want to use an n-band priority queue packet
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100106 scheduler.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700107
108 To compile this code as a module, choose M here: the
109 module will be called sch_prio.
110
Alexander Duyck92651942008-09-12 16:29:34 -0700111config NET_SCH_MULTIQ
112 tristate "Hardware Multiqueue-aware Multi Band Queuing (MULTIQ)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900113 help
Alexander Duyck92651942008-09-12 16:29:34 -0700114 Say Y here if you want to use an n-band queue packet scheduler
115 to support devices that have multiple hardware transmit queues.
116
117 To compile this code as a module, choose M here: the
118 module will be called sch_multiq.
119
Linus Torvalds1da177e2005-04-16 15:20:36 -0700120config NET_SCH_RED
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100121 tristate "Random Early Detection (RED)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900122 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700123 Say Y here if you want to use the Random Early Detection (RED)
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100124 packet scheduling algorithm.
125
126 See the top of <file:net/sched/sch_red.c> for more details.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700127
128 To compile this code as a module, choose M here: the
129 module will be called sch_red.
130
Eric Dumazete13e02a2011-02-23 10:56:17 +0000131config NET_SCH_SFB
132 tristate "Stochastic Fair Blue (SFB)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900133 help
Eric Dumazete13e02a2011-02-23 10:56:17 +0000134 Say Y here if you want to use the Stochastic Fair Blue (SFB)
135 packet scheduling algorithm.
136
137 See the top of <file:net/sched/sch_sfb.c> for more details.
138
139 To compile this code as a module, choose M here: the
140 module will be called sch_sfb.
141
Linus Torvalds1da177e2005-04-16 15:20:36 -0700142config NET_SCH_SFQ
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100143 tristate "Stochastic Fairness Queueing (SFQ)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900144 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700145 Say Y here if you want to use the Stochastic Fairness Queueing (SFQ)
Gabriel Craciunescu99acaeb2007-07-18 02:00:04 -0700146 packet scheduling algorithm.
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100147
148 See the top of <file:net/sched/sch_sfq.c> for more details.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700149
150 To compile this code as a module, choose M here: the
151 module will be called sch_sfq.
152
153config NET_SCH_TEQL
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100154 tristate "True Link Equalizer (TEQL)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900155 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700156 Say Y here if you want to use the True Link Equalizer (TLE) packet
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100157 scheduling algorithm. This queueing discipline allows the combination
158 of several physical devices into one virtual device.
159
160 See the top of <file:net/sched/sch_teql.c> for more details.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700161
162 To compile this code as a module, choose M here: the
163 module will be called sch_teql.
164
165config NET_SCH_TBF
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100166 tristate "Token Bucket Filter (TBF)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900167 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100168 Say Y here if you want to use the Token Bucket Filter (TBF) packet
169 scheduling algorithm.
170
171 See the top of <file:net/sched/sch_tbf.c> for more details.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700172
173 To compile this code as a module, choose M here: the
174 module will be called sch_tbf.
175
Vinicius Costa Gomes585d7632017-10-16 18:01:26 -0700176config NET_SCH_CBS
177 tristate "Credit Based Shaper (CBS)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900178 help
Vinicius Costa Gomes585d7632017-10-16 18:01:26 -0700179 Say Y here if you want to use the Credit Based Shaper (CBS) packet
180 scheduling algorithm.
181
182 See the top of <file:net/sched/sch_cbs.c> for more details.
183
184 To compile this code as a module, choose M here: the
185 module will be called sch_cbs.
186
Vinicius Costa Gomes25db26a2018-07-03 15:42:53 -0700187config NET_SCH_ETF
188 tristate "Earliest TxTime First (ETF)"
189 help
190 Say Y here if you want to use the Earliest TxTime First (ETF) packet
191 scheduling algorithm.
192
193 See the top of <file:net/sched/sch_etf.c> for more details.
194
195 To compile this code as a module, choose M here: the
196 module will be called sch_etf.
197
Vinicius Costa Gomes5a781cc2018-09-28 17:59:43 -0700198config NET_SCH_TAPRIO
199 tristate "Time Aware Priority (taprio) Scheduler"
200 help
201 Say Y here if you want to use the Time Aware Priority (taprio) packet
202 scheduling algorithm.
203
204 See the top of <file:net/sched/sch_taprio.c> for more details.
205
206 To compile this code as a module, choose M here: the
207 module will be called sch_taprio.
208
Linus Torvalds1da177e2005-04-16 15:20:36 -0700209config NET_SCH_GRED
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100210 tristate "Generic Random Early Detection (GRED)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900211 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700212 Say Y here if you want to use the Generic Random Early Detection
Lucas Correia Villa Real20cc6be2005-05-03 14:34:20 -0700213 (GRED) packet scheduling algorithm for some of your network devices
Linus Torvalds1da177e2005-04-16 15:20:36 -0700214 (see the top of <file:net/sched/sch_red.c> for details and
215 references about the algorithm).
216
217 To compile this code as a module, choose M here: the
218 module will be called sch_gred.
219
220config NET_SCH_DSMARK
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100221 tristate "Differentiated Services marker (DSMARK)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900222 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700223 Say Y if you want to schedule packets according to the
224 Differentiated Services architecture proposed in RFC 2475.
225 Technical information on this method, with pointers to associated
226 RFCs, is available at <http://www.gta.ufrj.br/diffserv/>.
227
228 To compile this code as a module, choose M here: the
229 module will be called sch_dsmark.
230
231config NET_SCH_NETEM
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100232 tristate "Network emulator (NETEM)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900233 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700234 Say Y if you want to emulate network delay, loss, and packet
235 re-ordering. This is often useful to simulate networks when
236 testing applications or protocols.
237
238 To compile this driver as a module, choose M here: the module
239 will be called sch_netem.
240
241 If unsure, say N.
242
Patrick McHardy13d2a1d2008-11-20 04:10:00 -0800243config NET_SCH_DRR
244 tristate "Deficit Round Robin scheduler (DRR)"
245 help
246 Say Y here if you want to use the Deficit Round Robin (DRR) packet
247 scheduling algorithm.
248
249 To compile this driver as a module, choose M here: the module
250 will be called sch_drr.
251
252 If unsure, say N.
253
John Fastabendb8970f02011-01-17 08:06:09 +0000254config NET_SCH_MQPRIO
255 tristate "Multi-queue priority scheduler (MQPRIO)"
256 help
257 Say Y here if you want to use the Multi-queue Priority scheduler.
258 This scheduler allows QOS to be offloaded on NICs that have support
259 for offloading QOS schedulers.
260
261 To compile this driver as a module, choose M here: the module will
262 be called sch_mqprio.
263
264 If unsure, say N.
265
Nishanth Devarajanaea5f6542018-07-23 19:37:41 +0530266config NET_SCH_SKBPRIO
267 tristate "SKB priority queue scheduler (SKBPRIO)"
268 help
269 Say Y here if you want to use the SKB priority queue
270 scheduler. This schedules packets according to skb->priority,
271 which is useful for request packets in DoS mitigation systems such
272 as Gatekeeper.
273
274 To compile this driver as a module, choose M here: the module will
275 be called sch_skbprio.
276
277 If unsure, say N.
278
stephen hemminger45e14432011-02-02 15:21:10 +0000279config NET_SCH_CHOKE
280 tristate "CHOose and Keep responsive flow scheduler (CHOKE)"
281 help
282 Say Y here if you want to use the CHOKe packet scheduler (CHOose
283 and Keep for responsive flows, CHOose and Kill for unresponsive
Colin Ian King8354bcb2020-12-07 16:12:31 +0000284 flows). This is a variation of RED which tries to penalize flows
stephen hemminger45e14432011-02-02 15:21:10 +0000285 that monopolize the queue.
286
287 To compile this code as a module, choose M here: the
288 module will be called sch_choke.
289
stephen hemminger0545a302011-04-04 05:30:58 +0000290config NET_SCH_QFQ
291 tristate "Quick Fair Queueing scheduler (QFQ)"
292 help
293 Say Y here if you want to use the Quick Fair Queueing Scheduler (QFQ)
294 packet scheduling algorithm.
295
296 To compile this driver as a module, choose M here: the module
297 will be called sch_qfq.
298
299 If unsure, say N.
300
Eric Dumazet76e3cc12012-05-10 07:51:25 +0000301config NET_SCH_CODEL
302 tristate "Controlled Delay AQM (CODEL)"
303 help
304 Say Y here if you want to use the Controlled Delay (CODEL)
305 packet scheduling algorithm.
306
307 To compile this driver as a module, choose M here: the module
308 will be called sch_codel.
309
310 If unsure, say N.
311
Eric Dumazet4b549a22012-05-11 09:30:50 +0000312config NET_SCH_FQ_CODEL
313 tristate "Fair Queue Controlled Delay AQM (FQ_CODEL)"
314 help
315 Say Y here if you want to use the FQ Controlled Delay (FQ_CODEL)
316 packet scheduling algorithm.
317
318 To compile this driver as a module, choose M here: the module
319 will be called sch_fq_codel.
320
321 If unsure, say N.
322
Toke Høiland-Jørgensen046f6fd2018-07-06 17:37:19 +0200323config NET_SCH_CAKE
324 tristate "Common Applications Kept Enhanced (CAKE)"
325 help
326 Say Y here if you want to use the Common Applications Kept Enhanced
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200327 (CAKE) queue management algorithm.
Toke Høiland-Jørgensen046f6fd2018-07-06 17:37:19 +0200328
329 To compile this driver as a module, choose M here: the module
330 will be called sch_cake.
331
332 If unsure, say N.
333
Eric Dumazetafe4fd02013-08-29 15:49:55 -0700334config NET_SCH_FQ
335 tristate "Fair Queue"
336 help
337 Say Y here if you want to use the FQ packet scheduling algorithm.
338
339 FQ does flow separation, and is able to respect pacing requirements
340 set by TCP stack into sk->sk_pacing_rate (for localy generated
341 traffic)
342
343 To compile this driver as a module, choose M here: the module
344 will be called sch_fq.
345
346 If unsure, say N.
347
Terry Lam10239ed2013-12-15 00:30:21 -0800348config NET_SCH_HHF
349 tristate "Heavy-Hitter Filter (HHF)"
350 help
351 Say Y here if you want to use the Heavy-Hitter Filter (HHF)
352 packet scheduling algorithm.
353
354 To compile this driver as a module, choose M here: the module
355 will be called sch_hhf.
356
Vijay Subramaniand4b36212014-01-04 17:33:55 -0800357config NET_SCH_PIE
358 tristate "Proportional Integral controller Enhanced (PIE) scheduler"
359 help
360 Say Y here if you want to use the Proportional Integral controller
361 Enhanced scheduler packet scheduling algorithm.
Leslie Monis1f8389b2019-03-23 19:11:33 +0530362 For more information, please see https://tools.ietf.org/html/rfc8033
Vijay Subramaniand4b36212014-01-04 17:33:55 -0800363
364 To compile this driver as a module, choose M here: the module
365 will be called sch_pie.
366
367 If unsure, say N.
368
Mohit P. Tahilianiec97ecf2020-01-22 23:52:33 +0530369config NET_SCH_FQ_PIE
370 depends on NET_SCH_PIE
371 tristate "Flow Queue Proportional Integral controller Enhanced (FQ-PIE)"
372 help
373 Say Y here if you want to use the Flow Queue Proportional Integral
374 controller Enhanced (FQ-PIE) packet scheduling algorithm.
375 For more information, please see https://tools.ietf.org/html/rfc8033
376
377 To compile this driver as a module, choose M here: the module
378 will be called sch_fq_pie.
379
380 If unsure, say N.
381
Linus Torvalds1da177e2005-04-16 15:20:36 -0700382config NET_SCH_INGRESS
Daniel Borkmann1f211a12016-01-07 22:29:47 +0100383 tristate "Ingress/classifier-action Qdisc"
Patrick McHardy72eb7bd2008-01-31 16:57:15 -0800384 depends on NET_CLS_ACT
Pablo Neira1cf519002015-05-13 18:19:37 +0200385 select NET_INGRESS
Daniel Borkmann1f211a12016-01-07 22:29:47 +0100386 select NET_EGRESS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900387 help
Daniel Borkmann1f211a12016-01-07 22:29:47 +0100388 Say Y here if you want to use classifiers for incoming and/or outgoing
389 packets. This qdisc doesn't do anything else besides running classifiers,
390 which can also have actions attached to them. In case of outgoing packets,
391 classifiers that this qdisc holds are executed in the transmit path
392 before real enqueuing to an egress qdisc happens.
393
Linus Torvalds1da177e2005-04-16 15:20:36 -0700394 If unsure, say Y.
395
Daniel Borkmann1f211a12016-01-07 22:29:47 +0100396 To compile this code as a module, choose M here: the module will be
397 called sch_ingress with alias of sch_clsact.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700398
Shriram Rajagopalanc3059be2012-02-05 13:51:32 +0000399config NET_SCH_PLUG
400 tristate "Plug network traffic until release (PLUG)"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900401 help
Shriram Rajagopalanc3059be2012-02-05 13:51:32 +0000402
403 This queuing discipline allows userspace to plug/unplug a network
404 output queue, using the netlink interface. When it receives an
405 enqueue command it inserts a plug into the outbound queue that
406 causes following packets to enqueue until a dequeue command arrives
407 over netlink, causing the plug to be removed and resuming the normal
408 packet flow.
409
410 This module also provides a generic "network output buffering"
411 functionality (aka output commit), wherein upon arrival of a dequeue
412 command, only packets up to the first plug are released for delivery.
413 The Remus HA project uses this module to enable speculative execution
414 of virtual machines by allowing the generated network output to be rolled
415 back if needed.
416
Andrew Shewmaker5d330cd2014-12-03 14:07:31 -0800417 For more information, please refer to <http://wiki.xenproject.org/wiki/Remus>
Shriram Rajagopalanc3059be2012-02-05 13:51:32 +0000418
419 Say Y here if you are using this kernel for Xen dom0 and
420 want to protect Xen guests with Remus.
421
422 To compile this code as a module, choose M here: the
423 module will be called sch_plug.
424
Petr Machatadcc68b42019-12-18 14:55:13 +0000425config NET_SCH_ETS
426 tristate "Enhanced transmission selection scheduler (ETS)"
427 help
428 The Enhanced Transmission Selection scheduler is a classful
429 queuing discipline that merges functionality of PRIO and DRR
430 qdiscs in one scheduler. ETS makes it easy to configure a set of
431 strict and bandwidth-sharing bands to implement the transmission
432 selection described in 802.1Qaz.
433
434 Say Y here if you want to use the ETS packet scheduling
435 algorithm.
436
437 To compile this driver as a module, choose M here: the module
438 will be called sch_ets.
439
440 If unsure, say N.
441
stephen hemminger8ea3e432017-04-13 08:40:53 -0700442menuconfig NET_SCH_DEFAULT
443 bool "Allow override default queue discipline"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900444 help
stephen hemminger8ea3e432017-04-13 08:40:53 -0700445 Support for selection of default queuing discipline.
446
447 Nearly all users can safely say no here, and the default
448 of pfifo_fast will be used. Many distributions already set
449 the default value via /proc/sys/net/core/default_qdisc.
450
451 If unsure, say N.
452
453if NET_SCH_DEFAULT
454
455choice
456 prompt "Default queuing discipline"
457 default DEFAULT_PFIFO_FAST
458 help
459 Select the queueing discipline that will be used by default
460 for all network devices.
461
462 config DEFAULT_FQ
463 bool "Fair Queue" if NET_SCH_FQ
464
465 config DEFAULT_CODEL
466 bool "Controlled Delay" if NET_SCH_CODEL
467
468 config DEFAULT_FQ_CODEL
469 bool "Fair Queue Controlled Delay" if NET_SCH_FQ_CODEL
470
Danny Linb97e9d92020-07-01 16:01:52 -0700471 config DEFAULT_FQ_PIE
472 bool "Flow Queue Proportional Integral controller Enhanced" if NET_SCH_FQ_PIE
473
stephen hemminger8ea3e432017-04-13 08:40:53 -0700474 config DEFAULT_SFQ
475 bool "Stochastic Fair Queue" if NET_SCH_SFQ
476
477 config DEFAULT_PFIFO_FAST
478 bool "Priority FIFO Fast"
479endchoice
480
481config DEFAULT_NET_SCH
482 string
483 default "pfifo_fast" if DEFAULT_PFIFO_FAST
484 default "fq" if DEFAULT_FQ
485 default "fq_codel" if DEFAULT_FQ_CODEL
Danny Linb97e9d92020-07-01 16:01:52 -0700486 default "fq_pie" if DEFAULT_FQ_PIE
stephen hemminger8ea3e432017-04-13 08:40:53 -0700487 default "sfq" if DEFAULT_SFQ
488 default "pfifo_fast"
489endif
490
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100491comment "Classification"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700492
493config NET_CLS
Christoph Jaeger6341e622014-12-20 15:41:11 -0500494 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -0700495
496config NET_CLS_BASIC
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100497 tristate "Elementary classification (BASIC)"
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100498 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900499 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700500 Say Y here if you want to be able to classify packets using
501 only extended matches and actions.
502
503 To compile this code as a module, choose M here: the
504 module will be called cls_basic.
505
506config NET_CLS_TCINDEX
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100507 tristate "Traffic-Control Index (TCINDEX)"
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100508 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900509 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100510 Say Y here if you want to be able to classify packets based on
511 traffic control indices. You will want this feature if you want
512 to implement Differentiated Services together with DSMARK.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700513
514 To compile this code as a module, choose M here: the
515 module will be called cls_tcindex.
516
517config NET_CLS_ROUTE4
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100518 tristate "Routing decision (ROUTE)"
Randy Dunlap034cfe42011-05-19 19:23:28 -0400519 depends on INET
Patrick McHardyc7066f72011-01-14 13:36:42 +0100520 select IP_ROUTE_CLASSID
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100521 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900522 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100523 If you say Y here, you will be able to classify packets
524 according to the route table entry they matched.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700525
526 To compile this code as a module, choose M here: the
527 module will be called cls_route.
528
Linus Torvalds1da177e2005-04-16 15:20:36 -0700529config NET_CLS_FW
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100530 tristate "Netfilter mark (FW)"
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100531 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900532 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100533 If you say Y here, you will be able to classify packets
534 according to netfilter/firewall marks.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700535
536 To compile this code as a module, choose M here: the
537 module will be called cls_fw.
538
539config NET_CLS_U32
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100540 tristate "Universal 32bit comparisons w/ hashing (U32)"
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100541 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900542 help
Matt LaPlante3539c272006-06-30 18:53:46 +0200543 Say Y here to be able to classify packets using a universal
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100544 32bit pieces based comparison scheme.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700545
546 To compile this code as a module, choose M here: the
547 module will be called cls_u32.
548
549config CLS_U32_PERF
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100550 bool "Performance counters support"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700551 depends on NET_CLS_U32
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900552 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100553 Say Y here to make u32 gather additional statistics useful for
554 fine tuning u32 classifiers.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700555
556config CLS_U32_MARK
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100557 bool "Netfilter marks support"
Thomas Graf82e91ff2006-11-09 15:19:14 -0800558 depends on NET_CLS_U32
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900559 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100560 Say Y here to be able to use netfilter marks as u32 key.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700561
562config NET_CLS_RSVP
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100563 tristate "IPv4 Resource Reservation Protocol (RSVP)"
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100564 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900565 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700566 The Resource Reservation Protocol (RSVP) permits end systems to
567 request a minimum and maximum data flow rate for a connection; this
568 is important for real time data such as streaming sound or video.
569
570 Say Y here if you want to be able to classify outgoing packets based
571 on their RSVP requests.
572
573 To compile this code as a module, choose M here: the
574 module will be called cls_rsvp.
575
576config NET_CLS_RSVP6
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100577 tristate "IPv6 Resource Reservation Protocol (RSVP6)"
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100578 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900579 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700580 The Resource Reservation Protocol (RSVP) permits end systems to
581 request a minimum and maximum data flow rate for a connection; this
582 is important for real time data such as streaming sound or video.
583
584 Say Y here if you want to be able to classify outgoing packets based
Gabriel Craciunescu99acaeb2007-07-18 02:00:04 -0700585 on their RSVP requests and you are using the IPv6 protocol.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700586
587 To compile this code as a module, choose M here: the
588 module will be called cls_rsvp6.
589
Patrick McHardye5dfb812008-01-31 18:37:42 -0800590config NET_CLS_FLOW
591 tristate "Flow classifier"
592 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900593 help
Patrick McHardye5dfb812008-01-31 18:37:42 -0800594 If you say Y here, you will be able to classify packets based on
595 a configurable combination of packet keys. This is mostly useful
596 in combination with SFQ.
597
598 To compile this code as a module, choose M here: the
599 module will be called cls_flow.
600
Thomas Graff4009232008-11-07 22:56:00 -0800601config NET_CLS_CGROUP
Ben Blum8e039d82010-03-23 05:24:03 +0000602 tristate "Control Group Classifier"
Thomas Graff4009232008-11-07 22:56:00 -0800603 select NET_CLS
Daniel Borkmannfe1217c2013-12-29 18:27:10 +0100604 select CGROUP_NET_CLASSID
Thomas Graff4009232008-11-07 22:56:00 -0800605 depends on CGROUPS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900606 help
Thomas Graff4009232008-11-07 22:56:00 -0800607 Say Y here if you want to classify packets based on the control
608 cgroup of their process.
609
Ben Blum8e039d82010-03-23 05:24:03 +0000610 To compile this code as a module, choose M here: the
611 module will be called cls_cgroup.
612
Daniel Borkmann7d1d65c2013-10-28 16:43:02 +0100613config NET_CLS_BPF
614 tristate "BPF-based classifier"
615 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900616 help
Daniel Borkmann7d1d65c2013-10-28 16:43:02 +0100617 If you say Y here, you will be able to classify packets based on
618 programmable BPF (JIT'ed) filters as an alternative to ematches.
619
620 To compile this code as a module, choose M here: the module will
621 be called cls_bpf.
622
Jiri Pirko77b99002015-05-12 14:56:21 +0200623config NET_CLS_FLOWER
624 tristate "Flower classifier"
625 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900626 help
Jiri Pirko77b99002015-05-12 14:56:21 +0200627 If you say Y here, you will be able to classify packets based on
628 a configurable combination of packet keys and masks.
629
630 To compile this code as a module, choose M here: the module will
631 be called cls_flower.
632
Jiri Pirkobf3994d2016-07-21 12:03:11 +0200633config NET_CLS_MATCHALL
634 tristate "Match-all classifier"
635 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900636 help
Jiri Pirkobf3994d2016-07-21 12:03:11 +0200637 If you say Y here, you will be able to classify packets based on
638 nothing. Every packet will match.
639
640 To compile this code as a module, choose M here: the module will
641 be called cls_matchall.
642
Linus Torvalds1da177e2005-04-16 15:20:36 -0700643config NET_EMATCH
644 bool "Extended Matches"
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100645 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900646 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700647 Say Y here if you want to use extended matches on top of classifiers
648 and select the extended matches below.
649
650 Extended matches are small classification helpers not worth writing
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100651 a separate classifier for.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700652
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100653 A recent version of the iproute2 package is required to use
Linus Torvalds1da177e2005-04-16 15:20:36 -0700654 extended matches.
655
656config NET_EMATCH_STACK
657 int "Stack size"
658 depends on NET_EMATCH
659 default "32"
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900660 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700661 Size of the local stack variable used while evaluating the tree of
662 ematches. Limits the depth of the tree, i.e. the number of
Thomas Grafb8249792005-06-08 15:10:22 -0700663 encapsulated precedences. Every level requires 4 bytes of additional
Linus Torvalds1da177e2005-04-16 15:20:36 -0700664 stack space.
665
666config NET_EMATCH_CMP
667 tristate "Simple packet data comparison"
668 depends on NET_EMATCH
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900669 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700670 Say Y here if you want to be able to classify packets based on
671 simple packet data comparisons for 8, 16, and 32bit values.
672
673 To compile this code as a module, choose M here: the
674 module will be called em_cmp.
675
676config NET_EMATCH_NBYTE
677 tristate "Multi byte comparison"
678 depends on NET_EMATCH
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900679 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700680 Say Y here if you want to be able to classify packets based on
681 multiple byte comparisons mainly useful for IPv6 address comparisons.
682
683 To compile this code as a module, choose M here: the
684 module will be called em_nbyte.
685
686config NET_EMATCH_U32
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100687 tristate "U32 key"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700688 depends on NET_EMATCH
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900689 help
Linus Torvalds1da177e2005-04-16 15:20:36 -0700690 Say Y here if you want to be able to classify packets using
691 the famous u32 key in combination with logic relations.
692
693 To compile this code as a module, choose M here: the
694 module will be called em_u32.
695
696config NET_EMATCH_META
697 tristate "Metadata"
698 depends on NET_EMATCH
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900699 help
Adrian Bunkbb7e8c52006-01-11 16:40:30 -0800700 Say Y here if you want to be able to classify packets based on
Linus Torvalds1da177e2005-04-16 15:20:36 -0700701 metadata such as load average, netfilter attributes, socket
702 attributes and routing decisions.
703
704 To compile this code as a module, choose M here: the
705 module will be called em_meta.
706
Thomas Grafd675c982005-06-23 21:00:58 -0700707config NET_EMATCH_TEXT
708 tristate "Textsearch"
709 depends on NET_EMATCH
David S. Millerf2d368f2005-06-23 23:55:41 -0700710 select TEXTSEARCH
David S. Millerf7704342005-06-24 17:39:03 -0700711 select TEXTSEARCH_KMP
David S. Miller29cb9f92005-08-25 16:23:11 -0700712 select TEXTSEARCH_BM
David S. Millerf7704342005-06-24 17:39:03 -0700713 select TEXTSEARCH_FSM
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900714 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100715 Say Y here if you want to be able to classify packets based on
David S. Millerf7704342005-06-24 17:39:03 -0700716 textsearch comparisons.
Thomas Grafd675c982005-06-23 21:00:58 -0700717
718 To compile this code as a module, choose M here: the
719 module will be called em_text.
720
Rostislav Lisovyf057bbb2012-07-04 05:32:03 +0200721config NET_EMATCH_CANID
722 tristate "CAN Identifier"
Marc Kleine-Buddea303fbf2012-11-23 00:44:57 +0000723 depends on NET_EMATCH && (CAN=y || CAN=m)
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900724 help
Rostislav Lisovyf057bbb2012-07-04 05:32:03 +0200725 Say Y here if you want to be able to classify CAN frames based
726 on CAN Identifier.
727
728 To compile this code as a module, choose M here: the
729 module will be called em_canid.
730
Florian Westphal6d4fa852012-07-11 10:56:57 +0000731config NET_EMATCH_IPSET
732 tristate "IPset"
733 depends on NET_EMATCH && IP_SET
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900734 help
Florian Westphal6d4fa852012-07-11 10:56:57 +0000735 Say Y here if you want to be able to classify packets based on
736 ipset membership.
737
738 To compile this code as a module, choose M here: the
739 module will be called em_ipset.
740
Eyal Birgerccc007e2018-02-15 19:42:43 +0200741config NET_EMATCH_IPT
742 tristate "IPtables Matches"
743 depends on NET_EMATCH && NETFILTER && NETFILTER_XTABLES
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900744 help
Eyal Birgerccc007e2018-02-15 19:42:43 +0200745 Say Y here to be able to classify packets based on iptables
746 matches.
747 Current supported match is "policy" which allows packet classification
748 based on IPsec policy that was used during decapsulation
749
750 To compile this code as a module, choose M here: the
751 module will be called em_ipt.
752
Linus Torvalds1da177e2005-04-16 15:20:36 -0700753config NET_CLS_ACT
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100754 bool "Actions"
Jiri Pirko8ec15072017-06-04 18:49:28 +0200755 select NET_CLS
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900756 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100757 Say Y here if you want to use traffic control actions. Actions
758 get attached to classifiers and are invoked after a successful
759 classification. They are used to overwrite the classification
760 result, instantly drop or redirect packets, etc.
761
762 A recent version of the iproute2 package is required to use
763 extended matches.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700764
765config NET_ACT_POLICE
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100766 tristate "Traffic Policing"
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200767 depends on NET_CLS_ACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900768 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100769 Say Y here if you want to do traffic policing, i.e. strict
770 bandwidth limiting. This action replaces the existing policing
771 module.
772
773 To compile this code as a module, choose M here: the
Jan Luebbed4ae20b2010-02-08 22:41:44 -0800774 module will be called act_police.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700775
776config NET_ACT_GACT
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200777 tristate "Generic actions"
778 depends on NET_CLS_ACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900779 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100780 Say Y here to take generic actions such as dropping and
781 accepting packets.
782
783 To compile this code as a module, choose M here: the
Jan Luebbed4ae20b2010-02-08 22:41:44 -0800784 module will be called act_gact.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700785
786config GACT_PROB
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200787 bool "Probability support"
788 depends on NET_ACT_GACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900789 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100790 Say Y here to use the generic action randomly or deterministically.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700791
792config NET_ACT_MIRRED
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200793 tristate "Redirecting and Mirroring"
794 depends on NET_CLS_ACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900795 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100796 Say Y here to allow packets to be mirrored or redirected to
797 other devices.
798
799 To compile this code as a module, choose M here: the
Jan Luebbed4ae20b2010-02-08 22:41:44 -0800800 module will be called act_mirred.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700801
Yotam Gigi5c5670f2017-01-23 11:07:09 +0100802config NET_ACT_SAMPLE
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200803 tristate "Traffic Sampling"
804 depends on NET_CLS_ACT
805 select PSAMPLE
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900806 help
Yotam Gigi5c5670f2017-01-23 11:07:09 +0100807 Say Y here to allow packet sampling tc action. The packet sample
808 action consists of statistically choosing packets and sampling
809 them using the psample module.
810
811 To compile this code as a module, choose M here: the
812 module will be called act_sample.
813
Linus Torvalds1da177e2005-04-16 15:20:36 -0700814config NET_ACT_IPT
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200815 tristate "IPtables targets"
Pablo Neira Ayuso102e2c02020-12-08 21:47:07 +0100816 depends on NET_CLS_ACT && NETFILTER && NETFILTER_XTABLES
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900817 help
Matt LaPlante3539c272006-06-30 18:53:46 +0200818 Say Y here to be able to invoke iptables targets after successful
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100819 classification.
820
821 To compile this code as a module, choose M here: the
Jan Luebbed4ae20b2010-02-08 22:41:44 -0800822 module will be called act_ipt.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700823
Herbert Xub4219952007-09-27 12:48:05 -0700824config NET_ACT_NAT
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200825 tristate "Stateless NAT"
826 depends on NET_CLS_ACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900827 help
Herbert Xub4219952007-09-27 12:48:05 -0700828 Say Y here to do stateless NAT on IPv4 packets. You should use
829 netfilter for NAT unless you know what you are doing.
830
831 To compile this code as a module, choose M here: the
Jan Luebbed4ae20b2010-02-08 22:41:44 -0800832 module will be called act_nat.
Herbert Xub4219952007-09-27 12:48:05 -0700833
Linus Torvalds1da177e2005-04-16 15:20:36 -0700834config NET_ACT_PEDIT
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200835 tristate "Packet Editing"
836 depends on NET_CLS_ACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900837 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100838 Say Y here if you want to mangle the content of packets.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700839
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100840 To compile this code as a module, choose M here: the
Jan Luebbed4ae20b2010-02-08 22:41:44 -0800841 module will be called act_pedit.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700842
Jamal Hadi Salimdb753072005-04-24 20:10:16 -0700843config NET_ACT_SIMP
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200844 tristate "Simple Example (Debug)"
845 depends on NET_CLS_ACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900846 help
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100847 Say Y here to add a simple action for demonstration purposes.
848 It is meant as an example and for debugging purposes. It will
849 print a configured policy string followed by the packet count
850 to the console for every packet that passes by.
Jamal Hadi Salimdb753072005-04-24 20:10:16 -0700851
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100852 If unsure, say N.
853
854 To compile this code as a module, choose M here: the
Jan Luebbed4ae20b2010-02-08 22:41:44 -0800855 module will be called act_simple.
Thomas Graf52ab4ac2005-11-01 15:13:02 +0100856
Alexander Duyckca9b0e22008-09-12 16:30:20 -0700857config NET_ACT_SKBEDIT
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200858 tristate "SKB Editing"
859 depends on NET_CLS_ACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900860 help
Alexander Duyckca9b0e22008-09-12 16:30:20 -0700861 Say Y here to change skb priority or queue_mapping settings.
862
863 If unsure, say N.
864
865 To compile this code as a module, choose M here: the
Jan Luebbed4ae20b2010-02-08 22:41:44 -0800866 module will be called act_skbedit.
Alexander Duyckca9b0e22008-09-12 16:30:20 -0700867
Grégoire Baroneb4d4062010-08-18 13:10:35 +0000868config NET_ACT_CSUM
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200869 tristate "Checksum Updating"
870 depends on NET_CLS_ACT && INET
871 select LIBCRC32C
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900872 help
Grégoire Baroneb4d4062010-08-18 13:10:35 +0000873 Say Y here to update some common checksum after some direct
874 packet alterations.
875
876 To compile this code as a module, choose M here: the
877 module will be called act_csum.
878
John Hurley2a2ea502019-07-07 15:01:57 +0100879config NET_ACT_MPLS
880 tristate "MPLS manipulation"
881 depends on NET_CLS_ACT
882 help
883 Say Y here to push or pop MPLS headers.
884
885 If unsure, say N.
886
887 To compile this code as a module, choose M here: the
888 module will be called act_mpls.
889
Jiri Pirkoc7e2b962014-11-19 14:05:03 +0100890config NET_ACT_VLAN
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200891 tristate "Vlan manipulation"
892 depends on NET_CLS_ACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900893 help
Jiri Pirkoc7e2b962014-11-19 14:05:03 +0100894 Say Y here to push or pop vlan headers.
895
896 If unsure, say N.
897
898 To compile this code as a module, choose M here: the
899 module will be called act_vlan.
900
Jiri Pirkod23b8ad2015-01-15 09:52:39 +0100901config NET_ACT_BPF
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200902 tristate "BPF based action"
903 depends on NET_CLS_ACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900904 help
Jiri Pirkod23b8ad2015-01-15 09:52:39 +0100905 Say Y here to execute BPF code on packets. The BPF code will decide
906 if the packet should be dropped or not.
907
908 If unsure, say N.
909
910 To compile this code as a module, choose M here: the
911 module will be called act_bpf.
912
Felix Fietkau22a5dc02015-01-18 16:35:14 -0500913config NET_ACT_CONNMARK
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200914 tristate "Netfilter Connection Mark Retriever"
Pablo Neira Ayuso102e2c02020-12-08 21:47:07 +0100915 depends on NET_CLS_ACT && NETFILTER
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200916 depends on NF_CONNTRACK && NF_CONNTRACK_MARK
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900917 help
Felix Fietkau22a5dc02015-01-18 16:35:14 -0500918 Say Y here to allow retrieving of conn mark
919
920 If unsure, say N.
921
922 To compile this code as a module, choose M here: the
923 module will be called act_connmark.
924
Kevin 'ldir' Darbyshire-Bryant24ec4832019-05-28 17:03:50 +0000925config NET_ACT_CTINFO
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200926 tristate "Netfilter Connection Mark Actions"
Pablo Neira Ayuso102e2c02020-12-08 21:47:07 +0100927 depends on NET_CLS_ACT && NETFILTER
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200928 depends on NF_CONNTRACK && NF_CONNTRACK_MARK
929 help
Kevin 'ldir' Darbyshire-Bryant24ec4832019-05-28 17:03:50 +0000930 Say Y here to allow transfer of a connmark stored information.
931 Current actions transfer connmark stored DSCP into
932 ipv4/v6 diffserv and/or to transfer connmark to packet
933 mark. Both are useful for restoring egress based marks
934 back onto ingress connections for qdisc priority mapping
935 purposes.
936
937 If unsure, say N.
938
939 To compile this code as a module, choose M here: the
940 module will be called act_ctinfo.
941
Jamal Hadi Salim86da71b2016-09-12 20:13:09 -0400942config NET_ACT_SKBMOD
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200943 tristate "skb data modification action"
944 depends on NET_CLS_ACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900945 help
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200946 Say Y here to allow modification of skb data
Jamal Hadi Salim86da71b2016-09-12 20:13:09 -0400947
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200948 If unsure, say N.
Jamal Hadi Salim86da71b2016-09-12 20:13:09 -0400949
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200950 To compile this code as a module, choose M here: the
951 module will be called act_skbmod.
Jamal Hadi Salim86da71b2016-09-12 20:13:09 -0400952
Jamal Hadi Salimef6980b62016-02-27 08:08:54 -0500953config NET_ACT_IFE
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200954 tristate "Inter-FE action based on IETF ForCES InterFE LFB"
955 depends on NET_CLS_ACT
956 select NET_IFE
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900957 help
Jamal Hadi Salimef6980b62016-02-27 08:08:54 -0500958 Say Y here to allow for sourcing and terminating metadata
959 For details refer to netdev01 paper:
960 "Distributing Linux Traffic Control Classifier-Action Subsystem"
961 Authors: Jamal Hadi Salim and Damascene M. Joachimpillai
962
963 To compile this code as a module, choose M here: the
964 module will be called act_ife.
965
Amir Vadaid0f6dd82016-09-08 16:23:48 +0300966config NET_ACT_TUNNEL_KEY
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200967 tristate "IP tunnel metadata manipulation"
968 depends on NET_CLS_ACT
Masahiro Yamadaa7f7f622020-06-14 01:50:22 +0900969 help
Amir Vadaid0f6dd82016-09-08 16:23:48 +0300970 Say Y here to set/release ip tunnel metadata.
971
972 If unsure, say N.
973
974 To compile this code as a module, choose M here: the
975 module will be called act_tunnel_key.
976
Paul Blakeyb57dc7c2019-07-09 10:30:48 +0300977config NET_ACT_CT
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200978 tristate "connection tracking tc action"
Paul Blakeyc34b9612020-03-03 15:07:49 +0200979 depends on NET_CLS_ACT && NF_CONNTRACK && NF_NAT && NF_FLOW_TABLE
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +0200980 help
Paul Blakeyb57dc7c2019-07-09 10:30:48 +0300981 Say Y here to allow sending the packets to conntrack module.
982
983 If unsure, say N.
984
985 To compile this code as a module, choose M here: the
986 module will be called act_ct.
987
Po Liua51c3282020-05-01 08:53:15 +0800988config NET_ACT_GATE
989 tristate "Frame gate entry list control tc action"
990 depends on NET_CLS_ACT
991 help
992 Say Y here to allow to control the ingress flow to be passed at
993 specific time slot and be dropped at other specific time slot by
994 the gate entry list.
995
996 If unsure, say N.
997 To compile this code as a module, choose M here: the
998 module will be called act_gate.
999
Jamal Hadi Salim084e2f62016-02-27 08:08:55 -05001000config NET_IFE_SKBMARK
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +02001001 tristate "Support to encoding decoding skb mark on IFE action"
1002 depends on NET_ACT_IFE
Jamal Hadi Salim084e2f62016-02-27 08:08:55 -05001003
Jamal Hadi Salim200e10f2016-02-27 08:08:56 -05001004config NET_IFE_SKBPRIO
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +02001005 tristate "Support to encoding decoding skb prio on IFE action"
1006 depends on NET_ACT_IFE
Jamal Hadi Salim200e10f2016-02-27 08:08:56 -05001007
Jamal Hadi Salim408fbc22016-09-18 07:31:43 -04001008config NET_IFE_SKBTCINDEX
Krzysztof Kozlowskibf69aba2019-09-23 17:52:42 +02001009 tristate "Support to encoding decoding skb tcindex on IFE action"
1010 depends on NET_ACT_IFE
Jamal Hadi Salim408fbc22016-09-18 07:31:43 -04001011
Paul Blakey95a72332019-09-04 16:56:37 +03001012config NET_TC_SKB_EXT
1013 bool "TC recirculation support"
1014 depends on NET_CLS_ACT
Paul Blakey95a72332019-09-04 16:56:37 +03001015 select SKB_EXTENSIONS
1016
1017 help
1018 Say Y here to allow tc chain misses to continue in OvS datapath in
1019 the correct recirc_id, and hardware chain misses to continue in
1020 the correct chain in tc software datapath.
1021
1022 Say N here if you won't be using tc<->ovs offload or tc chains offload.
1023
Roman Zippel05b8b0f2005-11-17 15:22:39 -08001024endif # NET_SCHED
1025
Randy Dunlap85ef3e52007-10-18 21:56:38 -07001026config NET_SCH_FIFO
1027 bool