aboutsummaryrefslogtreecommitdiffstats
path: root/src/framework/common/include/generic/dmm_spinlock.h
diff options
context:
space:
mode:
authornanger <zhenyinan@huawei.com>2018-08-20 11:14:15 +0800
committeryinan zhen <zhenyinan@huawei.com>2018-08-24 01:00:15 +0000
commitb63ec47559ad7b90f348dd733b805d78d156893d (patch)
tree2118aca2dd56f41972d96b7e478c00af55206d95 /src/framework/common/include/generic/dmm_spinlock.h
parent866a942c3581440bef9ebda5d84c039490bb3179 (diff)
Feat: add new share memory module
Change-Id: I25e6ca1bd3d2acc0031926e3f46d4501e8d78f1a Signed-off-by: nanger <zhenyinan@huawei.com>
Diffstat (limited to 'src/framework/common/include/generic/dmm_spinlock.h')
-rw-r--r--src/framework/common/include/generic/dmm_spinlock.h53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/framework/common/include/generic/dmm_spinlock.h b/src/framework/common/include/generic/dmm_spinlock.h
new file mode 100644
index 0000000..be183a6
--- /dev/null
+++ b/src/framework/common/include/generic/dmm_spinlock.h
@@ -0,0 +1,53 @@
+/*
+*
+* Copyright (c) 2018 Huawei Technologies Co.,Ltd.
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at:
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*/
+#ifndef _DMM_SPINLOCK_H_
+#define _DMM_SPINLOCK_H_
+
+#include "dmm_pause.h"
+
+typedef struct
+{
+ volatile int lock;
+} dmm_spinlock_t;
+
+inline static void
+dmm_spin_init (dmm_spinlock_t * spinlock)
+{
+ spinlock->lock = 0;
+}
+
+inline static void
+dmm_spin_lock (dmm_spinlock_t * spinlock)
+{
+ while (0 != __sync_lock_test_and_set (&spinlock->lock, 1))
+ {
+ DMM_PAUSE_WHILE (spinlock->lock);
+ }
+}
+
+inline static int
+dmm_spin_trylock (dmm_spinlock_t * spinlock)
+{
+ return 0 == __sync_lock_test_and_set (&spinlock->lock, 1);
+}
+
+inline static void
+dmm_spin_unlock (dmm_spinlock_t * spinlock)
+{
+ spinlock->lock = 0;
+}
+
+#endif /* #ifndef _DMM_SPINLOCK_H_ */