diff options
Diffstat (limited to 'include/asm-mips/mach-generic')
-rw-r--r-- | include/asm-mips/mach-generic/cpu-feature-overrides.h | 2 | ||||
-rw-r--r-- | include/asm-mips/mach-generic/ide.h | 73 | ||||
-rw-r--r-- | include/asm-mips/mach-generic/ioremap.h | 23 | ||||
-rw-r--r-- | include/asm-mips/mach-generic/kernel-entry-init.h | 25 | ||||
-rw-r--r-- | include/asm-mips/mach-generic/kmalloc.h | 13 | ||||
-rw-r--r-- | include/asm-mips/mach-generic/spaces.h | 10 |
6 files changed, 132 insertions, 14 deletions
diff --git a/include/asm-mips/mach-generic/cpu-feature-overrides.h b/include/asm-mips/mach-generic/cpu-feature-overrides.h index 0aecfd08e39a..7c185bb06f13 100644 --- a/include/asm-mips/mach-generic/cpu-feature-overrides.h +++ b/include/asm-mips/mach-generic/cpu-feature-overrides.h | |||
@@ -8,6 +8,6 @@ | |||
8 | #ifndef __ASM_MACH_GENERIC_CPU_FEATURE_OVERRIDES_H | 8 | #ifndef __ASM_MACH_GENERIC_CPU_FEATURE_OVERRIDES_H |
9 | #define __ASM_MACH_GENERIC_CPU_FEATURE_OVERRIDES_H | 9 | #define __ASM_MACH_GENERIC_CPU_FEATURE_OVERRIDES_H |
10 | 10 | ||
11 | /* Intensionally empty file ... */ | 11 | /* Intentionally empty file ... */ |
12 | 12 | ||
13 | #endif /* __ASM_MACH_GENERIC_CPU_FEATURE_OVERRIDES_H */ | 13 | #endif /* __ASM_MACH_GENERIC_CPU_FEATURE_OVERRIDES_H */ |
diff --git a/include/asm-mips/mach-generic/ide.h b/include/asm-mips/mach-generic/ide.h index cb2edd018ad6..961006948c7c 100644 --- a/include/asm-mips/mach-generic/ide.h +++ b/include/asm-mips/mach-generic/ide.h | |||
@@ -18,6 +18,7 @@ | |||
18 | #include <linux/config.h> | 18 | #include <linux/config.h> |
19 | #include <linux/pci.h> | 19 | #include <linux/pci.h> |
20 | #include <linux/stddef.h> | 20 | #include <linux/stddef.h> |
21 | #include <asm/processor.h> | ||
21 | 22 | ||
22 | #ifndef MAX_HWIFS | 23 | #ifndef MAX_HWIFS |
23 | # ifdef CONFIG_BLK_DEV_IDEPCI | 24 | # ifdef CONFIG_BLK_DEV_IDEPCI |
@@ -104,15 +105,71 @@ static __inline__ unsigned long ide_default_io_base(int index) | |||
104 | 105 | ||
105 | /* MIPS port and memory-mapped I/O string operations. */ | 106 | /* MIPS port and memory-mapped I/O string operations. */ |
106 | 107 | ||
107 | #define __ide_insw insw | 108 | static inline void __ide_flush_dcache_range(unsigned long addr, unsigned long size) |
108 | #define __ide_insl insl | 109 | { |
109 | #define __ide_outsw outsw | 110 | if (cpu_has_dc_aliases) { |
110 | #define __ide_outsl outsl | 111 | unsigned long end = addr + size; |
112 | for (; addr < end; addr += PAGE_SIZE) | ||
113 | flush_dcache_page(virt_to_page(addr)); | ||
114 | } | ||
115 | } | ||
116 | |||
117 | static inline void __ide_insw(unsigned long port, void *addr, | ||
118 | unsigned int count) | ||
119 | { | ||
120 | insw(port, addr, count); | ||
121 | __ide_flush_dcache_range((unsigned long)addr, count * 2); | ||
122 | } | ||
123 | |||
124 | static inline void __ide_insl(unsigned long port, void *addr, unsigned int count) | ||
125 | { | ||
126 | insl(port, addr, count); | ||
127 | __ide_flush_dcache_range((unsigned long)addr, count * 4); | ||
128 | } | ||
129 | |||
130 | static inline void __ide_outsw(unsigned long port, const void *addr, | ||
131 | unsigned long count) | ||
132 | { | ||
133 | outsw(port, addr, count); | ||
134 | __ide_flush_dcache_range((unsigned long)addr, count * 2); | ||
135 | } | ||
136 | |||
137 | static inline void __ide_outsl(unsigned long port, const void *addr, | ||
138 | unsigned long count) | ||
139 | { | ||
140 | outsl(port, addr, count); | ||
141 | __ide_flush_dcache_range((unsigned long)addr, count * 4); | ||
142 | } | ||
143 | |||
144 | static inline void __ide_mm_insw(void __iomem *port, void *addr, u32 count) | ||
145 | { | ||
146 | readsw(port, addr, count); | ||
147 | __ide_flush_dcache_range((unsigned long)addr, count * 2); | ||
148 | } | ||
149 | |||
150 | static inline void __ide_mm_insl(void __iomem *port, void *addr, u32 count) | ||
151 | { | ||
152 | readsl(port, addr, count); | ||
153 | __ide_flush_dcache_range((unsigned long)addr, count * 4); | ||
154 | } | ||
155 | |||
156 | static inline void __ide_mm_outsw(void __iomem *port, void *addr, u32 count) | ||
157 | { | ||
158 | writesw(port, addr, count); | ||
159 | __ide_flush_dcache_range((unsigned long)addr, count * 2); | ||
160 | } | ||
161 | |||
162 | static inline void __ide_mm_outsl(void __iomem * port, void *addr, u32 count) | ||
163 | { | ||
164 | writesl(port, addr, count); | ||
165 | __ide_flush_dcache_range((unsigned long)addr, count * 4); | ||
166 | } | ||
111 | 167 | ||
112 | #define __ide_mm_insw readsw | 168 | /* ide_insw calls insw, not __ide_insw. Why? */ |
113 | #define __ide_mm_insl readsl | 169 | #undef insw |
114 | #define __ide_mm_outsw writesw | 170 | #undef insl |
115 | #define __ide_mm_outsl writesl | 171 | #define insw(port, addr, count) __ide_insw(port, addr, count) |
172 | #define insl(port, addr, count) __ide_insl(port, addr, count) | ||
116 | 173 | ||
117 | #endif /* __KERNEL__ */ | 174 | #endif /* __KERNEL__ */ |
118 | 175 | ||
diff --git a/include/asm-mips/mach-generic/ioremap.h b/include/asm-mips/mach-generic/ioremap.h new file mode 100644 index 000000000000..9b64ff6e485d --- /dev/null +++ b/include/asm-mips/mach-generic/ioremap.h | |||
@@ -0,0 +1,23 @@ | |||
1 | /* | ||
2 | * include/asm-mips/mach-generic/ioremap.h | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or | ||
5 | * modify it under the terms of the GNU General Public License | ||
6 | * as published by the Free Software Foundation; either version | ||
7 | * 2 of the License, or (at your option) any later version. | ||
8 | */ | ||
9 | #ifndef __ASM_MACH_GENERIC_IOREMAP_H | ||
10 | #define __ASM_MACH_GENERIC_IOREMAP_H | ||
11 | |||
12 | #include <linux/types.h> | ||
13 | |||
14 | /* | ||
15 | * Allow physical addresses to be fixed up to help peripherals located | ||
16 | * outside the low 32-bit range -- generic pass-through version. | ||
17 | */ | ||
18 | static inline phys_t fixup_bigphys_addr(phys_t phys_addr, phys_t size) | ||
19 | { | ||
20 | return phys_addr; | ||
21 | } | ||
22 | |||
23 | #endif /* __ASM_MACH_GENERIC_IOREMAP_H */ | ||
diff --git a/include/asm-mips/mach-generic/kernel-entry-init.h b/include/asm-mips/mach-generic/kernel-entry-init.h new file mode 100644 index 000000000000..7e66505fa574 --- /dev/null +++ b/include/asm-mips/mach-generic/kernel-entry-init.h | |||
@@ -0,0 +1,25 @@ | |||
1 | /* | ||
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 | ||
4 | * for more details. | ||
5 | * | ||
6 | * Copyright (C) 2005 Embedded Alley Solutions, Inc | ||
7 | * Copyright (C) 2005 Ralf Baechle (ralf@linux-mips.org) | ||
8 | */ | ||
9 | #ifndef __ASM_MACH_GENERIC_KERNEL_ENTRY_H | ||
10 | #define __ASM_MACH_GENERIC_KERNEL_ENTRY_H | ||
11 | |||
12 | /* Intentionally empty macro, used in head.S. Override in | ||
13 | * arch/mips/mach-xxx/kernel-entry-init.h when necessary. | ||
14 | */ | ||
15 | .macro kernel_entry_setup | ||
16 | .endm | ||
17 | |||
18 | /* | ||
19 | * Do SMP slave processor setup necessary before we can savely execute C code. | ||
20 | */ | ||
21 | .macro smp_slave_setup | ||
22 | .endm | ||
23 | |||
24 | |||
25 | #endif /* __ASM_MACH_GENERIC_KERNEL_ENTRY_H */ | ||
diff --git a/include/asm-mips/mach-generic/kmalloc.h b/include/asm-mips/mach-generic/kmalloc.h new file mode 100644 index 000000000000..373d66dee9d7 --- /dev/null +++ b/include/asm-mips/mach-generic/kmalloc.h | |||
@@ -0,0 +1,13 @@ | |||
1 | #ifndef __ASM_MACH_GENERIC_KMALLOC_H | ||
2 | #define __ASM_MACH_GENERIC_KMALLOC_H | ||
3 | |||
4 | #include <linux/config.h> | ||
5 | |||
6 | #ifndef CONFIG_DMA_COHERENT | ||
7 | /* | ||
8 | * Total overkill for most systems but need as a safe default. | ||
9 | */ | ||
10 | #define ARCH_KMALLOC_MINALIGN 128 | ||
11 | #endif | ||
12 | |||
13 | #endif /* __ASM_MACH_GENERIC_KMALLOC_H */ | ||
diff --git a/include/asm-mips/mach-generic/spaces.h b/include/asm-mips/mach-generic/spaces.h index 5a2c1efb4eb7..b849d8dd7e78 100644 --- a/include/asm-mips/mach-generic/spaces.h +++ b/include/asm-mips/mach-generic/spaces.h | |||
@@ -55,13 +55,13 @@ | |||
55 | #endif | 55 | #endif |
56 | 56 | ||
57 | #ifdef CONFIG_DMA_NONCOHERENT | 57 | #ifdef CONFIG_DMA_NONCOHERENT |
58 | #define CAC_BASE 0x9800000000000000 | 58 | #define CAC_BASE 0x9800000000000000UL |
59 | #else | 59 | #else |
60 | #define CAC_BASE 0xa800000000000000 | 60 | #define CAC_BASE 0xa800000000000000UL |
61 | #endif | 61 | #endif |
62 | #define IO_BASE 0x9000000000000000 | 62 | #define IO_BASE 0x9000000000000000UL |
63 | #define UNCAC_BASE 0x9000000000000000 | 63 | #define UNCAC_BASE 0x9000000000000000UL |
64 | #define MAP_BASE 0xc000000000000000 | 64 | #define MAP_BASE 0xc000000000000000UL |
65 | 65 | ||
66 | #define TO_PHYS(x) ( ((x) & TO_PHYS_MASK)) | 66 | #define TO_PHYS(x) ( ((x) & TO_PHYS_MASK)) |
67 | #define TO_CAC(x) (CAC_BASE | ((x) & TO_PHYS_MASK)) | 67 | #define TO_CAC(x) (CAC_BASE | ((x) & TO_PHYS_MASK)) |