--- /dev/null
+From guillaume.bertholon@ens.fr Tue Feb 1 17:58:29 2022
+From: Guillaume Bertholon <guillaume.bertholon@ens.fr>
+Date: Tue, 1 Feb 2022 15:24:50 +0100
+Subject: Bluetooth: MGMT: Fix misplaced BT_HS check
+To: gregkh@linuxfoundation.org
+Cc: guillaume.bertholon@ens.fr, stable@vger.kernel.org
+Message-ID: <1643725490-5917-1-git-send-email-guillaume.bertholon@ens.fr>
+
+From: Guillaume Bertholon <guillaume.bertholon@ens.fr>
+
+The upstream commit b560a208cda0 ("Bluetooth: MGMT: Fix not checking if
+BT_HS is enabled") inserted a new check in the `set_hs` function.
+However, its backported version in stable (commit 5abe9f99f512
+("Bluetooth: MGMT: Fix not checking if BT_HS is enabled")),
+added the check in `set_link_security` instead.
+
+This patch restores the intent of the upstream commit by moving back the
+BT_HS check to `set_hs`.
+
+Fixes: 5abe9f99f512 ("Bluetooth: MGMT: Fix not checking if BT_HS is enabled")
+Signed-off-by: Guillaume Bertholon <guillaume.bertholon@ens.fr>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ net/bluetooth/mgmt.c | 8 ++++----
+ 1 file changed, 4 insertions(+), 4 deletions(-)
+
+--- a/net/bluetooth/mgmt.c
++++ b/net/bluetooth/mgmt.c
+@@ -2285,10 +2285,6 @@ static int set_link_security(struct sock
+
+ BT_DBG("request for %s", hdev->name);
+
+- if (!IS_ENABLED(CONFIG_BT_HS))
+- return mgmt_cmd_status(sk, hdev->id, MGMT_OP_SET_HS,
+- MGMT_STATUS_NOT_SUPPORTED);
+-
+ status = mgmt_bredr_support(hdev);
+ if (status)
+ return mgmt_cmd_status(sk, hdev->id, MGMT_OP_SET_LINK_SECURITY,
+@@ -2438,6 +2434,10 @@ static int set_hs(struct sock *sk, struc
+
+ BT_DBG("request for %s", hdev->name);
+
++ if (!IS_ENABLED(CONFIG_BT_HS))
++ return mgmt_cmd_status(sk, hdev->id, MGMT_OP_SET_HS,
++ MGMT_STATUS_NOT_SUPPORTED);
++
+ status = mgmt_bredr_support(hdev);
+ if (status)
+ return mgmt_cmd_status(sk, hdev->id, MGMT_OP_SET_HS, status);