Loading...
/* * console.c: SGI arcs console code. * * Copyright (C) 1996 David S. Miller (dm@sgi.com) * Compability with board caches, Ulf Carlsson * * $Id: console.c,v 1.2 1999/06/12 18:42:38 ulfc Exp $ */ #include <linux/config.h> #include <linux/init.h> #include <asm/sgialib.h> #include <asm/bcache.h> /* The romvec is not compatible with board caches. Thus we disable it during * romvec action. Since r4xx0.c is always compiled and linked with your kernel, * this shouldn't cause any harm regardless what MIPS processor you have. * * The romvec write and read functions seem to interfere with the serial lines * in some way. You should be careful with them. */ extern struct bcache_ops *bcops; #ifdef CONFIG_SGI_PROM_CONSOLE void prom_putchar(char c) #else __initfunc(void prom_putchar(char c)) #endif { long cnt; char it = c; bcops->bc_disable(); romvec->write(1, &it, 1, &cnt); bcops->bc_enable(); } #ifdef CONFIG_SGI_PROM_CONSOLE char prom_getchar(void) #else __initfunc(char prom_getchar(void)) #endif { long cnt; char c; bcops->bc_disable(); romvec->read(0, &c, 1, &cnt); bcops->bc_enable(); return c; } |