Received: by 2002:ab2:620c:0:b0:1ef:ffd0:ce49 with SMTP id o12csp336223lqt; Mon, 18 Mar 2024 09:08:44 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUN9gGgsrRL6qIt4caEu7ez63AqD5WugEBCIPnKYY19unca5cEFRr/2jNkhA9jK948MWQZIDfcLs0juJ7MCXSQrO8OYd7BlI48fECtF/w== X-Google-Smtp-Source: AGHT+IEqi69uZFRmPuLlNTWLkHZmG5c6TkA26f6Wv27kBrhD1+kVC1G6ZhlFYnsaa6v5RgmcUseV X-Received: by 2002:a17:902:d3c6:b0:1df:f9fc:c9f7 with SMTP id w6-20020a170902d3c600b001dff9fcc9f7mr92931plb.61.1710778123785; Mon, 18 Mar 2024 09:08:43 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710778123; cv=pass; d=google.com; s=arc-20160816; b=sb1isBSRU5id5q2mxmaml4pXKRMfU04GEfmOWo/BhzkVOa1TCiYB0nHERBDYw5206b 3dykr2xPKX0evK9l2Nr/38XmfrcejB+o9q1/CCHb2HedDYMzF7Ch+NHY5cIKsTYNnxVM pyH42YYaNe1Qx+sV1ufNRIEw4QYhOwzxpfzXc1X12teBndAMGu5kDP7Amfkde91pTRn/ YkB3UzrfOjevhUk9azMoyvHEOsrz/gEliIKwQh1HTk8wRqL0NIaba+qXfm4QbJP5W7sF zdSeSzk9JaSrWU5UzzFEnq7ewhIrp3ukWkI2GnI3m2/MzgxCKVNRLzzQIE3FAUMAbZsb OZYw== 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:message-id:date:subject:to:from :dkim-signature; bh=688Oa3pVNei7pc+xdUk174lTU1EQp6WO10bjNFM1Q8c=; fh=4lGQI6056MBa4/oovMyIYaKLn+Wz/24RGvUivMmQP8E=; b=PKlAkZQ2zJN04AAqPSoGp9UXqSQQRlqmn/pna9nf4YNTGF9QAmszDcL6ElhtjVaaVU wrr800wkQ3WKJVwNjRXWIp0NZMUx37RJuQ/70XMDVaWd5TLlNWjV8C05T6vSD+IZxtS2 WG4hJln/I02qXhsuj/v+3lKWql+eZlrg+B99D8dZAj896PBS8bPtdxXx9b3N8/gybYnV mAfPj91fMgS/BXU1qpkYuDQkxlkJtes/08I869fb7foBMr3HUbzoBy2/KLXuvAr2BzDZ TqnTkobWYAAMG9D7640cs+rGoWXY61N+Xv8s7nJaFEnob8NHSoPE7vZ9uP8/VdscHZrh 7ZTw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=AaDDUtV+; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-bluetooth+bounces-2593-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) smtp.mailfrom="linux-bluetooth+bounces-2593-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [2604:1380:45e3:2400::1]) by mx.google.com with ESMTPS id i3-20020a17090332c300b001dede3a67ddsi8744818plr.106.2024.03.18.09.08.43 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Mar 2024 09:08:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-bluetooth+bounces-2593-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) client-ip=2604:1380:45e3:2400::1; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=AaDDUtV+; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-bluetooth+bounces-2593-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) smtp.mailfrom="linux-bluetooth+bounces-2593-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com 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 sv.mirrors.kernel.org (Postfix) with ESMTPS id 14D7F281421 for ; Mon, 18 Mar 2024 16:08:43 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id A64C152F94; Mon, 18 Mar 2024 16:08:38 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="AaDDUtV+" X-Original-To: linux-bluetooth@vger.kernel.org Received: from mail-wm1-f54.google.com (mail-wm1-f54.google.com [209.85.128.54]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 6EEAE524D9 for ; Mon, 18 Mar 2024 16:08:36 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.54 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710778118; cv=none; b=mCVzAmLliBWCjcStqyaj27BM0ffr1XL2XTKqppYeWrs52UkBvspqoJ/kBuNSGH0nKIn0WbDhRP7Qw98EBAC/3JDHYkTjmISkhzrr3Cs1G702zpLAfgPRgmMQQlHVjxuly57Ea4I4mrB7XccrSHlmr65FmHo3pet0P2wu3GA+qNs= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710778118; c=relaxed/simple; bh=9VbhXpgHzUgQJu9IFDvwDMdvKT6B3joEPMCqbScH2G0=; h=From:To:Subject:Date:Message-ID:MIME-Version; b=FpeiJ1wo2ieiD65vjwbIVPZ/zJGptAtuctsbU6uyWJAQhbAXZOFCSmfmTFqUmPC2o0JUakcK3Bx+MiVLRHjyPNjTi1TEu75ZWm71Mw62/RcdV/TNXWezt8wXKVMBzE0ZnntN6L88bKPGXQKJ5TW0jdgiy8uDxYkmDHfxmT7jZaE= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=AaDDUtV+; arc=none smtp.client-ip=209.85.128.54 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Received: by mail-wm1-f54.google.com with SMTP id 5b1f17b1804b1-41413d116f6so5117285e9.1 for ; Mon, 18 Mar 2024 09:08:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1710778114; x=1711382914; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:to :from:from:to:cc:subject:date:message-id:reply-to; bh=688Oa3pVNei7pc+xdUk174lTU1EQp6WO10bjNFM1Q8c=; b=AaDDUtV+V8jTWSGByPPNkImcnD6eGcUuFnQyCfqObMbtABUlUCkx3RRpMwWY/LIcfJ E+0AlVyiP7Zb5ePwyzxTwcgstgonPn2vRbaQ8XcJqd4JKIJK3k/rAvOpt55chmP5jjJi gCl4v17pxAFIL825hvu5XijLxBBdBjUn15WOKZ4CRxfcOW7auv7taHWNMDwfpQPGod0a BD2M4j9r2mJI+sme9kIbPSe5uU85gRhg23ZqxIGfh51TV7c3Cb9ZVfQMz3e86B7Wr5iK Jfyt2w6iaMOBpWmusw3w/JpHxKEjRSEvndMHC47zALPhn09G1rUzn4aJhlu2D4CpJd5l /59A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1710778114; x=1711382914; h=content-transfer-encoding:mime-version:message-id:date:subject:to :from:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=688Oa3pVNei7pc+xdUk174lTU1EQp6WO10bjNFM1Q8c=; b=KGnyb3wSqUvhf6ybjBpFo/nK1B8zcndN2RHaDhb/4TQxnKkOIZT4AnkDNbGp/xqjJQ 9IuNdJnO8ExAipis0sMuI6SLy3C/JQzRmvoZeXtZ+Ts5/Lp23SW383czwR1yxS00xzqM ywuAsAghn6hvhnSgN+9KpO8HqQ1Jr28nSCPUzk4Yk9yJYMT1wMhw9z+m0bcmlJQTj9p0 jfmvhXeIjOXQzT3M66grwY97GikJlF5cXyyxMX8Rb9oFUUtftF/toxsmsnv2Si/D/uS+ 9PFpcGMDeAP+8Z6GaiMVvCRL84Qp5sp9wApWOR7iueOT0eb+A5Y+K35NLlMV4UQ7sHIC zFuw== X-Gm-Message-State: AOJu0YwmyDorcL8n4LbukKAv2JCMW/prXYwbKDZE06v6T03GI2VyoemM 8qFIDlW8EkS9ku9Vvlo4UYzYtxfq8R4xu1fkX6nzYrxK7njGC7X2aIzinoTnneQISA== X-Received: by 2002:adf:f04e:0:b0:33e:b7a0:4790 with SMTP id t14-20020adff04e000000b0033eb7a04790mr7213540wro.50.1710778113556; Mon, 18 Mar 2024 09:08:33 -0700 (PDT) Received: from lvondent-mobl3.. (ftip004290803.acc4.faraday.21cn-nte.bt.net. [109.144.76.63]) by smtp.gmail.com with ESMTPSA id dd15-20020a0560001e8f00b0033ce727e728sm10117727wrb.94.2024.03.18.09.08.32 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Mar 2024 09:08:32 -0700 (PDT) From: Luiz Augusto von Dentz To: linux-bluetooth@vger.kernel.org Subject: [PATCH BlueZ v1] device: Fix device_is_connected checking for services being connected Date: Mon, 18 Mar 2024 16:08:31 +0000 Message-ID: <20240318160831.354442-1-luiz.dentz@gmail.com> X-Mailer: git-send-email 2.44.0 Precedence: bulk X-Mailing-List: linux-bluetooth@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit From: Luiz Augusto von Dentz Change 44d3f67277f83983e1e9697eda7b9aeb40ca231d since to have introduced quite a few bugs related to device_is_connected return true which prevents proper cleanup of connection. Fixes: https://github.com/bluez/bluez/issues/774 Fixes: https://github.com/bluez/bluez/issues/778 Fixes: https://github.com/bluez/bluez/issues/783 Fixes: https://github.com/bluez/bluez/issues/784 --- src/device.c | 22 ++++++++++++---------- 1 file changed, 12 insertions(+), 10 deletions(-) diff --git a/src/device.c b/src/device.c index aecceb100..b5b574233 100644 --- a/src/device.c +++ b/src/device.c @@ -3324,22 +3324,24 @@ void device_add_connection(struct btd_device *dev, uint8_t bdaddr_type, "Connected"); } +static bool device_service_connected(struct btd_device *dev) +{ + if (find_service_with_state(dev->services, + BTD_SERVICE_STATE_CONNECTING)) + return true; + + return find_service_with_state(dev->services, + BTD_SERVICE_STATE_CONNECTED); +} + static bool device_disappeared(gpointer user_data) { struct btd_device *dev = user_data; - if (btd_device_is_connected(dev)) { - char addr[18]; - ba2str(&dev->bdaddr, addr); - DBG("Device %s is marked as connected", dev->path); - return TRUE; - } - - /* If there are services connecting restart the timer to give more time + /* If there are services connected restart the timer to give more time * for the service to either complete the connection or disconnect. */ - if (find_service_with_state(dev->services, - BTD_SERVICE_STATE_CONNECTING)) + if (device_service_connected(dev)) return TRUE; dev->temporary_timer = 0; -- 2.44.0