1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- /*
- * 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;
- }
|