2005-04-16 15:20:36 -07:00
/*
* Setup pointers to hardware - dependent routines .
*
* 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 .
*
2006-01-18 17:37:07 +00:00
* Copyright ( C ) 1996 , 97 , 98 , 2000 , 03 , 04 , 06 Ralf Baechle ( ralf @ linux - mips . org )
2007-05-17 14:53:12 +02:00
* Copyright ( C ) 2006 , 2007 Thomas Bogendoerfer ( tsbogend @ alpha . franken . de )
2005-04-16 15:20:36 -07:00
*/
# include <linux/eisa.h>
# include <linux/init.h>
# include <linux/console.h>
# include <linux/fb.h>
2006-07-10 04:44:13 -07:00
# include <linux/screen_info.h>
2005-04-16 15:20:36 -07:00
2006-06-13 13:59:01 +02:00
# ifdef CONFIG_ARC
2007-09-05 08:59:34 +02:00
# include <asm/fw/arc/types.h>
2005-04-16 15:20:36 -07:00
# include <asm/sgialib.h>
2006-06-13 13:59:01 +02:00
# endif
2008-01-04 23:31:07 +01:00
# ifdef CONFIG_SNIPROM
# include <asm/mipsprom.h>
# endif
# include <asm/bootinfo.h>
2005-04-16 15:20:36 -07:00
# include <asm/io.h>
# include <asm/reboot.h>
# include <asm/sni.h>
2006-12-28 18:22:32 +01:00
unsigned int sni_brd_type ;
2008-01-04 23:31:07 +01:00
EXPORT_SYMBOL ( sni_brd_type ) ;
2005-04-16 15:20:36 -07:00
extern void sni_machine_restart ( char * command ) ;
extern void sni_machine_power_off ( void ) ;
static void __init sni_display_setup ( void )
{
2006-06-13 13:59:01 +02:00
# if defined(CONFIG_VT) && defined(CONFIG_VGA_CONSOLE) && defined(CONFIG_ARC)
2005-04-16 15:20:36 -07:00
struct screen_info * si = & screen_info ;
DISPLAY_STATUS * di ;
di = ArcGetDisplayStatus ( 1 ) ;
if ( di ) {
si - > orig_x = di - > CursorXPosition ;
si - > orig_y = di - > CursorYPosition ;
si - > orig_video_cols = di - > CursorMaxXPosition ;
si - > orig_video_lines = di - > CursorMaxYPosition ;
si - > orig_video_isVGA = VIDEO_TYPE_VGAC ;
si - > orig_video_points = 16 ;
}
# endif
}
2008-01-04 23:31:07 +01:00
static void __init sni_console_setup ( void )
{
# ifndef CONFIG_ARC
char * ctype ;
char * cdev ;
char * baud ;
int port ;
static char options [ 8 ] ;
cdev = prom_getenv ( " console_dev " ) ;
if ( strncmp ( cdev , " tty " , 3 ) = = 0 ) {
ctype = prom_getenv ( " console " ) ;
switch ( * ctype ) {
default :
case ' l ' :
port = 0 ;
baud = prom_getenv ( " lbaud " ) ;
break ;
case ' r ' :
port = 1 ;
baud = prom_getenv ( " rbaud " ) ;
break ;
}
if ( baud )
strcpy ( options , baud ) ;
if ( strncmp ( cdev , " tty552 " , 6 ) = = 0 )
add_preferred_console ( " ttyS " , port ,
baud ? options : NULL ) ;
else
add_preferred_console ( " ttySC " , port ,
baud ? options : NULL ) ;
}
# endif
}
# ifdef DEBUG
static void __init sni_idprom_dump ( void )
{
int i ;
pr_debug ( " SNI IDProm dump: \n " ) ;
for ( i = 0 ; i < 256 ; i + + ) {
if ( i % 16 = = 0 )
pr_debug ( " %04x " , i ) ;
printk ( " %02x " , * ( unsigned char * ) ( SNI_IDPROM_BASE + i ) ) ;
if ( i % 16 = = 15 )
printk ( " \n " ) ;
}
}
# endif
2005-04-16 15:20:36 -07:00
2006-06-18 01:32:22 +01:00
void __init plat_mem_setup ( void )
2005-04-16 15:20:36 -07:00
{
2008-01-04 23:31:07 +01:00
int cputype ;
2005-04-16 15:20:36 -07:00
set_io_port_base ( SNI_PORT_BASE ) ;
2006-12-28 18:22:32 +01:00
// ioport_resource.end = sni_io_resource.end;
2005-04-16 15:20:36 -07:00
/*
* Setup ( E ) ISA I / O memory access stuff
*/
# ifdef CONFIG_EISA
EISA_bus = 1 ;
# endif
2008-01-04 23:31:07 +01:00
sni_brd_type = * ( unsigned char * ) SNI_IDPROM_BRDTYPE ;
cputype = * ( unsigned char * ) SNI_IDPROM_CPUTYPE ;
switch ( sni_brd_type ) {
case SNI_BRD_TOWER_OASIC :
switch ( cputype ) {
case SNI_CPU_M8030 :
system_type = " RM400-330 " ;
break ;
case SNI_CPU_M8031 :
system_type = " RM400-430 " ;
break ;
case SNI_CPU_M8037 :
system_type = " RM400-530 " ;
break ;
case SNI_CPU_M8034 :
system_type = " RM400-730 " ;
break ;
default :
system_type = " RM400-xxx " ;
break ;
}
break ;
case SNI_BRD_MINITOWER :
switch ( cputype ) {
case SNI_CPU_M8021 :
case SNI_CPU_M8043 :
system_type = " RM400-120 " ;
break ;
case SNI_CPU_M8040 :
system_type = " RM400-220 " ;
break ;
case SNI_CPU_M8053 :
system_type = " RM400-225 " ;
break ;
case SNI_CPU_M8050 :
system_type = " RM400-420 " ;
break ;
default :
system_type = " RM400-xxx " ;
break ;
}
break ;
case SNI_BRD_PCI_TOWER :
system_type = " RM400-Cxx " ;
break ;
case SNI_BRD_RM200 :
system_type = " RM200-xxx " ;
break ;
case SNI_BRD_PCI_MTOWER :
system_type = " RM300-Cxx " ;
break ;
case SNI_BRD_PCI_DESKTOP :
switch ( read_c0_prid ( ) & 0xff00 ) {
case PRID_IMP_R4600 :
case PRID_IMP_R4700 :
system_type = " RM200-C20 " ;
break ;
case PRID_IMP_R5000 :
system_type = " RM200-C40 " ;
break ;
default :
system_type = " RM200-Cxx " ;
break ;
}
break ;
case SNI_BRD_PCI_TOWER_CPLUS :
system_type = " RM400-Exx " ;
break ;
case SNI_BRD_PCI_MTOWER_CPLUS :
system_type = " RM300-Exx " ;
break ;
}
pr_debug ( " Found SNI brdtype %02x name %s \n " , sni_brd_type , system_type ) ;
# ifdef DEBUG
sni_idprom_dump ( ) ;
# endif
2006-12-28 18:22:32 +01:00
switch ( sni_brd_type ) {
case SNI_BRD_10 :
case SNI_BRD_10NEW :
case SNI_BRD_TOWER_OASIC :
case SNI_BRD_MINITOWER :
sni_a20r_init ( ) ;
break ;
case SNI_BRD_PCI_TOWER :
case SNI_BRD_PCI_TOWER_CPLUS :
sni_pcit_init ( ) ;
break ;
case SNI_BRD_RM200 :
sni_rm200_init ( ) ;
break ;
case SNI_BRD_PCI_MTOWER :
case SNI_BRD_PCI_DESKTOP :
case SNI_BRD_PCI_MTOWER_CPLUS :
sni_pcimt_init ( ) ;
break ;
}
2005-04-16 15:20:36 -07:00
_machine_restart = sni_machine_restart ;
2006-01-18 17:37:07 +00:00
pm_power_off = sni_machine_power_off ;
2005-04-16 15:20:36 -07:00
sni_display_setup ( ) ;
2008-01-04 23:31:07 +01:00
sni_console_setup ( ) ;
2005-04-16 15:20:36 -07:00
}
2007-05-17 14:53:12 +02:00
2008-01-04 23:31:07 +01:00
# ifdef CONFIG_PCI
2007-05-17 14:53:12 +02:00
# include <linux/pci.h>
# include <video/vga.h>
# include <video/cirrus.h>
static void __devinit quirk_cirrus_ram_size ( struct pci_dev * dev )
{
u16 cmd ;
/*
* firmware doesn ' t set the ram size correct , so we
* need to do it here , otherwise we get screen corruption
* on older Cirrus chips
*/
2007-10-11 23:46:15 +01:00
pci_read_config_word ( dev , PCI_COMMAND , & cmd ) ;
2007-05-17 14:53:12 +02:00
if ( ( cmd & ( PCI_COMMAND_IO | PCI_COMMAND_MEMORY ) )
= = ( PCI_COMMAND_IO | PCI_COMMAND_MEMORY ) ) {
2007-10-11 23:46:15 +01:00
vga_wseq ( NULL , CL_SEQR6 , 0x12 ) ; /* unlock all extension registers */
vga_wseq ( NULL , CL_SEQRF , 0x18 ) ;
2007-05-17 14:53:12 +02:00
}
}
DECLARE_PCI_FIXUP_FINAL ( PCI_VENDOR_ID_CIRRUS , PCI_DEVICE_ID_CIRRUS_5434_8 ,
quirk_cirrus_ram_size ) ;
DECLARE_PCI_FIXUP_FINAL ( PCI_VENDOR_ID_CIRRUS , PCI_DEVICE_ID_CIRRUS_5436 ,
quirk_cirrus_ram_size ) ;
DECLARE_PCI_FIXUP_FINAL ( PCI_VENDOR_ID_CIRRUS , PCI_DEVICE_ID_CIRRUS_5446 ,
quirk_cirrus_ram_size ) ;
# endif