diff options
| author | Kristoffer Ericson <Kristoffer_e1@hotmail.com> | 2007-04-09 18:45:08 -0400 |
|---|---|---|
| committer | Paul Mundt <lethal@hera.kernel.org> | 2007-05-06 22:11:56 -0400 |
| commit | 34a780a0afeb8f99c9ca9934f4cc0822541769c6 (patch) | |
| tree | 9afecb9b8af6b6b7e3160a3dacff70ab4eea438c | |
| parent | dd12666278daa0008ac439603c8d3037bc213556 (diff) | |
sh: hp6xx pata_platform support.
Drop the hd64461 I/O ops and wire up pata_platform for MMIO.
Signed-off-by: Kristoffer Ericson <Kristoffer_e1@hotmail.com>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
| -rw-r--r-- | arch/sh/boards/hp6xx/setup.c | 67 |
1 files changed, 37 insertions, 30 deletions
diff --git a/arch/sh/boards/hp6xx/setup.c b/arch/sh/boards/hp6xx/setup.c index b5a96649ed26..6aeee85c9785 100644 --- a/arch/sh/boards/hp6xx/setup.c +++ b/arch/sh/boards/hp6xx/setup.c | |||
| @@ -2,6 +2,7 @@ | |||
| 2 | * linux/arch/sh/boards/hp6xx/setup.c | 2 | * linux/arch/sh/boards/hp6xx/setup.c |
| 3 | * | 3 | * |
| 4 | * Copyright (C) 2002 Andriy Skulysh | 4 | * Copyright (C) 2002 Andriy Skulysh |
| 5 | * Copyright (C) 2007 Kristoffer Ericson <Kristoffer_e1@hotmail.com> | ||
| 5 | * | 6 | * |
| 6 | * May be copied or modified under the terms of the GNU General Public | 7 | * May be copied or modified under the terms of the GNU General Public |
| 7 | * License. See linux/COPYING for more information. | 8 | * License. See linux/COPYING for more information. |
| @@ -10,6 +11,7 @@ | |||
| 10 | */ | 11 | */ |
| 11 | #include <linux/types.h> | 12 | #include <linux/types.h> |
| 12 | #include <linux/init.h> | 13 | #include <linux/init.h> |
| 14 | #include <linux/platform_device.h> | ||
| 13 | #include <asm/hd64461.h> | 15 | #include <asm/hd64461.h> |
| 14 | #include <asm/io.h> | 16 | #include <asm/io.h> |
| 15 | #include <asm/irq.h> | 17 | #include <asm/irq.h> |
| @@ -19,6 +21,40 @@ | |||
| 19 | #define SCPCR 0xa4000116 | 21 | #define SCPCR 0xa4000116 |
| 20 | #define SCPDR 0xa4000136 | 22 | #define SCPDR 0xa4000136 |
| 21 | 23 | ||
| 24 | /* CF Slot */ | ||
| 25 | static struct resource cf_ide_resources[] = { | ||
| 26 | [0] = { | ||
| 27 | .start = 0x15000000 + 0x1f0, | ||
| 28 | .end = 0x15000000 + 0x1f0 + 0x08 - 0x01, | ||
| 29 | .flags = IORESOURCE_MEM, | ||
| 30 | }, | ||
| 31 | [1] = { | ||
| 32 | .start = 0x15000000 + 0x1fe, | ||
| 33 | .end = 0x15000000 + 0x1fe + 0x01, | ||
| 34 | .flags = IORESOURCE_MEM, | ||
| 35 | }, | ||
| 36 | [2] = { | ||
| 37 | .start = 93, | ||
| 38 | .flags = IORESOURCE_IRQ, | ||
| 39 | }, | ||
| 40 | }; | ||
| 41 | |||
| 42 | static struct platform_device cf_ide_device = { | ||
| 43 | .name = "pata_platform", | ||
| 44 | .id = -1, | ||
| 45 | .num_resources = ARRAY_SIZE(cf_ide_resources), | ||
| 46 | .resource = cf_ide_resources, | ||
| 47 | }; | ||
| 48 | |||
| 49 | static struct platform_device *hp6xx_devices[] __initdata = { | ||
| 50 | &cf_ide_device, | ||
| 51 | }; | ||
| 52 | |||
| 53 | static int __init hp6xx_devices_setup(void) | ||
| 54 | { | ||
| 55 | return platform_add_devices(hp6xx_devices, ARRAY_SIZE(hp6xx_devices)); | ||
| 56 | } | ||
| 57 | |||
| 22 | static void __init hp6xx_setup(char **cmdline_p) | 58 | static void __init hp6xx_setup(char **cmdline_p) |
| 23 | { | 59 | { |
| 24 | u8 v8; | 60 | u8 v8; |
| @@ -60,41 +96,12 @@ static void __init hp6xx_setup(char **cmdline_p) | |||
| 60 | v |= SCPCR_TS_ENABLE; | 96 | v |= SCPCR_TS_ENABLE; |
| 61 | ctrl_outw(v, SCPCR); | 97 | ctrl_outw(v, SCPCR); |
| 62 | } | 98 | } |
| 99 | device_initcall(hp6xx_devices_setup); | ||
| 63 | 100 | ||
| 64 | /* | ||
| 65 | * XXX: This is stupid, we should have a generic machine vector for the cchips | ||
| 66 | * and just wrap the platform setup code in to this, as it's the only thing | ||
| 67 | * that ends up being different. | ||
| 68 | */ | ||
| 69 | struct sh_machine_vector mv_hp6xx __initmv = { | 101 | struct sh_machine_vector mv_hp6xx __initmv = { |
| 70 | .mv_name = "hp6xx", | 102 | .mv_name = "hp6xx", |
| 71 | .mv_setup = hp6xx_setup, | 103 | .mv_setup = hp6xx_setup, |
| 72 | .mv_nr_irqs = HD64461_IRQBASE + HD64461_IRQ_NUM, | 104 | .mv_nr_irqs = HD64461_IRQBASE + HD64461_IRQ_NUM, |
| 73 | |||
| 74 | .mv_inb = hd64461_inb, | ||
| 75 | .mv_inw = hd64461_inw, | ||
| 76 | .mv_inl = hd64461_inl, | ||
| 77 | .mv_outb = hd64461_outb, | ||
| 78 | .mv_outw = hd64461_outw, | ||
| 79 | .mv_outl = hd64461_outl, | ||
| 80 | |||
| 81 | .mv_inb_p = hd64461_inb_p, | ||
| 82 | .mv_inw_p = hd64461_inw, | ||
| 83 | .mv_inl_p = hd64461_inl, | ||
| 84 | .mv_outb_p = hd64461_outb_p, | ||
| 85 | .mv_outw_p = hd64461_outw, | ||
| 86 | .mv_outl_p = hd64461_outl, | ||
| 87 | |||
| 88 | .mv_insb = hd64461_insb, | ||
| 89 | .mv_insw = hd64461_insw, | ||
| 90 | .mv_insl = hd64461_insl, | ||
| 91 | .mv_outsb = hd64461_outsb, | ||
| 92 | .mv_outsw = hd64461_outsw, | ||
| 93 | .mv_outsl = hd64461_outsl, | ||
| 94 | |||
| 95 | .mv_readw = hd64461_readw, | ||
| 96 | .mv_writew = hd64461_writew, | ||
| 97 | |||
| 98 | .mv_irq_demux = hd64461_irq_demux, | 105 | .mv_irq_demux = hd64461_irq_demux, |
| 99 | }; | 106 | }; |
| 100 | ALIAS_MV(hp6xx) | 107 | ALIAS_MV(hp6xx) |
