Commit f33b0068 authored by Luiz Augusto von Dentz's avatar Luiz Augusto von Dentz Committed by Marcel Holtmann

Bluetooth: vhci: Fix checking of msft_opcode

msft_opcode shall be use a vendor ogf (0x3f) but the check was
swifting the bits in the wrong order due to a missing parantesis
over val & 0xffff, but since the code already checks for values over
0xffff it shall not be necessary to perform that operation it now just
removes which makes it work properly when setting opcodes like 0xfce1.

Fixes: b8f5482c ("Bluetooth: vhci: Add support for setting msft_opcode and aosp_capable")
Signed-off-by: default avatarLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent 7a517ac9
...@@ -200,7 +200,7 @@ static int msft_opcode_set(void *data, u64 val) ...@@ -200,7 +200,7 @@ static int msft_opcode_set(void *data, u64 val)
{ {
struct vhci_data *vhci = data; struct vhci_data *vhci = data;
if (val > 0xffff || (val & 0xffff >> 10) != 0x3f) if (val > 0xffff || hci_opcode_ogf(val) != 0x3f)
return -EINVAL; return -EINVAL;
if (vhci->msft_opcode) if (vhci->msft_opcode)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment