ide_arm.c 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /*
  2. * ARM default IDE host driver
  3. *
  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. #include <linux/kernel.h>
  10. #include <linux/init.h>
  11. #include <linux/ide.h>
  12. #include <asm/mach-types.h>
  13. #include <asm/irq.h>
  14. #define DRV_NAME "ide_arm"
  15. #ifdef CONFIG_ARCH_CLPS7500
  16. # include <asm/arch/hardware.h>
  17. #
  18. # define IDE_ARM_IO (ISASLOT_IO + 0x1f0)
  19. # define IDE_ARM_IRQ IRQ_ISA_14
  20. #else
  21. # define IDE_ARM_IO 0x1f0
  22. # define IDE_ARM_IRQ IRQ_HARDDISK
  23. #endif
  24. static int __init ide_arm_init(void)
  25. {
  26. ide_hwif_t *hwif;
  27. hw_regs_t hw;
  28. unsigned long base = IDE_ARM_IO, ctl = IDE_ARM_IO + 0x206;
  29. u8 idx[4] = { 0xff, 0xff, 0xff, 0xff };
  30. 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. if (!request_region(ctl, 1, DRV_NAME)) {
  36. printk(KERN_ERR "%s: I/O resource 0x%lX not free.\n",
  37. DRV_NAME, ctl);
  38. release_region(base, 8);
  39. return -EBUSY;
  40. }
  41. memset(&hw, 0, sizeof(hw));
  42. ide_std_init_ports(&hw, base, ctl);
  43. hw.irq = IDE_ARM_IRQ;
  44. hw.chipset = ide_generic;
  45. hwif = ide_find_port();
  46. if (hwif) {
  47. ide_init_port_hw(hwif, &hw);
  48. idx[0] = hwif->index;
  49. ide_device_add(idx, NULL);
  50. }
  51. return 0;
  52. }
  53. module_init(ide_arm_init);
  54. MODULE_LICENSE("GPL");