[POWERPC] Allow hooking of PCI MMIO & PIO accessors on 64 bits
[safe/jmp/linux-2.6] / include / asm-powerpc / ide.h
1 /*
2  *  Copyright (C) 1994-1996 Linus Torvalds & authors
3  *
4  *  This file contains the powerpc architecture specific IDE code.
5  */
6 #ifndef _ASM_POWERPC_IDE_H
7 #define _ASM_POWERPC_IDE_H
8
9 #ifdef __KERNEL__
10
11 #ifndef __powerpc64__
12 #include <linux/sched.h>
13 #include <asm/mpc8xx.h>
14 #endif
15 #include <asm/io.h>
16
17 #ifndef MAX_HWIFS
18 #ifdef __powerpc64__
19 #define MAX_HWIFS       10
20 #else
21 #define MAX_HWIFS       8
22 #endif
23 #endif
24
25 #ifdef __powerpc64__
26 #define __ide_mm_insw(p, a, c)  readsw((void __iomem *)(p), (a), (c))
27 #define __ide_mm_insl(p, a, c)  readsl((void __iomem *)(p), (a), (c))
28 #define __ide_mm_outsw(p, a, c) writesw((void __iomem *)(p), (a), (c))
29 #define __ide_mm_outsl(p, a, c) writesl((void __iomem *)(p), (a), (c))
30 #else
31 #define __ide_mm_insw(p, a, c)  _insw_ns((volatile u16 __iomem *)(p), (a), (c))
32 #define __ide_mm_insl(p, a, c)  _insl_ns((volatile u32 __iomem *)(p), (a), (c))
33 #define __ide_mm_outsw(p, a, c) _outsw_ns((volatile u16 __iomem *)(p), (a), (c))
34 #define __ide_mm_outsl(p, a, c) _outsl_ns((volatile u32 __iomem *)(p), (a), (c))
35 #endif
36
37 #ifndef  __powerpc64__
38 #include <linux/hdreg.h>
39 #include <linux/ioport.h>
40
41 struct ide_machdep_calls {
42         int         (*default_irq)(unsigned long base);
43         unsigned long (*default_io_base)(int index);
44         void        (*ide_init_hwif)(hw_regs_t *hw,
45                                      unsigned long data_port,
46                                      unsigned long ctrl_port,
47                                      int *irq);
48 };
49
50 extern struct ide_machdep_calls ppc_ide_md;
51
52 #undef  SUPPORT_SLOW_DATA_PORTS
53 #define SUPPORT_SLOW_DATA_PORTS 0
54
55 #define IDE_ARCH_OBSOLETE_DEFAULTS
56
57 static __inline__ int ide_default_irq(unsigned long base)
58 {
59         if (ppc_ide_md.default_irq)
60                 return ppc_ide_md.default_irq(base);
61         return 0;
62 }
63
64 static __inline__ unsigned long ide_default_io_base(int index)
65 {
66         if (ppc_ide_md.default_io_base)
67                 return ppc_ide_md.default_io_base(index);
68         return 0;
69 }
70
71 #ifdef CONFIG_PCI
72 #define ide_init_default_irq(base)      (0)
73 #else
74 #define ide_init_default_irq(base)      ide_default_irq(base)
75 #endif
76
77 #if (defined CONFIG_APUS || defined CONFIG_BLK_DEV_MPC8xx_IDE )
78 #define IDE_ARCH_ACK_INTR  1
79 #define ide_ack_intr(hwif) (hwif->hw.ack_intr ? hwif->hw.ack_intr(hwif) : 1)
80 #endif
81
82 #endif /* __powerpc64__ */
83
84 #define IDE_ARCH_OBSOLETE_INIT
85 #define ide_default_io_ctl(base)        ((base) + 0x206) /* obsolete */
86
87 #endif /* __KERNEL__ */
88
89 #endif /* _ASM_POWERPC_IDE_H */