source: mainline/generic/include/synch/spinlock.h@ 248fc1a

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 248fc1a was 80d2bdb, checked in by Ondrej Palkovsky <ondrap@…>, 20 years ago

We are now almost -Wall clean.

  • redefined atomic_t
  • deleted many, many unused variables
  • some minor code cleanups found using compiler warning.
  • Property mode set to 100644
File size: 2.7 KB
RevLine 
[f761f1eb]1/*
2 * Copyright (C) 2001-2004 Jakub Jermar
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29#ifndef __SPINLOCK_H__
30#define __SPINLOCK_H__
31
32#include <arch/types.h>
33#include <typedefs.h>
[c842f04]34#include <preemption.h>
[80d2bdb]35#include <arch/atomic.h>
[f761f1eb]36
[5f85c91]37#ifdef CONFIG_SMP
[f761f1eb]38struct spinlock {
[2d93f1f9]39#ifdef CONFIG_DEBUG_SPINLOCK
40 char *name;
41#endif
[80d2bdb]42 atomic_t val;
[f761f1eb]43};
44
[dc747e3]45/*
46 * SPINLOCK_DECLARE is to be used for dynamically allocated spinlocks,
47 * where the lock gets initialized in run time.
48 */
49#define SPINLOCK_DECLARE(slname) spinlock_t slname
50
51/*
52 * SPINLOCK_INITIALIZE is to be used for statically allocated spinlocks.
53 * It declares and initializes the lock.
54 */
55#ifdef CONFIG_DEBUG_SPINLOCK
56#define SPINLOCK_INITIALIZE(slname) \
57 spinlock_t slname = { \
58 .name = #slname, \
[80d2bdb]59 .val = { 0 } \
[dc747e3]60 }
61#else
62#define SPINLOCK_INITIALIZE(slname) \
63 spinlock_t slname = { \
[80d2bdb]64 .val = { 0 } \
[dc747e3]65 }
66#endif
67
[2d93f1f9]68extern void spinlock_initialize(spinlock_t *sl, char *name);
[f761f1eb]69extern void spinlock_lock(spinlock_t *sl);
70extern int spinlock_trylock(spinlock_t *sl);
71extern void spinlock_unlock(spinlock_t *sl);
72
73#else
74
[dc747e3]75/* On UP systems, spinlocks are effectively left out. */
76#define SPINLOCK_DECLARE(name)
77#define SPINLOCK_INITIALIZE(name)
[f761f1eb]78
[a80d406]79#define spinlock_initialize(x,name)
[c842f04]80#define spinlock_lock(x) preemption_disable()
81#define spinlock_trylock(x) (preemption_disable(), 1)
82#define spinlock_unlock(x) preemption_enable()
[f761f1eb]83
84#endif
85
86#endif
Note: See TracBrowser for help on using the repository browser.