Merge branch 'smack-for-3.16' of git://git.gitorious.org/smack-next/kernel into next
[deliverable/linux.git] / Documentation / networking / tc-actions-env-rules.txt
CommitLineData
d892afe2 1
25985edc 2The "environmental" rules for authors of any new tc actions are:
d892afe2
JHS
3
41) If you stealeth or borroweth any packet thou shalt be branching
5from the righteous path and thou shalt cloneth.
6
d9195881
ML
7For example if your action queues a packet to be processed later,
8or intentionally branches by redirecting a packet, then you need to
d892afe2 9clone the packet.
d9195881 10
d892afe2 11There are certain fields in the skb tc_verd that need to be reset so we
d9195881
ML
12avoid loops, etc. A few are generic enough that skb_act_clone()
13resets them for you, so invoke skb_act_clone() rather than skb_clone().
d892afe2
JHS
14
152) If you munge any packet thou shalt call pskb_expand_head in the case
16someone else is referencing the skb. After that you "own" the skb.
17You must also tell us if it is ok to munge the packet (TC_OK2MUNGE),
18this way any action downstream can stomp on the packet.
19
d9195881 203) Dropping packets you don't own is a no-no. You simply return
d892afe2
JHS
21TC_ACT_SHOT to the caller and they will drop it.
22
25985edc 23The "environmental" rules for callers of actions (qdiscs etc) are:
d892afe2 24
d9195881 25*) Thou art responsible for freeing anything returned as being
d892afe2 26TC_ACT_SHOT/STOLEN/QUEUED. If none of TC_ACT_SHOT/STOLEN/QUEUED is
d9195881 27returned, then all is great and you don't need to do anything.
d892afe2
JHS
28
29Post on netdev if something is unclear.
30
This page took 0.402531 seconds and 5 git commands to generate.