2010-05-28 23:09:12 -04:00
/*
* Copyright 2010 Tilera Corporation . All Rights Reserved .
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation , version 2.
*
* 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 , GOOD TITLE or
* NON INFRINGEMENT . See the GNU General Public License for
* more details .
*/
# include <linux/console.h>
# include <linux/kernel.h>
# include <linux/init.h>
# include <linux/string.h>
2012-03-28 18:30:03 +01:00
# include <linux/irqflags.h>
2013-04-29 16:17:18 -07:00
# include <linux/printk.h>
2010-05-28 23:09:12 -04:00
# include <asm/setup.h>
# include <hv/hypervisor.h>
static void early_hv_write ( struct console * con , const char * s , unsigned n )
{
2013-08-06 14:11:21 -04:00
tile_console_write ( s , n ) ;
/*
* Convert NL to NLCR ( close enough to CRNL ) during early boot .
* We assume newlines are at the ends of strings , which turns out
* to be good enough for early boot console output .
*/
if ( n & & s [ n - 1 ] = = ' \n ' )
tile_console_write ( " \r " , 1 ) ;
2010-05-28 23:09:12 -04:00
}
static struct console early_hv_console = {
. name = " earlyhv " ,
. write = early_hv_write ,
2013-08-06 14:11:21 -04:00
. flags = CON_PRINTBUFFER | CON_BOOT ,
2010-05-28 23:09:12 -04:00
. index = - 1 ,
} ;
void early_panic ( const char * fmt , . . . )
{
va_list ap ;
2010-11-01 15:24:29 -04:00
arch_local_irq_disable_all ( ) ;
2010-05-28 23:09:12 -04:00
va_start ( ap , fmt ) ;
early_printk ( " Kernel panic - not syncing: " ) ;
early_vprintk ( fmt , ap ) ;
2013-08-06 14:11:21 -04:00
early_printk ( " \n " ) ;
2010-05-28 23:09:12 -04:00
va_end ( ap ) ;
dump_stack ( ) ;
hv_halt ( ) ;
}
static int __init setup_early_printk ( char * str )
{
2013-04-29 16:17:18 -07:00
if ( early_console )
2010-05-28 23:09:12 -04:00
return 1 ;
early_console = & early_hv_console ;
register_console ( early_console ) ;
return 0 ;
}
early_param ( " earlyprintk " , setup_early_printk ) ;