mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-07-02 02:51:42 +00:00
[wpilib, hal] DigitalGlitchFilter: Fix sim crash and clean up construction (#6937)
Fixes error when >3 are constructed- in java, m_filterAllocated[index] would be evaluated before the bounds check and throw IndexOutOfBounds, in c++ a vague assertion error would be thrown. Makes DoAdd static in c++ Makes the error message when HAL_SetFilterSelect fails consistent with java
This commit is contained in:
@@ -25,14 +25,11 @@ std::array<bool, 3> DigitalGlitchFilter::m_filterAllocated = {
|
||||
wpi::mutex DigitalGlitchFilter::m_mutex;
|
||||
|
||||
DigitalGlitchFilter::DigitalGlitchFilter() {
|
||||
std::scoped_lock lock(m_mutex);
|
||||
auto index =
|
||||
std::find(m_filterAllocated.begin(), m_filterAllocated.end(), false);
|
||||
FRC_Assert(index != m_filterAllocated.end());
|
||||
|
||||
m_channelIndex = std::distance(m_filterAllocated.begin(), index);
|
||||
*index = true;
|
||||
|
||||
m_channelIndex = AllocateFilterIndex();
|
||||
if (m_channelIndex < 0) {
|
||||
throw FRC_MakeError(err::NoAvailableResources,
|
||||
"No filters available to allocate.");
|
||||
}
|
||||
HAL_Report(HALUsageReporting::kResourceType_DigitalGlitchFilter,
|
||||
m_channelIndex + 1);
|
||||
wpi::SendableRegistry::AddLW(this, "DigitalGlitchFilter", m_channelIndex);
|
||||
@@ -45,6 +42,18 @@ DigitalGlitchFilter::~DigitalGlitchFilter() {
|
||||
}
|
||||
}
|
||||
|
||||
int DigitalGlitchFilter::AllocateFilterIndex() {
|
||||
std::scoped_lock lock{m_mutex};
|
||||
auto filter =
|
||||
std::find(m_filterAllocated.begin(), m_filterAllocated.end(), false);
|
||||
|
||||
if (filter == m_filterAllocated.end()) {
|
||||
return -1;
|
||||
}
|
||||
*filter = true;
|
||||
return std::distance(m_filterAllocated.begin(), filter);
|
||||
}
|
||||
|
||||
void DigitalGlitchFilter::Add(DigitalSource* input) {
|
||||
DoAdd(input, m_channelIndex + 1);
|
||||
}
|
||||
@@ -67,7 +76,9 @@ void DigitalGlitchFilter::DoAdd(DigitalSource* input, int requestedIndex) {
|
||||
int actualIndex =
|
||||
HAL_GetFilterSelect(input->GetPortHandleForRouting(), &status);
|
||||
FRC_CheckErrorStatus(status, "requested index {}", requestedIndex);
|
||||
FRC_Assert(actualIndex == requestedIndex);
|
||||
FRC_AssertMessage(actualIndex == requestedIndex,
|
||||
"HAL_SetFilterSelect({}) failed -> {}", requestedIndex,
|
||||
actualIndex);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -117,12 +117,20 @@ class DigitalGlitchFilter : public wpi::Sendable,
|
||||
void InitSendable(wpi::SendableBuilder& builder) override;
|
||||
|
||||
private:
|
||||
int m_channelIndex;
|
||||
|
||||
// Sets the filter for the input to be the requested index. A value of 0
|
||||
// disables the filter, and the filter value must be between 1 and 3,
|
||||
// inclusive.
|
||||
void DoAdd(DigitalSource* input, int requested_index);
|
||||
static void DoAdd(DigitalSource* input, int requested_index);
|
||||
|
||||
/**
|
||||
* Allocates the next available filter index, or -1 if there are no filters
|
||||
* available.
|
||||
* @return the filter index
|
||||
*/
|
||||
static int AllocateFilterIndex();
|
||||
|
||||
int m_channelIndex = -1;
|
||||
static wpi::mutex m_mutex;
|
||||
static std::array<bool, 3> m_filterAllocated;
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user