mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-12-08 16:42:47 +00:00
[C++] rename the Thread/Mutex to cxx_Thread/Mutex to avoid same name issue
This commit is contained in:
43
components/cplusplus/cxx_Mutex.cpp
Normal file
43
components/cplusplus/cxx_Mutex.cpp
Normal file
@@ -0,0 +1,43 @@
|
||||
/*
|
||||
* Copyright (c) 2006-2018, RT-Thread Development Team
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
* Change Logs:
|
||||
* Date Author Notes
|
||||
*/
|
||||
#include "Mutex.h"
|
||||
|
||||
using namespace rtthread;
|
||||
|
||||
Mutex::Mutex(const char *name)
|
||||
{
|
||||
rt_mutex_init(&mID, name, RT_IPC_FLAG_FIFO);
|
||||
}
|
||||
|
||||
bool Mutex::lock(int32_t millisec)
|
||||
{
|
||||
rt_int32_t tick;
|
||||
|
||||
if (millisec < 0)
|
||||
tick = -1;
|
||||
else
|
||||
tick = rt_tick_from_millisecond(millisec);
|
||||
|
||||
return rt_mutex_take(&mID, tick) == RT_EOK;
|
||||
}
|
||||
|
||||
bool Mutex::trylock()
|
||||
{
|
||||
return lock(0);
|
||||
}
|
||||
|
||||
void Mutex::unlock()
|
||||
{
|
||||
rt_mutex_release(&mID);
|
||||
}
|
||||
|
||||
Mutex::~Mutex()
|
||||
{
|
||||
rt_mutex_detach(&mID);
|
||||
}
|
||||
Reference in New Issue
Block a user