blob: 606d25a4b870098698fc409c0cb81ddc68ebea4d [file] [log] [blame]
Jamie Lenehana09749d2006-09-27 15:05:39 +09001/*
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +09002 * arch/sh/boards/titan/setup.c - Setup for Titan
3 *
4 * Copyright (C) 2006 Jamie Lenehan
5 *
6 * This file is subject to the terms and conditions of the GNU General Public
7 * License. See the file "COPYING" in the main directory of this archive
8 * for more details.
Jamie Lenehana09749d2006-09-27 15:05:39 +09009 */
Jamie Lenehana09749d2006-09-27 15:05:39 +090010#include <linux/init.h>
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +090011#include <linux/irq.h>
Jamie Lenehana09749d2006-09-27 15:05:39 +090012#include <asm/titan.h>
13#include <asm/io.h>
14
Magnus Damm68abdbb2007-06-15 18:56:19 +090015static struct ipr_data ipr_irq_table[] = {
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +090016 /* IRQ, IPR idx, shift, prio */
17 { TITAN_IRQ_WAN, 3, 12, 8 }, /* eth0 (WAN) */
18 { TITAN_IRQ_LAN, 3, 8, 8 }, /* eth1 (LAN) */
19 { TITAN_IRQ_MPCIA, 3, 4, 8 }, /* mPCI A (top) */
20 { TITAN_IRQ_USB, 3, 0, 8 }, /* mPCI B (bottom), USB */
Jamie Lenehanbd71ab82006-10-31 12:35:02 +090021};
22
Magnus Damm68abdbb2007-06-15 18:56:19 +090023static unsigned long ipr_offsets[] = { /* stolen from setup-sh7750.c */
24 0xffd00004UL, /* 0: IPRA */
25 0xffd00008UL, /* 1: IPRB */
26 0xffd0000cUL, /* 2: IPRC */
27 0xffd00010UL, /* 3: IPRD */
28};
29
30static struct ipr_desc ipr_irq_desc = {
31 .ipr_offsets = ipr_offsets,
32 .nr_offsets = ARRAY_SIZE(ipr_offsets),
33
34 .ipr_data = ipr_irq_table,
35 .nr_irqs = ARRAY_SIZE(ipr_irq_table),
36
37 .chip = {
38 .name = "IPR-titan",
39 },
40};
Jamie Lenehana09749d2006-09-27 15:05:39 +090041static void __init init_titan_irq(void)
42{
43 /* enable individual interrupt mode for externals */
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +090044 ipr_irq_enable_irlm();
45 /* register ipr irqs */
Magnus Damm68abdbb2007-06-15 18:56:19 +090046 register_ipr_controller(&ipr_irq_desc);
Jamie Lenehana09749d2006-09-27 15:05:39 +090047}
48
Paul Mundt82f81f42007-05-15 15:19:34 +090049static struct sh_machine_vector mv_titan __initmv = {
Paul Mundt2c7834a2006-09-27 18:17:31 +090050 .mv_name = "Titan",
Jamie Lenehana09749d2006-09-27 15:05:39 +090051
52 .mv_inb = titan_inb,
53 .mv_inw = titan_inw,
54 .mv_inl = titan_inl,
55 .mv_outb = titan_outb,
56 .mv_outw = titan_outw,
57 .mv_outl = titan_outl,
58
59 .mv_inb_p = titan_inb_p,
60 .mv_inw_p = titan_inw,
61 .mv_inl_p = titan_inl,
62 .mv_outb_p = titan_outb_p,
63 .mv_outw_p = titan_outw,
64 .mv_outl_p = titan_outl,
65
66 .mv_insl = titan_insl,
67 .mv_outsl = titan_outsl,
68
Jamie Lenehana09749d2006-09-27 15:05:39 +090069 .mv_ioport_map = titan_ioport_map,
70
71 .mv_init_irq = init_titan_irq,
Jamie Lenehana09749d2006-09-27 15:05:39 +090072};