mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-04-26 16:23:57 +00:00
Bluetooth: Check SOL_HCI for raw socket options
The SOL_HCI level should be enforced when using socket options on the HCI raw socket interface. Signed-off-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
This commit is contained in:
parent
7e8524591f
commit
47b0f573f2
1 changed files with 6 additions and 0 deletions
|
@ -1440,6 +1440,9 @@ static int hci_sock_setsockopt(struct socket *sock, int level, int optname,
|
||||||
|
|
||||||
BT_DBG("sk %p, opt %d", sk, optname);
|
BT_DBG("sk %p, opt %d", sk, optname);
|
||||||
|
|
||||||
|
if (level != SOL_HCI)
|
||||||
|
return -ENOPROTOOPT;
|
||||||
|
|
||||||
lock_sock(sk);
|
lock_sock(sk);
|
||||||
|
|
||||||
if (hci_pi(sk)->channel != HCI_CHANNEL_RAW) {
|
if (hci_pi(sk)->channel != HCI_CHANNEL_RAW) {
|
||||||
|
@ -1523,6 +1526,9 @@ static int hci_sock_getsockopt(struct socket *sock, int level, int optname,
|
||||||
|
|
||||||
BT_DBG("sk %p, opt %d", sk, optname);
|
BT_DBG("sk %p, opt %d", sk, optname);
|
||||||
|
|
||||||
|
if (level != SOL_HCI)
|
||||||
|
return -ENOPROTOOPT;
|
||||||
|
|
||||||
if (get_user(len, optlen))
|
if (get_user(len, optlen))
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue