Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3876171pxf; Tue, 6 Apr 2021 02:26:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxJWNqGU0wyRtT3u2I9TmjoRs4lyUtQoFDQtAhAEjFNy7T89FVzlYpOh242Vo+Or4UCqJf8 X-Received: by 2002:a6b:fc05:: with SMTP id r5mr23336029ioh.103.1617701209005; Tue, 06 Apr 2021 02:26:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617701208; cv=none; d=google.com; s=arc-20160816; b=OmgAgVoSJ0615AkdUO85KVYHS2i3yQqcb2IYN/UrQ6j2TXqzSF2LL0TOv8yZGcX9x1 0Y7EcoOQX7Z16YJQgSoDuoU7+euC3oyLC34XXShr14JuCeH5PIj6sBPHNKoElpQ4szt9 6gNV2iO1HLD727iJmcyc2ljEfTSI5La81BQQLnG4rEtvMQu8zob1XBEh9qIagfqizbRT VOQcAEkCu++s03INBHdg/gGQeYa2MZKdIwu0cqW0iUjDjo89jDRqOZcOOVOqiJPY1Shv 5iwcbHjmvmR5C+tAbVlNzeqfdqQkGB3DN3xzPlX/PrcVMHdssaR3tvKzZvYQU7N2pZ56 SBwA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=cFNg79nyIF5RiupscoranBOwCXgBdT7UV4RmYj6ptPk=; b=jkrlNvlWKTHIZTPxKgBHSblMm1GJOiV5R2I67D1OL7mHQCmdvG5ugrWLwGNZhbVCRh /dhEJ5tyU0VoeRFaFZJk/Y6AMX09hIm0Tdqt+d1c349XLkwnEEXoJoKgielk/rXlNPbv bgdiRzPsSxLeofjs12F6DudOERGvkJRDyL8clMMyzKXTHKeKTLZfVHQTqY5fxuH/3gw2 jpZYC/uZxJCPexqCAuRL1jHAJiCUFYU+5W6AInwlKUtTZoRYZqZqFp0UeXxqUba1oRXt SIh3Cipjqg8JPWk8hGcsTTwMIRPdJNjI4dS/+coXjy4OvV6Woj4PhNBM1VlaTpjxqHJq I6VA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=jRBfq3Ce; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l11si19923370ils.61.2021.04.06.02.26.05; Tue, 06 Apr 2021 02:26:48 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=jRBfq3Ce; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240884AbhDEUgQ (ORCPT + 99 others); Mon, 5 Apr 2021 16:36:16 -0400 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:51993 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236422AbhDEUgP (ORCPT ); Mon, 5 Apr 2021 16:36:15 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1617654968; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding; bh=cFNg79nyIF5RiupscoranBOwCXgBdT7UV4RmYj6ptPk=; b=jRBfq3CeF27GR70n8P0faTVwXJOiypT5aDy+KPjjMTg3aMYaPvaDE0ifft+CHRKSV0377/ cntMqQNfu43OjODKS+OWN2DoSP1r+b9LlOfLEMTVpNVFZsIVWp5UpYyvmdDMPlLGLUa3SN xacDaW4Vwlh4r4pZ1KTH0v15wlZuxmg= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-575-vaLmDVPCP_azrN8VeKAmbw-1; Mon, 05 Apr 2021 16:36:06 -0400 X-MC-Unique: vaLmDVPCP_azrN8VeKAmbw-1 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.phx2.redhat.com [10.5.11.15]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 5CEAD1084C8C; Mon, 5 Apr 2021 20:36:05 +0000 (UTC) Received: from x1.localdomain (ovpn-112-31.ams2.redhat.com [10.36.112.31]) by smtp.corp.redhat.com (Postfix) with ESMTP id 9E1725D74B; Mon, 5 Apr 2021 20:36:03 +0000 (UTC) From: Hans de Goede To: Marcel Holtmann , Johan Hedberg , Luiz Augusto von Dentz Cc: Hans de Goede , linux-bluetooth@vger.kernel.org, Luiz Augusto von Dentz , Vasily Khoruzhick , Abhishek Pandit-Subedi Subject: [PATCH resend] Bluetooth: hci_h5: Disable the hci_suspend_notifier for btrtl devices Date: Mon, 5 Apr 2021 22:36:02 +0200 Message-Id: <20210405203602.17151-1-hdegoede@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.15 Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org The hci_suspend_notifier which was introduced last year, is causing problems for uart attached btrtl devices. These devices may loose their firmware and their baudrate setting over a suspend/resume. Since we don't even know the baudrate after a suspend/resume recovering from this is tricky. The driver solves this by treating these devices the same as USB BT HCIs which drop of the bus during suspend. Specifically the driver: 1. Simply unconditionally turns the device fully off during system-suspend to save maximum power. 2. Calls device_reprobe() from a workqueue to fully re-init the device from scratch on system-resume (unregistering the old HCI and registering a new HCI). This means that these devices do not benefit from the suspend / resume handling work done by the hci_suspend_notifier. At best this unnecessarily adds some time to the suspend/resume time. But in practice this is actually causing problems: 1. These btrtl devices seem to not like the HCI_OP_WRITE_SCAN_ENABLE( SCAN_DISABLED) request being send to them when entering the BT_SUSPEND_CONFIGURE_WAKE state. The same request send on BT_SUSPEND_DISCONNECT works fine, but the second one send (unnecessarily?) from the BT_SUSPEND_CONFIGURE_WAKE transition causes the device to hang: [ 573.497754] PM: suspend entry (s2idle) [ 573.554615] Filesystems sync: 0.056 seconds [ 575.837753] Bluetooth: hci0: Timed out waiting for suspend events [ 575.837801] Bluetooth: hci0: Suspend timeout bit: 4 [ 575.837925] Bluetooth: hci0: Suspend notifier action (3) failed: -110 2. The PM_POST_SUSPEND / BT_RUNNING transition races with the driver-unbinding done by the device_reprobe() work. If the hci_suspend_notifier wins the race it is talking to a dead device leading to the following errors being logged: [ 598.686060] Bluetooth: hci0: Timed out waiting for suspend events [ 598.686124] Bluetooth: hci0: Suspend timeout bit: 5 [ 598.686237] Bluetooth: hci0: Suspend notifier action (4) failed: -110 In both cases things still work, but the suspend-notifier is causing these ugly errors getting logged and ut increase both the suspend- and the resume-time by 2 seconds. This commit avoids these problems by disabling the hci_suspend_notifier. Cc: Luiz Augusto von Dentz Cc: Vasily Khoruzhick Cc: Abhishek Pandit-Subedi Signed-off-by: Hans de Goede --- Changes in v2: - Use the new HCI_QUIRK_NO_SUSPEND_NOTIFIER quirk, instead of directly unregistering the notifier from hci_h5.c --- drivers/bluetooth/hci_h5.c | 7 +++++++ drivers/bluetooth/hci_serdev.c | 3 +++ drivers/bluetooth/hci_uart.h | 13 +++++++------ 3 files changed, 17 insertions(+), 6 deletions(-) diff --git a/drivers/bluetooth/hci_h5.c b/drivers/bluetooth/hci_h5.c index 27e96681d583..d79b7bbe6d94 100644 --- a/drivers/bluetooth/hci_h5.c +++ b/drivers/bluetooth/hci_h5.c @@ -919,6 +919,13 @@ static int h5_btrtl_setup(struct h5 *h5) static void h5_btrtl_open(struct h5 *h5) { + /* + * Since h5_btrtl_resume() does a device_reprobe() the suspend handling + * done by the hci_suspend_notifier is not necessary; it actually causes + * delays and a bunch of errors to get logged, so disable it. + */ + set_bit(HCI_UART_NO_SUSPEND_NOTIFIER, &h5->hu->hdev_flags); + /* Devices always start with these fixed parameters */ serdev_device_set_flow_control(h5->hu->serdev, false); serdev_device_set_parity(h5->hu->serdev, SERDEV_PARITY_EVEN); diff --git a/drivers/bluetooth/hci_serdev.c b/drivers/bluetooth/hci_serdev.c index 9e03402ef1b3..113045e98c19 100644 --- a/drivers/bluetooth/hci_serdev.c +++ b/drivers/bluetooth/hci_serdev.c @@ -349,6 +349,9 @@ int hci_uart_register_device(struct hci_uart *hu, if (test_bit(HCI_UART_EXT_CONFIG, &hu->hdev_flags)) set_bit(HCI_QUIRK_EXTERNAL_CONFIG, &hdev->quirks); + if (test_bit(HCI_UART_NO_SUSPEND_NOTIFIER, &hu->hdev_flags)) + set_bit(HCI_QUIRK_NO_SUSPEND_NOTIFIER, &hdev->quirks); + if (test_bit(HCI_UART_CREATE_AMP, &hu->hdev_flags)) hdev->dev_type = HCI_AMP; else diff --git a/drivers/bluetooth/hci_uart.h b/drivers/bluetooth/hci_uart.h index 4e039d7a16f8..4df2330ac103 100644 --- a/drivers/bluetooth/hci_uart.h +++ b/drivers/bluetooth/hci_uart.h @@ -35,12 +35,13 @@ #define HCI_UART_NOKIA 10 #define HCI_UART_MRVL 11 -#define HCI_UART_RAW_DEVICE 0 -#define HCI_UART_RESET_ON_INIT 1 -#define HCI_UART_CREATE_AMP 2 -#define HCI_UART_INIT_PENDING 3 -#define HCI_UART_EXT_CONFIG 4 -#define HCI_UART_VND_DETECT 5 +#define HCI_UART_RAW_DEVICE 0 +#define HCI_UART_RESET_ON_INIT 1 +#define HCI_UART_CREATE_AMP 2 +#define HCI_UART_INIT_PENDING 3 +#define HCI_UART_EXT_CONFIG 4 +#define HCI_UART_VND_DETECT 5 +#define HCI_UART_NO_SUSPEND_NOTIFIER 6 struct hci_uart; struct serdev_device; -- 2.30.2