hc
2024-03-22 f63cd4c03ea42695d5f9b0e1798edd196923aae6
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
35
36
37
38
39
40
41
42
43
44
45
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * Copyright (c) 2008 Intel Corporation
 * Author: Matthew Wilcox <willy@linux.intel.com>
 *
 * Please see kernel/locking/semaphore.c for documentation of these functions
 */
#ifndef __LINUX_SEMAPHORE_H
#define __LINUX_SEMAPHORE_H
 
#include <linux/list.h>
#include <linux/spinlock.h>
 
/* Please don't access any members of this structure directly */
struct semaphore {
   raw_spinlock_t        lock;
   unsigned int        count;
   struct list_head    wait_list;
};
 
#define __SEMAPHORE_INITIALIZER(name, n)                \
{                                    \
   .lock        = __RAW_SPIN_LOCK_UNLOCKED((name).lock),    \
   .count        = n,                        \
   .wait_list    = LIST_HEAD_INIT((name).wait_list),        \
}
 
#define DEFINE_SEMAPHORE(name)    \
   struct semaphore name = __SEMAPHORE_INITIALIZER(name, 1)
 
static inline void sema_init(struct semaphore *sem, int val)
{
   static struct lock_class_key __key;
   *sem = (struct semaphore) __SEMAPHORE_INITIALIZER(*sem, val);
   lockdep_init_map(&sem->lock.dep_map, "semaphore->lock", &__key, 0);
}
 
extern void down(struct semaphore *sem);
extern int __must_check down_interruptible(struct semaphore *sem);
extern int __must_check down_killable(struct semaphore *sem);
extern int __must_check down_trylock(struct semaphore *sem);
extern int __must_check down_timeout(struct semaphore *sem, long jiffies);
extern void up(struct semaphore *sem);
 
#endif /* __LINUX_SEMAPHORE_H */