Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3462632pxb; Mon, 24 Jan 2022 10:03:58 -0800 (PST) X-Google-Smtp-Source: ABdhPJytBKndc0EqyCUnS+uxMZ5ic5yDtKlCJHgRaEW8W2QEDezBcETKj06q15MUgRH4FLLIVf+k X-Received: by 2002:a05:6a00:1a52:b0:4c6:a871:b5db with SMTP id h18-20020a056a001a5200b004c6a871b5dbmr14800602pfv.66.1643047438375; Mon, 24 Jan 2022 10:03:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643047438; cv=none; d=google.com; s=arc-20160816; b=pVCrK9WPfO1XvX0kX1Of72iWjcvRO/RwNoxGf5mmclklRtVQxPTYUXpTnr8fVKERuk ViMT8EsDOF00TGn3H/ogjP00o2WfVO4CDp40176e4VhyiQq3LL2XwRnPZ+Ih/91CqWF9 eWejwYhE2VqLsnhD2Rim/tijinMS0WVw+o6ZJH9UHmR6+CzYJuQ3SBFKG4ugleL+vg0q 8zxtTJLg1r6LfBa4iYMdMW+2pODK+vuM8bDnittjCVAXDfCj1T3TAEFXjwJ0HykymsXI V3zNF7reLRY3xFaSHH0cAE2TtfpENFiTa/jhkyoaxw1Z+uWnJQ/6XvOOX8qeuDtw1Co7 StCA== 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:dkim-signature; bh=L9a5B5RGVmJ6PZ7we55uVKingQ30djeTUqYcDv5kgvY=; b=VhQd65m+Bu8+yXJMmwmsgh8I/u1wNX9SEojAGkXh+9spfH+kcqBokMfNfxkbn5PiPa K6Q2rsJRn3V7n7zMiuW1vHVCTNPAszgp657ppJRAB3TWF5uEGjLtVVRtNeLXmP36kAOf nXbXUFj1yx3VjQLrlESlAWmNFwKIT3QcqKp1cpaeoOdAjtwjRJdkC1e3AZLS82ycpqvy KSPJRUwGldV4XQNg7shRTiXx3/l8OcRTfsuFM6Xq/8fpCRSXjvvvCIc1uQnwzaH+woe3 3jBCn5oJ6ph3femkt5NH3YTU/VPlQGV/YPK0hwXewghmGwSY+Du0K7LA/rWQuuX+3a/c rBdg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.cz header.s=susede2_rsa header.b=0sjKwF5c; dkim=neutral (no key) header.i=@suse.cz header.s=susede2_ed25519; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v9si12608798plp.304.2022.01.24.10.03.45; Mon, 24 Jan 2022 10:03:58 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-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=@suse.cz header.s=susede2_rsa header.b=0sjKwF5c; dkim=neutral (no key) header.i=@suse.cz header.s=susede2_ed25519; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S241782AbiAXHOt (ORCPT + 99 others); Mon, 24 Jan 2022 02:14:49 -0500 Received: from smtp-out2.suse.de ([195.135.220.29]:58082 "EHLO smtp-out2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241696AbiAXHOe (ORCPT ); Mon, 24 Jan 2022 02:14:34 -0500 Received: from relay2.suse.de (relay2.suse.de [149.44.160.134]) by smtp-out2.suse.de (Postfix) with ESMTP id C583C1F3B6; Mon, 24 Jan 2022 07:14:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.cz; s=susede2_rsa; t=1643008473; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=L9a5B5RGVmJ6PZ7we55uVKingQ30djeTUqYcDv5kgvY=; b=0sjKwF5c8FiS2KpPZTRL9Si8lqNFI5zSHu6Z24Mw/l75IrqwfVJqmIhzDTPbN4v327hKtw R8BG1X4P3b3dwUP6huhppJTAJXQL404gKteW5Day/nOWR4zEbAzjpYStr4CzsSxoaDJc3M 4owRPASDfA+SAOaIW56YIEXTllVujvo= DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=suse.cz; s=susede2_ed25519; t=1643008473; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=L9a5B5RGVmJ6PZ7we55uVKingQ30djeTUqYcDv5kgvY=; b=LgXxeYj1hXPl+LT5X5nZ0LRWQujhs/Y6iHgB2TtHYl4C4nGGvjajDVXjOZOCkbOhW68XJw q01kz5BNuBWoqEAg== Received: from localhost.localdomain (unknown [10.100.208.98]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by relay2.suse.de (Postfix) with ESMTPS id 90E84A3B84; Mon, 24 Jan 2022 07:14:33 +0000 (UTC) From: Jiri Slaby To: gregkh@linuxfoundation.org Cc: linux-serial@vger.kernel.org, linux-kernel@vger.kernel.org, johan@kernel.org, Jiri Slaby Subject: [PATCH 06/11] mxser: use tty_port xmit_buf helpers Date: Mon, 24 Jan 2022 08:14:25 +0100 Message-Id: <20220124071430.14907-7-jslaby@suse.cz> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124071430.14907-1-jslaby@suse.cz> References: <20220124071430.14907-1-jslaby@suse.cz> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org For the mxser driver to use kfifo, use tty_port_alloc_xmit_buf() and tty_port_free_xmit_buf() helpers in activate/shutdown, respectively. As these calls have to be done in a non-atomic context, we have to move them outside spinlock and make sure irq is really stopped after we write to the ISR register. Signed-off-by: Jiri Slaby --- drivers/tty/mxser.c | 24 +++++++++--------------- 1 file changed, 9 insertions(+), 15 deletions(-) diff --git a/drivers/tty/mxser.c b/drivers/tty/mxser.c index fbb796f83753..4ddc12a63666 100644 --- a/drivers/tty/mxser.c +++ b/drivers/tty/mxser.c @@ -742,13 +742,12 @@ static void mxser_disable_and_clear_FIFO(struct mxser_port *info) static int mxser_activate(struct tty_port *port, struct tty_struct *tty) { struct mxser_port *info = container_of(port, struct mxser_port, port); - unsigned long page; unsigned long flags; int ret; - page = __get_free_page(GFP_KERNEL); - if (!page) - return -ENOMEM; + ret = tty_port_alloc_xmit_buf(port); + if (ret < 0) + return ret; spin_lock_irqsave(&info->slock, flags); @@ -758,7 +757,6 @@ static int mxser_activate(struct tty_port *port, struct tty_struct *tty) ret = 0; goto err_free_xmit; } - info->port.xmit_buf = (unsigned char *) page; /* * Clear the FIFO buffers and disable them @@ -825,8 +823,7 @@ static int mxser_activate(struct tty_port *port, struct tty_struct *tty) return 0; err_free_xmit: - free_page(page); - info->port.xmit_buf = NULL; + tty_port_free_xmit_buf(port); return ret; } @@ -862,14 +859,6 @@ static void mxser_shutdown_port(struct tty_port *port) */ wake_up_interruptible(&info->port.delta_msr_wait); - /* - * Free the xmit buffer, if necessary - */ - if (info->port.xmit_buf) { - free_page((unsigned long) info->port.xmit_buf); - info->port.xmit_buf = NULL; - } - info->IER = 0; outb(0x00, info->ioaddr + UART_IER); @@ -884,6 +873,11 @@ static void mxser_shutdown_port(struct tty_port *port) mxser_must_no_sw_flow_control(info->ioaddr); spin_unlock_irqrestore(&info->slock, flags); + + /* make sure ISR is not running while we free the buffer */ + synchronize_irq(info->board->irq); + + tty_port_free_xmit_buf(port); } /* -- 2.34.1