mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-22 01:11:42 +00:00
Change hal sim to use spinlocks (#1291)
This makes callback registration completely thread safe. This patch also uses templates and macros to dramatically reduce the amount of manual boilerplate.
This commit is contained in:
@@ -7,7 +7,6 @@
|
||||
|
||||
#include "../PortsInternal.h"
|
||||
#include "AnalogTriggerDataInternal.h"
|
||||
#include "mockdata/NotifyCallbackHelpers.h"
|
||||
|
||||
using namespace hal;
|
||||
|
||||
@@ -22,160 +21,10 @@ void InitializeAnalogTriggerData() {
|
||||
|
||||
AnalogTriggerData* hal::SimAnalogTriggerData;
|
||||
void AnalogTriggerData::ResetData() {
|
||||
m_initialized = 0;
|
||||
m_initializedCallbacks = nullptr;
|
||||
m_triggerLowerBound = 0;
|
||||
m_triggerLowerBoundCallbacks = nullptr;
|
||||
m_triggerUpperBound = 0;
|
||||
m_triggerUpperBoundCallbacks = nullptr;
|
||||
m_triggerMode = static_cast<HALSIM_AnalogTriggerMode>(0);
|
||||
m_triggerModeCallbacks = nullptr;
|
||||
}
|
||||
|
||||
int32_t AnalogTriggerData::RegisterInitializedCallback(
|
||||
HAL_NotifyCallback callback, void* param, HAL_Bool initialNotify) {
|
||||
// Must return -1 on a null callback for error handling
|
||||
if (callback == nullptr) return -1;
|
||||
int32_t newUid = 0;
|
||||
{
|
||||
std::lock_guard<wpi::mutex> lock(m_registerMutex);
|
||||
m_initializedCallbacks = RegisterCallback(
|
||||
m_initializedCallbacks, "Initialized", callback, param, &newUid);
|
||||
}
|
||||
if (initialNotify) {
|
||||
// We know that the callback is not null because of earlier null check
|
||||
HAL_Value value = MakeBoolean(GetInitialized());
|
||||
callback("Initialized", param, &value);
|
||||
}
|
||||
return newUid;
|
||||
}
|
||||
|
||||
void AnalogTriggerData::CancelInitializedCallback(int32_t uid) {
|
||||
m_initializedCallbacks = CancelCallback(m_initializedCallbacks, uid);
|
||||
}
|
||||
|
||||
void AnalogTriggerData::InvokeInitializedCallback(HAL_Value value) {
|
||||
InvokeCallback(m_initializedCallbacks, "Initialized", &value);
|
||||
}
|
||||
|
||||
HAL_Bool AnalogTriggerData::GetInitialized() { return m_initialized; }
|
||||
|
||||
void AnalogTriggerData::SetInitialized(HAL_Bool initialized) {
|
||||
HAL_Bool oldValue = m_initialized.exchange(initialized);
|
||||
if (oldValue != initialized) {
|
||||
InvokeInitializedCallback(MakeBoolean(initialized));
|
||||
}
|
||||
}
|
||||
|
||||
int32_t AnalogTriggerData::RegisterTriggerLowerBoundCallback(
|
||||
HAL_NotifyCallback callback, void* param, HAL_Bool initialNotify) {
|
||||
// Must return -1 on a null callback for error handling
|
||||
if (callback == nullptr) return -1;
|
||||
int32_t newUid = 0;
|
||||
{
|
||||
std::lock_guard<wpi::mutex> lock(m_registerMutex);
|
||||
m_triggerLowerBoundCallbacks =
|
||||
RegisterCallback(m_triggerLowerBoundCallbacks, "TriggerLowerBound",
|
||||
callback, param, &newUid);
|
||||
}
|
||||
if (initialNotify) {
|
||||
// We know that the callback is not null because of earlier null check
|
||||
HAL_Value value = MakeDouble(GetTriggerLowerBound());
|
||||
callback("TriggerLowerBound", param, &value);
|
||||
}
|
||||
return newUid;
|
||||
}
|
||||
|
||||
void AnalogTriggerData::CancelTriggerLowerBoundCallback(int32_t uid) {
|
||||
m_triggerLowerBoundCallbacks =
|
||||
CancelCallback(m_triggerLowerBoundCallbacks, uid);
|
||||
}
|
||||
|
||||
void AnalogTriggerData::InvokeTriggerLowerBoundCallback(HAL_Value value) {
|
||||
InvokeCallback(m_triggerLowerBoundCallbacks, "TriggerLowerBound", &value);
|
||||
}
|
||||
|
||||
double AnalogTriggerData::GetTriggerLowerBound() { return m_triggerLowerBound; }
|
||||
|
||||
void AnalogTriggerData::SetTriggerLowerBound(double triggerLowerBound) {
|
||||
double oldValue = m_triggerLowerBound.exchange(triggerLowerBound);
|
||||
if (oldValue != triggerLowerBound) {
|
||||
InvokeTriggerLowerBoundCallback(MakeDouble(triggerLowerBound));
|
||||
}
|
||||
}
|
||||
|
||||
int32_t AnalogTriggerData::RegisterTriggerUpperBoundCallback(
|
||||
HAL_NotifyCallback callback, void* param, HAL_Bool initialNotify) {
|
||||
// Must return -1 on a null callback for error handling
|
||||
if (callback == nullptr) return -1;
|
||||
int32_t newUid = 0;
|
||||
{
|
||||
std::lock_guard<wpi::mutex> lock(m_registerMutex);
|
||||
m_triggerUpperBoundCallbacks =
|
||||
RegisterCallback(m_triggerUpperBoundCallbacks, "TriggerUpperBound",
|
||||
callback, param, &newUid);
|
||||
}
|
||||
if (initialNotify) {
|
||||
// We know that the callback is not null because of earlier null check
|
||||
HAL_Value value = MakeDouble(GetTriggerUpperBound());
|
||||
callback("TriggerUpperBound", param, &value);
|
||||
}
|
||||
return newUid;
|
||||
}
|
||||
|
||||
void AnalogTriggerData::CancelTriggerUpperBoundCallback(int32_t uid) {
|
||||
m_triggerUpperBoundCallbacks =
|
||||
CancelCallback(m_triggerUpperBoundCallbacks, uid);
|
||||
}
|
||||
|
||||
void AnalogTriggerData::InvokeTriggerUpperBoundCallback(HAL_Value value) {
|
||||
InvokeCallback(m_triggerUpperBoundCallbacks, "TriggerUpperBound", &value);
|
||||
}
|
||||
|
||||
double AnalogTriggerData::GetTriggerUpperBound() { return m_triggerUpperBound; }
|
||||
|
||||
void AnalogTriggerData::SetTriggerUpperBound(double triggerUpperBound) {
|
||||
double oldValue = m_triggerUpperBound.exchange(triggerUpperBound);
|
||||
if (oldValue != triggerUpperBound) {
|
||||
InvokeTriggerUpperBoundCallback(MakeDouble(triggerUpperBound));
|
||||
}
|
||||
}
|
||||
|
||||
int32_t AnalogTriggerData::RegisterTriggerModeCallback(
|
||||
HAL_NotifyCallback callback, void* param, HAL_Bool initialNotify) {
|
||||
// Must return -1 on a null callback for error handling
|
||||
if (callback == nullptr) return -1;
|
||||
int32_t newUid = 0;
|
||||
{
|
||||
std::lock_guard<wpi::mutex> lock(m_registerMutex);
|
||||
m_triggerModeCallbacks = RegisterCallback(
|
||||
m_triggerModeCallbacks, "TriggerMode", callback, param, &newUid);
|
||||
}
|
||||
if (initialNotify) {
|
||||
// We know that the callback is not null because of earlier null check
|
||||
HAL_Value value = MakeEnum(GetTriggerMode());
|
||||
callback("TriggerMode", param, &value);
|
||||
}
|
||||
return newUid;
|
||||
}
|
||||
|
||||
void AnalogTriggerData::CancelTriggerModeCallback(int32_t uid) {
|
||||
m_triggerModeCallbacks = CancelCallback(m_triggerModeCallbacks, uid);
|
||||
}
|
||||
|
||||
void AnalogTriggerData::InvokeTriggerModeCallback(HAL_Value value) {
|
||||
InvokeCallback(m_triggerModeCallbacks, "TriggerMode", &value);
|
||||
}
|
||||
|
||||
HALSIM_AnalogTriggerMode AnalogTriggerData::GetTriggerMode() {
|
||||
return m_triggerMode;
|
||||
}
|
||||
|
||||
void AnalogTriggerData::SetTriggerMode(HALSIM_AnalogTriggerMode triggerMode) {
|
||||
HALSIM_AnalogTriggerMode oldValue = m_triggerMode.exchange(triggerMode);
|
||||
if (oldValue != triggerMode) {
|
||||
InvokeTriggerModeCallback(MakeEnum(triggerMode));
|
||||
}
|
||||
initialized.Reset(0);
|
||||
triggerLowerBound.Reset(0);
|
||||
triggerUpperBound.Reset(0);
|
||||
triggerMode.Reset(static_cast<HALSIM_AnalogTriggerMode>(0));
|
||||
}
|
||||
|
||||
extern "C" {
|
||||
@@ -183,98 +32,26 @@ void HALSIM_ResetAnalogTriggerData(int32_t index) {
|
||||
SimAnalogTriggerData[index].ResetData();
|
||||
}
|
||||
|
||||
int32_t HALSIM_RegisterAnalogTriggerInitializedCallback(
|
||||
int32_t index, HAL_NotifyCallback callback, void* param,
|
||||
HAL_Bool initialNotify) {
|
||||
return SimAnalogTriggerData[index].RegisterInitializedCallback(
|
||||
callback, param, initialNotify);
|
||||
}
|
||||
#define DEFINE_CAPI(TYPE, CAPINAME, LOWERNAME) \
|
||||
HAL_SIMDATAVALUE_DEFINE_CAPI(TYPE, HALSIM, AnalogTrigger##CAPINAME, \
|
||||
SimAnalogTriggerData, LOWERNAME)
|
||||
|
||||
void HALSIM_CancelAnalogTriggerInitializedCallback(int32_t index, int32_t uid) {
|
||||
SimAnalogTriggerData[index].CancelInitializedCallback(uid);
|
||||
}
|
||||
DEFINE_CAPI(HAL_Bool, Initialized, initialized)
|
||||
DEFINE_CAPI(double, TriggerLowerBound, triggerLowerBound)
|
||||
DEFINE_CAPI(double, TriggerUpperBound, triggerUpperBound)
|
||||
DEFINE_CAPI(HALSIM_AnalogTriggerMode, TriggerMode, triggerMode)
|
||||
|
||||
HAL_Bool HALSIM_GetAnalogTriggerInitialized(int32_t index) {
|
||||
return SimAnalogTriggerData[index].GetInitialized();
|
||||
}
|
||||
|
||||
void HALSIM_SetAnalogTriggerInitialized(int32_t index, HAL_Bool initialized) {
|
||||
SimAnalogTriggerData[index].SetInitialized(initialized);
|
||||
}
|
||||
|
||||
int32_t HALSIM_RegisterAnalogTriggerTriggerLowerBoundCallback(
|
||||
int32_t index, HAL_NotifyCallback callback, void* param,
|
||||
HAL_Bool initialNotify) {
|
||||
return SimAnalogTriggerData[index].RegisterTriggerLowerBoundCallback(
|
||||
callback, param, initialNotify);
|
||||
}
|
||||
|
||||
void HALSIM_CancelAnalogTriggerTriggerLowerBoundCallback(int32_t index,
|
||||
int32_t uid) {
|
||||
SimAnalogTriggerData[index].CancelTriggerLowerBoundCallback(uid);
|
||||
}
|
||||
|
||||
double HALSIM_GetAnalogTriggerTriggerLowerBound(int32_t index) {
|
||||
return SimAnalogTriggerData[index].GetTriggerLowerBound();
|
||||
}
|
||||
|
||||
void HALSIM_SetAnalogTriggerTriggerLowerBound(int32_t index,
|
||||
double triggerLowerBound) {
|
||||
SimAnalogTriggerData[index].SetTriggerLowerBound(triggerLowerBound);
|
||||
}
|
||||
|
||||
int32_t HALSIM_RegisterAnalogTriggerTriggerUpperBoundCallback(
|
||||
int32_t index, HAL_NotifyCallback callback, void* param,
|
||||
HAL_Bool initialNotify) {
|
||||
return SimAnalogTriggerData[index].RegisterTriggerUpperBoundCallback(
|
||||
callback, param, initialNotify);
|
||||
}
|
||||
|
||||
void HALSIM_CancelAnalogTriggerTriggerUpperBoundCallback(int32_t index,
|
||||
int32_t uid) {
|
||||
SimAnalogTriggerData[index].CancelTriggerUpperBoundCallback(uid);
|
||||
}
|
||||
|
||||
double HALSIM_GetAnalogTriggerTriggerUpperBound(int32_t index) {
|
||||
return SimAnalogTriggerData[index].GetTriggerUpperBound();
|
||||
}
|
||||
|
||||
void HALSIM_SetAnalogTriggerTriggerUpperBound(int32_t index,
|
||||
double triggerUpperBound) {
|
||||
SimAnalogTriggerData[index].SetTriggerUpperBound(triggerUpperBound);
|
||||
}
|
||||
|
||||
int32_t HALSIM_RegisterAnalogTriggerTriggerModeCallback(
|
||||
int32_t index, HAL_NotifyCallback callback, void* param,
|
||||
HAL_Bool initialNotify) {
|
||||
return SimAnalogTriggerData[index].RegisterTriggerModeCallback(
|
||||
callback, param, initialNotify);
|
||||
}
|
||||
|
||||
void HALSIM_CancelAnalogTriggerTriggerModeCallback(int32_t index, int32_t uid) {
|
||||
SimAnalogTriggerData[index].CancelTriggerModeCallback(uid);
|
||||
}
|
||||
|
||||
HALSIM_AnalogTriggerMode HALSIM_GetAnalogTriggerTriggerMode(int32_t index) {
|
||||
return SimAnalogTriggerData[index].GetTriggerMode();
|
||||
}
|
||||
|
||||
void HALSIM_SetAnalogTriggerTriggerMode(int32_t index,
|
||||
HALSIM_AnalogTriggerMode triggerMode) {
|
||||
SimAnalogTriggerData[index].SetTriggerMode(triggerMode);
|
||||
}
|
||||
#define REGISTER(NAME) \
|
||||
SimAnalogTriggerData[index].NAME.RegisterCallback(callback, param, \
|
||||
initialNotify)
|
||||
|
||||
void HALSIM_RegisterAnalogTriggerAllCallbacks(int32_t index,
|
||||
HAL_NotifyCallback callback,
|
||||
void* param,
|
||||
HAL_Bool initialNotify) {
|
||||
SimAnalogTriggerData[index].RegisterInitializedCallback(callback, param,
|
||||
initialNotify);
|
||||
SimAnalogTriggerData[index].RegisterTriggerLowerBoundCallback(callback, param,
|
||||
initialNotify);
|
||||
SimAnalogTriggerData[index].RegisterTriggerUpperBoundCallback(callback, param,
|
||||
initialNotify);
|
||||
SimAnalogTriggerData[index].RegisterTriggerModeCallback(callback, param,
|
||||
initialNotify);
|
||||
REGISTER(initialized);
|
||||
REGISTER(triggerLowerBound);
|
||||
REGISTER(triggerUpperBound);
|
||||
REGISTER(triggerMode);
|
||||
}
|
||||
} // extern "C"
|
||||
|
||||
Reference in New Issue
Block a user