xref: /OK3568_Linux_fs/external/mpp/osal/mpp_lock.cpp (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Copyright 2021 Rockchip Electronics Co. LTD
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * Licensed under the Apache License, Version 2.0 (the "License");
5*4882a593Smuzhiyun  * you may not use this file except in compliance with the License.
6*4882a593Smuzhiyun  * You may obtain a copy of the License at
7*4882a593Smuzhiyun  *
8*4882a593Smuzhiyun  *      http://www.apache.org/licenses/LICENSE-2.0
9*4882a593Smuzhiyun  *
10*4882a593Smuzhiyun  * Unless required by applicable law or agreed to in writing, software
11*4882a593Smuzhiyun  * distributed under the License is distributed on an "AS IS" BASIS,
12*4882a593Smuzhiyun  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*4882a593Smuzhiyun  * See the License for the specific language governing permissions and
14*4882a593Smuzhiyun  * limitations under the License.
15*4882a593Smuzhiyun  */
16*4882a593Smuzhiyun 
17*4882a593Smuzhiyun #define MODULE_TAG "mpp_lock"
18*4882a593Smuzhiyun 
19*4882a593Smuzhiyun #include "mpp_log.h"
20*4882a593Smuzhiyun #include "mpp_lock.h"
21*4882a593Smuzhiyun 
22*4882a593Smuzhiyun #define LOCK_IDLE   0
23*4882a593Smuzhiyun #define LOCK_BUSY   1
24*4882a593Smuzhiyun 
mpp_spinlock_init(spinlock_t * lock)25*4882a593Smuzhiyun void mpp_spinlock_init(spinlock_t *lock)
26*4882a593Smuzhiyun {
27*4882a593Smuzhiyun     MPP_SYNC_CLR(&lock->lock);
28*4882a593Smuzhiyun }
29*4882a593Smuzhiyun 
mpp_spinlock_lock(spinlock_t * lock)30*4882a593Smuzhiyun void mpp_spinlock_lock(spinlock_t *lock)
31*4882a593Smuzhiyun {
32*4882a593Smuzhiyun     while (!MPP_BOOL_CAS(&lock->lock, LOCK_IDLE, LOCK_BUSY)) {
33*4882a593Smuzhiyun         asm("NOP");
34*4882a593Smuzhiyun         asm("NOP");
35*4882a593Smuzhiyun     }
36*4882a593Smuzhiyun }
37*4882a593Smuzhiyun 
mpp_spinlock_unlock(spinlock_t * lock)38*4882a593Smuzhiyun void mpp_spinlock_unlock(spinlock_t *lock)
39*4882a593Smuzhiyun {
40*4882a593Smuzhiyun     MPP_SYNC_CLR(&lock->lock);
41*4882a593Smuzhiyun }
42*4882a593Smuzhiyun 
mpp_spinlock_trylock(spinlock_t * lock)43*4882a593Smuzhiyun bool mpp_spinlock_trylock(spinlock_t *lock)
44*4882a593Smuzhiyun {
45*4882a593Smuzhiyun     return MPP_BOOL_CAS(&lock->lock, LOCK_IDLE, LOCK_BUSY);
46*4882a593Smuzhiyun }
47