Received: by 2002:a05:622a:1442:b0:3a5:28ea:c4b9 with SMTP id v2csp830384qtx; Mon, 31 Oct 2022 15:09:21 -0700 (PDT) X-Google-Smtp-Source: AMsMyM5eVN3Zp3H4Di8zvAyuiEIKfShYSpB4GD87VbDwQIkrB2rVv0Nuo8cAMw0wNPWpGGK62Ful X-Received: by 2002:aa7:ccd7:0:b0:461:c6e9:8b0 with SMTP id y23-20020aa7ccd7000000b00461c6e908b0mr15829358edt.287.1667254161701; Mon, 31 Oct 2022 15:09:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1667254161; cv=none; d=google.com; s=arc-20160816; b=BzOU/3T7tQBXCyHubhakaq/FqEHMbL098HjPvAU8WxhElwR8N0FNJHd+5Ep61tnpJX rBrLFlf4GHJdOtUw6Y75y8NwwTU+SfTi/e6BD5OoHPM7Y4l7fber04k/KP30NwrwQyB/ jOXeXkXy9AA4y2USfpeiqBA9/GBeXWW6vH4Ph+0jBAIkKWlRRNxX5ZK7SDTGF1HUaWnz kjLxgEEAaIf/Wk0fQSAXaV5I8ih8F2junXn/l8nGwEwPxYnO3JTd9DhhdEDFwHpbEnUx jdRklk93p7Kf3LM3JuJMQ+BwMGxb0J0AmvvNWMtj2IVDC0kw+BSk+KgM9AoQcZabqU2v dsNw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=mP2Jc+qIiD1uQ6TtOkhPe1h+TlMNaYX+5fehzFHUypU=; b=PfNfGavNbpoEYw2ep21iPzchPJNN95uRdfjoPYFvFGVzhWqKsDIfPKR62ZcdcwJBPK aX5wGfhTnFRLcFe89aqgF4jEC5AcY8WRkbMZ8LpZ8L2B/bma+KCQDl/C4cF8BsTksiWB Rjr+hvOv4z51bg3MOy20UItQK2AlIKdL7l5hEQ+9HcF83akXiBnMESv6hwfBiQkVcIye MUhJn9niHPdkHZ8Wij70wPUd0vuTrUrs0PdY9+yaJZ+96wL9FW+q1RzP8kohpTKKi/Dz 5MLvbr5T+pR1g48lZNp7r7S8hxyDKaBQgvEp0KZOBgll4Xef8rfeKmaKBDN5SbO9AzTP 5+tA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=AVEbzPOL; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ji10-20020a170907980a00b0073d71124609si9981009ejc.182.2022.10.31.15.08.54; Mon, 31 Oct 2022 15:09:21 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=AVEbzPOL; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229576AbiJaWCR (ORCPT + 99 others); Mon, 31 Oct 2022 18:02:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54746 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229476AbiJaWCQ (ORCPT ); Mon, 31 Oct 2022 18:02:16 -0400 Received: from mga02.intel.com (mga02.intel.com [134.134.136.20]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7DE0E140C4 for ; Mon, 31 Oct 2022 15:02:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1667253735; x=1698789735; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=InEZeZdNqHj6bbfxfSEZhhK1gaslNg5sOEx6GflAtY8=; b=AVEbzPOLTJy0OIjqerHZoUrfk/MyhzEE1/FNSJaZZbCn4dCrNJaSWNHA hQR9WmFbXARh6nEupW1U2v8E8RvP+cYQkJTd7z1NXr8XsF4iUqQayCZoY 9suMvXU0YDdXn3Y5FUI6/V8hEDwYX+BdpaT2+YyTZUt1tCPEo3KD3ybUE I/0+tFVBD5jTyMlzMAfy0ASQvM42KN/k9RtnbmwUJcnXfL4uHJ9Y2X4AG /7DmPVtDtLxdMEZxtLyP6MnpDC4s/dXL6VPwtStx3eL1ckFMHk0pNNblK VEaA7E6x18cYTm1mIGP39ERrrjkpzihWBM8yEYUSPsQyJDB8xxXOaohMM A==; X-IronPort-AV: E=McAfee;i="6500,9779,10517"; a="296428749" X-IronPort-AV: E=Sophos;i="5.95,228,1661842800"; d="scan'208";a="296428749" Received: from orsmga001.jf.intel.com ([10.7.209.18]) by orsmga101.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 31 Oct 2022 15:02:14 -0700 X-IronPort-AV: E=McAfee;i="6500,9779,10517"; a="666981279" X-IronPort-AV: E=Sophos;i="5.95,228,1661842800"; d="scan'208";a="666981279" Received: from fsbeena-mobl.amr.corp.intel.com (HELO bgi1-mobl2.amr.corp.intel.com) ([10.212.176.165]) by orsmga001-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 31 Oct 2022 15:02:14 -0700 From: Brian Gix To: linux-bluetooth@vger.kernel.org Cc: luiz.dentz@gmail.com, brian.gix@intel.com, marex@denx.de Subject: [RFC] Bluetooth: Convert MSFT filter HCI cmd to hci_sync Date: Mon, 31 Oct 2022 15:02:05 -0700 Message-Id: <20221031220205.91975-1-brian.gix@intel.com> X-Mailer: git-send-email 2.38.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-5.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED, RCVD_IN_MSPIKE_H3,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org The msft_set_filter_enable() command was using the deprecated hci_request mechanism rather than hci_sync. This caused the warning error: hci0: HCI_REQ-0xfcf0 Signed-off-by: Brian Gix --- net/bluetooth/msft.c | 36 +++++++++++------------------------- 1 file changed, 11 insertions(+), 25 deletions(-) diff --git a/net/bluetooth/msft.c b/net/bluetooth/msft.c index bee6a4c656be..bf5cee48916c 100644 --- a/net/bluetooth/msft.c +++ b/net/bluetooth/msft.c @@ -743,17 +743,12 @@ __u64 msft_get_features(struct hci_dev *hdev) } static void msft_le_set_advertisement_filter_enable_cb(struct hci_dev *hdev, - u8 status, u16 opcode, - struct sk_buff *skb) + void *user_data, + u8 status) { - struct msft_cp_le_set_advertisement_filter_enable *cp; - struct msft_rp_le_set_advertisement_filter_enable *rp; + struct msft_cp_le_set_advertisement_filter_enable *cp = user_data; struct msft_data *msft = hdev->msft_data; - rp = (struct msft_rp_le_set_advertisement_filter_enable *)skb->data; - if (skb->len < sizeof(*rp)) - return; - /* Error 0x0C would be returned if the filter enabled status is * already set to whatever we were trying to set. * Although the default state should be disabled, some controller set @@ -766,7 +761,6 @@ static void msft_le_set_advertisement_filter_enable_cb(struct hci_dev *hdev, hci_dev_lock(hdev); - cp = hci_sent_cmd_data(hdev, hdev->msft_opcode); msft->filter_enabled = cp->enable; if (status == 0x0C) @@ -804,31 +798,23 @@ int msft_remove_monitor(struct hci_dev *hdev, struct adv_monitor *monitor) return msft_remove_monitor_sync(hdev, monitor); } -void msft_req_add_set_filter_enable(struct hci_request *req, bool enable) -{ - struct hci_dev *hdev = req->hdev; - struct msft_cp_le_set_advertisement_filter_enable cp; - - cp.sub_opcode = MSFT_OP_LE_SET_ADVERTISEMENT_FILTER_ENABLE; - cp.enable = enable; - - hci_req_add(req, hdev->msft_opcode, sizeof(cp), &cp); -} - int msft_set_filter_enable(struct hci_dev *hdev, bool enable) { - struct hci_request req; + struct msft_cp_le_set_advertisement_filter_enable cp; struct msft_data *msft = hdev->msft_data; int err; if (!msft) return -EOPNOTSUPP; - hci_req_init(&req, hdev); - msft_req_add_set_filter_enable(&req, enable); - err = hci_req_run_skb(&req, msft_le_set_advertisement_filter_enable_cb); + cp.sub_opcode = MSFT_OP_LE_SET_ADVERTISEMENT_FILTER_ENABLE; + cp.enable = enable; + err = __hci_cmd_sync_status(hdev, hdev->msft_opcode, sizeof(cp), &cp, + HCI_CMD_TIMEOUT); + + msft_le_set_advertisement_filter_enable_cb(hdev, &cp, err); - return err; + return 0; } bool msft_curve_validity(struct hci_dev *hdev) -- 2.38.1