blob: 9efd7a86db450e8cb3e2650a0e9bc3d0756546e2 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
Adrian Bunk99eb8a52007-07-31 00:38:19 -07002 * ARM default IDE host driver
Linus Torvalds1da177e2005-04-16 15:20:36 -07003 *
4 * Copyright (C) 2004 Bartlomiej Zolnierkiewicz
5 * Based on code by: Russell King, Ian Molton and Alexander Schulz.
6 *
7 * May be copied or modified under the terms of the GNU General Public License.
8 */
9
10#include <linux/kernel.h>
11#include <linux/init.h>
12#include <linux/ide.h>
13
14#include <asm/mach-types.h>
15#include <asm/irq.h>
16
Bartlomiej Zolnierkiewicz2305d942008-04-26 22:25:18 +020017#define DRV_NAME "ide_arm"
18
Linus Torvalds1da177e2005-04-16 15:20:36 -070019#ifdef CONFIG_ARCH_CLPS7500
20# include <asm/arch/hardware.h>
21#
22# define IDE_ARM_IO (ISASLOT_IO + 0x1f0)
23# define IDE_ARM_IRQ IRQ_ISA_14
24#else
25# define IDE_ARM_IO 0x1f0
26# define IDE_ARM_IRQ IRQ_HARDDISK
27#endif
28
Bartlomiej Zolnierkiewiczade2daf2008-01-26 20:13:07 +010029static int __init ide_arm_init(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -070030{
Bartlomiej Zolnierkiewicz48c3c102008-07-23 19:55:57 +020031 struct ide_host *host;
Bartlomiej Zolnierkiewicz2305d942008-04-26 22:25:18 +020032 unsigned long base = IDE_ARM_IO, ctl = IDE_ARM_IO + 0x206;
Bartlomiej Zolnierkiewiczc97c6ac2008-07-23 19:55:50 +020033 hw_regs_t hw, *hws[] = { &hw, NULL, NULL, NULL };
Linus Torvalds1da177e2005-04-16 15:20:36 -070034
Bartlomiej Zolnierkiewicz2305d942008-04-26 22:25:18 +020035 if (!request_region(base, 8, DRV_NAME)) {
36 printk(KERN_ERR "%s: I/O resource 0x%lX-0x%lX not free.\n",
37 DRV_NAME, base, base + 7);
38 return -EBUSY;
39 }
40
41 if (!request_region(ctl, 1, DRV_NAME)) {
42 printk(KERN_ERR "%s: I/O resource 0x%lX not free.\n",
43 DRV_NAME, ctl);
44 release_region(base, 8);
45 return -EBUSY;
46 }
47
Adrian Bunk99eb8a52007-07-31 00:38:19 -070048 memset(&hw, 0, sizeof(hw));
Bartlomiej Zolnierkiewicz2305d942008-04-26 22:25:18 +020049 ide_std_init_ports(&hw, base, ctl);
Adrian Bunk99eb8a52007-07-31 00:38:19 -070050 hw.irq = IDE_ARM_IRQ;
Bartlomiej Zolnierkiewiczd427e832008-06-10 20:56:37 +020051 hw.chipset = ide_generic;
Bartlomiej Zolnierkiewiczcbb010c2008-01-26 20:13:06 +010052
Bartlomiej Zolnierkiewicz48c3c102008-07-23 19:55:57 +020053 host = ide_host_alloc(NULL, hws);
54 if (host)
55 ide_host_register(host, NULL, hws);
Bartlomiej Zolnierkiewiczade2daf2008-01-26 20:13:07 +010056
57 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070058}
Bartlomiej Zolnierkiewiczade2daf2008-01-26 20:13:07 +010059
60module_init(ide_arm_init);
Adrian Bunk57ad3ea02008-04-02 21:22:03 +020061
62MODULE_LICENSE("GPL");