72 lines
1.5 KiB
C
72 lines
1.5 KiB
C
|
/*
|
||
|
* linux/arch/sh/kernel/setup_sh2000.c
|
||
|
*
|
||
|
* Copyright (C) 2001 SUGIOKA Tochinobu
|
||
|
*
|
||
|
* SH-2000 Support.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#include <linux/config.h>
|
||
|
#include <linux/init.h>
|
||
|
#include <linux/irq.h>
|
||
|
|
||
|
#include <asm/io.h>
|
||
|
#include <asm/machvec.h>
|
||
|
#include <asm/mach/sh2000.h>
|
||
|
|
||
|
#define CF_CIS_BASE 0xb4200000
|
||
|
|
||
|
#define PORT_PECR 0xa4000108
|
||
|
#define PORT_PHCR 0xa400010E
|
||
|
#define PORT_ICR1 0xa4000010
|
||
|
#define PORT_IRR0 0xa4000004
|
||
|
|
||
|
#define IDE_OFFSET 0xb6200000
|
||
|
#define NIC_OFFSET 0xb6000000
|
||
|
#define EXTBUS_OFFSET 0xba000000
|
||
|
|
||
|
|
||
|
const char *get_system_type(void)
|
||
|
{
|
||
|
return "sh2000";
|
||
|
}
|
||
|
|
||
|
static unsigned long sh2000_isa_port2addr(unsigned long offset)
|
||
|
{
|
||
|
if((offset & ~7) == 0x1f0 || offset == 0x3f6)
|
||
|
return IDE_OFFSET + offset;
|
||
|
else if((offset & ~0x1f) == 0x300)
|
||
|
return NIC_OFFSET + offset;
|
||
|
return EXTBUS_OFFSET + offset;
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* The Machine Vector
|
||
|
*/
|
||
|
struct sh_machine_vector mv_sh2000 __initmv = {
|
||
|
.mv_nr_irqs = 80,
|
||
|
.mv_isa_port2addr = sh2000_isa_port2addr,
|
||
|
};
|
||
|
ALIAS_MV(sh2000)
|
||
|
|
||
|
/*
|
||
|
* Initialize the board
|
||
|
*/
|
||
|
int __init platform_setup(void)
|
||
|
{
|
||
|
/* XXX: RTC setting comes here */
|
||
|
|
||
|
/* These should be done by BIOS/IPL ... */
|
||
|
/* Enable nCE2A, nCE2B output */
|
||
|
ctrl_outw(ctrl_inw(PORT_PECR) & ~0xf00, PORT_PECR);
|
||
|
/* Enable the Compact Flash card, and set the level interrupt */
|
||
|
ctrl_outw(0x0042, CF_CIS_BASE+0x0200);
|
||
|
/* Enable interrupt */
|
||
|
ctrl_outw(ctrl_inw(PORT_PHCR) & ~0x03f3, PORT_PHCR);
|
||
|
ctrl_outw(1, PORT_ICR1);
|
||
|
ctrl_outw(ctrl_inw(PORT_IRR0) & ~0xff3f, PORT_IRR0);
|
||
|
printk(KERN_INFO "SH-2000 Setup...done\n");
|
||
|
return 0;
|
||
|
}
|