Received: by 2002:a05:7412:bbc7:b0:fc:a2b0:25d7 with SMTP id kh7csp2274355rdb; Mon, 5 Feb 2024 01:00:34 -0800 (PST) X-Google-Smtp-Source: AGHT+IFL1/Pdaxo6yDtceicKBuEKR7eGnIVn7OVE7OD89EaiBzgL1MlJoY/D2TQk8+Z56MYIzBlG X-Received: by 2002:a17:902:ce82:b0:1d9:af60:a7e3 with SMTP id f2-20020a170902ce8200b001d9af60a7e3mr2866619plg.27.1707123634456; Mon, 05 Feb 2024 01:00:34 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1707123634; cv=pass; d=google.com; s=arc-20160816; b=rwc+Xtc64LWaarhT2cj33AT7AEQQWqY2Aw9cbczbKqPb+L569AJzA77dBCPmG9Djxf 7cgOo8Fa8ltw52Wha5fhpRYJYuBM87l/+Nw5/lAU9MYAC1cvYG9ODEONqmoP/BMX1Hg7 OA+9nopoZ6E/9XlRydimStieJDlRkMMdjQ5JdRWtlL9RsSeZ05QQr9q2SS8yEpwX0sL4 qWPCu/isS5IH82tj304dSrVtQL8083nL0sTIKWq9EencZFbR9DBRboKvoLVpDwS9+Tdv Nc2q8O7jcBMzhridjeL5PqlV6bYSOSad7ZGSoGjAl4jFL2mUdPVodrBhiVZ2cDfHf5/0 rv2A== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:user-agent:date:message-id:from :references:to:subject:cc; bh=OlGbaEtpFcgWSCmdjMbVVU12KuwFMEkh7wcF+BN6TM4=; fh=OCHFgf5hC/j+8Jmyt5PQkKkOKXFza1EpGT+G6RcUng4=; b=yjliVKSRNKXOZWkIEiQjz2ihJPyLEaC5gOa4/29vlr1fMR2/KQI27DNrURvwHqSwyX kg/TLyOCGrrSEaPuh9Ii1AyO8j71ngMUKQNHVzrKUjXXB+cp3cYjsuHL8bPbXkIS5vgt w+OlNsjRr8sFV0LasiQBpOX3ljpGTB328aBUIlL2KiTNvFC0GrSjnneWhf1GxmONoFG3 2qI4Dox1qZJcLjduQPICsesln8sMEA1M0QAu4mbWXfzMUkx5305ouaYOBCcRBUqqKl39 GFm3keSWxEan0tVvTuCFc1oGjXdE95m23RThjbPm4jwJ8E6Z0wEk67W7Qh1M50TgUPac EBLA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=huawei.com dmarc=pass fromdomain=huawei.com); spf=pass (google.com: domain of linux-kernel+bounces-52232-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-52232-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com X-Forwarded-Encrypted: i=1; AJvYcCWipctxKzGmvN5GNypuTG9lfNLHuzbOj3g4R3Jwl/SSRRee8/mDVkhk9rxt2Yphg1Cd7TJwxNTvHdpfDjJbpn4ocssGGUtyqtUPXG+5Nw== Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id q16-20020a170902eb9000b001d74eb88097si6028149plg.219.2024.02.05.01.00.33 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 05 Feb 2024 01:00:34 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-52232-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; arc=pass (i=1 spf=pass spfdomain=huawei.com dmarc=pass fromdomain=huawei.com); spf=pass (google.com: domain of linux-kernel+bounces-52232-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-52232-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.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 sy.mirrors.kernel.org (Postfix) with ESMTPS id 8FD27B243CD for ; Mon, 5 Feb 2024 08:56:11 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 052E711CB3; Mon, 5 Feb 2024 08:56:02 +0000 (UTC) Received: from szxga06-in.huawei.com (szxga06-in.huawei.com [45.249.212.32]) (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 C6C7911CA9; Mon, 5 Feb 2024 08:55:58 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=45.249.212.32 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707123361; cv=none; b=sKS2RkDso8xQyzJ+6yeLxm3BfGa9sHl6IqLzEiCuXMt8xs+Nfgty2r70dxGDSKOmSYHWKfH0HP0F1h1Ns0VcrA6B7K6Daxh/nQhoJdB58WLLy6174xoZYd42XCs8gOUGoYDJcCovbm4vHUw3/+tEuaMb4Jw9uNY2mbGNcatDc0k= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707123361; c=relaxed/simple; bh=fLbhecTLyO0qKUHDd+wj0hsYeRDa0CZBKLdtJyJKsgw=; h=CC:Subject:To:References:From:Message-ID:Date:MIME-Version: In-Reply-To:Content-Type; b=SlzhH6rsvC6+oEqH9Zo6Wq+9hA8AaFLcQ7iPoJTYvk5sdNFC805ioikqMUjGlKq/eZ7rAr9djIMpO6MBfv5XD4PeO0vy8Yp9fV0f0/xvBt82i8lLw81WTZy/jqFTD/4orFT/4YmSjEaej10j0SwNIh71ZwqtD9zPiYrzroJdRR4= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=huawei.com; spf=pass smtp.mailfrom=huawei.com; arc=none smtp.client-ip=45.249.212.32 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=huawei.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=huawei.com Received: from mail.maildlp.com (unknown [172.19.162.112]) by szxga06-in.huawei.com (SkyGuard) with ESMTP id 4TT0Zg4cMDz1vtD3; Mon, 5 Feb 2024 16:55:23 +0800 (CST) Received: from canpemm500009.china.huawei.com (unknown [7.192.105.203]) by mail.maildlp.com (Postfix) with ESMTPS id D9EF7140153; Mon, 5 Feb 2024 16:55:50 +0800 (CST) Received: from [10.67.121.177] (10.67.121.177) by canpemm500009.china.huawei.com (7.192.105.203) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.35; Mon, 5 Feb 2024 16:55:50 +0800 CC: , , , , , , , , , , , Subject: Re: [PATCH] serial: port: Don't suspend if the port is still busy To: Tony Lindgren References: <20240204031957.58176-1-yangyicong@huawei.com> <20240205065126.GB5185@atomide.com> From: Yicong Yang Message-ID: Date: Mon, 5 Feb 2024 16:55:50 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.5.1 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 In-Reply-To: <20240205065126.GB5185@atomide.com> Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 8bit X-ClientProxiedBy: dggems701-chm.china.huawei.com (10.3.19.178) To canpemm500009.china.huawei.com (7.192.105.203) On 2024/2/5 14:51, Tony Lindgren wrote: > * Yicong Yang [240204 03:24]: >> From: Yicong Yang >> >> We accidently met the issue that the bash prompt is not shown after the >> previous command done and until the next input if there's only one CPU >> (In our issue other CPUs are isolated by isolcpus=). Further analysis >> shows it's because the port entering runtime suspend even if there's >> still pending chars in the buffer and the pending chars will only be >> processed in next device resuming. We are using amba-pl011 and the >> problematic flow is like below: >> >> Bash                                         kworker >> tty_write() >>   file_tty_write() >>     n_tty_write() >>       uart_write() >>         __uart_start() >>           pm_runtime_get() // wakeup waker >>             queue_work() >>                                     pm_runtime_work() >>                                                rpm_resume() >>                                                 status = RPM_RESUMING >>                                                 serial_port_runtime_resume() >>                                                   port->ops->start_tx() >>                                                     pl011_tx_chars() >>                                                       uart_write_wakeup() >>         […] >>         __uart_start() >>           pm_runtime_get() < 0 // because runtime status = RPM_RESUMING >>                                // later data are not commit to the port driver >>                                                 status = RPM_ACTIVE >>                                                 rpm_idle() -> rpm_suspend() > > Can you please confirm if this still happens also with commit 6f699743aebf > ("serial: core: Fix runtime PM handling for pending tx")? It adds a check > for -EINPROGRESS. Tested nagetive on latest v6.8-rc3. Paste the current code snippet below in __uart_start(): /* Increment the runtime PM usage count for the active check below */ err = pm_runtime_get(&port_dev->dev); if (err < 0 && err != -EINPROGRESS) { pm_runtime_put_noidle(&port_dev->dev); return; } /* * Start TX if enabled, and kick runtime PM. If the device is not * enabled, serial_port_runtime_resume() calls start_tx() again * after enabling the device. */ if (pm_runtime_active(&port_dev->dev)) port->ops->start_tx(port); In our issue case, the dev->power.runtime_status == RPM_RESUMING as analyzed in commit. So we cannot pass the pm_runtime_active() check and the chars will still be pending. > >> This patch tries to fix this by checking the port busy before entering >> runtime suspending. A runtime_suspend callback is added for the port >> driver. When entering runtime suspend the callback is invoked, if there's >> still pending chars in the buffer then request an runtime resume for >> handling this. > > OK. Let's look at this further after you have checked what happens with > commit 6f699743aebf. > > If needed, to me it seems that flushing tx and returning -EBUSY from > serial_port_runtime_suspend() if busy might do the trick though. > Do you mean something like below? static int serial_port_runtime_suspend(struct device *dev) { struct serial_port_device *port_dev = to_serial_base_port_device(dev); struct uart_port *port; unsigned long flags; int ret = 0; port = port_dev->port; if (port->flags & UPF_DEAD) return ret; spin_lock_irqsave(&port->lock, flags); if (__serial_port_busy(port)) { port->ops->start_tx(port); ret = -EBUSY; } spin_unlock_irqrestore(&port->lock, flags); return ret; } If so will the port fail to suspend after flushing the pending chars? Considering underlay driver like amba-pl011 doesn't implement runtime power management, does anyone will get the port into suspend routine later? I'm not quite sure about it. In the patch's implementation the pending chars will be flushed in runtime_resume() callback and rpm_resume() will try to call rpm_idle() later. Thanks.