2  * This file is subject to the terms and conditions of the GNU General Public
 
   3  * License.  See the file "COPYING" in the main directory of this archive
 
   6  * Copyright (C) 1994-1996  Linus Torvalds & authors
 
   8  * Copied from i386; many of the especially older MIPS or ISA-based platforms
 
   9  * are basically identical.  Using this file probably implies i8259 PIC
 
  10  * support in a system but the very least interrupt numbers 0 - 15 need to
 
  11  * be put aside for legacy devices.
 
  13 #ifndef __ASM_MACH_GENERIC_IDE_H
 
  14 #define __ASM_MACH_GENERIC_IDE_H
 
  18 #include <linux/config.h>
 
  19 #include <linux/pci.h>
 
  20 #include <linux/stddef.h>
 
  21 #include <asm/processor.h>
 
  24 # ifdef CONFIG_BLK_DEV_IDEPCI
 
  31 #define IDE_ARCH_OBSOLETE_DEFAULTS
 
  33 static __inline__ int ide_probe_legacy(void)
 
  37         if ((dev = pci_get_class(PCI_CLASS_BRIDGE_EISA << 8, NULL)) != NULL ||
 
  38             (dev = pci_get_class(PCI_CLASS_BRIDGE_ISA << 8, NULL)) != NULL) {
 
  44 #elif defined(CONFIG_EISA) || defined(CONFIG_ISA)
 
  51 static __inline__ int ide_default_irq(unsigned long base)
 
  53         if (ide_probe_legacy())
 
  74 static __inline__ unsigned long ide_default_io_base(int index)
 
  76         if (ide_probe_legacy())
 
  97 #define IDE_ARCH_OBSOLETE_INIT
 
  98 #define ide_default_io_ctl(base)        ((base) + 0x206) /* obsolete */
 
 100 #ifdef CONFIG_BLK_DEV_IDEPCI
 
 101 #define ide_init_default_irq(base)      (0)
 
 103 #define ide_init_default_irq(base)      ide_default_irq(base)
 
 106 /* MIPS port and memory-mapped I/O string operations.  */
 
 108 static inline void __ide_flush_dcache_range(unsigned long addr, unsigned long size)
 
 110         if (cpu_has_dc_aliases) {
 
 111                 unsigned long end = addr + size;
 
 112                 for (; addr < end; addr += PAGE_SIZE)
 
 113                         flush_dcache_page(virt_to_page(addr));
 
 117 static inline void __ide_insw(unsigned long port, void *addr,
 
 120         insw(port, addr, count);
 
 121         __ide_flush_dcache_range((unsigned long)addr, count * 2);
 
 124 static inline void __ide_insl(unsigned long port, void *addr, unsigned int count)
 
 126         insl(port, addr, count);
 
 127         __ide_flush_dcache_range((unsigned long)addr, count * 4);
 
 130 static inline void __ide_outsw(unsigned long port, const void *addr,
 
 133         outsw(port, addr, count);
 
 134         __ide_flush_dcache_range((unsigned long)addr, count * 2);
 
 137 static inline void __ide_outsl(unsigned long port, const void *addr,
 
 140         outsl(port, addr, count);
 
 141         __ide_flush_dcache_range((unsigned long)addr, count * 4);
 
 144 static inline void __ide_mm_insw(void __iomem *port, void *addr, u32 count)
 
 146         readsw(port, addr, count);
 
 147         __ide_flush_dcache_range((unsigned long)addr, count * 2);
 
 150 static inline void __ide_mm_insl(void __iomem *port, void *addr, u32 count)
 
 152         readsl(port, addr, count);
 
 153         __ide_flush_dcache_range((unsigned long)addr, count * 4);
 
 156 static inline void __ide_mm_outsw(void __iomem *port, void *addr, u32 count)
 
 158         writesw(port, addr, count);
 
 159         __ide_flush_dcache_range((unsigned long)addr, count * 2);
 
 162 static inline void __ide_mm_outsl(void __iomem * port, void *addr, u32 count)
 
 164         writesl(port, addr, count);
 
 165         __ide_flush_dcache_range((unsigned long)addr, count * 4);
 
 168 /* ide_insw calls insw, not __ide_insw.  Why? */
 
 173 #define insw(port, addr, count) __ide_insw(port, addr, count)
 
 174 #define insl(port, addr, count) __ide_insl(port, addr, count)
 
 175 #define outsw(port, addr, count) __ide_outsw(port, addr, count)
 
 176 #define outsl(port, addr, count) __ide_outsl(port, addr, count)
 
 178 #endif /* __KERNEL__ */
 
 180 #endif /* __ASM_MACH_GENERIC_IDE_H */