Changeset fc10e1b in mainline for kernel/generic/src/synch/spinlock.c
- Timestamp:
- 2018-09-07T16:34:11Z (6 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- d2c91ab
- Parents:
- 508b0df1 (diff), e90cfa6 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/generic/src/synch/spinlock.c
r508b0df1 rfc10e1b 56 56 void spinlock_initialize(spinlock_t *lock, const char *name) 57 57 { 58 atomic_ set(&lock->val, 0);58 atomic_flag_clear_explicit(&lock->flag, memory_order_relaxed); 59 59 #ifdef CONFIG_DEBUG_SPINLOCK 60 60 lock->name = name; … … 79 79 80 80 preemption_disable(); 81 while ( test_and_set(&lock->val)) {81 while (atomic_flag_test_and_set_explicit(&lock->flag, memory_order_acquire)) { 82 82 /* 83 83 * We need to be careful about particular locks … … 115 115 if (deadlock_reported) 116 116 printf("cpu%u: not deadlocked\n", CPU->id); 117 118 /*119 * Prevent critical section code from bleeding out this way up.120 */121 CS_ENTER_BARRIER();122 117 } 123 118 … … 132 127 ASSERT_SPINLOCK(spinlock_locked(lock), lock); 133 128 134 /* 135 * Prevent critical section code from bleeding out this way down. 136 */ 137 CS_LEAVE_BARRIER(); 138 139 atomic_set(&lock->val, 0); 129 atomic_flag_clear_explicit(&lock->flag, memory_order_release); 140 130 preemption_enable(); 141 131 } … … 156 146 { 157 147 preemption_disable(); 158 bool ret = !test_and_set(&lock->val); 159 160 /* 161 * Prevent critical section code from bleeding out this way up. 162 */ 163 CS_ENTER_BARRIER(); 148 bool ret = !atomic_flag_test_and_set_explicit(&lock->flag, memory_order_acquire); 164 149 165 150 if (!ret) … … 176 161 bool spinlock_locked(spinlock_t *lock) 177 162 { 178 return atomic_get(&lock->val) != 0; 163 // XXX: Atomic flag doesn't support simple atomic read (by design), 164 // so instead we test_and_set and then clear if necessary. 165 // This function is only used inside assert, so we don't need 166 // any preemption_disable/enable here. 167 168 bool ret = atomic_flag_test_and_set_explicit(&lock->flag, memory_order_relaxed); 169 if (!ret) 170 atomic_flag_clear_explicit(&lock->flag, memory_order_relaxed); 171 return ret; 179 172 } 180 173
Note:
See TracChangeset
for help on using the changeset viewer.