diff options
| author | Marcel Holtmann <marcel@holtmann.org> | 2019-11-22 00:33:45 +0100 | 
|---|---|---|
| committer | Johan Hedberg <johan.hedberg@intel.com> | 2019-11-22 10:05:09 +0200 | 
| commit | 7fdf6c6a0d0e032aac2aa4537a23af1e04a397ce (patch) | |
| tree | 82f2633030204969e9786351095818862e03c5ab | |
| parent | 1199ab4c9e1d4cdfbabd70b4aadbc8e72c691f65 (diff) | |
| download | blackbird-op-linux-7fdf6c6a0d0e032aac2aa4537a23af1e04a397ce.tar.gz blackbird-op-linux-7fdf6c6a0d0e032aac2aa4537a23af1e04a397ce.zip  | |
Bluetooth: Allow combination of BDADDR_PROPERTY and INVALID_BDADDR quirks
When utilizing BDADDR_PROPERTY and INVALID_BDADDR quirks together it
results in an unconfigured controller even if the bootloader provides
a valid address. Fix this by allowing a bootloader provided address
to mark the controller as configured.
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Tested-by: Andre Heider <a.heider@gmail.com>
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
| -rw-r--r-- | net/bluetooth/hci_core.c | 26 | 
1 files changed, 24 insertions, 2 deletions
diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c index 0cc9ce917222..9e19d5a3aac8 100644 --- a/net/bluetooth/hci_core.c +++ b/net/bluetooth/hci_core.c @@ -1444,11 +1444,20 @@ static int hci_dev_do_open(struct hci_dev *hdev)  	if (hci_dev_test_flag(hdev, HCI_SETUP) ||  	    test_bit(HCI_QUIRK_NON_PERSISTENT_SETUP, &hdev->quirks)) { +		bool invalid_bdaddr; +  		hci_sock_dev_event(hdev, HCI_DEV_SETUP);  		if (hdev->setup)  			ret = hdev->setup(hdev); +		/* The transport driver can set the quirk to mark the +		 * BD_ADDR invalid before creating the HCI device or in +		 * its setup callback. +		 */ +		invalid_bdaddr = test_bit(HCI_QUIRK_INVALID_BDADDR, +					  &hdev->quirks); +  		if (ret)  			goto setup_failed; @@ -1457,20 +1466,33 @@ static int hci_dev_do_open(struct hci_dev *hdev)  				hci_dev_get_bd_addr_from_property(hdev);  			if (bacmp(&hdev->public_addr, BDADDR_ANY) && -			    hdev->set_bdaddr) +			    hdev->set_bdaddr) {  				ret = hdev->set_bdaddr(hdev,  						       &hdev->public_addr); + +				/* If setting of the BD_ADDR from the device +				 * property succeeds, then treat the address +				 * as valid even if the invalid BD_ADDR +				 * quirk indicates otherwise. +				 */ +				if (!ret) +					invalid_bdaddr = false; +			}  		}  setup_failed:  		/* The transport driver can set these quirks before  		 * creating the HCI device or in its setup callback.  		 * +		 * For the invalid BD_ADDR quirk it is possible that +		 * it becomes a valid address if the bootloader does +		 * provide it (see above). +		 *  		 * In case any of them is set, the controller has to  		 * start up as unconfigured.  		 */  		if (test_bit(HCI_QUIRK_EXTERNAL_CONFIG, &hdev->quirks) || -		    test_bit(HCI_QUIRK_INVALID_BDADDR, &hdev->quirks)) +		    invalid_bdaddr)  			hci_dev_set_flag(hdev, HCI_UNCONFIGURED);  		/* For an unconfigured controller it is required to  | 

