Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp4729344imm; Mon, 18 Jun 2018 21:55:56 -0700 (PDT) X-Google-Smtp-Source: ADUXVKLmbSJOrGJxSe2i3ZKxZ3nQt1B7rEE2BuLTxlKlgT8bfYShtVSCFcOUg0s/qdr43YBrixjh X-Received: by 2002:a63:4346:: with SMTP id q67-v6mr13387521pga.328.1529384156064; Mon, 18 Jun 2018 21:55:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1529384156; cv=none; d=google.com; s=arc-20160816; b=FvevT0/Lbt6h6McaTwLLd+5T2G2oF7VIY8m4ps9oPGYgLc6iNwbJr74Y1LvcXtJ06m mcygQVnGohWfaBWz3kACJdnnZ5NW5tQmqcar4Gf8Fd1aSF8FmGBlWGzgL3R7/Ue3egja jRPR/DcUnn+D74p5EON9wfsa1CvSFxMecHToT4/XosuJm/siAQbohJGdvGRIz2ZQsC59 QGJUe5rzs0xRhdqXFc3eTKJK6MTi9x5PYorhll8bMhpRbkgaNPqs03LsK6cQTXZxYoRU jHkcc9gw3SyyYJGlNtyGZp9Tq9KAWVFkZ9l+BsVj7Wzowjw7JWF0pcLzmhes/GDicwUC OdNg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=ydtPFiCSjbtnpCqtIM6tg8r1MWp5rp7POmlT0HoEEwA=; b=esEroljLEWwlGfaRZNxignjngJwazzRpjplRJKoB2q7ec+lPJQeks0seEBJ30d+zzm NaPLcb8sLVmFK3MNvYxJkgkzLWlc2omUsk6nd4MdIiK6ZGeFBTfAlDUGVxKoinZt0UcW PbJbba2qCpRtZLI+ULT5V/aeEgs6h8Ip0+i2k/okLYqWKbd+csQ4DP9rw40OX+3DiYYO VeoyO8mGDFXKIkEOgFik+D7ryQAFlF0j+d35+j4N1o2kkiMvjUlB32RnNLDebDz+2lt+ CFIbVmZ+TpqR5p43hHzKw27eNJsnfjGMuHbd1DdYPkHuDlnMCbYd0oUBut1p85MyX0pu v1mw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@roeck-us.net header.s=default header.b=tWoOwCNf; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b12-v6si13311574pgn.308.2018.06.18.21.55.42; Mon, 18 Jun 2018 21:55:56 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=fail header.i=@roeck-us.net header.s=default header.b=tWoOwCNf; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S937252AbeFSEzE (ORCPT + 99 others); Tue, 19 Jun 2018 00:55:04 -0400 Received: from bh-25.webhostbox.net ([208.91.199.152]:40595 "EHLO bh-25.webhostbox.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S937085AbeFSEzB (ORCPT ); Tue, 19 Jun 2018 00:55:01 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=roeck-us.net; s=default; h=Message-Id:Date:Subject:Cc:To:From:Sender: Reply-To:MIME-Version:Content-Type:Content-Transfer-Encoding:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:In-Reply-To:References:List-Id:List-Help:List-Unsubscribe: List-Subscribe:List-Post:List-Owner:List-Archive; bh=ydtPFiCSjbtnpCqtIM6tg8r1MWp5rp7POmlT0HoEEwA=; b=tWoOwCNfLywrri6YLM5VyZCDQS be4gZuRuGjtFtExXQwT4keKrpCcaWR+hRWNGc7HKRoUWNJMRVFqwEZyxcVk8wD3JDWMU4Ku57K1ZP azoddPQ1xXFnxrlSq+vNzNoSGvoaxpiF10/qpAlmCqaqKNpsJNDkWLAgHZcPEN6yOWg9CHUQLi2x6 GIVHo+Rn7/NWanqsk7GVd4o7RKCyYwr40XauCFzO1o84GGuHc6HSrUsqHA2zwpUDD/nvQNAEtY1It C9/e+pvrogGMVk1dKqIh9s2Ijs0WV4ll4+Xhw0YuK3efOMqXiMmiB7haMYBvlsRx3xz6mBNEGExnC F6uK6MGA==; Received: from 108-223-40-66.lightspeed.sntcca.sbcglobal.net ([108.223.40.66]:41150 helo=localhost) by bh-25.webhostbox.net with esmtpa (Exim 4.89) (envelope-from ) id 1fV8fS-00HVQ6-UV; Tue, 19 Jun 2018 04:54:59 +0000 From: Guenter Roeck To: Greg Kroah-Hartman Cc: Jiri Slaby , Vladimir Murzin , linux-serial@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Liviu Dudau , Sudeep Holla , Lorenzo Pieralisi , Guenter Roeck Subject: [PATCH] serial: mps2-uart: Initialize early console Date: Mon, 18 Jun 2018 21:54:57 -0700 Message-Id: <1529384097-1631-1-git-send-email-linux@roeck-us.net> X-Mailer: git-send-email 2.7.4 X-Authenticated_sender: guenter@roeck-us.net X-OutGoing-Spam-Status: No, score=-1.0 X-AntiAbuse: This header was added to track abuse, please include it with any abuse report X-AntiAbuse: Primary Hostname - bh-25.webhostbox.net X-AntiAbuse: Original Domain - vger.kernel.org X-AntiAbuse: Originator/Caller UID/GID - [47 12] / [47 12] X-AntiAbuse: Sender Address Domain - roeck-us.net X-Get-Message-Sender-Via: bh-25.webhostbox.net: authenticated_id: guenter@roeck-us.net X-Authenticated-Sender: bh-25.webhostbox.net: guenter@roeck-us.net X-Source: X-Source-Args: X-Source-Dir: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The early console code for mps2-uart assumes that the serial hardware is enabled for transmit when the system boots. However, this is not the case after reset. This results in a hang in mps2_early_putchar() if the serial transmitter is not enabled by a boot loader or ROM monitor. Signed-off-by: Guenter Roeck --- drivers/tty/serial/mps2-uart.c | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/drivers/tty/serial/mps2-uart.c b/drivers/tty/serial/mps2-uart.c index 9f8f63719126..0743a0551ce1 100644 --- a/drivers/tty/serial/mps2-uart.c +++ b/drivers/tty/serial/mps2-uart.c @@ -448,6 +448,14 @@ static struct console mps2_uart_console = { #define MPS2_SERIAL_CONSOLE (&mps2_uart_console) +static void mps2_early_init(struct uart_port *port) +{ + u8 control = readb(port->membase + UARTn_CTRL); + + control |= UARTn_CTRL_TX_ENABLE; + writeb(control, port->membase + UARTn_CTRL); +} + static void mps2_early_putchar(struct uart_port *port, int ch) { while (readb(port->membase + UARTn_STATE) & UARTn_STATE_TX_FULL) @@ -469,6 +477,7 @@ static int __init mps2_early_console_setup(struct earlycon_device *device, if (!device->port.membase) return -ENODEV; + mps2_early_init(&device->port); device->con->write = mps2_early_write; return 0; -- 2.7.4