diff options
author | Johan Hedberg <johan.hedberg@intel.com> | 2014-07-11 14:32:23 +0200 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2014-07-11 15:23:23 +0200 |
commit | 6c53823ae0e10e723131055e1e65dd6a328a228e (patch) | |
tree | 99204b4d1eb473fb20d167bca8c995c1ec00227e /net/ieee802154/ieee802154.h | |
parent | Bluetooth: Add support for external configuration with UART driver (diff) | |
download | linux-6c53823ae0e10e723131055e1e65dd6a328a228e.tar.xz linux-6c53823ae0e10e723131055e1e65dd6a328a228e.zip |
Bluetooth: Fix tracking local SSP authentication requirement
When we need to make the decision whether to perform just-works or real
user confirmation we need to know the exact local authentication
requirement that was passed to the controller. So far conn->auth_type
(the local requirement) wasn't in one case updated appropriately in fear
of the user confirmation being rejected later.
The real problem however was not really that conn->auth_type couldn't
represent the true value but that we were checking the local MITM
requirement in an incorrect way. It's perfectly fine to let auth_type
follow what we tell the controller since we're still tracking the target
security level with conn->pending_sec_level.
This patch updates the check for local MITM requirement in the
hci_user_confirm_request_evt function to use the locally requested
security level and ensures that auth_type always represents what we tell
the controller. All other code in hci_user_confirm_request_evt still
uses the auth_type instead of pending_sec_level for determining whether
to do just-works or not, since that's the only value that's in sync with
what the remote device knows.
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
Tested-by: Szymon Janc <szymon.janc@tieto.com>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Cc: stable@vger.kernel.org # 3.16
Diffstat (limited to 'net/ieee802154/ieee802154.h')
0 files changed, 0 insertions, 0 deletions