#include <net/bluetooth/bluetooth.h>
 #include <net/bluetooth/hci_core.h>
 
+#include "btintel.h"
 #include "btbcm.h"
 
 #define VERSION "0.8"
        return 0;
 }
 
-#define BDADDR_INTEL (&(bdaddr_t) {{0x00, 0x8b, 0x9e, 0x19, 0x03, 0x00}})
-
-static int btusb_check_bdaddr_intel(struct hci_dev *hdev)
-{
-       struct sk_buff *skb;
-       struct hci_rp_read_bd_addr *rp;
-
-       skb = __hci_cmd_sync(hdev, HCI_OP_READ_BD_ADDR, 0, NULL,
-                            HCI_INIT_TIMEOUT);
-       if (IS_ERR(skb)) {
-               BT_ERR("%s reading Intel device address failed (%ld)",
-                      hdev->name, PTR_ERR(skb));
-               return PTR_ERR(skb);
-       }
-
-       if (skb->len != sizeof(*rp)) {
-               BT_ERR("%s Intel device address length mismatch", hdev->name);
-               kfree_skb(skb);
-               return -EIO;
-       }
-
-       rp = (struct hci_rp_read_bd_addr *)skb->data;
-       if (rp->status) {
-               BT_ERR("%s Intel device address result failed (%02x)",
-                      hdev->name, rp->status);
-               kfree_skb(skb);
-               return -bt_to_errno(rp->status);
-       }
-
-       /* For some Intel based controllers, the default Bluetooth device
-        * address 00:03:19:9E:8B:00 can be found. These controllers are
-        * fully operational, but have the danger of duplicate addresses
-        * and that in turn can cause problems with Bluetooth operation.
-        */
-       if (!bacmp(&rp->bdaddr, BDADDR_INTEL)) {
-               BT_ERR("%s found Intel default device address (%pMR)",
-                      hdev->name, &rp->bdaddr);
-               set_bit(HCI_QUIRK_INVALID_BDADDR, &hdev->quirks);
-       }
-
-       kfree_skb(skb);
-
-       return 0;
-}
-
 static int btusb_setup_intel(struct hci_dev *hdev)
 {
        struct sk_buff *skb;
                BT_INFO("%s: Intel device is already patched. patch num: %02x",
                        hdev->name, ver->fw_patch_num);
                kfree_skb(skb);
-               btusb_check_bdaddr_intel(hdev);
+               btintel_check_bdaddr(hdev);
                return 0;
        }
 
        fw = btusb_setup_intel_get_fw(hdev, ver);
        if (!fw) {
                kfree_skb(skb);
-               btusb_check_bdaddr_intel(hdev);
+               btintel_check_bdaddr(hdev);
                return 0;
        }
        fw_ptr = fw->data;
        BT_INFO("%s: Intel Bluetooth firmware patch completed and activated",
                hdev->name);
 
-       btusb_check_bdaddr_intel(hdev);
+       btintel_check_bdaddr(hdev);
        return 0;
 
 exit_mfg_disable:
 
        BT_INFO("%s: Intel Bluetooth firmware patch completed", hdev->name);
 
-       btusb_check_bdaddr_intel(hdev);
+       btintel_check_bdaddr(hdev);
        return 0;
 
 exit_mfg_deactivate:
        BT_INFO("%s: Intel Bluetooth firmware patch completed and deactivated",
                hdev->name);
 
-       btusb_check_bdaddr_intel(hdev);
+       btintel_check_bdaddr(hdev);
        return 0;
 }
 
        if (ver->fw_variant == 0x23) {
                kfree_skb(skb);
                clear_bit(BTUSB_BOOTLOADER, &data->flags);
-               btusb_check_bdaddr_intel(hdev);
+               btintel_check_bdaddr(hdev);
                return 0;
        }
 
        kfree_skb(skb);
 }
 
-static int btusb_set_bdaddr_intel(struct hci_dev *hdev, const bdaddr_t *bdaddr)
-{
-       struct sk_buff *skb;
-       long ret;
-
-       skb = __hci_cmd_sync(hdev, 0xfc31, 6, bdaddr, HCI_INIT_TIMEOUT);
-       if (IS_ERR(skb)) {
-               ret = PTR_ERR(skb);
-               BT_ERR("%s: changing Intel device address failed (%ld)",
-                      hdev->name, ret);
-               return ret;
-       }
-       kfree_skb(skb);
-
-       return 0;
-}
-
 static int btusb_shutdown_intel(struct hci_dev *hdev)
 {
        struct sk_buff *skb;
        if (id->driver_info & BTUSB_INTEL) {
                hdev->setup = btusb_setup_intel;
                hdev->shutdown = btusb_shutdown_intel;
-               hdev->set_bdaddr = btusb_set_bdaddr_intel;
+               hdev->set_bdaddr = btintel_set_bdaddr;
                set_bit(HCI_QUIRK_STRICT_DUPLICATE_FILTER, &hdev->quirks);
                set_bit(HCI_QUIRK_SIMULTANEOUS_DISCOVERY, &hdev->quirks);
        }
                hdev->send = btusb_send_frame_intel;
                hdev->setup = btusb_setup_intel_new;
                hdev->hw_error = btusb_hw_error_intel;
-               hdev->set_bdaddr = btusb_set_bdaddr_intel;
+               hdev->set_bdaddr = btintel_set_bdaddr;
                set_bit(HCI_QUIRK_STRICT_DUPLICATE_FILTER, &hdev->quirks);
        }