Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
CriticalSectionLock.h
00001 /* 00002 * PackageLicenseDeclared: Apache-2.0 00003 * Copyright (c) 2017 ARM Limited 00004 * 00005 * Licensed under the Apache License, Version 2.0 (the "License"); 00006 * you may not use this file except in compliance with the License. 00007 * You may obtain a copy of the License at 00008 * 00009 * http://www.apache.org/licenses/LICENSE-2.0 00010 * 00011 * Unless required by applicable law or agreed to in writing, software 00012 * distributed under the License is distributed on an "AS IS" BASIS, 00013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 00014 * See the License for the specific language governing permissions and 00015 * limitations under the License. 00016 */ 00017 00018 #ifndef MBED_CRITICALSECTIONLOCK_H 00019 #define MBED_CRITICALSECTIONLOCK_H 00020 00021 #include "platform/mbed_critical.h" 00022 #include "platform/mbed_toolchain.h" 00023 00024 namespace mbed { 00025 00026 /** \addtogroup platform */ 00027 /** @{*/ 00028 /** 00029 * \defgroup platform_CriticalSectionLock CriticalSectionLock functions 00030 * @{ 00031 */ 00032 00033 /** RAII object for disabling, then restoring, interrupt state 00034 * Usage: 00035 * @code 00036 * 00037 * // RAII style usage 00038 * unsigned int atomic_counter_increment(unsigned int &counter) { 00039 * CriticalSectionLock lock; 00040 * // Code in this block will run with interrupts disabled 00041 * // Interrupts will be restored to their previous state automatically 00042 * // at the end of function scope 00043 * return ++counter; 00044 * } 00045 * 00046 * // free locking usage 00047 * unsigned int atomic_counter_decrement(unsigned int &counter) { 00048 * CriticalSectionLock::enable(); 00049 * // Code in this block will run with interrupts disabled 00050 * counter--; 00051 * CriticalSectionLock::disable(); // need explicitly to disable critical section lock 00052 * // interrupts will be restored to their previous state here 00053 * return counter; 00054 * } 00055 * 00056 * @endcode 00057 */ 00058 class CriticalSectionLock { 00059 public: 00060 CriticalSectionLock() 00061 { 00062 core_util_critical_section_enter(); 00063 } 00064 00065 ~CriticalSectionLock() 00066 { 00067 core_util_critical_section_exit(); 00068 } 00069 00070 /** Mark the start of a critical section 00071 * @deprecated This function is inconsistent with RAII and is being removed in the future. Replaced by static function CriticalSectionLock::enable. 00072 * 00073 */ 00074 MBED_DEPRECATED_SINCE("mbed-os-5.8", 00075 "This function is inconsistent with RAII and is being removed in the future." 00076 "Replaced by static function CriticalSectionLock::enable.") 00077 void lock() 00078 { 00079 core_util_critical_section_enter(); 00080 } 00081 00082 /** Mark the end of a critical section 00083 * @deprecated This function is inconsistent with RAII and is being removed in the future. Replaced by static function CriticalSectionLock::enable. 00084 * 00085 */ 00086 MBED_DEPRECATED_SINCE("mbed-os-5.8", 00087 "This function is inconsistent with RAII and is being removed in the future." 00088 "Replaced by static function CriticalSectionLock::disable.") 00089 void unlock() 00090 { 00091 core_util_critical_section_exit(); 00092 } 00093 00094 /** Mark the start of a critical section 00095 */ 00096 static void enable() 00097 { 00098 core_util_critical_section_enter(); 00099 } 00100 00101 /** Mark the end of a critical section 00102 */ 00103 static void disable() 00104 { 00105 core_util_critical_section_exit(); 00106 } 00107 }; 00108 00109 /**@}*/ 00110 00111 /**@}*/ 00112 00113 } // namespace mbed 00114 00115 #endif
Generated on Tue Jul 12 2022 14:23:32 by
