PeripheralDriver_AutoChips_.../inc/pct_drv.h

340 lines
12 KiB
C

/* Copyright Statement:
*
* This software/firmware and related documentation ("AutoChips Software") are
* protected under relevant copyright laws. The information contained herein is
* confidential and proprietary to AutoChips Inc. and/or its licensors. Without
* the prior written psramission of AutoChips inc. and/or its licensors, any
* reproduction, modification, use or disclosure of AutoChips Software, and
* information contained herein, in whole or in part, shall be strictly
* prohibited.
*
* AutoChips Inc. (C) 2021. All rights reserved.
*
* BY OPENING THIS FILE, RECEIVER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
* THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("AUTOCHIPS SOFTWARE")
* RECEIVED FROM AUTOCHIPS AND/OR ITS REPRESENTATIVES ARE PROVIDED TO RECEIVER
* ON AN "AS-IS" BASIS ONLY. AUTOCHIPS EXPRESSLY DISCLAIMS ANY AND ALL
* WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED
* WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR
* NONINFRINGEMENT. NEITHER DOES AUTOCHIPS PROVIDE ANY WARRANTY WHATSOEVER WITH
* RESPECT TO THE SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY,
* INCORPORATED IN, OR SUPPLIED WITH THE AUTOCHIPS SOFTWARE, AND RECEIVER AGREES
* TO LOOK ONLY TO SUCH THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO.
* RECEIVER EXPRESSLY ACKNOWLEDGES THAT IT IS RECEIVER'S SOLE RESPONSIBILITY TO
* OBTAIN FROM ANY THIRD PARTY ALL PROPER LICENSES CONTAINED IN AUTOCHIPS
* SOFTWARE. AUTOCHIPS SHALL ALSO NOT BE RESPONSIBLE FOR ANY AUTOCHIPS SOFTWARE
* RELEASES MADE TO RECEIVER'S SPECIFICATION OR TO CONFORM TO A PARTICULAR
* STANDARD OR OPEN FORUM. RECEIVER'S SOLE AND EXCLUSIVE REMEDY AND AUTOCHIPS'S
* ENTIRE AND CUMULATIVE LIABILITY WITH RESPECT TO THE AUTOCHIPS SOFTWARE
* RELEASED HEREUNDER WILL BE, AT AUTOCHIPS'S OPTION, TO REVISE OR REPLACE THE
* AUTOCHIPS SOFTWARE AT ISSUE, OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE
* CHARGE PAID BY RECEIVER TO AUTOCHIPS FOR SUCH AUTOCHIPS SOFTWARE AT ISSUE.
*/
/*!
* @file pct_drv.h
*
* @brief This file provides pct functions interface.
*
*/
/* PRQA S 3630 EOF */ /* struct/union type will be used by user app. */
#ifndef PCT_DRV_H
#define PCT_DRV_H
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
/* =========================================== Includes =========================================== */
#include "device_register.h"
/*=====================================SOURCE FILE VERSION INFORMATION==============================*/
#define PCT_HAL_MODULE_ID (44U)
#define PCT_HAL_SW_MAJOR_VERSION (1U)
#define PCT_HAL_SW_MINOR_VERSION (2U)
#define PCT_HAL_SW_PATCH_VERSION (0U)
/* ============================================ Define ============================================ */
/* =========================================== Typedef ============================================ */
/*!< Callback for PCT module */
typedef void (*pct_callback_t)(void *device, uint32_t wpara, uint32_t lpara);
/*!
* @brief Input Pulse selection
*/
typedef enum
{
PCT_PINSELECT_TRGMUX = 0x00U, /*!< pulse from TRGMUX trigger */
PCT_PINSELECT_ALT1 = 0x01U, /*!< pulse from pin 1 */
PCT_PINSELECT_ALT2 = 0x02U, /*!< pulse from pin 2 */
PCT_PINSELECT_ALT3 = 0x03U /*!< pulse from pin 3 */
}pct_pinselect_t;
/*!
* @brief Pulse count polarity
*/
typedef enum
{
PCT_PINPOLARITY_RISING = 0U, /*!< Count pulse on rising edge */
PCT_PINPOLARITY_FALLING = 1U /*!< Count pulse on falling edge */
} pct_pinpolarity_t;
/*!
* @brief PCT count Mode
*/
typedef enum
{
PCT_WORKMODE_TIMER = 0U, /*!< Time counter */
PCT_WORKMODE_PULSECOUNTER = 1U /*!< Pulse counter */
} pct_workmode_t;
/*!
* @brief Prescaler & filter Selection
*/
typedef enum
{
PCT_PRESCALE_2 = 0x00U, /*!< Time mode: prescaler 2, Filter mode: invalid */
PCT_PRESCALE_4_GLITCHFILTER_2 = 0x01U, /*!< Time mode: prescaler 4, Filter mode: 2 clocks */
PCT_PRESCALE_8_GLITCHFILTER_4 = 0x02U, /*!< Time mode: prescaler 8, Filter mode: 4 clocks */
PCT_PRESCALE_16_GLITCHFILTER_8 = 0x03U, /*!< Time mode: prescaler 16, Filter mode: 8 clocks */
PCT_PRESCALE_32_GLITCHFILTER_16 = 0x04U, /*!< Time mode: prescaler 32, Filter mode: 16 clocks */
PCT_PRESCALE_64_GLITCHFILTER_32 = 0x05U, /*!< Time mode: prescaler 64, Filter mode: 32 clocks */
PCT_PRESCALE_128_GLITCHFILTER_64 = 0x06U, /*!< Time mode: prescaler 128, Filter mode: 64 clocks */
PCT_PRESCALE_256_GLITCHFILTER_128 = 0x07U, /*!< Time mode: prescaler 256, Filter mode: 128 clocks */
PCT_PRESCALE_512_GLITCHFILTER_256 = 0x08U, /*!< Time mode: prescaler 512, Filter mode: 256 clocks */
PCT_PRESCALE_1024_GLITCHFILTER_512 = 0x09U, /*!< Time mode: prescaler 1024, Filter mode: 512 clocks */
PCT_PRESCALE_2048_GLITCHFILTER_1024 = 0x0AU, /*!< Time mode: prescaler 2048, Filter mode: 1024 clocks */
PCT_PRESCALE_4096_GLITCHFILTER_2048 = 0x0BU, /*!< Time mode: prescaler 4096, Filter mode: 2048 clocks */
PCT_PRESCALE_8192_GLITCHFILTER_4096 = 0x0CU, /*!< Time mode: prescaler 8192, Filter mode: 4096 clocks */
PCT_PRESCALE_16384_GLITCHFILTER_8192 = 0x0DU, /*!< Time mode: prescaler 16384, Filter mode: 8192 clocks */
PCT_PRESCALE_32768_GLITCHFILTER_16384 = 0x0EU, /*!< Time mode: prescaler 32768, Filter mode: 16384 clocks */
PCT_PRESCALE_65536_GLITCHFILTER_32768 = 0x0FU /*!< Time mode: prescaler 65536, Filter mode: 32768 clocks */
} pct_prescaler_t;
/*!
* @brief pct cval read presicion sel
*/
typedef enum
{
PCT_BCLK_FCLK_4 = 0x00U, /*!< BUSCLK/FUNCTION CLK >= 4 */
PCT_BCLK_FCLK_3 = 0x01U, /*!< BUSCLK/FUNCTION CLK >= 3 */
PCT_BCLK_FCLK_1 = 0x02U, /*!< BUSCLK/FUNCTION CLK >= 1 */
} pct_sel_t;
/*!
* @brief Clock source selection
*/
typedef enum
{
PCT_CLOCKSOURCE_HSIDIV2 = 0x00U, /*!< HSIDIV2 clock */
PCT_CLOCKSOURCE_LSI1K = 0x01U, /*!< LSI1K clock */
PCT_CLOCKSOURCE_RTC = 0x02U, /*!< RTC clock */
PCT_CLOCKSOURCE_PCC = 0x03U /*!< PCC configured clock */
} pct_clocksource_t;
/*!
* @brief PCT counter units
*/
typedef enum
{
PCT_COUNTER_UNITS_TICKS = 0x00U,
PCT_COUNTER_UNITS_MICROSECONDS = 0x01U
} pct_counter_units_t;
/*!
* @brief Configuration structure for PCT
*/
typedef struct
{
bool interruptEnable; /*!< Enable/Disable Interrupt */
bool freeRun; /*!< Enable/Disable Free Running Mode */
pct_workmode_t workMode; /*!< Time/Pulse Counter Mode */
pct_clocksource_t clockSelect; /*!< Clock source selection */
pct_prescaler_t prescaler; /*!< Prescaler & filter Selection */
pct_sel_t cvalreadsel; /*!< Read Cval presicison sel */
bool bypassPrescaler; /*!< Enable/Disable prescaler & fliter bypass */
uint32_t compareValue; /*!< Compare value */
pct_counter_units_t counterUnits; /*!< Compare value units */
pct_pinselect_t pinSelect; /*!< Pin selection for Pulse-Count mode */
pct_pinpolarity_t pinPolarity; /*!< Pin Polarity for Pulse-Count mode */
pct_callback_t callback; /*!< call back function */
} pct_config_t;
/* ========================================== Variables =========================================== */
/* ==================================== Functions declaration ===================================== */
/*!
* @brief Initializes configuration structure to default values.
*
* @param[out] config: the configuration structure to be initialized
* @return none
*/
void PCT_DRV_InitConfigStruct(pct_config_t *const config);
/*!
* @brief Initializes PCT.
*
* @param[in] instance: instance number of PCT
* @param[in] config: the configuration structure
* @param[in] startCounter: starting counting control
* @return none
*/
void PCT_DRV_Init(const uint8_t instance, const pct_config_t *const config, const bool startCounter);
/*!
* @brief Configure PCT.
*
* @param[in] instance: instance number of PCT
* @param[in] config: the configuration structure
* @return none
*/
void PCT_DRV_SetConfig(const uint8_t instance, const pct_config_t *const config);
/*!
* @brief Gets the configuration of PCT.
*
* @param[in] instance: instance number of PCT
* @param[out] config: the configuration structure to get
* @return none
*/
void PCT_DRV_GetConfig(const uint8_t instance, pct_config_t *const config);
/*!
* @brief De-initialize PCT.
*
* @param[in] instance: instance number of PCT
* @return none
*/
void PCT_DRV_Deinit(const uint8_t instance);
/*!
* @brief Sets the compare value in counter unit.
*
* @param[in] instance: instance number of PCT
* @param[in] compareValueByCount: The compare value in counter ticks
* @return Operation status
*/
status_t PCT_DRV_SetCompareValueByCount(const uint8_t instance, const uint16_t compareValueByCount);
/*!
* @brief Gets the compare value in counter tick units.
*
* @param[in] instance: instance number of PCT
* @param[out] compareValueByCount: current compare value in counter ticks
* @return none
*/
void PCT_DRV_GetCompareValueByCount(const uint8_t instance, uint16_t *const compareValueByCount);
/*!
* @brief Sets the compare value in microseconds unit.
*
* @param[in] instance: instance number of PCT
* @param[in] compareValueUs: Compare value in microseconds unit
* @return Operation status
*/
status_t PCT_DRV_SetCompareValueByUs(const uint8_t instance, const uint32_t compareValueUs);
/*!
* @brief Gets the compare value in microseconds.
*
* @param[in] instance: instance number of PCT
* @param[out] compareValueUs: current compare value in microseconds
* @return none
*/
void PCT_DRV_GetCompareValueByUs(const uint8_t instance, uint32_t *const compareValueUs);
/*!
* @brief Gets the compare flag of PCT.
*
* @param[in] instance: instance number of PCT
* @return the compare flag
*/
bool PCT_DRV_GetCompareFlag(const uint8_t instance);
/*!
* @brief Clears the compare flag of PCT.
*
* @param[in] instance: instance number of PCT
* @return none
*/
void PCT_DRV_ClearCompareFlag(const uint8_t instance);
/*!
* @brief Gets if PCT is running.
*
* @param[in] instance: instance number of PCT
* @return The running state of PCT
*/
bool PCT_DRV_IsRunning(const uint8_t instance);
/*!
* @brief Enable/disable PCT interrupt.
*
* @param[in] instance: instance number of PCT
* @param[in] enableInterrupt: The PCT interrupt enable flag
* @return none
*/
void PCT_DRV_SetInterrupt(const uint8_t instance, const bool enableInterrupt);
/*!
* @brief Gets the current counter value in counter units.
*
* @param[in] instance: instance number of PCT
* @return The current counter value
*/
uint16_t PCT_DRV_GetCounterValueByCount(const uint8_t instance);
/*!
* @brief Starts the counter.
*
* @param[in] instance: instance number of PCT
* @return none
*/
void PCT_DRV_StartCounter(const uint8_t instance);
/*!
* @brief Stops the counter.
*
* @param[in] instance: instance number of PCT
* @return none
*/
void PCT_DRV_StopCounter(const uint8_t instance);
/*!
* @brief Sets the Input Pin configuration for Pulse Count mode.
*
* @param[in] instance: instance number of PCT
* @param[in] pinSelect: PCT pin selection
* @param[in] pinPolarity: Polarity of counting pin(at rising/falling edge)
* @return none
*/
void PCT_DRV_SetPinConfiguration(const uint8_t instance, const pct_pinselect_t pinSelect,
const pct_pinpolarity_t pinPolarity);
/*!
* @brief Installs PCT callback function.
*
* @param[in] func: PCT interrupt callback
* @return none
*/
void PCT_DRV_InstallCallback(const pct_callback_t func);
/*!
* @brief Get module version information.
*
* @param[out] versionInfo: Module version information address.
* @return void
*/
void PCT_DRV_GetVersionInfo(Drv_VersionInfo_Type *versionInfo);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* PCT_DRV_H */
/* ============================================= EOF ============================================== */