blob: f728f2927b5a03a9ed4d1c8086ba67c9da350810 [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
Linus Torvalds1da177e2005-04-16 15:20:36 -070014#include <asm/irq.h>
15
Bartlomiej Zolnierkiewicz2305d942008-04-26 22:25:18 +020016#define DRV_NAME "ide_arm"
17
Linus Torvalds1da177e2005-04-16 15:20:36 -070018#ifdef CONFIG_ARCH_CLPS7500
Russell Kinga09e64f2008-08-05 16:14:15 +010019# include <mach/hardware.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070020#
21# define IDE_ARM_IO (ISASLOT_IO + 0x1f0)
22# define IDE_ARM_IRQ IRQ_ISA_14
23#else
24# define IDE_ARM_IO 0x1f0
25# define IDE_ARM_IRQ IRQ_HARDDISK
26#endif
27
Bartlomiej Zolnierkiewiczade2daf2008-01-26 20:13:07 +010028static int __init ide_arm_init(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -070029{
Bartlomiej Zolnierkiewicz2305d942008-04-26 22:25:18 +020030 unsigned long base = IDE_ARM_IO, ctl = IDE_ARM_IO + 0x206;
Bartlomiej Zolnierkiewiczc97c6ac2008-07-23 19:55:50 +020031 hw_regs_t hw, *hws[] = { &hw, NULL, NULL, NULL };
Linus Torvalds1da177e2005-04-16 15:20:36 -070032
Bartlomiej Zolnierkiewicz2305d942008-04-26 22:25:18 +020033 if (!request_region(base, 8, DRV_NAME)) {
34 printk(KERN_ERR "%s: I/O resource 0x%lX-0x%lX not free.\n",
35 DRV_NAME, base, base + 7);
36 return -EBUSY;
37 }
38
39 if (!request_region(ctl, 1, DRV_NAME)) {
40 printk(KERN_ERR "%s: I/O resource 0x%lX not free.\n",
41 DRV_NAME, ctl);
42 release_region(base, 8);
43 return -EBUSY;
44 }
45
Adrian Bunk99eb8a52007-07-31 00:38:19 -070046 memset(&hw, 0, sizeof(hw));
Bartlomiej Zolnierkiewicz2305d942008-04-26 22:25:18 +020047 ide_std_init_ports(&hw, base, ctl);
Adrian Bunk99eb8a52007-07-31 00:38:19 -070048 hw.irq = IDE_ARM_IRQ;
Bartlomiej Zolnierkiewiczd427e832008-06-10 20:56:37 +020049 hw.chipset = ide_generic;
Bartlomiej Zolnierkiewiczcbb010c2008-01-26 20:13:06 +010050
Bartlomiej Zolnierkiewicz6f904d02008-07-23 19:55:57 +020051 return ide_host_add(NULL, hws, NULL);
Linus Torvalds1da177e2005-04-16 15:20:36 -070052}
Bartlomiej Zolnierkiewiczade2daf2008-01-26 20:13:07 +010053
54module_init(ide_arm_init);
Adrian Bunk57ad3ea02008-04-02 21:22:03 +020055
56MODULE_LICENSE("GPL");