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); |
