Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp1753502iob; Thu, 5 May 2022 07:38:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJylh2IiqDE/LcaqpJbP+58v5WqOMVBDxLZIWY0BM9EduMVpOmAWQBTdnGuawLWZJB+BXlPh X-Received: by 2002:a05:6e02:1c82:b0:2cf:1836:2579 with SMTP id w2-20020a056e021c8200b002cf18362579mr7861004ill.237.1651761496590; Thu, 05 May 2022 07:38:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651761496; cv=none; d=google.com; s=arc-20160816; b=hdTaB6ZIDVxhKfqIpgsHad7YsMlbuzEOz0eRF1O7cTb/3gT8xdq2DHpDCsRk9G5HKI de1e83FMjPe261GnYGY6dyAQbn6MRv/DjPyRiux6zcKbewmD9pCH5LfTiAPOle0G7C3H QhZPja+CFIy5TdXnUSILLVJdTEqX15gvnoj7UFOtzYZgGXIdzimzpCpLxgtgj31NIVJd t0vB8j8bc17ZFMarBFv5+exUinq62mUOLvAnAWRn7ZsnDSHH1MNXTHdrJs6ib1HFlZkW 34h6/UrK1jzQpkTnxYAD1sy5bHQPmdE/qaXuthDyczBij/VOZk87Do7E2nNVkgESInR8 yQ4A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:feedback-id:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=pAhSICUghL2Tdq7gJgyrM0AnGc3NFl9PMHLsjpLV0lg=; b=0rpJtuzXzi/DZTMWSOQa6AKAMK4PHRtHvJyOvQ+D9CtiKBAfY4WFBnhxQJUC5sHoE3 JW1UfzbRP2KtLzOwYRx34POikMZK9tdONhvRB5cxTetoca5inve0sfwE+OWSf00WliIB 1xz3GUjE4dsQfm69w29PLK9JJxT9Vi27Uo6B6HUnzLrk+na01kz6qf8l31pbsWHEREAf 4drdrhOxwm8Eqxhs4uhTdGDQrHKQkxghvLSALt8PFKSLf2SUCOouodNFyMtnfA3lrLA5 XLQENYUbwjUDx5WmM6p2p/VteZVWbxbwPqyYC8pjkpAy3owsj9FQ5N9jHP31Z29CjO0k xQOg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@siemens.com header.s=fm1 header.b=F3dffOSV; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=siemens.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i14-20020a0566022c8e00b006540b802c16si1173076iow.73.2022.05.05.07.37.59; Thu, 05 May 2022 07:38:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@siemens.com header.s=fm1 header.b=F3dffOSV; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=siemens.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1346215AbiEDIWx (ORCPT + 99 others); Wed, 4 May 2022 04:22:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50658 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1346330AbiEDIWp (ORCPT ); Wed, 4 May 2022 04:22:45 -0400 X-Greylist: delayed 62 seconds by postgrey-1.37 at lindbergh.monkeyblade.net; Wed, 04 May 2022 01:19:08 PDT Received: from mta-64-227.siemens.flowmailer.net (mta-64-227.siemens.flowmailer.net [185.136.64.227]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1A93322BEC for ; Wed, 4 May 2022 01:19:08 -0700 (PDT) Received: by mta-64-227.siemens.flowmailer.net with ESMTPSA id 202205040818047e1ff9d629ca237038 for ; Wed, 04 May 2022 10:18:05 +0200 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; s=fm1; d=siemens.com; i=daniel.starke@siemens.com; h=Date:From:Subject:To:Message-ID:MIME-Version:Content-Type:Content-Transfer-Encoding:Cc:References:In-Reply-To; bh=pAhSICUghL2Tdq7gJgyrM0AnGc3NFl9PMHLsjpLV0lg=; b=F3dffOSVez5dYK+lSZgubH5uaAJwwDy0kuPiCOJJ9/fzIxVXeR6pDvVYJdzwSYmVRRf4C/ 38bTz0xrAnfV80m6NBW22MfpjnOgdMoNq3+MD+e/Yet5byonFiKQBHDRGwm7V/mzPYldmOMR ZjVBAiqkeyXt5K9nC2PfxCKIISC7w=; From: "D. Starke" To: linux-serial@vger.kernel.org, gregkh@linuxfoundation.org, jirislaby@kernel.org Cc: linux-kernel@vger.kernel.org, Daniel Starke Subject: [PATCH 3/3] tty: n_gsm: fix invalid gsmtty_write_room() result Date: Wed, 4 May 2022 10:17:33 +0200 Message-Id: <20220504081733.3494-3-daniel.starke@siemens.com> In-Reply-To: <20220504081733.3494-1-daniel.starke@siemens.com> References: <20220504081733.3494-1-daniel.starke@siemens.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Flowmailer-Platform: Siemens Feedback-ID: 519:519-314044:519-21489:flowmailer X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Daniel Starke gsmtty_write() does not prevent the user to use the full fifo size of 4096 bytes as allocated in gsm_dlci_alloc(). However, gsmtty_write_room() tries to limit the return value by 'TX_SIZE' and returns a negative value if the fifo has more than 'TX_SIZE' bytes stored. This is obviously wrong as 'TX_SIZE' is defined as 512. Define 'TX_SIZE' to the fifo size and use it accordingly for allocation to keep the current behavior. Return the correct remaining size of the fifo in gsmtty_write_room() via kfifo_avail(). Fixes: e1eaea46bb40 ("tty: n_gsm line discipline") Cc: stable@vger.kernel.org Signed-off-by: Daniel Starke --- drivers/tty/n_gsm.c | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/drivers/tty/n_gsm.c b/drivers/tty/n_gsm.c index bcb714031d69..fd8b86dde525 100644 --- a/drivers/tty/n_gsm.c +++ b/drivers/tty/n_gsm.c @@ -137,6 +137,7 @@ struct gsm_dlci { int retries; /* Uplink tty if active */ struct tty_port port; /* The tty bound to this DLCI if there is one */ +#define TX_SIZE 4096 /* Must be power of 2. */ struct kfifo fifo; /* Queue fifo for the DLCI */ int adaption; /* Adaption layer in use */ int prev_adaption; @@ -1731,7 +1732,7 @@ static struct gsm_dlci *gsm_dlci_alloc(struct gsm_mux *gsm, int addr) return NULL; spin_lock_init(&dlci->lock); mutex_init(&dlci->mutex); - if (kfifo_alloc(&dlci->fifo, 4096, GFP_KERNEL) < 0) { + if (kfifo_alloc(&dlci->fifo, TX_SIZE, GFP_KERNEL) < 0) { kfree(dlci); return NULL; } @@ -2976,8 +2977,6 @@ static struct tty_ldisc_ops tty_ldisc_packet = { * Virtual tty side */ -#define TX_SIZE 512 - /** * gsm_modem_upd_via_data - send modem bits via convergence layer * @dlci: channel @@ -3217,7 +3216,7 @@ static unsigned int gsmtty_write_room(struct tty_struct *tty) struct gsm_dlci *dlci = tty->driver_data; if (dlci->state == DLCI_CLOSED) return 0; - return TX_SIZE - kfifo_len(&dlci->fifo); + return kfifo_avail(&dlci->fifo); } static unsigned int gsmtty_chars_in_buffer(struct tty_struct *tty) -- 2.34.1