hc
2024-05-10 9999e48639b3cecb08ffb37358bcba3b48161b29
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
 */
 
#ifndef __ASM_SPINLOCK_TYPES_H
#define __ASM_SPINLOCK_TYPES_H
 
typedef struct {
   volatile unsigned int slock;
} arch_spinlock_t;
 
#define __ARCH_SPIN_LOCK_UNLOCKED__    0
#define __ARCH_SPIN_LOCK_LOCKED__    1
 
#define __ARCH_SPIN_LOCK_UNLOCKED    { __ARCH_SPIN_LOCK_UNLOCKED__ }
#define __ARCH_SPIN_LOCK_LOCKED        { __ARCH_SPIN_LOCK_LOCKED__ }
 
/*
 * Unlocked     : 0x0100_0000
 * Read lock(s) : 0x00FF_FFFF to 0x01  (Multiple Readers decrement it)
 * Write lock   : 0x0, but only if prior value is "unlocked" 0x0100_0000
 */
typedef struct {
   volatile unsigned int    counter;
#ifndef CONFIG_ARC_HAS_LLSC
   arch_spinlock_t        lock_mutex;
#endif
} arch_rwlock_t;
 
#define __ARCH_RW_LOCK_UNLOCKED__    0x01000000
#define __ARCH_RW_LOCK_UNLOCKED        { .counter = __ARCH_RW_LOCK_UNLOCKED__ }
 
#endif