Commit 49a5f782 authored by Marcel Holtmann's avatar Marcel Holtmann

Bluetooth: btusb: Set early vendor info for Intel and Broadcom

For the controllers from Intel and Broadcom (including Apple), it is
helpful to have the information about the manufacturer send out early.

This patch sets the hdev->manufacturer information which will be send
out before actually calling the vendor specific hdev->setup driver
callback.
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
Signed-off-by: default avatarJohan Hedberg <johan.hedberg@intel.com>
parent e131d74a
...@@ -2874,6 +2874,7 @@ static int btusb_probe(struct usb_interface *intf, ...@@ -2874,6 +2874,7 @@ static int btusb_probe(struct usb_interface *intf,
#ifdef CONFIG_BT_HCIBTUSB_BCM #ifdef CONFIG_BT_HCIBTUSB_BCM
if (id->driver_info & BTUSB_BCM_PATCHRAM) { if (id->driver_info & BTUSB_BCM_PATCHRAM) {
hdev->manufacturer = 15;
hdev->setup = btbcm_setup_patchram; hdev->setup = btbcm_setup_patchram;
hdev->set_diag = btusb_bcm_set_diag; hdev->set_diag = btusb_bcm_set_diag;
hdev->set_bdaddr = btbcm_set_bdaddr; hdev->set_bdaddr = btbcm_set_bdaddr;
...@@ -2883,6 +2884,7 @@ static int btusb_probe(struct usb_interface *intf, ...@@ -2883,6 +2884,7 @@ static int btusb_probe(struct usb_interface *intf,
} }
if (id->driver_info & BTUSB_BCM_APPLE) { if (id->driver_info & BTUSB_BCM_APPLE) {
hdev->manufacturer = 15;
hdev->setup = btbcm_setup_apple; hdev->setup = btbcm_setup_apple;
hdev->set_diag = btusb_bcm_set_diag; hdev->set_diag = btusb_bcm_set_diag;
...@@ -2892,6 +2894,7 @@ static int btusb_probe(struct usb_interface *intf, ...@@ -2892,6 +2894,7 @@ static int btusb_probe(struct usb_interface *intf,
#endif #endif
if (id->driver_info & BTUSB_INTEL) { if (id->driver_info & BTUSB_INTEL) {
hdev->manufacturer = 2;
hdev->setup = btusb_setup_intel; hdev->setup = btusb_setup_intel;
hdev->shutdown = btusb_shutdown_intel; hdev->shutdown = btusb_shutdown_intel;
hdev->set_diag = btintel_set_diag_mfg; hdev->set_diag = btintel_set_diag_mfg;
...@@ -2902,6 +2905,7 @@ static int btusb_probe(struct usb_interface *intf, ...@@ -2902,6 +2905,7 @@ static int btusb_probe(struct usb_interface *intf,
} }
if (id->driver_info & BTUSB_INTEL_NEW) { if (id->driver_info & BTUSB_INTEL_NEW) {
hdev->manufacturer = 2;
hdev->send = btusb_send_frame_intel; hdev->send = btusb_send_frame_intel;
hdev->setup = btusb_setup_intel_new; hdev->setup = btusb_setup_intel_new;
hdev->hw_error = btintel_hw_error; hdev->hw_error = btintel_hw_error;
......
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