source: rtems/bsps/no_cpu/no_bsp/mpci/lock.c

Last change on this file was a3571e39, checked in by Joel Sherrill <joel@…>, on 07/11/22 at 22:26:21

bsps/no_cpu/no_bsp: Change license to BSD-2

Updates #3053.

  • Property mode set to 100644
File size: 3.1 KB
Line 
1/* SPDX-License-Identifier: BSD-2-Clause */
2
3/*  Shared Memory Lock Routines
4 *
5 *  This shared memory locked queue support routine need to be
6 *  able to lock the specified locked queue.  Interrupts are
7 *  disabled while the queue is locked to prevent preemption
8 *  and deadlock when two tasks poll for the same lock.
9 *  previous level.
10 *
11 *  COPYRIGHT (c) 1989-1999.
12 *  On-Line Applications Research Corporation (OAR).
13 *
14 * Redistribution and use in source and binary forms, with or without
15 * modification, are permitted provided that the following conditions
16 * are met:
17 * 1. Redistributions of source code must retain the above copyright
18 *    notice, this list of conditions and the following disclaimer.
19 * 2. Redistributions in binary form must reproduce the above copyright
20 *    notice, this list of conditions and the following disclaimer in the
21 *    documentation and/or other materials provided with the distribution.
22 *
23 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
24 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
27 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
28 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
29 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
30 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
31 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
32 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33 * POSSIBILITY OF SUCH DAMAGE.
34 */
35
36#include <rtems.h>
37#include <bsp.h>
38#include <shm_driver.h>
39
40/*
41 *  Shm_Initialize_lock
42 *
43 *  Initialize the lock for the specified locked queue.
44 */
45
46void Shm_Initialize_lock(
47  Shm_Locked_queue_Control *lq_cb
48)
49{
50  lq_cb->lock = LQ_UNLOCKED;
51}
52
53/*  void _Shm_Lock( &lq_cb )
54 *
55 *  This shared memory locked queue support routine locks the
56 *  specified locked queue.  It disables interrupts to prevent
57 *  a deadlock condition.
58 */
59
60void Shm_Lock(
61  Shm_Locked_queue_Control *lq_cb
62)
63{
64  uint32_t         isr_level;
65  uint32_t         *lockptr = (uint32_t*) &lq_cb->lock;
66  uint32_t         lock_value;
67
68  lock_value = 0x80000000;
69  rtems_interrupt_disable( isr_level );
70
71    Shm_isrstat = isr_level;
72    while ( lock_value ) {
73      __asm__ volatile( ""
74                         : "=r" (lockptr), "=r" (lock_value)
75                         : "0" (lockptr),  "1" (lock_value)
76                  );
77      /*
78       *  If not available, then may want to delay to reduce load on lock.
79       *
80       *  NOTE: BSP must initialize the counter facility. Delay value is BSP
81       *        dependent.
82       */
83      if ( lock_value )
84        rtems_counter_delay_nanoseconds( 100 );
85   }
86}
87
88/*
89 *  Shm_Unlock
90 *
91 *  Unlock the lock for the specified locked queue.
92 */
93
94void Shm_Unlock(
95  Shm_Locked_queue_Control *lq_cb
96)
97{
98  uint32_t         isr_level;
99
100  lq_cb->lock = SHM_UNLOCK_VALUE;
101  isr_level = Shm_isrstat;
102  rtems_interrupt_enable( isr_level );
103}
Note: See TracBrowser for help on using the repository browser.