Received: by 2002:ab2:620c:0:b0:1ef:ffd0:ce49 with SMTP id o12csp1356971lqt; Wed, 20 Mar 2024 00:59:13 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUzdLUAnKtgQCcHVDuHU5Rw9PmRbB4PHQd2Uso9foE6wjosKo4t4CsukypH27z89iYleUcld4qA7eN3PPbPk1/YnzmxQIjuLZGNUaaKcg== X-Google-Smtp-Source: AGHT+IHUKes1chMFw+5po9/9im+FRYcxkYU11M2z3X6yAUrMg1sX1r3xFwLPdolEjlYP7bMSn3Hz X-Received: by 2002:a05:6830:3d14:b0:6e6:878e:5622 with SMTP id eu20-20020a0568303d1400b006e6878e5622mr9848721otb.14.1710921552917; Wed, 20 Mar 2024 00:59:12 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710921552; cv=pass; d=google.com; s=arc-20160816; b=PQToT7fY5LOZuT6xECQR2TjeyIPGMLIu+jS//3NOofK04hYikyqw8FLt7qkk6XuzCk /DSW9petHuqJkts5T81i4t3Wxfrqx8NcVPM6ndug8u6eMGTtp9IzE08CzDsFqgl+q5Ba uVn1DQk5ApQwtlDxv1GenFDiR017V9W0xCIA9Zhubgtyof2ZfnSJVdkHRGVQs32wR+JR YLeLZYQgZnRIdri5ks53cVcdOZ1w17UDC2F/wPGrw8dcC5bLOIWd5QM2+ix3lzF2Y5FX WeOM5B4DAe3ZyPC/jpNhQijch/eB/I3BwDKSQRt41i/kl9IqVtBLIIx/QATi1Ilks2l0 Fsww== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=6MbgPB04gnhurfjJ3X/hTweUSxwLVTle7hSEagKCPuc=; fh=F04fe33vT5eaSryyQ03DAGap9f22wfke0VhAQjB9gNc=; b=pmowc/LJ7Gn0H19xzC3Xkn3gjEd0SL+cCgO/EoKSXub/NY9A0rhAuKYVXAeemhOXnI mg/h/O/ECDtpfe0T6fV0kqC5RZ6f72OFFddt1xqL6CEdXGX3oD3q9iGMtWyZQSWyKpm2 dtfhgEllQNpsmGOzTumFof0qh+3oBfZv3y/nCUGNWEvhzao3sw4MWRHQWJfn5q1SvbBc 6Z+tRVesnWQ4pvTWSC99h0kRX1T4gjqyR7E9EcB4D3AhhL8lDVUG0vI7Uekt2Mts2nNG 7EooKavSD8DdeirJRc8v4Y/lVKKsQ1N+8IGoUWvV7fVxOztfjZ8/1GXrAbRHdI6bOcp+ q3Ew==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=LS9BStrb; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-bluetooth+bounces-2652-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-bluetooth+bounces-2652-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id l66-20020a633e45000000b005dc785e4a28si11608185pga.30.2024.03.20.00.59.12 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 20 Mar 2024 00:59:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-bluetooth+bounces-2652-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=LS9BStrb; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-bluetooth+bounces-2652-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-bluetooth+bounces-2652-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 947F2B21450 for ; Wed, 20 Mar 2024 07:59:11 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 790BB3A8DD; Wed, 20 Mar 2024 07:58:20 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="LS9BStrb" X-Original-To: linux-bluetooth@vger.kernel.org Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 9B2C32C6B5; Wed, 20 Mar 2024 07:58:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710921499; cv=none; b=ozYDm8X6CvlkA76Jp0n9O8VdO62d2mwuVIOsJjoX6o+rWGnKSutyFqpLiN6nDYOIQyn9SbJo3R1X1jZbMSXOqnc7qAluILD8nVLjX5OQwJPnNptuxVwbXEYSPkrLyVI34fTy8W/NMejKtGa/ohczTnv/cgVuMxrqZM0+BAMVhzA= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710921499; c=relaxed/simple; bh=jMwtybi/vY23D4ux1YBawunur6a8HYoEY3QxQ+/Xaks=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=D/DOe4EbtquMsv1RTeaDivbi1NUOUbQDzD/xBQPRj7X+pMYO2BNrQZUg9NCwTFEWI1J6A/FiHq508T+AZuySkF5H3IBKAItgwo1kWHR0uisVEJ+rByqQwps+WCSXFHDrNvnvSOQg84SUCXWq+FId/y/hFCAFxvM7NjD9GzXNhLg= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=LS9BStrb; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 14B87C433A6; Wed, 20 Mar 2024 07:58:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1710921499; bh=jMwtybi/vY23D4ux1YBawunur6a8HYoEY3QxQ+/Xaks=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=LS9BStrbKU6UmW+ub3pVIJtdgxGz4vgAD+ZGiEFJDZDHzB0ZafWf+Ct2gVVwsBSqW cwXiwLZyUzjHcdfRYPqtfqdmEPvNaQS/MbAataMyCtxgESpBf+uZva7WwSWLXffTOL 4sCSnRt+fnL6ZowqObgV/yG5eDolPOxJB6udC0peUwJS1jXtG3bDjV8Dy0r3uRnEsw bE3HJf0l2EEX0GqkND3obUUVmVsKtAV3Vh2k/gWem2QuS5IlWQrZNGJQ+MIkPlpD+E udCdBvcuOSEuaeH7q5mhcTfJqJa5G0gyjz276l/w5oNjcxMcVGzmUBXSxpHXs60wVZ fsHmS/U4Ux/6A== Received: from johan by xi.lan with local (Exim 4.97.1) (envelope-from ) id 1rmqq9-0000000029Q-24gf; Wed, 20 Mar 2024 08:58:25 +0100 From: Johan Hovold To: Marcel Holtmann , Luiz Augusto von Dentz , Bjorn Andersson Cc: Rob Herring , Krzysztof Kozlowski , Conor Dooley , cros-qcom-dts-watchers@chromium.org, Konrad Dybcio , Johan Hedberg , Balakrishna Godavarthi , Matthias Kaehlcke , Douglas Anderson , Rocky Liao , Dmitry Baryshkov , linux-bluetooth@vger.kernel.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org, Johan Hovold , stable@vger.kernel.org Subject: [PATCH v4 3/4] Bluetooth: add quirk for broken address properties Date: Wed, 20 Mar 2024 08:55:53 +0100 Message-ID: <20240320075554.8178-4-johan+linaro@kernel.org> X-Mailer: git-send-email 2.43.2 In-Reply-To: <20240320075554.8178-1-johan+linaro@kernel.org> References: <20240320075554.8178-1-johan+linaro@kernel.org> Precedence: bulk X-Mailing-List: linux-bluetooth@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Some Bluetooth controllers lack persistent storage for the device address and instead one can be provided by the boot firmware using the 'local-bd-address' devicetree property. The Bluetooth devicetree bindings clearly states that the address should be specified in little-endian order, but due to a long-standing bug in the Qualcomm driver which reversed the address some boot firmware has been providing the address in big-endian order instead. Add a new quirk that can be set on platforms with broken firmware and use it to reverse the address when parsing the property so that the underlying driver bug can be fixed. Fixes: 5c0a1001c8be ("Bluetooth: hci_qca: Add helper to set device address") Cc: stable@vger.kernel.org # 5.1 Reviewed-by: Douglas Anderson Signed-off-by: Johan Hovold --- include/net/bluetooth/hci.h | 9 +++++++++ net/bluetooth/hci_sync.c | 5 ++++- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/include/net/bluetooth/hci.h b/include/net/bluetooth/hci.h index bdee5d649cc6..191077d8d578 100644 --- a/include/net/bluetooth/hci.h +++ b/include/net/bluetooth/hci.h @@ -176,6 +176,15 @@ enum { */ HCI_QUIRK_USE_BDADDR_PROPERTY, + /* When this quirk is set, the Bluetooth Device Address provided by + * the 'local-bd-address' fwnode property is incorrectly specified in + * big-endian order. + * + * This quirk can be set before hci_register_dev is called or + * during the hdev->setup vendor callback. + */ + HCI_QUIRK_BDADDR_PROPERTY_BROKEN, + /* When this quirk is set, the duplicate filtering during * scanning is based on Bluetooth devices addresses. To allow * RSSI based updates, restart scanning if needed. diff --git a/net/bluetooth/hci_sync.c b/net/bluetooth/hci_sync.c index 5716345a26df..283ae8edc1e5 100644 --- a/net/bluetooth/hci_sync.c +++ b/net/bluetooth/hci_sync.c @@ -3215,7 +3215,10 @@ static void hci_dev_get_bd_addr_from_property(struct hci_dev *hdev) if (ret < 0 || !bacmp(&ba, BDADDR_ANY)) return; - bacpy(&hdev->public_addr, &ba); + if (test_bit(HCI_QUIRK_BDADDR_PROPERTY_BROKEN, &hdev->quirks)) + baswap(&hdev->public_addr, &ba); + else + bacpy(&hdev->public_addr, &ba); } struct hci_init_stage { -- 2.43.2