Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp918772ybg; Wed, 3 Jun 2020 17:57:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz2R+p6JjdicTOKsVSA1ohx9ds1KU57931pKZNh7ncA0Pmsihk+QvN24u+/rj/aIYMdojJE X-Received: by 2002:a17:906:f46:: with SMTP id h6mr1745169ejj.144.1591232228385; Wed, 03 Jun 2020 17:57:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591232228; cv=none; d=google.com; s=arc-20160816; b=MJkYmj5oiNUatNLixdmgfVMpwoFWyBRF0YlAf+Ap9TLB+AydNuN9Jx9tn/2rGraWp9 PJbqwD0HVt0F+fUfDIPNBIUJCLvEgwDK2URD8/DVDf/owQpWGfmVLVELQx4qEXp7uzuJ G8hB1m0Dd+ksmpv9SGeo6TOE3OHivROOte3m3pDrRe3WEjYEjMk4B58HVi4LefSSlCnp dX7hsDH2OLkDZLXur0i0wrJ6WYpHF7rEXG/sgjOoqSp/R8rb89sYeZ5CopHLBdGupQqQ EmNN0v6Y41jMAjb/j93vOzakavE7iK2o6HnoXZStEiBVCf0wOCkAh1oqaYqSRprd082M jXHg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=tsAEWVgiuouqxfd6Wi8d7OEy4kthux10MXkuiPKGJng=; b=Ng6ampVpmHgZbw4sg11YakUPEdf9FkQTyTcTcmD4fe7aTL4SKjcDisdMOmglCs6D6N hVBKYKyfVj+/Sl0DJ5QL+xL4ncNsK+aNWauFWmXrGrUBA25MRjshun5mZdW6dP0ZsOBr cBZAgoffyYnw9LIZVjouXqlN4YZExg0YWTc7dmYw/tlsNoFJMpwH0e8i2g3Jryhnv+Zw I4dv97fkUKTIULKslvQR0/m4qEm7QDfhv/82MbDO1isiCB5D3eslZme4Y4azWfdn8Jnn EgikyBDoe2kgsb1QZQ8cPW8l57k/1BCK++6SvGFxPTnshsLP0v713ajKwPxikprssUq3 XbGA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b="JE/QvKr+"; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u6si670204ejn.111.2020.06.03.17.56.29; Wed, 03 Jun 2020 17:57:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b="JE/QvKr+"; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730068AbgFDA4X (ORCPT + 99 others); Wed, 3 Jun 2020 20:56:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40334 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730064AbgFDA4W (ORCPT ); Wed, 3 Jun 2020 20:56:22 -0400 Received: from mail-ot1-x344.google.com (mail-ot1-x344.google.com [IPv6:2607:f8b0:4864:20::344]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8B747C03E96D for ; Wed, 3 Jun 2020 17:56:22 -0700 (PDT) Received: by mail-ot1-x344.google.com with SMTP id m2so3439282otr.12 for ; Wed, 03 Jun 2020 17:56:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=tsAEWVgiuouqxfd6Wi8d7OEy4kthux10MXkuiPKGJng=; b=JE/QvKr+PACUsxXe/JNvuIoz12lUpJbjhfF7CLHSNoVYo3+BG17qufF+Fm1CuX4btE ptleY32UmuWNruRlhiey14GhuVzAi1IlPYCrQpo6/Rn61eyIUxEuLHsWLbr28bXGTA2A RXZHZ0PeZXC/ft2Q1KTHgaruk/EhAlP8rOkiEdkuIY1OHT6o6jy5mUj+PyQgiOaZj8tJ JwfzdGuOKEa4xtPNn8TnISszbEffS1ST2xq7ROgi13UqL/HNPU1cSNqu7LBzv0CEAg7T jmKOrzdJBU0AKJCnn2GKah8ZRWiBo2siizBY1Owm57Vo0Gw5+dGAD67ViECSJ9PiG5DV saFA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=tsAEWVgiuouqxfd6Wi8d7OEy4kthux10MXkuiPKGJng=; b=mrcu8L7gf/6PvT8GWZOnr5hX0huC6YzwnvJmlFJDE9PsDyMRFjpYRbvPAK6DwyURNN mTXVtbjrTSYGu/sUD17wZQR81XOllz50ZeStP23SBXlqYjK33bGcSc0zqgC4hEx/M+D0 SeuNUjoilkmLiCEQ1cF+auaiRVunNi81vV3wKvQkBLmejbVs+vMQ2qxMeyaC0zJDVQUY qu1AHh/6P2iqVdWrabmoxgNjApZ9TpcaYk6DhfgeOo7WAZmejg660i9Wibf1Ffo0Qdet XasdHo2mK8LEayHeFs70Y5SkworJSLL39BpYFmh/ACGOdSgfAidrjO4Jp1X/pnkWuvvJ Jr5w== X-Gm-Message-State: AOAM530z9d2VT+kGCE9YmBXUQyAYxuU7PE4Nmv3T9Z5kXpg0x7qNkIEc wMHxVY2W0IoQ0l4I/yQT5exNamtXKpmG7ZXiGiHxsM6a X-Received: by 2002:a05:6830:310c:: with SMTP id b12mr2005698ots.11.1591232181608; Wed, 03 Jun 2020 17:56:21 -0700 (PDT) MIME-Version: 1.0 References: <20200603145205.125167-1-alainm@chromium.org> In-Reply-To: From: Luiz Augusto von Dentz Date: Wed, 3 Jun 2020 17:56:08 -0700 Message-ID: Subject: Re: [PATCH v3] sco:Add support for BT_PKT_STATUS CMSG data To: Alain Michaud Cc: Alain Michaud , "linux-bluetooth@vger.kernel.org" Content-Type: text/plain; charset="UTF-8" Sender: linux-bluetooth-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org Hi Alain, On Wed, Jun 3, 2020 at 5:34 PM Alain Michaud wrote: > > Hi Luiz > > On Wed, Jun 3, 2020 at 5:15 PM Luiz Augusto von Dentz > wrote: > > > > Hi Alain, Marcel, > > > > On Wed, Jun 3, 2020 at 7:56 AM Alain Michaud wrote: > > > > > > This change adds support for reporting the BT_PKT_STATUS to the socket > > > CMSG data to allow the implementation of a packet loss correction on > > > erronous data received on the SCO socket. > > > > > > The patch was partially developed by Marcel Holtmann and validated by > > > Hsin-yu Chao > > > > > > Signed-off-by: Alain Michaud > > > > > > --- > > > > > > include/net/bluetooth/bluetooth.h | 8 +++++++ > > > include/net/bluetooth/sco.h | 3 +++ > > > net/bluetooth/af_bluetooth.c | 3 +++ > > > net/bluetooth/hci_core.c | 1 + > > > net/bluetooth/sco.c | 35 +++++++++++++++++++++++++++++++ > > > 5 files changed, 50 insertions(+) > > > > > > diff --git a/include/net/bluetooth/bluetooth.h b/include/net/bluetooth/bluetooth.h > > > index 3fa7b1e3c5d9..85e6c5754448 100644 > > > --- a/include/net/bluetooth/bluetooth.h > > > +++ b/include/net/bluetooth/bluetooth.h > > > @@ -147,6 +147,8 @@ struct bt_voice { > > > #define BT_MODE_LE_FLOWCTL 0x03 > > > #define BT_MODE_EXT_FLOWCTL 0x04 > > > > > > +#define BT_PKT_STATUS 16 > > > + > > > __printf(1, 2) > > > void bt_info(const char *fmt, ...); > > > __printf(1, 2) > > > @@ -275,6 +277,7 @@ struct bt_sock { > > > struct sock *parent; > > > unsigned long flags; > > > void (*skb_msg_name)(struct sk_buff *, void *, int *); > > > + void (*skb_put_cmsg)(struct sk_buff *, struct msghdr *, struct sock *); > > > }; > > > > > > enum { > > > @@ -324,6 +327,10 @@ struct l2cap_ctrl { > > > struct l2cap_chan *chan; > > > }; > > > > > > +struct sco_ctrl { > > > + u8 pkt_status; > > > +}; > > > + > > > struct hci_dev; > > > > > > typedef void (*hci_req_complete_t)(struct hci_dev *hdev, u8 status, u16 opcode); > > > @@ -350,6 +357,7 @@ struct bt_skb_cb { > > > u8 incoming:1; > > > union { > > > struct l2cap_ctrl l2cap; > > > + struct sco_ctrl sco; > > > struct hci_ctrl hci; > > > }; > > > }; > > > diff --git a/include/net/bluetooth/sco.h b/include/net/bluetooth/sco.h > > > index f40ddb4264fc..7f0d7bdc53f6 100644 > > > --- a/include/net/bluetooth/sco.h > > > +++ b/include/net/bluetooth/sco.h > > > @@ -46,4 +46,7 @@ struct sco_conninfo { > > > __u8 dev_class[3]; > > > }; > > > > > > +/* CMSG flags */ > > > +#define SCO_CMSG_PKT_STATUS 0x0001 > > > + > > > > I wonder if we can make this generic since ISO also has similar status > > of received packets so I was hoping I could reuse the same flag to > > indicate we want packet status to be transmitted with cmsg. Maybe have > > it as BT_CMSG_PKT_STATUS? > I think CMSG flags will be different based on the socket types. I > agree it's possible some will be shared between SCO and ISO, but I > would hesitate to make this generic to BT since it doesn't apply to > all BT sockets. This also isn't exposed to external components > either, it's sort of a SCO internal implementation detail more than > anything. ISO could have something similar and likely other flags... I was thinking that the flag could be the same just the content is different based on the socket type that way there is not even a chance of using a flag that is only suppose to work with certain socket type, BT_PKT_STATUS naming itself since to be generic enough so I wonder if the change of namespace does really make sense given that I could enable that on ISO socket but then I would have to add a separate flag for it? It is probably not a big deal we have been moving away from protocol specific options ever since we started using BT_ namespace for socket options. > > > > > > #endif /* __SCO_H */ > > > diff --git a/net/bluetooth/af_bluetooth.c b/net/bluetooth/af_bluetooth.c > > > index 3fd124927d4d..d0abea8d08cc 100644 > > > --- a/net/bluetooth/af_bluetooth.c > > > +++ b/net/bluetooth/af_bluetooth.c > > > @@ -286,6 +286,9 @@ int bt_sock_recvmsg(struct socket *sock, struct msghdr *msg, size_t len, > > > if (msg->msg_name && bt_sk(sk)->skb_msg_name) > > > bt_sk(sk)->skb_msg_name(skb, msg->msg_name, > > > &msg->msg_namelen); > > > + > > > + if (bt_sk(sk)->skb_put_cmsg) > > > + bt_sk(sk)->skb_put_cmsg(skb, msg, sk); > > > } > > > > > > skb_free_datagram(sk, skb); > > > diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c > > > index 51d399273276..7b5e46198d99 100644 > > > --- a/net/bluetooth/hci_core.c > > > +++ b/net/bluetooth/hci_core.c > > > @@ -4549,6 +4549,7 @@ static void hci_scodata_packet(struct hci_dev *hdev, struct sk_buff *skb) > > > > > > if (conn) { > > > /* Send to upper protocol */ > > > + bt_cb(skb)->sco.pkt_status = flags & 0x03; > > > sco_recv_scodata(conn, skb); > > > return; > > > } else { > > > diff --git a/net/bluetooth/sco.c b/net/bluetooth/sco.c > > > index c8c3d38cdc7b..f6b54853e547 100644 > > > --- a/net/bluetooth/sco.c > > > +++ b/net/bluetooth/sco.c > > > @@ -66,6 +66,7 @@ struct sco_pinfo { > > > bdaddr_t dst; > > > __u32 flags; > > > __u16 setting; > > > + __u32 cmsg_mask; > > > struct sco_conn *conn; > > > }; > > > > > > @@ -449,6 +450,15 @@ static void sco_sock_close(struct sock *sk) > > > sco_sock_kill(sk); > > > } > > > > > > +static void sco_skb_put_cmsg(struct sk_buff *skb, struct msghdr *msg, > > > + struct sock *sk) > > > +{ > > > + if (sco_pi(sk)->cmsg_mask & SCO_CMSG_PKT_STATUS) > > > + put_cmsg(msg, SOL_BLUETOOTH, BT_PKT_STATUS, > > > + sizeof(bt_cb(skb)->sco.pkt_status), > > > + &bt_cb(skb)->sco.pkt_status); > > > +} > > > + > > > static void sco_sock_init(struct sock *sk, struct sock *parent) > > > { > > > BT_DBG("sk %p", sk); > > > @@ -457,6 +467,8 @@ static void sco_sock_init(struct sock *sk, struct sock *parent) > > > sk->sk_type = parent->sk_type; > > > bt_sk(sk)->flags = bt_sk(parent)->flags; > > > security_sk_clone(parent, sk); > > > + } else { > > > + bt_sk(sk)->skb_put_cmsg = sco_skb_put_cmsg; > > > } > > > } > > > > > > @@ -846,6 +858,18 @@ static int sco_sock_setsockopt(struct socket *sock, int level, int optname, > > > sco_pi(sk)->setting = voice.setting; > > > break; > > > > > > + case BT_PKT_STATUS: > > > + if (get_user(opt, (u32 __user *)optval)) { > > > + err = -EFAULT; > > > + break; > > > + } > > > + > > > + if (opt) > > > + sco_pi(sk)->cmsg_mask |= SCO_CMSG_PKT_STATUS; > > > + else > > > + sco_pi(sk)->cmsg_mask &= ~SCO_CMSG_PKT_STATUS; > > > + break; > > > + > > > default: > > > err = -ENOPROTOOPT; > > > break; > > > @@ -923,6 +947,7 @@ static int sco_sock_getsockopt(struct socket *sock, int level, int optname, > > > int len, err = 0; > > > struct bt_voice voice; > > > u32 phys; > > > + u32 pkt_status; > > > > > > BT_DBG("sk %p", sk); > > > > > > @@ -969,6 +994,16 @@ static int sco_sock_getsockopt(struct socket *sock, int level, int optname, > > > err = -EFAULT; > > > break; > > > > > > + case BT_PKT_STATUS: > > > + if (sco_pi(sk)->cmsg_mask & SCO_CMSG_PKT_STATUS) > > > + pkt_status = 1; > > > + else > > > + pkt_status = 0; > > > + > > > + if (put_user(pkt_status, (u32 __user *)optval)) > > > + err = -EFAULT; > > > + break; > > > + > > > default: > > > err = -ENOPROTOOPT; > > > break; > > > -- > > > 2.27.0.rc2.251.g90737beb825-goog > > > > > > > > > -- > > Luiz Augusto von Dentz -- Luiz Augusto von Dentz