Bluetooth: ISO: Fix getpeername not returning sockaddr_iso_bc fields
authorLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
Tue, 15 Apr 2025 15:26:55 +0000 (11:26 -0400)
committerLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
Wed, 21 May 2025 14:28:08 +0000 (10:28 -0400)
If the socket is a broadcast receiver fields from sockaddr_iso_bc shall
be part of the values returned to getpeername since some of these fields
are updated while doing the PA and BIG sync procedures.

Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
net/bluetooth/iso.c

index 7c0012ce1b890e172dfa08d66ca3b26e61702bd4..2f348f48e99dbb55021afd20317184d310b7e0fa 100644 (file)
@@ -1330,6 +1330,7 @@ static int iso_sock_getname(struct socket *sock, struct sockaddr *addr,
 {
        struct sockaddr_iso *sa = (struct sockaddr_iso *)addr;
        struct sock *sk = sock->sk;
+       int len = sizeof(struct sockaddr_iso);
 
        BT_DBG("sock %p, sk %p", sock, sk);
 
@@ -1338,12 +1339,20 @@ static int iso_sock_getname(struct socket *sock, struct sockaddr *addr,
        if (peer) {
                bacpy(&sa->iso_bdaddr, &iso_pi(sk)->dst);
                sa->iso_bdaddr_type = iso_pi(sk)->dst_type;
+
+               if (test_bit(BT_SK_PA_SYNC, &iso_pi(sk)->flags)) {
+                       sa->iso_bc->bc_sid = iso_pi(sk)->bc_sid;
+                       sa->iso_bc->bc_num_bis = iso_pi(sk)->bc_num_bis;
+                       memcpy(sa->iso_bc->bc_bis, iso_pi(sk)->bc_bis,
+                              ISO_MAX_NUM_BIS);
+                       len += sizeof(struct sockaddr_iso_bc);
+               }
        } else {
                bacpy(&sa->iso_bdaddr, &iso_pi(sk)->src);
                sa->iso_bdaddr_type = iso_pi(sk)->src_type;
        }
 
-       return sizeof(struct sockaddr_iso);
+       return len;
 }
 
 static int iso_sock_sendmsg(struct socket *sock, struct msghdr *msg,
@@ -1988,11 +1997,13 @@ static void iso_conn_ready(struct iso_conn *conn)
                        hcon->dst_type = iso_pi(parent)->dst_type;
                }
 
-               if (ev3) {
+               if (test_bit(HCI_CONN_PA_SYNC, &hcon->flags)) {
                        iso_pi(sk)->qos = iso_pi(parent)->qos;
                        hcon->iso_qos = iso_pi(sk)->qos;
+                       iso_pi(sk)->bc_sid = iso_pi(parent)->bc_sid;
                        iso_pi(sk)->bc_num_bis = iso_pi(parent)->bc_num_bis;
-                       memcpy(iso_pi(sk)->bc_bis, iso_pi(parent)->bc_bis, ISO_MAX_NUM_BIS);
+                       memcpy(iso_pi(sk)->bc_bis, iso_pi(parent)->bc_bis,
+                              ISO_MAX_NUM_BIS);
                        set_bit(BT_SK_PA_SYNC, &iso_pi(sk)->flags);
                }