Commit 285e4280 authored by David S. Miller's avatar David S. Miller

net/core/user_dma.c: Use frag list abstraction interfaces.

Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent fbb398a8
...@@ -51,6 +51,7 @@ int dma_skb_copy_datagram_iovec(struct dma_chan *chan, ...@@ -51,6 +51,7 @@ int dma_skb_copy_datagram_iovec(struct dma_chan *chan,
{ {
int start = skb_headlen(skb); int start = skb_headlen(skb);
int i, copy = start - offset; int i, copy = start - offset;
struct sk_buff *frag_iter;
dma_cookie_t cookie = 0; dma_cookie_t cookie = 0;
/* Copy header. */ /* Copy header. */
...@@ -94,31 +95,28 @@ int dma_skb_copy_datagram_iovec(struct dma_chan *chan, ...@@ -94,31 +95,28 @@ int dma_skb_copy_datagram_iovec(struct dma_chan *chan,
start = end; start = end;
} }
if (skb_shinfo(skb)->frag_list) { skb_walk_frags(skb, frag_iter) {
struct sk_buff *list = skb_shinfo(skb)->frag_list; int end;
for (; list; list = list->next) { WARN_ON(start > offset + len);
int end;
end = start + frag_iter->len;
WARN_ON(start > offset + len); copy = end - offset;
if (copy > 0) {
end = start + list->len; if (copy > len)
copy = end - offset; copy = len;
if (copy > 0) { cookie = dma_skb_copy_datagram_iovec(chan, frag_iter,
if (copy > len) offset - start,
copy = len; to, copy,
cookie = dma_skb_copy_datagram_iovec(chan, list, pinned_list);
offset - start, to, copy, if (cookie < 0)
pinned_list); goto fault;
if (cookie < 0) len -= copy;
goto fault; if (len == 0)
len -= copy; goto end;
if (len == 0) offset += copy;
goto end;
offset += copy;
}
start = end;
} }
start = end;
} }
end: end:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment