source: mainline/kernel/generic/include/synch/rwlock.h@ da1bafb

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since da1bafb was da1bafb, checked in by Martin Decky <martin@…>, 15 years ago

major code revision

  • replace spinlocks taken with interrupts disabled with irq_spinlocks
  • change spacing (not indendation) to be tab-size independent
  • use unsigned integer types where appropriate (especially bit flags)
  • visual separation
  • remove argument names in function prototypes
  • string changes
  • correct some formating directives
  • replace various cryptic single-character variables (t, a, m, c, b, etc.) with proper identifiers (thread, task, timeout, as, itm, itc, etc.)
  • unify some assembler constructs
  • unused page table levels are now optimized out in compile time
  • replace several ints (with boolean semantics) with bools
  • use specifically sized types instead of generic types where appropriate (size_t, uint32_t, btree_key_t)
  • improve comments
  • split asserts with conjuction into multiple independent asserts
  • Property mode set to 100644
File size: 2.9 KB
RevLine 
[f761f1eb]1/*
[df4ed85]2 * Copyright (c) 2001-2004 Jakub Jermar
[f761f1eb]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
[06e1e95]29/** @addtogroup sync
[b45c443]30 * @{
31 */
32/** @file
33 */
34
[06e1e95]35#ifndef KERN_RWLOCK_H_
36#define KERN_RWLOCK_H_
[f761f1eb]37
[d99c1d2]38#include <typedefs.h>
[f761f1eb]39#include <synch/mutex.h>
40#include <synch/synch.h>
[dc747e3]41#include <synch/spinlock.h>
[f761f1eb]42
[e71a61d]43typedef enum {
[f761f1eb]44 RWLOCK_NONE,
45 RWLOCK_READER,
46 RWLOCK_WRITER
[e71a61d]47} rwlock_type_t;
[f761f1eb]48
[e71a61d]49typedef struct {
[da1bafb]50 IRQ_SPINLOCK_DECLARE(lock);
51
[80bcaed]52 /**
53 * Mutex for writers, readers can bypass it if readers_in is positive.
[da1bafb]54 *
[80bcaed]55 */
56 mutex_t exclusive;
[da1bafb]57
[80bcaed]58 /** Number of readers in critical section. */
[98000fb]59 size_t readers_in;
[e71a61d]60} rwlock_t;
[f761f1eb]61
62#define rwlock_write_lock(rwl) \
[80bcaed]63 _rwlock_write_lock_timeout((rwl), SYNCH_NO_TIMEOUT, SYNCH_FLAGS_NONE)
[da1bafb]64
[f761f1eb]65#define rwlock_read_lock(rwl) \
[80bcaed]66 _rwlock_read_lock_timeout((rwl), SYNCH_NO_TIMEOUT, SYNCH_FLAGS_NONE)
[da1bafb]67
[f761f1eb]68#define rwlock_write_trylock(rwl) \
[80bcaed]69 _rwlock_write_lock_timeout((rwl), SYNCH_NO_TIMEOUT, \
70 SYNCH_FLAGS_NON_BLOCKING)
[da1bafb]71
[f761f1eb]72#define rwlock_read_trylock(rwl) \
[80bcaed]73 _rwlock_read_lock_timeout((rwl), SYNCH_NO_TIMEOUT, \
74 SYNCH_FLAGS_NON_BLOCKING)
[da1bafb]75
[80bcaed]76#define rwlock_write_lock_timeout(rwl, usec) \
77 _rwlock_write_lock_timeout((rwl), (usec), SYNCH_FLAGS_NONE)
[da1bafb]78
[80bcaed]79#define rwlock_read_lock_timeout(rwl, usec) \
80 _rwlock_read_lock_timeout((rwl), (usec), SYNCH_FLAGS_NONE)
[f761f1eb]81
[da1bafb]82extern void rwlock_initialize(rwlock_t *);
83extern void rwlock_read_unlock(rwlock_t *);
84extern void rwlock_write_unlock(rwlock_t *);
85extern int _rwlock_read_lock_timeout(rwlock_t *, uint32_t, unsigned int);
86extern int _rwlock_write_lock_timeout(rwlock_t *, uint32_t, unsigned int);
[f761f1eb]87
88#endif
[116d1ef4]89
[06e1e95]90/** @}
[b45c443]91 */
Note: See TracBrowser for help on using the repository browser.