Received: by 2002:a05:7412:37c9:b0:e2:908c:2ebd with SMTP id jz9csp507840rdb; Tue, 19 Sep 2023 01:58:58 -0700 (PDT) X-Google-Smtp-Source: AGHT+IH4XBKzCjJVJd4/ODaH24W2rWKYk8bvRRn7SaP9V8P7NmVhalSwus3fmqu+2lggfmxpHxtn X-Received: by 2002:a17:90a:bc45:b0:268:18e:9dfa with SMTP id t5-20020a17090abc4500b00268018e9dfamr10770493pjv.5.1695113938202; Tue, 19 Sep 2023 01:58:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695113938; cv=none; d=google.com; s=arc-20160816; b=gHLlAg6YZvF/+hLpHoJjfZdLR8yyVmeqFQw5C1aJrbWZwPfnkj+kFutzOh93tlyBXQ rzX0Hb8N4bQSYD/FNw05UZVKC1Dj/6PLt+mf/WF5BI20JAg0ZzGaIG2Fe8j21WfJQY9M nfgoFL6EMgXS6sZyeJagjxDXkxpYL6xBPzD4I2ELGKh9SZoHbhZlsOufTmTb66ToEBB+ N1RjuAM35PkGY7zTCPVaeaGJ+KoTek1+sjwG1l5MeKVSnVvMKmpyx42EEM1h+Mr5CaQ5 UnSscyQ0T4WGitlTXydXEayESjfKuNthZpWtCUcIGq5+9/sVZQK2wElYynTljBPR4yjs yTLg== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=FzEmZP7TazhDsXMS1L4MwVJk0Y08mZ0GfP+NcpF2zZ8=; fh=1YNwm5KBWetjB3qGkhgLqh/dZnCTsWuqRk83JW6hjgE=; b=hngABwXFtTHhADidT+FIgXC7I3kXCdj95vhhgplaxmEoOCcw1aAYJA9lA79SIvUk/U Nb8KQnAeILGCWqGWHKVZNPbQ0fhiRw1mPRMGsdzza34EGL0N9VblGuPUiFCPqBmmHrKR 53vSMq90NhMSr8eimrnRZchlXbAgHE2PxJHPnml9WX+AXvCMdVJdZIRKh9jz6LmdlW4X scyq1cqgAfKb5SRUvtu+CItgU6Ct/YSj9uyVIGT+sfUJBPVJ1m94ndbfSEKTPdVswsG0 q429/fLpHfIZpHaI9Yr+xs+zQFeRmG4z9htKPbYu0OawoOnAkg/rw22bpfnEWAUdfDDN KM2A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=hhAfZq9a; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from lipwig.vger.email (lipwig.vger.email. [2620:137:e000::3:3]) by mx.google.com with ESMTPS id i20-20020a17090a7e1400b0026b74f6aaa8si11330583pjl.63.2023.09.19.01.58.57 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Sep 2023 01:58:58 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) client-ip=2620:137:e000::3:3; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=hhAfZq9a; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by lipwig.vger.email (Postfix) with ESMTP id ED63880A58EE; Tue, 19 Sep 2023 01:52:31 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231183AbjISIw0 (ORCPT + 99 others); Tue, 19 Sep 2023 04:52:26 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40548 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230498AbjISIwP (ORCPT ); Tue, 19 Sep 2023 04:52:15 -0400 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 71300102; Tue, 19 Sep 2023 01:52:07 -0700 (PDT) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 0F31AC433C7; Tue, 19 Sep 2023 08:52:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1695113527; bh=OjwKIBmFPVUbsZin5q6xLKXnnlWzbN3in7M3kjyOOwg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=hhAfZq9aAM+DqMYLnxK4AQzV0iit37kY24wGkl6tBr386M+RHgG5r7gctFeka/q27 jXIL6cHNzfzhf6yeVKWiW+tUfvn5DiKUSm8rDcWouhipBDn6Qv1N/4ixOh9+fuyEwL 63N7ZrVIkZ0h8PYG8lrMEmE5wkjRCN1qcuwPoEE3nH7uHbaaaUgKT4BnX1CRcP80FC Lo+zi+gXB5J6qbKg9p9KwL4or57Tle7itLfqKmqMxSlYydKWGwgM4YmdGP5jAKxAyu /MpOIOiZ9CL1OxohhWpZiNMgd+W8CoA2ODuyRLraCtEjf1mqCvXa7y3iuG3GSyDD7W zJn5Na/RmvHYg== From: "Jiri Slaby (SUSE)" To: gregkh@linuxfoundation.org Cc: linux-serial@vger.kernel.org, linux-kernel@vger.kernel.org, "Jiri Slaby (SUSE)" Subject: [PATCH 05/15] tty: n_tty: use do-while in n_tty_check_{,un}throttle() Date: Tue, 19 Sep 2023 10:51:46 +0200 Message-ID: <20230919085156.1578-6-jirislaby@kernel.org> X-Mailer: git-send-email 2.42.0 In-Reply-To: <20230919085156.1578-1-jirislaby@kernel.org> References: <20230919085156.1578-1-jirislaby@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.2 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lipwig.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (lipwig.vger.email [0.0.0.0]); Tue, 19 Sep 2023 01:52:32 -0700 (PDT) This change gets rid of the complicated exit from the loops. It can be done much easier using do-while loops. Signed-off-by: Jiri Slaby (SUSE) --- drivers/tty/n_tty.c | 19 +++++++------------ 1 file changed, 7 insertions(+), 12 deletions(-) diff --git a/drivers/tty/n_tty.c b/drivers/tty/n_tty.c index 922fb61b587a..b34e6612aef6 100644 --- a/drivers/tty/n_tty.c +++ b/drivers/tty/n_tty.c @@ -249,15 +249,12 @@ static void n_tty_check_throttle(struct tty_struct *tty) if (ldata->icanon && ldata->canon_head == ldata->read_tail) return; - while (1) { - int throttled; + do { tty_set_flow_change(tty, TTY_THROTTLE_SAFE); if (N_TTY_BUF_SIZE - read_cnt(ldata) >= TTY_THRESHOLD_THROTTLE) break; - throttled = tty_throttle_safe(tty); - if (!throttled) - break; - } + } while (tty_throttle_safe(tty)); + __tty_set_flow_change(tty, 0); } @@ -279,16 +276,14 @@ static void n_tty_check_unthrottle(struct tty_struct *tty) * we won't get any more characters. */ - while (1) { - int unthrottled; + do { tty_set_flow_change(tty, TTY_UNTHROTTLE_SAFE); if (chars_in_buffer(tty) > TTY_THRESHOLD_UNTHROTTLE) break; + n_tty_kick_worker(tty); - unthrottled = tty_unthrottle_safe(tty); - if (!unthrottled) - break; - } + } while (tty_unthrottle_safe(tty)); + __tty_set_flow_change(tty, 0); } -- 2.42.0