David S. Miller | d113fcd | 2007-11-16 03:06:07 -0800 | [diff] [blame] | 1 | /* cache.h: Cache specific code for the Sparc. These include flushing |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | * and direct tag/data line access. |
| 3 | * |
David S. Miller | d113fcd | 2007-11-16 03:06:07 -0800 | [diff] [blame] | 4 | * Copyright (C) 1995, 2007 David S. Miller (davem@davemloft.net) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 5 | */ |
| 6 | |
| 7 | #ifndef _SPARC_CACHE_H |
| 8 | #define _SPARC_CACHE_H |
| 9 | |
David S. Miller | 273fca0 | 2010-05-18 15:23:58 -0700 | [diff] [blame] | 10 | #define ARCH_SLAB_MINALIGN __alignof__(unsigned long long) |
| 11 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 12 | #define L1_CACHE_SHIFT 5 |
| 13 | #define L1_CACHE_BYTES 32 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 | |
David S. Miller | d113fcd | 2007-11-16 03:06:07 -0800 | [diff] [blame] | 15 | #ifdef CONFIG_SPARC32 |
| 16 | #define SMP_CACHE_BYTES_SHIFT 5 |
| 17 | #else |
| 18 | #define SMP_CACHE_BYTES_SHIFT 6 |
| 19 | #endif |
| 20 | |
| 21 | #define SMP_CACHE_BYTES (1 << SMP_CACHE_BYTES_SHIFT) |
| 22 | |
Denys Vlasenko | 54cb27a | 2010-02-20 01:03:44 +0100 | [diff] [blame] | 23 | #define __read_mostly __attribute__((__section__(".data..read_mostly"))) |
David S. Miller | d113fcd | 2007-11-16 03:06:07 -0800 | [diff] [blame] | 24 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 25 | #endif /* !(_SPARC_CACHE_H) */ |