aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
Diffstat (limited to 'include')
-rw-r--r--include/asm-sh/page.h22
1 files changed, 9 insertions, 13 deletions
diff --git a/include/asm-sh/page.h b/include/asm-sh/page.h
index 407bf5a14936..bff635a078c8 100644
--- a/include/asm-sh/page.h
+++ b/include/asm-sh/page.h
@@ -138,22 +138,18 @@ typedef struct { unsigned long pgd; } pgd_t;
138#endif 138#endif
139 139
140/* 140/*
141 * Slub defaults to 8-byte alignment, we're only interested in 4. 141 * Some drivers need to perform DMA into kmalloc'ed buffers
142 * Slab defaults to BYTES_PER_WORD, which ends up being the same anyways. 142 * and so we have to increase the kmalloc minalign for this.
143 */ 143 */
144#ifdef CONFIG_SUPERH32 144#define ARCH_KMALLOC_MINALIGN L1_CACHE_BYTES
145#define ARCH_KMALLOC_MINALIGN 4
146#define ARCH_SLAB_MINALIGN 4
147#else
148/* If gcc inlines memset, it will use st.q instructions. Therefore, we need
149 kmalloc allocations to be 8-byte aligned. Without this, the alignment
150 becomes BYTE_PER_WORD i.e. only 4 (since sizeof(long)==sizeof(void*)==4 on
151 sh64 at the moment). */
152#define ARCH_KMALLOC_MINALIGN 8
153 145
146#ifdef CONFIG_SUPERH64
154/* 147/*
155 * We want 8-byte alignment for the slab caches as well, otherwise we have 148 * While BYTES_PER_WORD == 4 on the current sh64 ABI, GCC will still
156 * the same BYTES_PER_WORD (sizeof(void *)) min align in kmem_cache_create(). 149 * happily generate {ld/st}.q pairs, requiring us to have 8-byte
150 * alignment to avoid traps. The kmalloc alignment is gauranteed by
151 * virtue of L1_CACHE_BYTES, requiring this to only be special cased
152 * for slab caches.
157 */ 153 */
158#define ARCH_SLAB_MINALIGN 8 154#define ARCH_SLAB_MINALIGN 8
159#endif 155#endif