mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-22 01:11:42 +00:00
149 lines
5.3 KiB
C
149 lines
5.3 KiB
C
/*----------------------------------------------------------------------------*/
|
|
/* Copyright (c) 2016-2018 FIRST. All Rights Reserved. */
|
|
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
|
/* must be accompanied by the FIRST BSD license file in the root directory of */
|
|
/* the project. */
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
#pragma once
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "HAL/AnalogTrigger.h"
|
|
#include "HAL/Types.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
typedef void (*HAL_InterruptHandlerFunction)(uint32_t interruptAssertedMask,
|
|
void* param);
|
|
|
|
/**
|
|
* Initializes an interrupt.
|
|
*
|
|
* @param watcher true for synchronous interrupts, false for asynchronous
|
|
* @return the created interrupt handle
|
|
*/
|
|
HAL_InterruptHandle HAL_InitializeInterrupts(HAL_Bool watcher, int32_t* status);
|
|
|
|
/**
|
|
* Frees an interrupt.
|
|
*
|
|
* @param interruptHandle the interrupt handle
|
|
* @return the param passed to the interrupt, or nullptr if one
|
|
* wasn't passed.
|
|
*/
|
|
void* HAL_CleanInterrupts(HAL_InterruptHandle interruptHandle, int32_t* status);
|
|
|
|
/**
|
|
* In synchronous mode, waits for the defined interrupt to occur.
|
|
*
|
|
* @param interruptHandle the interrupt handle
|
|
* @param timeout timeout in seconds
|
|
* @param ignorePrevious if true, ignore interrupts that happened before
|
|
* waitForInterrupt was called
|
|
* @return the mask of interrupts that fired
|
|
*/
|
|
int64_t HAL_WaitForInterrupt(HAL_InterruptHandle interruptHandle,
|
|
double timeout, HAL_Bool ignorePrevious,
|
|
int32_t* status);
|
|
|
|
/**
|
|
* Enables interrupts to occur on this input.
|
|
*
|
|
* Interrupts are disabled when the RequestInterrupt call is made. This gives
|
|
* time to do the setup of the other options before starting to field
|
|
* interrupts.
|
|
*
|
|
* @param interruptHandle the interrupt handle
|
|
*/
|
|
void HAL_EnableInterrupts(HAL_InterruptHandle interruptHandle, int32_t* status);
|
|
|
|
/**
|
|
* Disables interrupts without without deallocating structures.
|
|
*
|
|
* @param interruptHandle the interrupt handle
|
|
*/
|
|
void HAL_DisableInterrupts(HAL_InterruptHandle interruptHandle,
|
|
int32_t* status);
|
|
|
|
/**
|
|
* Returns the timestamp for the rising interrupt that occurred most recently.
|
|
*
|
|
* This is in the same time domain as HAL_GetFPGATime().
|
|
*
|
|
* @param interruptHandle the interrupt handle
|
|
* @return timestamp in seconds since FPGA Initialization
|
|
*/
|
|
double HAL_ReadInterruptRisingTimestamp(HAL_InterruptHandle interruptHandle,
|
|
int32_t* status);
|
|
|
|
/**
|
|
* Returns the timestamp for the falling interrupt that occurred most recently.
|
|
*
|
|
* This is in the same time domain as HAL_GetFPGATime().
|
|
*
|
|
* @param interruptHandle the interrupt handle
|
|
* @return timestamp in seconds since FPGA Initialization
|
|
*/
|
|
double HAL_ReadInterruptFallingTimestamp(HAL_InterruptHandle interruptHandle,
|
|
int32_t* status);
|
|
|
|
/**
|
|
* Requests interrupts on a specific digital source.
|
|
*
|
|
* @param interruptHandle the interrupt handle
|
|
* @param digitalSourceHandle the digital source handle (either a
|
|
* HAL_AnalogTriggerHandle of a HAL_DigitalHandle)
|
|
* @param analogTriggerType the trigger type if the source is an AnalogTrigger
|
|
*/
|
|
void HAL_RequestInterrupts(HAL_InterruptHandle interruptHandle,
|
|
HAL_Handle digitalSourceHandle,
|
|
HAL_AnalogTriggerType analogTriggerType,
|
|
int32_t* status);
|
|
|
|
/**
|
|
* Attaches an asynchronous interrupt handler to the interrupt.
|
|
*
|
|
* This interrupt gets called directly on the FPGA interrupt thread, so will
|
|
* block other interrupts while running.
|
|
*
|
|
* @param interruptHandle the interrupt handle
|
|
* @param handler the handler function for the interrupt to call
|
|
* @param param a parameter to be passed to the handler
|
|
*/
|
|
void HAL_AttachInterruptHandler(HAL_InterruptHandle interruptHandle,
|
|
HAL_InterruptHandlerFunction handler,
|
|
void* param, int32_t* status);
|
|
|
|
/**
|
|
* Attaches an asynchronous interrupt handler to the interrupt.
|
|
*
|
|
* This interrupt gets called on a thread specific to the interrupt, so will not
|
|
* block other interrupts.
|
|
*
|
|
* @param interruptHandle the interrupt handle
|
|
* @param handler the handler function for the interrupt to call
|
|
* @param param a parameter to be passed to the handler
|
|
*/
|
|
void HAL_AttachInterruptHandlerThreaded(HAL_InterruptHandle interruptHandle,
|
|
HAL_InterruptHandlerFunction handler,
|
|
void* param, int32_t* status);
|
|
|
|
/**
|
|
* Sets the edges to trigger the interrupt on.
|
|
*
|
|
* Note that both edges triggered is a valid configuration.
|
|
*
|
|
* @param interruptHandle the interrupt handle
|
|
* @param risingEdge true for triggering on rising edge
|
|
* @param fallingEdge true for triggering on falling edge
|
|
*/
|
|
void HAL_SetInterruptUpSourceEdge(HAL_InterruptHandle interruptHandle,
|
|
HAL_Bool risingEdge, HAL_Bool fallingEdge,
|
|
int32_t* status);
|
|
#ifdef __cplusplus
|
|
} // extern "C"
|
|
#endif
|