1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */ 2deae26bfSKyle McMartin #ifndef __ASM_SPINLOCK_TYPES_H 3deae26bfSKyle McMartin #define __ASM_SPINLOCK_TYPES_H 4deae26bfSKyle McMartin 515e64ef6SHelge Deller #define __ARCH_SPIN_LOCK_UNLOCKED_VAL 0x1a46 615e64ef6SHelge Deller 7*a0f4b787SHelge Deller #define SPINLOCK_BREAK_INSN 0x0000c006 /* break 6,6 */ 8*a0f4b787SHelge Deller 9*a0f4b787SHelge Deller #ifndef __ASSEMBLY__ 10*a0f4b787SHelge Deller 11deae26bfSKyle McMartin typedef struct { 12deae26bfSKyle McMartin #ifdef CONFIG_PA20 13deae26bfSKyle McMartin volatile unsigned int slock; 1415e64ef6SHelge Deller # define __ARCH_SPIN_LOCK_UNLOCKED { __ARCH_SPIN_LOCK_UNLOCKED_VAL } 15deae26bfSKyle McMartin #else 16deae26bfSKyle McMartin volatile unsigned int lock[4]; 1715e64ef6SHelge Deller # define __ARCH_SPIN_LOCK_UNLOCKED \ 1815e64ef6SHelge Deller { { __ARCH_SPIN_LOCK_UNLOCKED_VAL, __ARCH_SPIN_LOCK_UNLOCKED_VAL, \ 1915e64ef6SHelge Deller __ARCH_SPIN_LOCK_UNLOCKED_VAL, __ARCH_SPIN_LOCK_UNLOCKED_VAL } } 20deae26bfSKyle McMartin #endif 21445c8951SThomas Gleixner } arch_spinlock_t; 22deae26bfSKyle McMartin 23fbdc8f0fSHelge Deller 24fbdc8f0fSHelge Deller /* counter: 25fbdc8f0fSHelge Deller * Unlocked : 0x0100_0000 26fbdc8f0fSHelge Deller * Read lock(s) : 0x00FF_FFFF to 0x01 (Multiple Readers decrement it) 27fbdc8f0fSHelge Deller * Write lock : 0x0, but only if prior value is "unlocked" 0x0100_0000 28fbdc8f0fSHelge Deller */ 29deae26bfSKyle McMartin typedef struct { 30fbdc8f0fSHelge Deller arch_spinlock_t lock_mutex; 31fbdc8f0fSHelge Deller volatile unsigned int counter; 32fb3a6bbcSThomas Gleixner } arch_rwlock_t; 33deae26bfSKyle McMartin 34*a0f4b787SHelge Deller #endif /* __ASSEMBLY__ */ 35*a0f4b787SHelge Deller 36fbdc8f0fSHelge Deller #define __ARCH_RW_LOCK_UNLOCKED__ 0x01000000 37fbdc8f0fSHelge Deller #define __ARCH_RW_LOCK_UNLOCKED { .lock_mutex = __ARCH_SPIN_LOCK_UNLOCKED, \ 38fbdc8f0fSHelge Deller .counter = __ARCH_RW_LOCK_UNLOCKED__ } 39deae26bfSKyle McMartin 40deae26bfSKyle McMartin #endif 41