2015-01-28 01:46:20 +08:00
|
|
|
/*
|
2015-11-21 20:42:58 +08:00
|
|
|
* arch/h8300/kernel/sim-console.c
|
2015-01-28 01:46:20 +08:00
|
|
|
*
|
2015-11-21 20:42:58 +08:00
|
|
|
* Copyright (C) 2015 Yoshinori Sato <ysato@users.sourceforge.jp>
|
2015-01-28 01:46:20 +08:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
|
|
* for more details.
|
|
|
|
*/
|
|
|
|
#include <linux/console.h>
|
|
|
|
#include <linux/init.h>
|
2015-11-21 20:42:58 +08:00
|
|
|
#include <linux/serial_core.h>
|
2015-01-28 01:46:20 +08:00
|
|
|
|
2015-11-21 20:42:58 +08:00
|
|
|
static void sim_write(struct console *con, const char *s, unsigned n)
|
2015-01-28 01:46:20 +08:00
|
|
|
{
|
2015-11-21 20:42:58 +08:00
|
|
|
register const char *_ptr __asm__("er1") = s;
|
|
|
|
register const unsigned _len __asm__("er2") = n;
|
2015-01-28 01:46:20 +08:00
|
|
|
|
2018-07-13 15:36:21 +08:00
|
|
|
__asm__("sub.l er0,er0\n\t" /* er0 = 1 (stdout) */
|
|
|
|
"inc.l #1,er0\n\t"
|
|
|
|
".byte 0x5e,0x00,0x00,0xc7\n\t" /* jsr @0xc7 (sys_write) */
|
|
|
|
: : "g"(_ptr), "g"(_len):"er0");
|
2015-01-28 01:46:20 +08:00
|
|
|
}
|
|
|
|
|
2015-11-21 20:42:58 +08:00
|
|
|
static int __init sim_setup(struct earlycon_device *device, const char *opt)
|
2015-01-28 01:46:20 +08:00
|
|
|
{
|
2015-11-21 20:42:58 +08:00
|
|
|
device->con->write = sim_write;
|
2015-01-28 01:46:20 +08:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2015-11-21 20:42:58 +08:00
|
|
|
EARLYCON_DECLARE(h8sim, sim_setup);
|