aboutsummaryrefslogtreecommitdiffstats
path: root/net/dccp/output.c
diff options
context:
space:
mode:
authorTomasz Grobelny <tomasz@grobelny.oswiecenia.net>2008-09-04 01:30:19 -0400
committerGerrit Renker <gerrit@erg.abdn.ac.uk>2008-09-04 01:45:39 -0400
commitd6da3511d6b558d0b017777b61dc08b8fbc06ea4 (patch)
tree473f9131b9e641d803bfbea174cf1dfc45aea3ca /net/dccp/output.c
parentddab05568eaa70fc92b2aae957136f188f724e9c (diff)
dccp: Policy-based packet dequeueing infrastructure
This patch adds a generic infrastructure for policy-based dequeueing of TX packets and provides two policies: * a simple FIFO policy (which is the default) and * a priority based policy (set via socket options). Both policies honour the tx_qlen sysctl for the maximum size of the write queue (can be overridden via socket options). The priority policy uses skb->priority internally to assign an u32 priority identifier, using the same ranking as SO_PRIORITY. The skb->priority field is set to 0 when the packet leaves DCCP. The priority is supplied as ancillary data using cmsg(3), the patch also provides the requisite parsing routines. Signed-off-by: Tomasz Grobelny <tomasz@grobelny.oswiecenia.net> Signed-off-by: Gerrit Renker <gerrit@erg.abdn.ac.uk>
Diffstat (limited to 'net/dccp/output.c')
-rw-r--r--net/dccp/output.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/net/dccp/output.c b/net/dccp/output.c
index b1eaf7bcfb11..2532797a8009 100644
--- a/net/dccp/output.c
+++ b/net/dccp/output.c
@@ -241,7 +241,7 @@ static void dccp_xmit_packet(struct sock *sk)
241{ 241{
242 int err, len; 242 int err, len;
243 struct dccp_sock *dp = dccp_sk(sk); 243 struct dccp_sock *dp = dccp_sk(sk);
244 struct sk_buff *skb = skb_dequeue(&sk->sk_write_queue); 244 struct sk_buff *skb = dccp_qpolicy_pop(sk);
245 245
246 if (unlikely(skb == NULL)) 246 if (unlikely(skb == NULL))
247 return; 247 return;
@@ -344,7 +344,7 @@ void dccp_write_xmit(struct sock *sk)
344 struct dccp_sock *dp = dccp_sk(sk); 344 struct dccp_sock *dp = dccp_sk(sk);
345 struct sk_buff *skb; 345 struct sk_buff *skb;
346 346
347 while ((skb = skb_peek(&sk->sk_write_queue))) { 347 while ((skb = dccp_qpolicy_top(sk))) {
348 int rc = ccid_hc_tx_send_packet(dp->dccps_hc_tx_ccid, sk, skb); 348 int rc = ccid_hc_tx_send_packet(dp->dccps_hc_tx_ccid, sk, skb);
349 349
350 switch (ccid_packet_dequeue_eval(rc)) { 350 switch (ccid_packet_dequeue_eval(rc)) {
@@ -358,8 +358,7 @@ void dccp_write_xmit(struct sock *sk)
358 dccp_xmit_packet(sk); 358 dccp_xmit_packet(sk);
359 break; 359 break;
360 case CCID_PACKET_ERR: 360 case CCID_PACKET_ERR:
361 skb_dequeue(&sk->sk_write_queue); 361 dccp_qpolicy_drop(sk, skb);
362 kfree_skb(skb);
363 dccp_pr_debug("packet discarded due to err=%d\n", rc); 362 dccp_pr_debug("packet discarded due to err=%d\n", rc);
364 } 363 }
365 } 364 }