mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-25 01:30:52 +07:00
Bluetooth: Remove mgmt_set_service_cache
Instead of having an explicit service cache command we can make the mgmt API simpler by implicitly enabling the cache when mgmt_read_info is called for the first time and disabling it when mgmt_set_dev_class is called. Signed-off-by: Johan Hedberg <johan.hedberg@intel.com> Acked-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
This commit is contained in:
parent
f7c6869ceb
commit
14c0b60829
@ -943,12 +943,16 @@ int mgmt_device_unblocked(struct hci_dev *hdev, bdaddr_t *bdaddr);
|
|||||||
/* HCI info for socket */
|
/* HCI info for socket */
|
||||||
#define hci_pi(sk) ((struct hci_pinfo *) sk)
|
#define hci_pi(sk) ((struct hci_pinfo *) sk)
|
||||||
|
|
||||||
|
/* HCI socket flags */
|
||||||
|
#define HCI_PI_MGMT_INIT 0
|
||||||
|
|
||||||
struct hci_pinfo {
|
struct hci_pinfo {
|
||||||
struct bt_sock bt;
|
struct bt_sock bt;
|
||||||
struct hci_dev *hdev;
|
struct hci_dev *hdev;
|
||||||
struct hci_filter filter;
|
struct hci_filter filter;
|
||||||
__u32 cmsg_mask;
|
__u32 cmsg_mask;
|
||||||
unsigned short channel;
|
unsigned short channel;
|
||||||
|
unsigned long flags;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* HCI security filter */
|
/* HCI security filter */
|
||||||
|
@ -121,11 +121,6 @@ struct mgmt_cp_set_dev_class {
|
|||||||
__u8 minor;
|
__u8 minor;
|
||||||
} __packed;
|
} __packed;
|
||||||
|
|
||||||
#define MGMT_OP_SET_SERVICE_CACHE 0x000C
|
|
||||||
struct mgmt_cp_set_service_cache {
|
|
||||||
__u8 enable;
|
|
||||||
} __packed;
|
|
||||||
|
|
||||||
struct mgmt_link_key_info {
|
struct mgmt_link_key_info {
|
||||||
bdaddr_t bdaddr;
|
bdaddr_t bdaddr;
|
||||||
u8 type;
|
u8 type;
|
||||||
|
@ -343,8 +343,11 @@ static int hci_sock_bind(struct socket *sock, struct sockaddr *addr, int addr_le
|
|||||||
if (haddr.hci_channel > HCI_CHANNEL_CONTROL)
|
if (haddr.hci_channel > HCI_CHANNEL_CONTROL)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
if (haddr.hci_channel == HCI_CHANNEL_CONTROL && !enable_mgmt)
|
if (haddr.hci_channel == HCI_CHANNEL_CONTROL) {
|
||||||
return -EINVAL;
|
if (!enable_mgmt)
|
||||||
|
return -EINVAL;
|
||||||
|
set_bit(HCI_PI_MGMT_INIT, &hci_pi(sk)->flags);
|
||||||
|
}
|
||||||
|
|
||||||
lock_sock(sk);
|
lock_sock(sk);
|
||||||
|
|
||||||
|
@ -316,7 +316,10 @@ static int read_controller_info(struct sock *sk, u16 index)
|
|||||||
|
|
||||||
hci_dev_lock(hdev);
|
hci_dev_lock(hdev);
|
||||||
|
|
||||||
set_bit(HCI_MGMT, &hdev->flags);
|
if (test_and_clear_bit(HCI_PI_MGMT_INIT, &hci_pi(sk)->flags)) {
|
||||||
|
set_bit(HCI_MGMT, &hdev->flags);
|
||||||
|
set_bit(HCI_SERVICE_CACHE, &hdev->flags);
|
||||||
|
}
|
||||||
|
|
||||||
memset(&rp, 0, sizeof(rp));
|
memset(&rp, 0, sizeof(rp));
|
||||||
|
|
||||||
@ -989,6 +992,9 @@ static int set_dev_class(struct sock *sk, u16 index, unsigned char *data,
|
|||||||
hdev->major_class = cp->major;
|
hdev->major_class = cp->major;
|
||||||
hdev->minor_class = cp->minor;
|
hdev->minor_class = cp->minor;
|
||||||
|
|
||||||
|
if (test_and_clear_bit(HCI_SERVICE_CACHE, &hdev->flags))
|
||||||
|
update_eir(hdev);
|
||||||
|
|
||||||
err = update_class(hdev);
|
err = update_class(hdev);
|
||||||
|
|
||||||
if (err == 0)
|
if (err == 0)
|
||||||
@ -1000,51 +1006,6 @@ static int set_dev_class(struct sock *sk, u16 index, unsigned char *data,
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int set_service_cache(struct sock *sk, u16 index, unsigned char *data,
|
|
||||||
u16 len)
|
|
||||||
{
|
|
||||||
struct hci_dev *hdev;
|
|
||||||
struct mgmt_cp_set_service_cache *cp;
|
|
||||||
int err;
|
|
||||||
|
|
||||||
cp = (void *) data;
|
|
||||||
|
|
||||||
if (len != sizeof(*cp))
|
|
||||||
return cmd_status(sk, index, MGMT_OP_SET_SERVICE_CACHE,
|
|
||||||
MGMT_STATUS_INVALID_PARAMS);
|
|
||||||
|
|
||||||
hdev = hci_dev_get(index);
|
|
||||||
if (!hdev)
|
|
||||||
return cmd_status(sk, index, MGMT_OP_SET_SERVICE_CACHE,
|
|
||||||
MGMT_STATUS_INVALID_PARAMS);
|
|
||||||
|
|
||||||
hci_dev_lock(hdev);
|
|
||||||
|
|
||||||
BT_DBG("hci%u enable %d", index, cp->enable);
|
|
||||||
|
|
||||||
if (cp->enable) {
|
|
||||||
set_bit(HCI_SERVICE_CACHE, &hdev->flags);
|
|
||||||
err = 0;
|
|
||||||
} else {
|
|
||||||
clear_bit(HCI_SERVICE_CACHE, &hdev->flags);
|
|
||||||
err = update_class(hdev);
|
|
||||||
if (err == 0)
|
|
||||||
err = update_eir(hdev);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (err == 0)
|
|
||||||
err = cmd_complete(sk, index, MGMT_OP_SET_SERVICE_CACHE, NULL,
|
|
||||||
0);
|
|
||||||
else
|
|
||||||
cmd_status(sk, index, MGMT_OP_SET_SERVICE_CACHE, -err);
|
|
||||||
|
|
||||||
|
|
||||||
hci_dev_unlock(hdev);
|
|
||||||
hci_dev_put(hdev);
|
|
||||||
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int load_link_keys(struct sock *sk, u16 index, unsigned char *data,
|
static int load_link_keys(struct sock *sk, u16 index, unsigned char *data,
|
||||||
u16 len)
|
u16 len)
|
||||||
{
|
{
|
||||||
@ -2170,9 +2131,6 @@ int mgmt_control(struct sock *sk, struct msghdr *msg, size_t msglen)
|
|||||||
case MGMT_OP_SET_DEV_CLASS:
|
case MGMT_OP_SET_DEV_CLASS:
|
||||||
err = set_dev_class(sk, index, buf + sizeof(*hdr), len);
|
err = set_dev_class(sk, index, buf + sizeof(*hdr), len);
|
||||||
break;
|
break;
|
||||||
case MGMT_OP_SET_SERVICE_CACHE:
|
|
||||||
err = set_service_cache(sk, index, buf + sizeof(*hdr), len);
|
|
||||||
break;
|
|
||||||
case MGMT_OP_LOAD_LINK_KEYS:
|
case MGMT_OP_LOAD_LINK_KEYS:
|
||||||
err = load_link_keys(sk, index, buf + sizeof(*hdr), len);
|
err = load_link_keys(sk, index, buf + sizeof(*hdr), len);
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user