blob: 46138f55a9ea7eedb86eeb60e074655d863bcc69 [file] [log] [blame]
Yoshinori Sato4e0c2092015-01-28 02:46:20 +09001/*
Yoshinori Sato8cad4892015-11-21 21:42:58 +09002 * arch/h8300/kernel/sim-console.c
Yoshinori Sato4e0c2092015-01-28 02:46:20 +09003 *
Yoshinori Sato8cad4892015-11-21 21:42:58 +09004 * Copyright (C) 2015 Yoshinori Sato <ysato@users.sourceforge.jp>
Yoshinori Sato4e0c2092015-01-28 02:46:20 +09005 *
6 * This file is subject to the terms and conditions of the GNU General Public
7 * License. See the file "COPYING" in the main directory of this archive
8 * for more details.
9 */
10#include <linux/console.h>
Yoshinori Sato4e0c2092015-01-28 02:46:20 +090011#include <linux/init.h>
Yoshinori Sato8cad4892015-11-21 21:42:58 +090012#include <linux/serial_core.h>
Yoshinori Sato4e0c2092015-01-28 02:46:20 +090013
Yoshinori Sato8cad4892015-11-21 21:42:58 +090014static void sim_write(struct console *con, const char *s, unsigned n)
Yoshinori Sato4e0c2092015-01-28 02:46:20 +090015{
16 register const int fd __asm__("er0") = 1; /* stdout */
Yoshinori Sato8cad4892015-11-21 21:42:58 +090017 register const char *_ptr __asm__("er1") = s;
18 register const unsigned _len __asm__("er2") = n;
Yoshinori Sato4e0c2092015-01-28 02:46:20 +090019
20 __asm__(".byte 0x5e,0x00,0x00,0xc7\n\t" /* jsr @0xc7 (sys_write) */
21 : : "g"(fd), "g"(_ptr), "g"(_len));
22}
23
Yoshinori Sato8cad4892015-11-21 21:42:58 +090024static int __init sim_setup(struct earlycon_device *device, const char *opt)
Yoshinori Sato4e0c2092015-01-28 02:46:20 +090025{
Yoshinori Sato8cad4892015-11-21 21:42:58 +090026 device->con->write = sim_write;
Yoshinori Sato4e0c2092015-01-28 02:46:20 +090027 return 0;
28}
29
Yoshinori Sato8cad4892015-11-21 21:42:58 +090030EARLYCON_DECLARE(h8sim, sim_setup);