blob: cf6385446ece9da9a0266bef1ce3f80154f62ead [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
Russell King635f0252008-10-28 09:43:54 +000018#define IDE_ARM_IO 0x1f0
19#define IDE_ARM_IRQ IRQ_HARDDISK
Linus Torvalds1da177e2005-04-16 15:20:36 -070020
Bartlomiej Zolnierkiewicz98046572009-03-27 12:46:17 +010021static const struct ide_port_info ide_arm_port_info = {
22 .host_flags = IDE_HFLAG_NO_DMA,
23};
24
Bartlomiej Zolnierkiewiczade2daf2008-01-26 20:13:07 +010025static int __init ide_arm_init(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -070026{
Bartlomiej Zolnierkiewicz2305d942008-04-26 22:25:18 +020027 unsigned long base = IDE_ARM_IO, ctl = IDE_ARM_IO + 0x206;
Bartlomiej Zolnierkiewiczc97c6ac2008-07-23 19:55:50 +020028 hw_regs_t hw, *hws[] = { &hw, NULL, NULL, NULL };
Linus Torvalds1da177e2005-04-16 15:20:36 -070029
Bartlomiej Zolnierkiewicz2305d942008-04-26 22:25:18 +020030 if (!request_region(base, 8, DRV_NAME)) {
31 printk(KERN_ERR "%s: I/O resource 0x%lX-0x%lX not free.\n",
32 DRV_NAME, base, base + 7);
33 return -EBUSY;
34 }
35
36 if (!request_region(ctl, 1, DRV_NAME)) {
37 printk(KERN_ERR "%s: I/O resource 0x%lX not free.\n",
38 DRV_NAME, ctl);
39 release_region(base, 8);
40 return -EBUSY;
41 }
42
Adrian Bunk99eb8a52007-07-31 00:38:19 -070043 memset(&hw, 0, sizeof(hw));
Bartlomiej Zolnierkiewicz2305d942008-04-26 22:25:18 +020044 ide_std_init_ports(&hw, base, ctl);
Adrian Bunk99eb8a52007-07-31 00:38:19 -070045 hw.irq = IDE_ARM_IRQ;
Bartlomiej Zolnierkiewiczd427e832008-06-10 20:56:37 +020046 hw.chipset = ide_generic;
Bartlomiej Zolnierkiewiczcbb010c2008-01-26 20:13:06 +010047
Bartlomiej Zolnierkiewicz98046572009-03-27 12:46:17 +010048 return ide_host_add(&ide_arm_port_info, hws, NULL);
Linus Torvalds1da177e2005-04-16 15:20:36 -070049}
Bartlomiej Zolnierkiewiczade2daf2008-01-26 20:13:07 +010050
51module_init(ide_arm_init);
Adrian Bunk57ad3ea02008-04-02 21:22:03 +020052
53MODULE_LICENSE("GPL");