From: Johan Hedberg Date: Thu, 10 Oct 2013 16:06:04 +0000 (+0200) Subject: Bluetooth: Fix checking for HCI_SETUP flag when receiving mgmt commands X-Git-Tag: accepted/tizen/common/20141203.182822~719^2~3^2^2~364^2~87 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=cebf4cfd8608cbcc941750801217988f0a8fc848;p=platform%2Fkernel%2Flinux-arm64.git Bluetooth: Fix checking for HCI_SETUP flag when receiving mgmt commands When the HCI_SETUP flag is set the controller has not yet been announced over mgmt and therefore doesn't exist from that perspective. If we nevertheless get a mgmt command for it we should respond with the appropriate INVALID_INDEX error. Signed-off-by: Johan Hedberg Signed-off-by: Marcel Holtmann --- diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c index e7ffd39..7d25d6d 100644 --- a/net/bluetooth/mgmt.c +++ b/net/bluetooth/mgmt.c @@ -3753,7 +3753,8 @@ int mgmt_control(struct sock *sk, struct msghdr *msg, size_t msglen) goto done; } - if (test_bit(HCI_USER_CHANNEL, &hdev->dev_flags)) { + if (test_bit(HCI_SETUP, &hdev->dev_flags) || + test_bit(HCI_USER_CHANNEL, &hdev->dev_flags)) { err = cmd_status(sk, index, opcode, MGMT_STATUS_INVALID_INDEX); goto done;