Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 83927882 authored by Arron Wang's avatar Arron Wang Committed by Marcel Holtmann
Browse files

Bluetooth: Move get info completed callback to a2mp.c



To avoid a2mp module hooks from hci_event.c and send
getinfo response operation only required by a2mp module,
we can move this callback to a2mp.c

Signed-off-by: default avatarArron Wang <arron.wang@intel.com>
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent a77a6a14
Loading
Loading
Loading
Loading
+16 −1
Original line number Original line Diff line number Diff line
@@ -16,6 +16,7 @@
#include <net/bluetooth/hci_core.h>
#include <net/bluetooth/hci_core.h>
#include <net/bluetooth/l2cap.h>
#include <net/bluetooth/l2cap.h>


#include "hci_request.h"
#include "a2mp.h"
#include "a2mp.h"
#include "amp.h"
#include "amp.h"


@@ -286,11 +287,21 @@ static int a2mp_change_notify(struct amp_mgr *mgr, struct sk_buff *skb,
	return 0;
	return 0;
}
}


static void read_local_amp_info_complete(struct hci_dev *hdev, u8 status,
					 u16 opcode)
{
	BT_DBG("%s status 0x%2.2x", hdev->name, status);

	a2mp_send_getinfo_rsp(hdev);
}

static int a2mp_getinfo_req(struct amp_mgr *mgr, struct sk_buff *skb,
static int a2mp_getinfo_req(struct amp_mgr *mgr, struct sk_buff *skb,
			    struct a2mp_cmd *hdr)
			    struct a2mp_cmd *hdr)
{
{
	struct a2mp_info_req *req  = (void *) skb->data;
	struct a2mp_info_req *req  = (void *) skb->data;
	struct hci_dev *hdev;
	struct hci_dev *hdev;
	struct hci_request hreq;
	int err = 0;


	if (le16_to_cpu(hdr->len) < sizeof(*req))
	if (le16_to_cpu(hdr->len) < sizeof(*req))
		return -EINVAL;
		return -EINVAL;
@@ -311,7 +322,11 @@ static int a2mp_getinfo_req(struct amp_mgr *mgr, struct sk_buff *skb,
	}
	}


	set_bit(READ_LOC_AMP_INFO, &mgr->state);
	set_bit(READ_LOC_AMP_INFO, &mgr->state);
	hci_send_cmd(hdev, HCI_OP_READ_LOCAL_AMP_INFO, 0, NULL);
	hci_req_init(&hreq, hdev);
	hci_req_add(&hreq, HCI_OP_READ_LOCAL_AMP_INFO, 0, NULL);
	err = hci_req_run(&hreq, read_local_amp_info_complete);
	if (err < 0)
		a2mp_send_getinfo_rsp(hdev);


done:
done:
	if (hdev)
	if (hdev)
+1 −4
Original line number Original line Diff line number Diff line
@@ -823,7 +823,7 @@ static void hci_cc_read_local_amp_info(struct hci_dev *hdev,
	BT_DBG("%s status 0x%2.2x", hdev->name, rp->status);
	BT_DBG("%s status 0x%2.2x", hdev->name, rp->status);


	if (rp->status)
	if (rp->status)
		goto a2mp_rsp;
		return;


	hdev->amp_status = rp->amp_status;
	hdev->amp_status = rp->amp_status;
	hdev->amp_total_bw = __le32_to_cpu(rp->total_bw);
	hdev->amp_total_bw = __le32_to_cpu(rp->total_bw);
@@ -835,9 +835,6 @@ static void hci_cc_read_local_amp_info(struct hci_dev *hdev,
	hdev->amp_assoc_size = __le16_to_cpu(rp->max_assoc_size);
	hdev->amp_assoc_size = __le16_to_cpu(rp->max_assoc_size);
	hdev->amp_be_flush_to = __le32_to_cpu(rp->be_flush_to);
	hdev->amp_be_flush_to = __le32_to_cpu(rp->be_flush_to);
	hdev->amp_max_flush_to = __le32_to_cpu(rp->max_flush_to);
	hdev->amp_max_flush_to = __le32_to_cpu(rp->max_flush_to);

a2mp_rsp:
	a2mp_send_getinfo_rsp(hdev);
}
}


static void hci_cc_read_local_amp_assoc(struct hci_dev *hdev,
static void hci_cc_read_local_amp_assoc(struct hci_dev *hdev,