Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 340953
b: refs/heads/master
c: 31ca61a
h: refs/heads/master
i:
  340951: f9bb8eb
v: v3
  • Loading branch information
Samuel Ortiz committed Oct 26, 2012
1 parent f5241f4 commit 445d739
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 2 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 968272bf0087b9a4e19e876fddccd162da0390a8
refs/heads/master: 31ca61a8dffa5c7171d00cfa40a2845e190863c0
19 changes: 18 additions & 1 deletion trunk/net/nfc/llcp/sock.c
Original file line number Diff line number Diff line change
Expand Up @@ -663,11 +663,28 @@ static int llcp_sock_recvmsg(struct kiocb *iocb, struct socket *sock,
return -EFAULT;
}

if (sk->sk_type == SOCK_DGRAM && msg->msg_name) {
struct nfc_llcp_ui_cb *ui_cb = nfc_llcp_ui_skb_cb(skb);
struct sockaddr_nfc_llcp sockaddr;

pr_debug("Datagram socket %d %d\n", ui_cb->dsap, ui_cb->ssap);

sockaddr.sa_family = AF_NFC;
sockaddr.nfc_protocol = NFC_PROTO_NFC_DEP;
sockaddr.dsap = ui_cb->dsap;
sockaddr.ssap = ui_cb->ssap;

memcpy(msg->msg_name, &sockaddr, sizeof(sockaddr));
msg->msg_namelen = sizeof(sockaddr);
}

/* Mark read part of skb as used */
if (!(flags & MSG_PEEK)) {

/* SOCK_STREAM: re-queue skb if it contains unreceived data */
if (sk->sk_type == SOCK_STREAM || sk->sk_type == SOCK_RAW) {
if (sk->sk_type == SOCK_STREAM ||
sk->sk_type == SOCK_DGRAM ||
sk->sk_type == SOCK_RAW) {
skb_pull(skb, copied);
if (skb->len) {
skb_queue_head(&sk->sk_receive_queue, skb);
Expand Down

0 comments on commit 445d739

Please sign in to comment.