sandbox: add locking primitives
This commit is contained in:
@@ -6,7 +6,7 @@ BUILD_DIR := $(SANDBOX_BASE_DIR)/../build/sandbox
|
|||||||
|
|
||||||
include $(SANDBOX_BASE_DIR)/../tools/make/gcc-host.mk
|
include $(SANDBOX_BASE_DIR)/../tools/make/gcc-host.mk
|
||||||
EXEC_NAME := sandbox
|
EXEC_NAME := sandbox
|
||||||
DIR_LIST := memblock vm base queue btree util
|
DIR_LIST := memblock vm base queue btree util locks
|
||||||
INCLUDE_DIRS := $(foreach dir,$(DIR_LIST),-I$(dir)/include)
|
INCLUDE_DIRS := $(foreach dir,$(DIR_LIST),-I$(dir)/include)
|
||||||
SRC := $(foreach dir,$(DIR_LIST),$(wildcard $(dir)/*.c))
|
SRC := $(foreach dir,$(DIR_LIST),$(wildcard $(dir)/*.c))
|
||||||
OBJ := $(addprefix $(BUILD_DIR)/,$(SRC:.c=.o))
|
OBJ := $(addprefix $(BUILD_DIR)/,$(SRC:.c=.o))
|
||||||
|
|||||||
11
sandbox/locks/include/socks/locks.h
Normal file
11
sandbox/locks/include/socks/locks.h
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
#ifndef SOCKS_LOCKS_H_
|
||||||
|
#define SOCKS_LOCKS_H_
|
||||||
|
|
||||||
|
typedef int __attribute__((aligned(8))) spin_lock_t;
|
||||||
|
|
||||||
|
#define SPIN_LOCK_INIT ((spin_lock_t)0)
|
||||||
|
|
||||||
|
extern void spin_lock_irqsave(spin_lock_t *lck, unsigned long *flags);
|
||||||
|
extern void spin_unlock_irqrestore(spin_lock_t *lck, unsigned long flags);
|
||||||
|
|
||||||
|
#endif
|
||||||
14
sandbox/locks/spinlock.c
Normal file
14
sandbox/locks/spinlock.c
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
#include <socks/locks.h>
|
||||||
|
|
||||||
|
void spin_lock_irqsave(spin_lock_t *lck, unsigned long *flags)
|
||||||
|
{
|
||||||
|
while (!__sync_bool_compare_and_swap(lck, 0, 1)) {
|
||||||
|
/* pause */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void spin_unlock_irqrestore(spin_lock_t *lck, unsigned long flags)
|
||||||
|
{
|
||||||
|
__sync_lock_release(lck);
|
||||||
|
}
|
||||||
|
|
||||||
Reference in New Issue
Block a user