diff options
author | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-07-13 13:52:27 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-07-13 13:52:27 -0400 |
commit | e030dbf91a87da7e8be3be3ca781558695bea683 (patch) | |
tree | 4ff2e01621a888be4098ca48c404775e56a55a0d /net/ipv4 | |
parent | 12a22960549979c10a95cc97f8ec63b461c55692 (diff) | |
parent | 3039f0735a280b54c7364fbfe6a9287f7f0b510a (diff) |
Merge branch 'ioat-md-accel-for-linus' of git://lost.foo-projects.org/~dwillia2/git/iop
* 'ioat-md-accel-for-linus' of git://lost.foo-projects.org/~dwillia2/git/iop: (28 commits)
ioatdma: add the unisys "i/oat" pci vendor/device id
ARM: Add drivers/dma to arch/arm/Kconfig
iop3xx: surface the iop3xx DMA and AAU units to the iop-adma driver
iop13xx: surface the iop13xx adma units to the iop-adma driver
dmaengine: driver for the iop32x, iop33x, and iop13xx raid engines
md: remove raid5 compute_block and compute_parity5
md: handle_stripe5 - request io processing in raid5_run_ops
md: handle_stripe5 - add request/completion logic for async expand ops
md: handle_stripe5 - add request/completion logic for async read ops
md: handle_stripe5 - add request/completion logic for async check ops
md: handle_stripe5 - add request/completion logic for async compute ops
md: handle_stripe5 - add request/completion logic for async write ops
md: common infrastructure for running operations with raid5_run_ops
md: raid5_run_ops - run stripe operations outside sh->lock
raid5: replace custom debug PRINTKs with standard pr_debug
raid5: refactor handle_stripe5 and handle_stripe6 (v3)
async_tx: add the async_tx api
xor: make 'xor_blocks' a library routine for use with async_tx
dmaengine: make clients responsible for managing channels
dmaengine: refactor dmaengine around dma_async_tx_descriptor
...
Diffstat (limited to 'net/ipv4')
-rw-r--r-- | net/ipv4/tcp.c | 26 |
1 files changed, 18 insertions, 8 deletions
diff --git a/net/ipv4/tcp.c b/net/ipv4/tcp.c index 450f44bb2c8e..987b94403be5 100644 --- a/net/ipv4/tcp.c +++ b/net/ipv4/tcp.c | |||
@@ -1116,6 +1116,7 @@ int tcp_recvmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg, | |||
1116 | long timeo; | 1116 | long timeo; |
1117 | struct task_struct *user_recv = NULL; | 1117 | struct task_struct *user_recv = NULL; |
1118 | int copied_early = 0; | 1118 | int copied_early = 0; |
1119 | struct sk_buff *skb; | ||
1119 | 1120 | ||
1120 | lock_sock(sk); | 1121 | lock_sock(sk); |
1121 | 1122 | ||
@@ -1142,16 +1143,26 @@ int tcp_recvmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg, | |||
1142 | #ifdef CONFIG_NET_DMA | 1143 | #ifdef CONFIG_NET_DMA |
1143 | tp->ucopy.dma_chan = NULL; | 1144 | tp->ucopy.dma_chan = NULL; |
1144 | preempt_disable(); | 1145 | preempt_disable(); |
1145 | if ((len > sysctl_tcp_dma_copybreak) && !(flags & MSG_PEEK) && | 1146 | skb = skb_peek_tail(&sk->sk_receive_queue); |
1146 | !sysctl_tcp_low_latency && __get_cpu_var(softnet_data).net_dma) { | 1147 | { |
1147 | preempt_enable_no_resched(); | 1148 | int available = 0; |
1148 | tp->ucopy.pinned_list = dma_pin_iovec_pages(msg->msg_iov, len); | 1149 | |
1149 | } else | 1150 | if (skb) |
1150 | preempt_enable_no_resched(); | 1151 | available = TCP_SKB_CB(skb)->seq + skb->len - (*seq); |
1152 | if ((available < target) && | ||
1153 | (len > sysctl_tcp_dma_copybreak) && !(flags & MSG_PEEK) && | ||
1154 | !sysctl_tcp_low_latency && | ||
1155 | __get_cpu_var(softnet_data).net_dma) { | ||
1156 | preempt_enable_no_resched(); | ||
1157 | tp->ucopy.pinned_list = | ||
1158 | dma_pin_iovec_pages(msg->msg_iov, len); | ||
1159 | } else { | ||
1160 | preempt_enable_no_resched(); | ||
1161 | } | ||
1162 | } | ||
1151 | #endif | 1163 | #endif |
1152 | 1164 | ||
1153 | do { | 1165 | do { |
1154 | struct sk_buff *skb; | ||
1155 | u32 offset; | 1166 | u32 offset; |
1156 | 1167 | ||
1157 | /* Are we at urgent data? Stop if we have read anything or have SIGURG pending. */ | 1168 | /* Are we at urgent data? Stop if we have read anything or have SIGURG pending. */ |
@@ -1439,7 +1450,6 @@ skip_copy: | |||
1439 | 1450 | ||
1440 | #ifdef CONFIG_NET_DMA | 1451 | #ifdef CONFIG_NET_DMA |
1441 | if (tp->ucopy.dma_chan) { | 1452 | if (tp->ucopy.dma_chan) { |
1442 | struct sk_buff *skb; | ||
1443 | dma_cookie_t done, used; | 1453 | dma_cookie_t done, used; |
1444 | 1454 | ||
1445 | dma_async_memcpy_issue_pending(tp->ucopy.dma_chan); | 1455 | dma_async_memcpy_issue_pending(tp->ucopy.dma_chan); |