From patchwork Fri Mar 21 21:08:47 2014 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Rob Herring X-Patchwork-Id: 3876551 Return-Path: X-Original-To: patchwork-linux-arm@patchwork.kernel.org Delivered-To: patchwork-parsemail@patchwork1.web.kernel.org Received: from mail.kernel.org (mail.kernel.org [198.145.19.201]) by patchwork1.web.kernel.org (Postfix) with ESMTP id 58A079F382 for ; Fri, 21 Mar 2014 21:28:51 +0000 (UTC) Received: from mail.kernel.org (localhost [127.0.0.1]) by mail.kernel.org (Postfix) with ESMTP id 615E120259 for ; Fri, 21 Mar 2014 21:28:50 +0000 (UTC) Received: from casper.infradead.org (casper.infradead.org [85.118.1.10]) (using TLSv1.2 with cipher DHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 06B7020213 for ; Fri, 21 Mar 2014 21:28:49 +0000 (UTC) Received: from merlin.infradead.org ([2001:4978:20e::2]) by casper.infradead.org with esmtps (Exim 4.80.1 #2 (Red Hat Linux)) id 1WR6jb-0005E1-4f; Fri, 21 Mar 2014 21:12:13 +0000 Received: from localhost ([::1] helo=merlin.infradead.org) by merlin.infradead.org with esmtp (Exim 4.80.1 #2 (Red Hat Linux)) id 1WR6ir-00029Z-2j; Fri, 21 Mar 2014 21:11:25 +0000 Received: from mail-ob0-x230.google.com ([2607:f8b0:4003:c01::230]) by merlin.infradead.org with esmtps (Exim 4.80.1 #2 (Red Hat Linux)) id 1WR6hg-00020C-Do for linux-arm-kernel@lists.infradead.org; Fri, 21 Mar 2014 21:10:17 +0000 Received: by mail-ob0-f176.google.com with SMTP id wp18so3103666obc.21 for ; Fri, 21 Mar 2014 14:09:50 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=MqG/M0xRDwG0Iq2c+TbVsNbph1qnEmhZoURq4grY6mQ=; b=Eg50gGUcxgsmvPOaAc/WejMHIxaZaWkVA72JHr+l/zDmUJ+QhL+4gfU6iUUX+YXWFz skoioYiB5uOkHZY3we+M0h2L8bZpLwcEqk3zO94Ru+Q4J7GAVER8LaSto7MheFCrab5x r7QkpTW1ykdfx7ymFEbEh1R+sF0ipC3e8HnHeh44mxi3XQFP0guf1QzkOjATFbEIY4p5 3JrA2zOm9h9rEJKGfnVbRBxiThtEDmQeIeqp6b22NslKGk6mST9CePZan2dLLn2dK5Oy N/2B4agQWcpivwXqDDeY8asn8ob+uEjL0S5JEfIxtOeScGPL2K0ZuQCvNxRypSqmaEvE iIng== X-Received: by 10.182.48.233 with SMTP id p9mr14556444obn.44.1395436190433; Fri, 21 Mar 2014 14:09:50 -0700 (PDT) Received: from localhost.localdomain (72-48-77-163.dyn.grandenetworks.net. [72.48.77.163]) by mx.google.com with ESMTPSA id tz6sm9859086obc.10.2014.03.21.14.09.49 for (version=TLSv1.1 cipher=ECDHE-RSA-RC4-SHA bits=128/128); Fri, 21 Mar 2014 14:09:49 -0700 (PDT) From: Rob Herring To: linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-serial@vger.kernel.org Subject: [PATCH 7/8] tty/serial: add arm64 semihosting earlycon Date: Fri, 21 Mar 2014 16:08:47 -0500 Message-Id: <1395436128-11244-8-git-send-email-robherring2@gmail.com> X-Mailer: git-send-email 1.8.3.2 In-Reply-To: <1395436128-11244-1-git-send-email-robherring2@gmail.com> References: <1395436128-11244-1-git-send-email-robherring2@gmail.com> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20140321_171012_652512_0E9F54D0 X-CRM114-Status: GOOD ( 21.06 ) X-Spam-Score: -1.8 (-) Cc: Rob Herring , Russell King , Arnd Bergmann , Greg Kroah-Hartman , x86@kernel.org, Will Deacon , Catalin Marinas , Jiri Slaby X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , MIME-Version: 1.0 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org X-Spam-Status: No, score=-4.1 required=5.0 tests=BAYES_00, DKIM_ADSP_CUSTOM_MED, DKIM_SIGNED, FREEMAIL_FROM, RCVD_IN_DNSWL_MED, T_DKIM_INVALID, T_RP_MATCHES_RCVD, UNPARSEABLE_RELAY autolearn=unavailable version=3.3.1 X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on mail.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP From: Rob Herring Add earlycon support for the arm64 semihosting debug serial interface. This allows enabling a debug console when early_params are processed. This is based on the arm64 earlyprintk smh support and is intended to replace it. This is named arm rather than arm64 in hopes it will be used for both, but only arm64 is supported ATM. Signed-off-by: Rob Herring Cc: Greg Kroah-Hartman Cc: Jiri Slaby --- Documentation/kernel-parameters.txt | 1 + drivers/tty/serial/Kconfig | 17 +++++++++--- drivers/tty/serial/Makefile | 1 + drivers/tty/serial/earlycon-arm-semihost.c | 44 ++++++++++++++++++++++++++++++ 4 files changed, 59 insertions(+), 4 deletions(-) create mode 100644 drivers/tty/serial/earlycon-arm-semihost.c diff --git a/Documentation/kernel-parameters.txt b/Documentation/kernel-parameters.txt index 81bdd52..e96e2ba 100644 --- a/Documentation/kernel-parameters.txt +++ b/Documentation/kernel-parameters.txt @@ -888,6 +888,7 @@ bytes respectively. Such letter suffixes can also be entirely omitted. uart[8250],mmio,[,options] uart[8250],mmio32,[,options] pl011, + smh Start an early, polled-mode console on a serial port at the specified I/O port or MMIO address. 8250 MMIO inter-register address stride is either 8-bit diff --git a/drivers/tty/serial/Kconfig b/drivers/tty/serial/Kconfig index 1685189..8b8f40e 100644 --- a/drivers/tty/serial/Kconfig +++ b/drivers/tty/serial/Kconfig @@ -14,6 +14,15 @@ config SERIAL_EARLYCON the console before standard serial driver is probed. The console is enabled when early_param is processed. +config SERIAL_EARLYCON_ARM_SEMIHOST + bool "Early console using ARM64 semihosting" + depends on ARM64 + help + Support for early debug console using ARM64 semihosting. This enables + the console before standard serial driver is probed. This is enabled + with "earlycon=smh" on the kernel command line. The console is + enabled when early_param is processed. + source "drivers/tty/serial/8250/Kconfig" comment "Non-8250 serial port support" @@ -230,7 +239,7 @@ config SERIAL_SAMSUNG_UARTS help Select the number of available UART ports for the Samsung S3C serial driver - + config SERIAL_SAMSUNG_DEBUG bool "Samsung SoC serial debug" depends on SERIAL_SAMSUNG && DEBUG_LL @@ -666,8 +675,8 @@ config PDC_CONSOLE depends on PARISC && !SERIAL_MUX && VT default n help - Saying Y here will enable the software based PDC console to be - used as the system console. This is useful for machines in + Saying Y here will enable the software based PDC console to be + used as the system console. This is useful for machines in which the hardware based console has not been written yet. The following steps must be competed to use the PDC console: @@ -858,7 +867,7 @@ config SERIAL_CPM depends on CPM2 || 8xx select SERIAL_CORE help - This driver supports the SCC and SMC serial ports on Motorola + This driver supports the SCC and SMC serial ports on Motorola embedded PowerPC that contain a CPM1 (8xx) or CPM2 (8xxx) config SERIAL_CPM_CONSOLE diff --git a/drivers/tty/serial/Makefile b/drivers/tty/serial/Makefile index 8af1415..9965b65 100644 --- a/drivers/tty/serial/Makefile +++ b/drivers/tty/serial/Makefile @@ -6,6 +6,7 @@ obj-$(CONFIG_SERIAL_CORE) += serial_core.o obj-$(CONFIG_SERIAL_21285) += 21285.o obj-$(CONFIG_SERIAL_EARLYCON) += earlycon.o +obj-$(CONFIG_SERIAL_EARLYCON_ARM_SEMIHOST) += earlycon-arm-semihost.o # These Sparc drivers have to appear before others such as 8250 # which share ttySx minor node space. Otherwise console device diff --git a/drivers/tty/serial/earlycon-arm-semihost.c b/drivers/tty/serial/earlycon-arm-semihost.c new file mode 100644 index 0000000..fecec9a --- /dev/null +++ b/drivers/tty/serial/earlycon-arm-semihost.c @@ -0,0 +1,44 @@ +/* + * Copyright (C) 2012 ARM Ltd. + * Author: Catalin Marinas + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ +#include +#include +#include +#include + +/* + * Semihosting-based debug console + */ +static void smh_putc(struct uart_port *port, int c) +{ + asm volatile("mov x1, %0\n" + "mov x0, #3\n" + "hlt 0xf000\n" + : : "r" (&c) : "x0", "x1", "memory"); +} + +static void smh_write(struct console *con, const char *s, unsigned n) +{ + struct earlycon_device *dev = con->data; + uart_console_write(&dev->port, s, n, smh_putc); +} + +int __init early_smh_setup(struct earlycon_device *device, const char *opt) +{ + device->con->write = smh_write; + return 0; +} +EARLYCON_DECLARE(smh, early_smh_setup);