diff options
Diffstat (limited to 'net/bluetooth')
| -rw-r--r-- | net/bluetooth/af_bluetooth.c | 9 | ||||
| -rw-r--r-- | net/bluetooth/hci_sock.c | 2 | ||||
| -rw-r--r-- | net/bluetooth/l2cap_core.c | 3 | ||||
| -rw-r--r-- | net/bluetooth/rfcomm/core.c | 3 | ||||
| -rw-r--r-- | net/bluetooth/rfcomm/sock.c | 7 | ||||
| -rw-r--r-- | net/bluetooth/sco.c | 1 | ||||
| -rw-r--r-- | net/bluetooth/smp.c | 3 |
7 files changed, 16 insertions, 12 deletions
diff --git a/net/bluetooth/af_bluetooth.c b/net/bluetooth/af_bluetooth.c index f6a1671ea2ff..56ca494621c6 100644 --- a/net/bluetooth/af_bluetooth.c +++ b/net/bluetooth/af_bluetooth.c | |||
| @@ -224,10 +224,9 @@ int bt_sock_recvmsg(struct kiocb *iocb, struct socket *sock, | |||
| 224 | 224 | ||
| 225 | skb = skb_recv_datagram(sk, flags, noblock, &err); | 225 | skb = skb_recv_datagram(sk, flags, noblock, &err); |
| 226 | if (!skb) { | 226 | if (!skb) { |
| 227 | if (sk->sk_shutdown & RCV_SHUTDOWN) { | 227 | if (sk->sk_shutdown & RCV_SHUTDOWN) |
| 228 | msg->msg_namelen = 0; | ||
| 229 | return 0; | 228 | return 0; |
| 230 | } | 229 | |
| 231 | return err; | 230 | return err; |
| 232 | } | 231 | } |
| 233 | 232 | ||
| @@ -245,8 +244,6 @@ int bt_sock_recvmsg(struct kiocb *iocb, struct socket *sock, | |||
| 245 | if (bt_sk(sk)->skb_msg_name) | 244 | if (bt_sk(sk)->skb_msg_name) |
| 246 | bt_sk(sk)->skb_msg_name(skb, msg->msg_name, | 245 | bt_sk(sk)->skb_msg_name(skb, msg->msg_name, |
| 247 | &msg->msg_namelen); | 246 | &msg->msg_namelen); |
| 248 | else | ||
| 249 | msg->msg_namelen = 0; | ||
| 250 | } | 247 | } |
| 251 | 248 | ||
| 252 | skb_free_datagram(sk, skb); | 249 | skb_free_datagram(sk, skb); |
| @@ -295,8 +292,6 @@ int bt_sock_stream_recvmsg(struct kiocb *iocb, struct socket *sock, | |||
| 295 | if (flags & MSG_OOB) | 292 | if (flags & MSG_OOB) |
| 296 | return -EOPNOTSUPP; | 293 | return -EOPNOTSUPP; |
| 297 | 294 | ||
| 298 | msg->msg_namelen = 0; | ||
| 299 | |||
| 300 | BT_DBG("sk %p size %zu", sk, size); | 295 | BT_DBG("sk %p size %zu", sk, size); |
| 301 | 296 | ||
| 302 | lock_sock(sk); | 297 | lock_sock(sk); |
diff --git a/net/bluetooth/hci_sock.c b/net/bluetooth/hci_sock.c index 71f0be173080..6a6c8bb4fd72 100644 --- a/net/bluetooth/hci_sock.c +++ b/net/bluetooth/hci_sock.c | |||
| @@ -856,8 +856,6 @@ static int hci_sock_recvmsg(struct kiocb *iocb, struct socket *sock, | |||
| 856 | if (!skb) | 856 | if (!skb) |
| 857 | return err; | 857 | return err; |
| 858 | 858 | ||
| 859 | msg->msg_namelen = 0; | ||
| 860 | |||
| 861 | copied = skb->len; | 859 | copied = skb->len; |
| 862 | if (len < copied) { | 860 | if (len < copied) { |
| 863 | msg->msg_flags |= MSG_TRUNC; | 861 | msg->msg_flags |= MSG_TRUNC; |
diff --git a/net/bluetooth/l2cap_core.c b/net/bluetooth/l2cap_core.c index 0cef67707838..4af3821df880 100644 --- a/net/bluetooth/l2cap_core.c +++ b/net/bluetooth/l2cap_core.c | |||
| @@ -2439,6 +2439,9 @@ int l2cap_chan_send(struct l2cap_chan *chan, struct msghdr *msg, size_t len, | |||
| 2439 | int err; | 2439 | int err; |
| 2440 | struct sk_buff_head seg_queue; | 2440 | struct sk_buff_head seg_queue; |
| 2441 | 2441 | ||
| 2442 | if (!chan->conn) | ||
| 2443 | return -ENOTCONN; | ||
| 2444 | |||
| 2442 | /* Connectionless channel */ | 2445 | /* Connectionless channel */ |
| 2443 | if (chan->chan_type == L2CAP_CHAN_CONN_LESS) { | 2446 | if (chan->chan_type == L2CAP_CHAN_CONN_LESS) { |
| 2444 | skb = l2cap_create_connless_pdu(chan, msg, len, priority); | 2447 | skb = l2cap_create_connless_pdu(chan, msg, len, priority); |
diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c index 94d06cbfbc18..facd8a79c038 100644 --- a/net/bluetooth/rfcomm/core.c +++ b/net/bluetooth/rfcomm/core.c | |||
| @@ -694,6 +694,7 @@ static struct rfcomm_session *rfcomm_session_create(bdaddr_t *src, | |||
| 694 | addr.l2_family = AF_BLUETOOTH; | 694 | addr.l2_family = AF_BLUETOOTH; |
| 695 | addr.l2_psm = 0; | 695 | addr.l2_psm = 0; |
| 696 | addr.l2_cid = 0; | 696 | addr.l2_cid = 0; |
| 697 | addr.l2_bdaddr_type = BDADDR_BREDR; | ||
| 697 | *err = kernel_bind(sock, (struct sockaddr *) &addr, sizeof(addr)); | 698 | *err = kernel_bind(sock, (struct sockaddr *) &addr, sizeof(addr)); |
| 698 | if (*err < 0) | 699 | if (*err < 0) |
| 699 | goto failed; | 700 | goto failed; |
| @@ -719,6 +720,7 @@ static struct rfcomm_session *rfcomm_session_create(bdaddr_t *src, | |||
| 719 | addr.l2_family = AF_BLUETOOTH; | 720 | addr.l2_family = AF_BLUETOOTH; |
| 720 | addr.l2_psm = __constant_cpu_to_le16(RFCOMM_PSM); | 721 | addr.l2_psm = __constant_cpu_to_le16(RFCOMM_PSM); |
| 721 | addr.l2_cid = 0; | 722 | addr.l2_cid = 0; |
| 723 | addr.l2_bdaddr_type = BDADDR_BREDR; | ||
| 722 | *err = kernel_connect(sock, (struct sockaddr *) &addr, sizeof(addr), O_NONBLOCK); | 724 | *err = kernel_connect(sock, (struct sockaddr *) &addr, sizeof(addr), O_NONBLOCK); |
| 723 | if (*err == 0 || *err == -EINPROGRESS) | 725 | if (*err == 0 || *err == -EINPROGRESS) |
| 724 | return s; | 726 | return s; |
| @@ -1983,6 +1985,7 @@ static int rfcomm_add_listener(bdaddr_t *ba) | |||
| 1983 | addr.l2_family = AF_BLUETOOTH; | 1985 | addr.l2_family = AF_BLUETOOTH; |
| 1984 | addr.l2_psm = __constant_cpu_to_le16(RFCOMM_PSM); | 1986 | addr.l2_psm = __constant_cpu_to_le16(RFCOMM_PSM); |
| 1985 | addr.l2_cid = 0; | 1987 | addr.l2_cid = 0; |
| 1988 | addr.l2_bdaddr_type = BDADDR_BREDR; | ||
| 1986 | err = kernel_bind(sock, (struct sockaddr *) &addr, sizeof(addr)); | 1989 | err = kernel_bind(sock, (struct sockaddr *) &addr, sizeof(addr)); |
| 1987 | if (err < 0) { | 1990 | if (err < 0) { |
| 1988 | BT_ERR("Bind failed %d", err); | 1991 | BT_ERR("Bind failed %d", err); |
diff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c index c4d3d423f89b..3c2d3e4aa2f5 100644 --- a/net/bluetooth/rfcomm/sock.c +++ b/net/bluetooth/rfcomm/sock.c | |||
| @@ -615,7 +615,6 @@ static int rfcomm_sock_recvmsg(struct kiocb *iocb, struct socket *sock, | |||
| 615 | 615 | ||
| 616 | if (test_and_clear_bit(RFCOMM_DEFER_SETUP, &d->flags)) { | 616 | if (test_and_clear_bit(RFCOMM_DEFER_SETUP, &d->flags)) { |
| 617 | rfcomm_dlc_accept(d); | 617 | rfcomm_dlc_accept(d); |
| 618 | msg->msg_namelen = 0; | ||
| 619 | return 0; | 618 | return 0; |
| 620 | } | 619 | } |
| 621 | 620 | ||
| @@ -739,8 +738,9 @@ static int rfcomm_sock_setsockopt(struct socket *sock, int level, int optname, c | |||
| 739 | static int rfcomm_sock_getsockopt_old(struct socket *sock, int optname, char __user *optval, int __user *optlen) | 738 | static int rfcomm_sock_getsockopt_old(struct socket *sock, int optname, char __user *optval, int __user *optlen) |
| 740 | { | 739 | { |
| 741 | struct sock *sk = sock->sk; | 740 | struct sock *sk = sock->sk; |
| 741 | struct sock *l2cap_sk; | ||
| 742 | struct l2cap_conn *conn; | ||
| 742 | struct rfcomm_conninfo cinfo; | 743 | struct rfcomm_conninfo cinfo; |
| 743 | struct l2cap_conn *conn = l2cap_pi(sk)->chan->conn; | ||
| 744 | int len, err = 0; | 744 | int len, err = 0; |
| 745 | u32 opt; | 745 | u32 opt; |
| 746 | 746 | ||
| @@ -783,6 +783,9 @@ static int rfcomm_sock_getsockopt_old(struct socket *sock, int optname, char __u | |||
| 783 | break; | 783 | break; |
| 784 | } | 784 | } |
| 785 | 785 | ||
| 786 | l2cap_sk = rfcomm_pi(sk)->dlc->session->sock->sk; | ||
| 787 | conn = l2cap_pi(l2cap_sk)->chan->conn; | ||
| 788 | |||
| 786 | memset(&cinfo, 0, sizeof(cinfo)); | 789 | memset(&cinfo, 0, sizeof(cinfo)); |
| 787 | cinfo.hci_handle = conn->hcon->handle; | 790 | cinfo.hci_handle = conn->hcon->handle; |
| 788 | memcpy(cinfo.dev_class, conn->hcon->dev_class, 3); | 791 | memcpy(cinfo.dev_class, conn->hcon->dev_class, 3); |
diff --git a/net/bluetooth/sco.c b/net/bluetooth/sco.c index 12a0e51e21e1..24fa3964b3c8 100644 --- a/net/bluetooth/sco.c +++ b/net/bluetooth/sco.c | |||
| @@ -711,7 +711,6 @@ static int sco_sock_recvmsg(struct kiocb *iocb, struct socket *sock, | |||
| 711 | test_bit(BT_SK_DEFER_SETUP, &bt_sk(sk)->flags)) { | 711 | test_bit(BT_SK_DEFER_SETUP, &bt_sk(sk)->flags)) { |
| 712 | sco_conn_defer_accept(pi->conn->hcon, pi->setting); | 712 | sco_conn_defer_accept(pi->conn->hcon, pi->setting); |
| 713 | sk->sk_state = BT_CONFIG; | 713 | sk->sk_state = BT_CONFIG; |
| 714 | msg->msg_namelen = 0; | ||
| 715 | 714 | ||
| 716 | release_sock(sk); | 715 | release_sock(sk); |
| 717 | return 0; | 716 | return 0; |
diff --git a/net/bluetooth/smp.c b/net/bluetooth/smp.c index 85a2796cac61..4b07acb8293c 100644 --- a/net/bluetooth/smp.c +++ b/net/bluetooth/smp.c | |||
| @@ -742,6 +742,9 @@ static u8 smp_cmd_security_req(struct l2cap_conn *conn, struct sk_buff *skb) | |||
| 742 | 742 | ||
| 743 | BT_DBG("conn %p", conn); | 743 | BT_DBG("conn %p", conn); |
| 744 | 744 | ||
| 745 | if (!(conn->hcon->link_mode & HCI_LM_MASTER)) | ||
| 746 | return SMP_CMD_NOTSUPP; | ||
| 747 | |||
| 745 | hcon->pending_sec_level = authreq_to_seclevel(rp->auth_req); | 748 | hcon->pending_sec_level = authreq_to_seclevel(rp->auth_req); |
| 746 | 749 | ||
| 747 | if (smp_ltk_encrypt(conn, hcon->pending_sec_level)) | 750 | if (smp_ltk_encrypt(conn, hcon->pending_sec_level)) |
