2020-12-26 14:12:05 -08:00
|
|
|
// Copyright (c) FIRST and other WPILib contributors.
|
|
|
|
|
// Open Source Software; you can modify and/or share it under the terms of
|
|
|
|
|
// the WPILib BSD license file in the root directory of this project.
|
2019-11-01 23:41:30 -07:00
|
|
|
|
|
|
|
|
#include "hal/DutyCycle.h"
|
|
|
|
|
|
|
|
|
|
#include "HALInitializer.h"
|
|
|
|
|
#include "PortsInternal.h"
|
|
|
|
|
#include "hal/Errors.h"
|
|
|
|
|
#include "hal/handles/HandlesInternal.h"
|
|
|
|
|
#include "hal/handles/LimitedHandleResource.h"
|
|
|
|
|
#include "mockdata/DutyCycleDataInternal.h"
|
|
|
|
|
|
|
|
|
|
using namespace hal;
|
|
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
struct DutyCycle {
|
|
|
|
|
uint8_t index;
|
|
|
|
|
};
|
|
|
|
|
struct Empty {};
|
|
|
|
|
} // namespace
|
|
|
|
|
|
|
|
|
|
static LimitedHandleResource<HAL_DutyCycleHandle, DutyCycle, kNumDutyCycles,
|
|
|
|
|
HAL_HandleEnum::DutyCycle>* dutyCycleHandles;
|
|
|
|
|
|
2020-12-28 01:19:59 -08:00
|
|
|
namespace hal::init {
|
2019-11-01 23:41:30 -07:00
|
|
|
void InitializeDutyCycle() {
|
|
|
|
|
static LimitedHandleResource<HAL_DutyCycleHandle, DutyCycle, kNumDutyCycles,
|
|
|
|
|
HAL_HandleEnum::DutyCycle>
|
|
|
|
|
dcH;
|
|
|
|
|
dutyCycleHandles = &dcH;
|
|
|
|
|
}
|
2020-12-28 01:19:59 -08:00
|
|
|
} // namespace hal::init
|
2019-11-01 23:41:30 -07:00
|
|
|
|
|
|
|
|
extern "C" {
|
|
|
|
|
HAL_DutyCycleHandle HAL_InitializeDutyCycle(HAL_Handle digitalSourceHandle,
|
|
|
|
|
HAL_AnalogTriggerType triggerType,
|
|
|
|
|
int32_t* status) {
|
|
|
|
|
hal::init::CheckInit();
|
|
|
|
|
|
|
|
|
|
HAL_DutyCycleHandle handle = dutyCycleHandles->Allocate();
|
|
|
|
|
if (handle == HAL_kInvalidHandle) {
|
|
|
|
|
*status = NO_AVAILABLE_RESOURCES;
|
|
|
|
|
return HAL_kInvalidHandle;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
auto dutyCycle = dutyCycleHandles->Get(handle);
|
|
|
|
|
if (dutyCycle == nullptr) { // would only occur on thread issue
|
|
|
|
|
*status = HAL_HANDLE_ERROR;
|
|
|
|
|
return HAL_kInvalidHandle;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int16_t index = getHandleIndex(handle);
|
|
|
|
|
SimDutyCycleData[index].digitalChannel = getHandleIndex(digitalSourceHandle);
|
|
|
|
|
SimDutyCycleData[index].initialized = true;
|
|
|
|
|
SimDutyCycleData[index].simDevice = 0;
|
|
|
|
|
dutyCycle->index = index;
|
|
|
|
|
return handle;
|
|
|
|
|
}
|
|
|
|
|
void HAL_FreeDutyCycle(HAL_DutyCycleHandle dutyCycleHandle) {
|
|
|
|
|
auto dutyCycle = dutyCycleHandles->Get(dutyCycleHandle);
|
|
|
|
|
dutyCycleHandles->Free(dutyCycleHandle);
|
2020-12-28 12:58:06 -08:00
|
|
|
if (dutyCycle == nullptr) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
2019-11-01 23:41:30 -07:00
|
|
|
SimDutyCycleData[dutyCycle->index].initialized = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void HAL_SetDutyCycleSimDevice(HAL_EncoderHandle handle,
|
|
|
|
|
HAL_SimDeviceHandle device) {
|
|
|
|
|
auto dutyCycle = dutyCycleHandles->Get(handle);
|
2020-12-28 12:58:06 -08:00
|
|
|
if (dutyCycle == nullptr) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
2019-11-01 23:41:30 -07:00
|
|
|
SimDutyCycleData[dutyCycle->index].simDevice = device;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int32_t HAL_GetDutyCycleFrequency(HAL_DutyCycleHandle dutyCycleHandle,
|
|
|
|
|
int32_t* status) {
|
|
|
|
|
auto dutyCycle = dutyCycleHandles->Get(dutyCycleHandle);
|
|
|
|
|
if (dutyCycle == nullptr) {
|
|
|
|
|
*status = HAL_HANDLE_ERROR;
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
return SimDutyCycleData[dutyCycle->index].frequency;
|
|
|
|
|
}
|
|
|
|
|
double HAL_GetDutyCycleOutput(HAL_DutyCycleHandle dutyCycleHandle,
|
|
|
|
|
int32_t* status) {
|
|
|
|
|
auto dutyCycle = dutyCycleHandles->Get(dutyCycleHandle);
|
|
|
|
|
if (dutyCycle == nullptr) {
|
|
|
|
|
*status = HAL_HANDLE_ERROR;
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
return SimDutyCycleData[dutyCycle->index].output;
|
|
|
|
|
}
|
|
|
|
|
int32_t HAL_GetDutyCycleOutputRaw(HAL_DutyCycleHandle dutyCycleHandle,
|
|
|
|
|
int32_t* status) {
|
|
|
|
|
auto dutyCycle = dutyCycleHandles->Get(dutyCycleHandle);
|
|
|
|
|
if (dutyCycle == nullptr) {
|
|
|
|
|
*status = HAL_HANDLE_ERROR;
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
return SimDutyCycleData[dutyCycle->index].output *
|
|
|
|
|
HAL_GetDutyCycleOutputScaleFactor(dutyCycleHandle, status);
|
|
|
|
|
}
|
|
|
|
|
int32_t HAL_GetDutyCycleOutputScaleFactor(HAL_DutyCycleHandle dutyCycleHandle,
|
|
|
|
|
int32_t* status) {
|
|
|
|
|
return 4e7 - 1;
|
|
|
|
|
}
|
|
|
|
|
int32_t HAL_GetDutyCycleFPGAIndex(HAL_DutyCycleHandle dutyCycleHandle,
|
|
|
|
|
int32_t* status) {
|
|
|
|
|
auto dutyCycle = dutyCycleHandles->Get(dutyCycleHandle);
|
|
|
|
|
if (dutyCycle == nullptr) {
|
|
|
|
|
*status = HAL_HANDLE_ERROR;
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
return dutyCycle->index;
|
|
|
|
|
}
|
|
|
|
|
} // extern "C"
|