/** * @file xmc_vadc.h * @date 2017-02-06 * * @cond ********************************************************************************************************************* * XMClib v2.1.12 - XMC Peripheral Driver Library * * Copyright (c) 2015-2017, Infineon Technologies AG * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification,are permitted provided that the * following conditions are met: * * Redistributions of source code must retain the above copyright notice, this list of conditions and the following * disclaimer. * * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following * disclaimer in the documentation and/or other materials provided with the distribution. * * Neither the name of the copyright holders nor the names of its contributors may be used to endorse or promote * products derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY,OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * To improve the quality of the software, users are encouraged to share modifications, enhancements or bug fixes with * Infineon Technologies AG dave@infineon.com). ********************************************************************************************************************* * * Change History * -------------- * * 2015-02-15: * - Initial
* * 2015-02-20: * - Revised for XMC1201 device.
* * 2015-04-27: * - Added new APIs for SHS.
* - Added New APIs for trigger edge selection.
* - Added new APIs for Queue flush entries, boundary selection, Boundary node pointer.
* - Revised GatingMode APIs and EMUX Control Init API.
* * 2015-06-20: * - Removed version macros and declaration of GetDriverVersion API * 2015-06-25: * - BFL configuration in channel initialization fixed. * * 2015-07-28: * - CLOCK_GATING_SUPPORTED and PERIPHERAL_RESET_SUPPORTED macros used * - Clubbed the macro definitions for XMC13 XMC12 and XMC14 * - Clubbed the macro definitions for XMC44 XMC47 and XMC48 * - New APIs Created. * - XMC_VADC_GLOBAL_SetIndividualBoundary * - XMC_VADC_GROUP_SetIndividualBoundary * - XMC_VADC_GROUP_GetAlias * - XMC_VADC_GROUP_GetInputClass * - XMC_VADC_GROUP_ChannelSetIclass * - XMC_VADC_GROUP_ChannelGetResultAlignment * - XMC_VADC_GROUP_ChannelGetInputClass * - XMC_VADC_GROUP_SetResultSubtractionValue * * 2015-12-01: * - Added: * - XMC4300 device supported * * - Fixed: * - XMC_VADC_GLOBAL_TriggerEvent API updated. OR operation removed. * - XMC_VADC_GLOBAL_ClearEvent API updated. Multiple events triggering on clearing the event is fixed. * - Wrong MACRO name defined in xmc_vadc_map.h file corrected for XMC4200/4100 devices. * XMC_VADC_G3_SAMPLE renamed to XMC_VADC_G1_SAMPLE * * 2015-12-01: * - New APIs Created. * - XMC_VADC_GROUP_ScanIsArbitrationSlotEnabled * - XMC_VADC_GROUP_QueueIsArbitrationSlotEnabled * - Fixed the analog calibration voltage for XMC1100 to external reference upper supply range. * - Fixed the XMC_VADC_GLOBAL_StartupCalibration() for XMC1100. * * 2016-03-09: * - Optimization of write only registers * * 2016-03-18: * - Fixed XMC_VADC_GLOBAL_SHS_IsConverterReady(): API checks the STEPCFG register for the ready bit instead of * SHSCFG SFR. * * 2016-06-17: * - New macros added XMC_VADC_SHS_FULL_SET_REG, XMC_VADC_RESULT_PRIORITY_AVAILABLE * - New Enum added XMC_VADC_SHS_GAIN_LEVEL_t and XMC_VADC_SYNCTR_EVAL_t * - New APIs added are: * - XMC_VADC_GROUP_SetSyncSlaveReadySignal * - XMC_VADC_GROUP_ChannelGetAssertedEvents * - XMC_VADC_GROUP_GetAssertedResultEvents * - XMC_VADC_GROUP_SetResultRegPriority * - XMC_VADC_GROUP_SetSyncReadySignal * - XMC_VADC_GROUP_GetSyncReadySignal * - XMC_VADC_GROUP_GetResultRegPriority * * 2017-02-06: * - Added new functions to remove channels from background request source, XMC_VADC_GLOBAL_BackgroundRemoveChannelFromSequence() and XMC_VADC_GLOBAL_BackgndRemoveMultipleChannels() * * @endcond * */ #ifndef XMC_VADC_H #define XMC_VADC_H /********************************************************************************************************************* * HEADER FILES ********************************************************************************************************************/ #include #include #include /** * @addtogroup XMClib XMC Peripheral Library * @{ */ /** * @addtogroup VADC * @brief Versatile Analog to Digital Converter (VADC) driver for XMC microcontroller family. * * The XMC microcontroller provides a series of analog input channels connected to a cluster of Analog/Digital * Converters using the Successive Approximation Register (SAR) principle to convert analog input values (voltages) * to discrete digital values. * \if XMC1 * The XMC1x is based on Sample & Hold converters, where a cluster contains 2 Sample&Hold units which share a common * converter. * \endif * * Each converter of the ADC cluster can operate independent of the others, controlled by a dedicated set of * registers and triggered by a dedicated group request source. The results of each channel can be stored in a * dedicated channel-specific result register or in a group-specific result register.
* * The Versatile Analog to Digital Converter module (VADC) of the XMC comprises a set of converter blocks that * can be operated either independently or via a common request source that emulates a background converter. * Each converter block is equipped with a dedicated input multiplexer and dedicated request sources, * which together build separate groups. * * \if XMC4 * @image html "vadc_overview_xmc4x.png" * \else * @image html "vadc_overview_xmc1x.png" * \endif * * The VADC LLD is split into GLOBAL and GROUP related APIs.
* GLOBAL:
*
    *
  • Global APIs act on the entire ADC module. Configures global configuration registers
  • *
  • Allows configuration of the background request source of the VADC.
  • *
  • The clock related configurations for the VADC module are configured in the Global APIs/
  • *
  • The Global API names are prefixed by the \b XMC_VADC_GLOBAL_ and they accept ::XMC_VADC_GLOBAL_t as * one of its arguments.
  • *
  • Configures the background request source of the VADC. The APIs which act on the background related registers * are prefixed by \b XMC_VADC_GLOBAL_Background
  • *
  • Configures the sample and hold unit of the VADC. The APIs which act on the SHS related registers * are prefixed by \b XMC_VADC_GLOBAL_SHS_
  • *

* * GROUP:
*
    *
  • Group APIs act on a VADC group. Configures the group configuration registers
  • *
  • Configures the queue request source of the VADC. The APIs which act on the queue related registers * are prefixed by \b XMC_VADC_GROUP_Queue
  • *
  • Configures the scan request source of the VADC. The APIs which act on the scan related registers * are prefixed by \b XMC_VADC_GROUP_Scan
  • *
  • Configuration of the channels of each group are done by the API which have a prefix as * \b XMC_VADC_GROUP_Channel.
  • *
  • The Group API names are prefixed by the \b XMC_VADC_GROUP_ and they accept ::XMC_VADC_GROUP_t as * one of its arguments.
  • *

* @{ */ /********************************************************************************************************************* * MACROS ********************************************************************************************************************/ #if ((UC_SERIES == XMC42)||(UC_SERIES == XMC41) || (UC_SERIES == XMC43)) #define XMC_VADC_GROUP_AVAILABLE (1U) /* Defines the availability of group resource in a device*/ #define XMC_VADC_GSCAN_AVAILABLE (1U) /* Defines the availability of scan request resource in a device*/ #define XMC_VADC_QUEUE_AVAILABLE (1U) /* Defines the availability of queue request resource in a device*/ #define XMC_VADC_EMUX_AVAILABLE (1U) /* Defines the availability of external multiplexer support in a device*/ #define XMC_VADC_BOUNDARY_AVAILABLE (1U) /* Defines the availability of boundary check support in a device*/ #define XMC_VADC_MULTIPLE_SLAVEGROUPS (1U) /* Defines the availability of synchronous request source in device*/ #define XMC_VADC_MAXIMUM_NUM_GROUPS (2U) /* Defines the maximum number of groups available in a device*/ #define XMC_VADC_BOUNDARY_FLAG_SELECT (1U) /* Defines the availability of boundary flags in a device*/ #define XMC_VADC_EMUX_CH_SEL_STYLE (1U) /* Defines the external multiplexer channel selection mode of operation for a particular device*/ #define XMC_VADC_SHS_AVAILABLE (0U) /* Defines the availability of sample and hold module*/ #define XMC_VADC_SHS_FULL_SET_REG (0U) /* Defines the availability of sample and hold module*/ #define XMC_VADC_GROUP_SRCREG_AVAILABLE (1U) /* Define the availability of a source specific result register */ #define XMC_VADC_RESULT_PRIORITY_AVAILABLE (0U) /* Define the availability of a priority for result register */ #endif #if (UC_SERIES == XMC44 || UC_SERIES == XMC47 || UC_SERIES == XMC48) #define XMC_VADC_GROUP_AVAILABLE (1U) /* Defines the availability of group resource in a device*/ #define XMC_VADC_GSCAN_AVAILABLE (1U) /* Defines the availability of scan request resource in a device*/ #define XMC_VADC_QUEUE_AVAILABLE (1U) /* Defines the availability of queue request resource in a device*/ #define XMC_VADC_EMUX_AVAILABLE (1U) /* Defines the availability of external multiplexer support in a device*/ #define XMC_VADC_BOUNDARY_AVAILABLE (1U) /* Defines the availability of boundary check support in a device*/ #define XMC_VADC_MULTIPLE_SLAVEGROUPS (1U) /* Defines the availability of synchronous request source in device*/ #define XMC_VADC_MAXIMUM_NUM_GROUPS (4U) /* Defines the maximum number of groups available in a device*/ #define XMC_VADC_BOUNDARY_FLAG_SELECT (1U) /* Defines the availability of boundary flags in a device*/ #define XMC_VADC_EMUX_CH_SEL_STYLE (1U) /* Defines the external multiplexer channel selection mode of operation for a particular device*/ #define XMC_VADC_SHS_AVAILABLE (0U) /* Defines the availability of sample and hold module*/ #define XMC_VADC_SHS_FULL_SET_REG (0U) /* Defines the availability of sample and hold module*/ #define XMC_VADC_GROUP_SRCREG_AVAILABLE (1U) /* Define the availability of a source specific result register */ #define XMC_VADC_RESULT_PRIORITY_AVAILABLE (0U) /* Define the availability of a priority for result register */ #endif #if (UC_SERIES == XMC45) #define XMC_VADC_GROUP_AVAILABLE (1U) /* Defines the availability of group resource in a device*/ #define XMC_VADC_GSCAN_AVAILABLE (1U) /* Defines the availability of scan request resource in a device*/ #define XMC_VADC_QUEUE_AVAILABLE (1U) /* Defines the availability of queue request resource in a device*/ #define XMC_VADC_EMUX_AVAILABLE (1U) /* Defines the availability of external multiplexer support in a device*/ #define XMC_VADC_BOUNDARY_AVAILABLE (1U) /* Defines the availability of boundary check support in a device*/ #define XMC_VADC_MULTIPLE_SLAVEGROUPS (1U) /* Defines the availability of synchronous request source in device*/ #define XMC_VADC_MAXIMUM_NUM_GROUPS (4U) /* Defines the maximum number of groups available in a device*/ #define XMC_VADC_BOUNDARY_FLAG_SELECT (0U) /* Defines the availability of boundary flags in a device*/ #define XMC_VADC_EMUX_CH_SEL_STYLE (0U) /* Defines the external multiplexer channel selection mode of operation for a particular device*/ #define XMC_VADC_SHS_AVAILABLE (0U) /* Defines the availability of sample and hold module*/ #define XMC_VADC_SHS_FULL_SET_REG (0U) /* Defines the availability of sample and hold module*/ #define XMC_VADC_GROUP_SRCREG_AVAILABLE (0U) /* Define the availability of a source specific result register */ #define XMC_VADC_RESULT_PRIORITY_AVAILABLE (0U) /* Define the availability of a priority for result register */ #endif #if (UC_SERIES == XMC14 || UC_SERIES == XMC13 || UC_SERIES == XMC12) #define XMC_VADC_GROUP_AVAILABLE (1U) /* Defines the availability of group resource in a device*/ #define XMC_VADC_GSCAN_AVAILABLE (1U) /* Defines the availability of scan request resource in a device*/ #define XMC_VADC_QUEUE_AVAILABLE (1U) /* Defines the availability of queue request resource in a device*/ #define XMC_VADC_EMUX_AVAILABLE (1U) /* Defines the availability of external multiplexer support in a device*/ #define XMC_VADC_BOUNDARY_AVAILABLE (1U) /* Defines the availability of boundary check support in a device*/ #define XMC_VADC_MULTIPLE_SLAVEGROUPS (1U) /* Defines the availability of synchronous request source in device*/ #define XMC_VADC_MAXIMUM_NUM_GROUPS (2U) /* Defines the maximum number of groups available in a device*/ #define XMC_VADC_BOUNDARY_FLAG_SELECT (1U) /* Defines the availability of boundary flags in a device*/ #define XMC_VADC_EMUX_CH_SEL_STYLE (1U) /* Defines the external multiplexer channel selection mode of operation for a particular device*/ #define XMC_VADC_SHS_AVAILABLE (1U) /* Defines the availability of sample and hold module*/ #define XMC_VADC_SHS_FULL_SET_REG (1U) /* Defines the availability of sample and hold module*/ #define XMC_VADC_GROUP_SRCREG_AVAILABLE (1U) /* Define the availability of a source specific result register */ #define XMC_VADC_RESULT_PRIORITY_AVAILABLE (1U) /* Define the availability of a priority for result register */ #endif #if (UC_SERIES == XMC11) #define XMC_VADC_GROUP_AVAILABLE (0U) /* Defines the availability of group resource in a device*/ #define XMC_VADC_GSCAN_AVAILABLE (0U) /* Defines the availability of scan request resource in a device*/ #define XMC_VADC_QUEUE_AVAILABLE (0U) /* Defines the availability of queue request resource in a device*/ #define XMC_VADC_EMUX_AVAILABLE (0U) /* Defines the availability of external multiplexer support in a device*/ #define XMC_VADC_BOUNDARY_AVAILABLE (0U) /* Defines the availability of boundary check support in a device*/ #define XMC_VADC_MULTIPLE_SLAVEGROUPS (0U) /* Defines the availability of synchronous request source in device*/ #define XMC_VADC_MAXIMUM_NUM_GROUPS (2U) /* Defines the maximum number of groups available in a device*/ #define XMC_VADC_BOUNDARY_FLAG_SELECT (0U) /* Defines the availability of boundary flags in a device*/ #define XMC_VADC_SHS_START_UP_CAL_ACTIVE (3U) /* Defines the need for SHS startup calibration activation for XMC1100 devices */ #define XMC_VADC_CONV_ENABLE_FOR_XMC11 (*(uint32_t*) 0x40010500UL) /* Defines the additional errata setting for XMC1100 device for effective working*/ #define XMC_VADC_EMUX_CH_SEL_STYLE (0U) /* Defines the external multiplexer channel selection mode of operation for a particular device*/ #define XMC_VADC_SHS_AVAILABLE (1U) /* Defines the availability of sample and hold module*/ #define XMC_VADC_SHS_FULL_SET_REG (0U) /* Defines the availability of sample and hold module*/ #define XMC_VADC_GROUP_SRCREG_AVAILABLE (0U) /* Define the availability of a source specific result register */ #define XMC_VADC_RESULT_PRIORITY_AVAILABLE (0U) /* Define the availability of a priority for result register */ #endif #define XMC_VADC_NUM_PORTS (16U) /* Defines the number of hardware ports that can be configured as triggers and gating signals */ #define XMC_VADC_NUM_RESULT_REGISTERS (16U) /* Defines the number of result holding registers per ADC group */ #define XMC_VADC_NUM_CHANNELS_PER_GROUP (8U) /**< Defines the number of ADC channels per group */ /********************************************************************************************************************* * ENUMS ********************************************************************************************************************/ typedef uint16_t XMC_VADC_RESULT_SIZE_t; /**< Type defined the converted result size to unsigned 16 bit integer */ typedef VADC_GLOBAL_TypeDef XMC_VADC_GLOBAL_t; /**< Type defined the device header file vadc global register structure type to VADC type*/ #if(XMC_VADC_GROUP_AVAILABLE == 1U) typedef VADC_G_TypeDef XMC_VADC_GROUP_t; /**< Type defined the device header file vadc group register structure type to VADC Group type*/ #endif #if(XMC_VADC_SHS_AVAILABLE == 1U) typedef SHS_Type XMC_VADC_GLOBAL_SHS_t; /**< Type defined the sample and hold register structure*/ #endif /** * Defines the return status after execution of VADC specific API's. Use @ref XMC_VADC_STATUS_t for this enumeration. */ typedef enum XMC_VADC_STATUS { XMC_VADC_STATUS_SUCCESS = 0, /**< Returned when the API has been able to fulfill the callers request */ XMC_VADC_STATUS_ERROR /**< Returned when the API cannot fulfill the request */ } XMC_VADC_STATUS_t; /** * Defines the various service requests lines. Each group can raise up to 4 service requests independently. While * all groups together have the possibility of raising 4 module wide service requests. Use @ref XMC_VADC_SR_t for this * enumeration. */ typedef enum XMC_VADC_SR { XMC_VADC_SR_GROUP_SR0 = 0, /**< Group specific Service Request-0 */ XMC_VADC_SR_GROUP_SR1, /**< Group specific Service Request-1 */ XMC_VADC_SR_GROUP_SR2, /**< Group specific Service Request-2 */ XMC_VADC_SR_GROUP_SR3, /**< Group specific Service Request-3 */ XMC_VADC_SR_SHARED_SR0, /**< Module Wide Common Service Request-0 */ XMC_VADC_SR_SHARED_SR1, /**< Module Wide Common Service Request-1 */ XMC_VADC_SR_SHARED_SR2, /**< Module Wide Common Service Request-2 */ XMC_VADC_SR_SHARED_SR3 /**< Module Wide Common Service Request-3 */ } XMC_VADC_SR_t; /** * Defines the mode of operation of a channel, when an ongoing conversion gets interrupted in between. * Use @ref XMC_VADC_STARTMODE_t for this enumeration. */ typedef enum XMC_VADC_STARTMODE { XMC_VADC_STARTMODE_WFS = 0, /**< An ongoing conversion completes without interruption */ XMC_VADC_STARTMODE_CIR, /**< An ongoing conversion can be interrupted and resumed later*/ XMC_VADC_STARTMODE_CNR /**< An ongoing conversion can be interrupted and never resumed */ } XMC_VADC_STARTMODE_t; /** * Defines the edge sensitivity of the trigger signal which can assert a conversion. * Use @ref XMC_VADC_TRIGGER_EDGE_t for this enumeration. */ typedef enum XMC_VADC_TRIGGER_EDGE { XMC_VADC_TRIGGER_EDGE_NONE = 0, /**< No external trigger. Conversion request can be asserted by software */ XMC_VADC_TRIGGER_EDGE_FALLING, /**< The falling edge of the external trigger can assert conversion request */ XMC_VADC_TRIGGER_EDGE_RISING, /**< The rising edge of the external trigger can assert conversion request */ XMC_VADC_TRIGGER_EDGE_ANY /**< Both the edges can assert conversion request */ } XMC_VADC_TRIGGER_EDGE_t; /** * Defines the external trigger input selection possibilities, to assert a conversion. Refer the VADC interconnects * section of the reference manual for details of peripherals which can be used. Also refer xmc_vadc_map.h file for * detailed definitions of the peripherals which can take the control of these enumeration items. * Use @ref XMC_VADC_TRIGGER_INPUT_SELECT_t for this enumeration. */ typedef enum XMC_VADC_TRIGGER_INPUT_SELECT { XMC_VADC_REQ_TR_A = 0, /**< Trigger select signal A */ XMC_VADC_REQ_TR_B, /**< Trigger select signal B */ XMC_VADC_REQ_TR_C, /**< Trigger select signal C */ XMC_VADC_REQ_TR_D, /**< Trigger select signal D */ XMC_VADC_REQ_TR_E, /**< Trigger select signal E */ XMC_VADC_REQ_TR_F, /**< Trigger select signal F */ XMC_VADC_REQ_TR_G, /**< Trigger select signal G */ XMC_VADC_REQ_TR_H, /**< Trigger select signal H */ XMC_VADC_REQ_TR_I, /**< Trigger select signal I */ XMC_VADC_REQ_TR_J, /**< Trigger select signal J */ XMC_VADC_REQ_TR_K, /**< Trigger select signal K */ XMC_VADC_REQ_TR_L, /**< Trigger select signal L */ XMC_VADC_REQ_TR_M, /**< Trigger select signal M */ XMC_VADC_REQ_TR_N, /**< Trigger select signal N */ XMC_VADC_REQ_TR_O, /**< Trigger select signal O */ XMC_VADC_REQ_TR_P /**< Trigger select signal P */ } XMC_VADC_TRIGGER_INPUT_SELECT_t; /** * Defines the external gating input selection possibilities, to gate the conversion requests. Refer the VADC * interconnects section of the reference manual for details of peripherals which can be used. Also refer * xmc_vadc_map.h file for detailed definitions of the peripherals which can take the control of these enumeration * items. Use @ref XMC_VADC_GATE_INPUT_SELECT_t for this enumeration. */ typedef enum XMC_VADC_GATE_INPUT_SELECT { XMC_VADC_REQ_GT_A = 0, /**< Gating select signal A */ XMC_VADC_REQ_GT_B, /**< Gating select signal B */ XMC_VADC_REQ_GT_C, /**< Gating select signal C */ XMC_VADC_REQ_GT_D, /**< Gating select signal D */ XMC_VADC_REQ_GT_E, /**< Gating select signal E */ XMC_VADC_REQ_GT_F, /**< Gating select signal F */ XMC_VADC_REQ_GT_G, /**< Gating select signal G */ XMC_VADC_REQ_GT_H, /**< Gating select signal H */ XMC_VADC_REQ_GT_I, /**< Gating select signal I */ XMC_VADC_REQ_GT_J, /**< Gating select signal J */ XMC_VADC_REQ_GT_K, /**< Gating select signal K */ XMC_VADC_REQ_GT_L, /**< Gating select signal L */ XMC_VADC_REQ_GT_M, /**< Gating select signal M */ XMC_VADC_REQ_GT_N, /**< Gating select signal N */ XMC_VADC_REQ_GT_O, /**< Gating select signal O */ XMC_VADC_REQ_GT_P /**< Gating select signal P */ } XMC_VADC_GATE_INPUT_SELECT_t; /** * Defines the condition for gating the conversion requests. It can be used to set the ENGT field * of ASMR/BSMR/QMR register respectively for auto_scan/background_scan/queue request sources. * Use @ref XMC_VADC_GATEMODE_t for this enumeration. */ typedef enum XMC_VADC_GATEMODE { XMC_VADC_GATEMODE_BLOCK = 0, /**< External triggers are permanently blocked */ XMC_VADC_GATEMODE_IGNORE, /**< External triggers are unconditionally passed */ XMC_VADC_GATEMODE_ACTIVEHIGH, /**< External trigger is passed only if the gate signal is high */ XMC_VADC_GATEMODE_ACTIVELOW /**< External trigger is passed only if the gate signal is low */ } XMC_VADC_GATEMODE_t; /** * Defines the conversion result handling mode. Use @ref XMC_VADC_DMM_t for this enumeration. */ typedef enum XMC_VADC_DMM { XMC_VADC_DMM_REDUCTION_MODE = 0, /**< Standard Data reduction mode*/ XMC_VADC_DMM_FILTERING_MODE, /**< Provide option to select Finite Impulse Response Filter (FIR) or Infinite Impulse Response Filter (IIR)*/ XMC_VADC_DMM_DIFFERENCE_MODE, /**< Difference mode is selected*/ } XMC_VADC_DMM_t; /** * Defines the conversion mode. It defines the resolution of conversion. Use XMC_VADC_CONVMODE_t for this enumeration. */ typedef enum XMC_VADC_CONVMODE { XMC_VADC_CONVMODE_12BIT = 0, /**< Results of conversion are 12bits wide */ XMC_VADC_CONVMODE_10BIT = 1, /**< Results of conversion are 10bits wide */ XMC_VADC_CONVMODE_8BIT = 2, /**< Results of conversion are 8bits wide */ XMC_VADC_CONVMODE_FASTCOMPARE = 5 /**< Input signal compared with a preset range */ } XMC_VADC_CONVMODE_t; /** * Defines the output of a fast compare mode. Use @ref XMC_VADC_FAST_COMPARE_t for * this enumeration. */ typedef enum XMC_VADC_FAST_COMPARE { XMC_VADC_FAST_COMPARE_LOW = 0, /**< Input lower than than programmed reference */ XMC_VADC_FAST_COMPARE_HIGH , /**< Input higher than than programmed reference */ XMC_VADC_FAST_COMPARE_UNKNOWN /**< Unknown, Conversion probably still ongoing */ } XMC_VADC_FAST_COMPARE_t; /** * Defines the type of scan request source to be used. It can choose between auto scan and background scan request * source methods. Use @ref XMC_VADC_SCAN_TYPE_t for this enumeration. */ typedef enum XMC_VADC_SCAN_TYPE { XMC_VADC_SCAN_TYPE_GROUPSCAN = 0, /**< Auto scan mode of operation selected. Also called as Group scan*/ XMC_VADC_SCAN_TYPE_BACKGROUND /**< Background scan mode of operation selected. Also called as Global scan*/ } XMC_VADC_SCAN_TYPE_t; /** * Defines the behavior of load event for the scan request source. Use @ref XMC_VADC_SCAN_LOAD_t for this enumeration. */ typedef enum XMC_VADC_SCAN_LOAD { XMC_VADC_SCAN_LOAD_OVERWRITE = 0, /**< The old set of channels is discarded in favor of the new set awaiting conversion */ XMC_VADC_SCAN_LOAD_COMBINE /**< The new set of channels are combined with the pending channels from previous set */ } XMC_VADC_SCAN_LOAD_t; /** * Defines the conversion classes that can be selected for each channel. The enumeration members holds the group or * global classes. The conversion classes decides the properties of conversion, like resolution, sampling time etc * Use @ref XMC_VADC_CHANNEL_CONV_t for this enumeration. */ typedef enum XMC_VADC_CHANNEL_CONV { XMC_VADC_CHANNEL_CONV_GROUP_CLASS0 = 0, /**< Conversion property set-0 specific to the group */ XMC_VADC_CHANNEL_CONV_GROUP_CLASS1, /**< Conversion property set-1 specific to the group */ XMC_VADC_CHANNEL_CONV_GLOBAL_CLASS0, /**< Conversion property set-0, Module wide */ XMC_VADC_CHANNEL_CONV_GLOBAL_CLASS1 /**< Conversion property set-1, Module wide */ } XMC_VADC_CHANNEL_CONV_t; /** * Defines the references to boundary values used for limit checking feature. Each of these can be assigned as * either an upper bound or a lower bound. Use @ref XMC_VADC_CHANNEL_BOUNDARY_t for this enumeration. */ typedef enum XMC_VADC_CHANNEL_BOUNDARY { XMC_VADC_CHANNEL_BOUNDARY_GROUP_BOUND0 = 0, /**< Group specific Boundary-0 value */ XMC_VADC_CHANNEL_BOUNDARY_GROUP_BOUND1, /**< Group specific Boundary-1 value */ XMC_VADC_CHANNEL_BOUNDARY_GLOBAL_BOUND0, /**< Module wide Boundary-0 value */ XMC_VADC_CHANNEL_BOUNDARY_GLOBAL_BOUND1 /**< Module wide Boundary-1 value */ } XMC_VADC_CHANNEL_BOUNDARY_t; /** * Defines the voltage which the capacitor is charged to. Used in Broken wire detection feature. Use * @ref XMC_VADC_CHANNEL_BWDCH_t for this enumeration. */ typedef enum XMC_VADC_CHANNEL_BWDCH { XMC_VADC_CHANNEL_BWDCH_VAGND = 0, /**< Capacitor pre-charged to ground*/ XMC_VADC_CHANNEL_BWDCH_VAREF /**< Capacitor pre-charged to reference voltage*/ } XMC_VADC_CHANNEL_BWDCH_t; /** * Defines the criteria for event generation by the channel. Use @ref XMC_VADC_CHANNEL_EVGEN_t for this enumeration. */ typedef enum XMC_VADC_CHANNEL_EVGEN { XMC_VADC_CHANNEL_EVGEN_NEVER = 0, /**< No event generated */ XMC_VADC_CHANNEL_EVGEN_INBOUND = 1U, /**< Event generated when the result is within the normal range */ XMC_VADC_CHANNEL_EVGEN_COMPHIGH = 1U, /**< Event generated when the result of fast compare operation is high */ XMC_VADC_CHANNEL_EVGEN_OUTBOUND = 2U, /**< Event generated when the result is outside the normal range */ XMC_VADC_CHANNEL_EVGEN_COMPLOW = 2U, /**< Event generated when the result result of fast compare operation is low */ XMC_VADC_CHANNEL_EVGEN_ALWAYS = 3U /**< Event generated always after conversion - unconditionally */ } XMC_VADC_CHANNEL_EVGEN_t; /** * Defines the reference voltage selection for conversion. Use @ref XMC_VADC_CHANNEL_REF_t for this enumeration. */ typedef enum XMC_VADC_CHANNEL_REF { XMC_VADC_CHANNEL_REF_INTREF = 0, /**< Internal VARef */ XMC_VADC_CHANNEL_REF_ALT_CH0 /**< External voltage available on Channel-0 of the perticular group */ } XMC_VADC_CHANNEL_REF_t; /** * Defines the criteria for boundary flag assertion. Use @ref XMC_VADC_CHANNEL_BOUNDARY_CONDITION_t for this * enumeration. */ typedef enum XMC_VADC_CHANNEL_BOUNDARY_CONDITION { XMC_VADC_CHANNEL_BOUNDARY_CONDITION_ABOVE_BAND = 0, /**< Set Boundary condition criteria to assert above the band */ XMC_VADC_CHANNEL_BOUNDARY_CONDITION_BELOW_BAND /**< Set Boundary condition criteria to assert below the band */ } XMC_VADC_CHANNEL_BOUNDARY_CONDITION_t; /** * Defines the event which can lead to a global service request assertion. Use @ref XMC_VADC_GLOBAL_EVENT_t for this * enumeration. */ typedef enum XMC_VADC_GLOBAL_EVENT { XMC_VADC_GLOBAL_EVENT_BKGNDSOURCE = VADC_GLOBEFLAG_SEVGLB_Msk, /**< Background scan request source event */ XMC_VADC_GLOBAL_EVENT_RESULT = VADC_GLOBEFLAG_REVGLB_Msk /**< Global result event */ } XMC_VADC_GLOBAL_EVENT_t; /** * Defines the power modes of a VADC Group. Use @ref XMC_VADC_GROUP_POWERMODE_t for this enumeration. */ typedef enum XMC_VADC_GROUP_POWERMODE { XMC_VADC_GROUP_POWERMODE_OFF = 0, /**< Group is powered down */ XMC_VADC_GROUP_POWERMODE_RESERVED1, /**< Reserved */ XMC_VADC_GROUP_POWERMODE_RESERVED2, /**< Reserved */ XMC_VADC_GROUP_POWERMODE_NORMAL /**< Group is powered up */ } XMC_VADC_GROUP_POWERMODE_t; /** * Defines the status of a VADC group (also known as kernel). Use @ref XMC_VADC_GROUP_STATE_t for this enumeration. */ typedef enum XMC_VADC_GROUP_STATE { XMC_VADC_GROUP_STATE_IDLE = 0, /**< Idle and can convert if requested */ XMC_VADC_GROUP_STATE_BUSY /**< Busy with an ongoing conversion */ } XMC_VADC_GROUP_STATE_t; /** * Defines the reference to sample time and conversion mode settings. Use @ref XMC_VADC_GROUP_CONV_t for this * enumeration. */ typedef enum XMC_VADC_GROUP_CONV { XMC_VADC_GROUP_CONV_STD = 0, /**< Settings pertaining to channels directly attached to VADC module */ XMC_VADC_GROUP_CONV_EMUX /**< Settings pertaining to channels connected to VADC via EMUX */ } XMC_VADC_GROUP_CONV_t; /** * Defines the request source arbiter behavior. Use @ref XMC_VADC_GROUP_ARBMODE_t for this enumeration. */ typedef enum XMC_VADC_GROUP_ARBMODE { XMC_VADC_GROUP_ARBMODE_ALWAYS = 0, /**< Arbiter runs all the time */ XMC_VADC_GROUP_ARBMODE_ONDEMAND /**< Arbiter runs only if a conversion request is asserted by any of the request sources */ } XMC_VADC_GROUP_ARBMODE_t; /** * Defines the EMUX mode of operation. Use @ref XMC_VADC_GROUP_EMUXMODE_t for this enumeration. */ typedef enum XMC_VADC_GROUP_EMUXMODE { XMC_VADC_GROUP_EMUXMODE_SWCTRL = 0, /**< Perform EMUX in Software control mode*/ XMC_VADC_GROUP_EMUXMODE_STEADYMODE, /**< Perform EMUX in Steady mode (Use EMUX set value)*/ XMC_VADC_GROUP_EMUXMODE_SINGLEMODE, /**< Perform EMUX in Single step mode*/ XMC_VADC_GROUP_EMUXMODE_SEQUENCEMODE, /**< Perform EMUX in Sequence mode*/ } XMC_VADC_GROUP_EMUXMODE_t; /** * Defines the EMUX channel selection encoding scheme. Use @ref XMC_VADC_GROUP_EMUXCODE_t for this enumeration. */ typedef enum XMC_VADC_GROUP_EMUXCODE { XMC_VADC_GROUP_EMUXCODE_BINARY = 0, /**< A linearly incrementing code serves are MUX-SEL */ XMC_VADC_GROUP_EMUXCODE_GRAY /**< The MUX-SEL is gray encoded */ } XMC_VADC_GROUP_EMUXCODE_t; /** * Defines the service request set used. Use @ref XMC_VADC_GROUP_IRQ_t for this enumeration. */ typedef enum XMC_VADC_GROUP_IRQ { XMC_VADC_GROUP_IRQ_KERNEL = 0, /**< Refers to Group specific service request */ XMC_VADC_GROUP_IRQ_SHARED /**< Refers to Module wide service request */ } XMC_VADC_GROUP_IRQ_t; /** * Defines the alignment of the converted result. Use @ref XMC_VADC_RESULT_ALIGN_t for this enumeration. */ typedef enum XMC_VADC_RESULT_ALIGN { XMC_VADC_RESULT_ALIGN_LEFT = 0, /**< Always align result to left */ XMC_VADC_RESULT_ALIGN_RIGHT /**< Always align result to right */ } XMC_VADC_RESULT_ALIGN_t; typedef enum XMC_VADC_RESULT_SUBTRATION { XMC_VADC_RESULT_SUBTRATION_12BIT_LEFT_ALIGN = 0U, /**< Always align result to left */ XMC_VADC_RESULT_SUBTRATION_12BIT_RIGHT_ALIGN = 0U, /**< Always align result to right */ XMC_VADC_RESULT_SUBTRATION_10BIT_LEFT_ALIGN = 2U, /**< Always align result to left */ XMC_VADC_RESULT_SUBTRATION_10BIT_RIGHT_ALIGN = 0U, /**< Always align result to right */ XMC_VADC_RESULT_SUBTRATION_8BIT_LEFT_ALIGN = 4U, /**< Always align result to left */ XMC_VADC_RESULT_SUBTRATION_8BIT_RIGHT_ALIGN = 0U, /**< Always align result to right */ } XMC_VADC_RESULT_SUBTRATION_t; /** * Defines the request source arbitration priority. Use @ref XMC_VADC_GROUP_RS_PRIORITY_t for this enumeration. */ typedef enum XMC_VADC_GROUP_RS_PRIORITY { XMC_VADC_GROUP_RS_PRIORITY_0 = 0, /**< Lowest priority for the request source*/ XMC_VADC_GROUP_RS_PRIORITY_1, /**< Second lowest priority for the request source*/ XMC_VADC_GROUP_RS_PRIORITY_2, /**< Second highest priority for the request source*/ XMC_VADC_GROUP_RS_PRIORITY_3, /**< Highest priority for the request source*/ }XMC_VADC_GROUP_RS_PRIORITY_t; /** * Defines the various modes for the boundary flag. Use @ref XMC_VADC_GROUP_BOUNDARY_FLAG_MODE_t for this enumeration. */ typedef enum XMC_VADC_GROUP_BOUNDARY_FLAG_MODE { XMC_VADC_GROUP_BOUNDARY_FLAG_MODE_DISABLED = 0, /**< Disable boundary flag*/ XMC_VADC_GROUP_BOUNDARY_FLAG_MODE_ENABLED, /**< Always enable boundary*/ XMC_VADC_GROUP_BOUNDARY_FLAG_MODE_ENABLED_ACTIVE_LOW, /**< Enable boundary flag when gate level is 0*/ XMC_VADC_GROUP_BOUNDARY_FLAG_MODE_ENABLED_ACTIVE_HIGH /**< Enable boundary flag when gate level is 1*/ }XMC_VADC_GROUP_BOUNDARY_FLAG_MODE_t; /** * Defines the boundary select for Channel. Use @ref XMC_VADC_GROUP_BOUNDARY_FLAG_MODE_t for this enumeration. */ typedef enum XMC_VADC_BOUNDARY_SELECT { XMC_VADC_BOUNDARY_SELECT_LOWER_BOUND = 0U, /**< Select the lower boundary*/ XMC_VADC_BOUNDARY_SELECT_UPPER_BOUND = 2U /**< Selects the upper boundary*/ }XMC_VADC_BOUNDARY_SELECT_t; /** * Defines the group indices. Use @ref XMC_VADC_GROUP_INDEX_t for this enumeration. */ typedef enum XMC_VADC_GROUP_INDEX { XMC_VADC_GROUP_INDEX_0 = 0, XMC_VADC_GROUP_INDEX_1, #if (XMC_VADC_MAXIMUM_NUM_GROUPS > 2U) XMC_VADC_GROUP_INDEX_2, XMC_VADC_GROUP_INDEX_3 #endif }XMC_VADC_GROUP_INDEX_t; /** * Defines channel alias. * All enum items are available for channels 0 and 1. Other Channels can accept only XMC_VADC_CHANNEL_ALIAS_DISABLED. */ typedef enum XMC_VADC_CHANNEL_ALIAS { XMC_VADC_CHANNEL_ALIAS_DISABLED = -1, XMC_VADC_CHANNEL_ALIAS_CH0 = 0, XMC_VADC_CHANNEL_ALIAS_CH1 = 1, XMC_VADC_CHANNEL_ALIAS_CH2 = 2, XMC_VADC_CHANNEL_ALIAS_CH3 = 3, XMC_VADC_CHANNEL_ALIAS_CH4 = 4, XMC_VADC_CHANNEL_ALIAS_CH5 = 5, XMC_VADC_CHANNEL_ALIAS_CH6 = 6, XMC_VADC_CHANNEL_ALIAS_CH7 = 7 } XMC_VADC_CHANNEL_ALIAS_t; #if(XMC_VADC_SHS_AVAILABLE == 1U) #if(XMC_VADC_SHS_FULL_SET_REG == 1U) /** * Defines the gain calibration selection. */ typedef enum XMC_VADC_SHS_GAIN_LEVEL { XMC_VADC_SHS_GAIN_LEVEL_0 = SHS_CALOC0_CALOFFVAL0_Pos, /**< Select the calibration value for gain level 0 */ XMC_VADC_SHS_GAIN_LEVEL_1 = SHS_CALOC0_CALOFFVAL1_Pos, /**< Select the calibration value for gain level 1 */ XMC_VADC_SHS_GAIN_LEVEL_2 = SHS_CALOC0_CALOFFVAL2_Pos, /**< Select the calibration value for gain level 2 */ XMC_VADC_SHS_GAIN_LEVEL_3 = SHS_CALOC0_CALOFFVAL3_Pos /**< Select the calibration value for gain level 3 */ }XMC_VADC_SHS_GAIN_LEVEL_t; #endif /** * Defines the Delta sigma loop. */ typedef enum XMC_VADC_SHS_LOOP_CH { XMC_VADC_SHS_LOOP_CH_0 = SHS_LOOP_LPCH0_Pos, /**< Select Delta-sigma loop 0*/ XMC_VADC_SHS_LOOP_CH_1 = SHS_LOOP_LPCH1_Pos /**< Select Delta-sigma loop 1*/ }XMC_VADC_SHS_LOOP_CH_t; /** * Provides the order in which the SHS should do the calibration */ typedef enum XMC_VADC_GLOBAL_SHS_CALIBRATION_ORDER { XMC_VADC_GLOBAL_SHS_CALIBRATION_ORDER_POST_CONV = 0, /**< Calibration occur after conversion takes place */ XMC_VADC_GLOBAL_SHS_CALIBRATION_ORDER_PRE_CONV /**< Calibration occur before conversion takes place */ }XMC_VADC_GLOBAL_SHS_CALIBRATION_ORDER_t; #endif #if (XMC_VADC_BOUNDARY_FLAG_SELECT == 1U) /** * Provides possible routing values for the boundary flag. */ typedef enum XMC_VADC_BOUNDARY_NODE { XMC_VADC_BOUNDARY_NODE_COMMON_BOUNDARY_FLAG_0 = 0U, /** 2U) XMC_VADC_SYNCTR_EVAL_2 = VADC_G_SYNCTR_EVALR2_Msk, /**Range:[0x0 to 0x7] */ uint32_t refill_needed : 1; /**< Conversion completed channel gets inserted back into the queue */ uint32_t generate_interrupt : 1; /**< Generates a queue request source event */ uint32_t external_trigger : 1; /**< Conversion requests are raised on an external trigger. */ uint32_t : 24; }; uint32_t qinr0; }; } XMC_VADC_QUEUE_ENTRY_t; /** * Structure initializing a VADC queue request source. Use type @ref XMC_VADC_QUEUE_CONFIG_t. */ typedef struct XMC_VADC_QUEUE_CONFIG { uint32_t conv_start_mode : 2; /**< One converter is shared between the queue and scan request sources of the same group. This field determines how queue request source would request for conversion. Uses @ref XMC_VADC_STARTMODE_t */ uint32_t req_src_priority : 2; /**< Request source priority for the arbiter.Uses @ref XMC_VADC_GROUP_RS_PRIORITY_t */ union { struct { #if(XMC_VADC_GROUP_SRCREG_AVAILABLE == (1U)) uint32_t src_specific_result_reg : 4; /**< Uses any one Group related result register as the destination for all conversions results. To use the individual result register from each channel configuration, configure this field with 0x0 */ #else uint32_t : 4; #endif uint32_t : 4; uint32_t trigger_signal : 4; /**< Select one of the 16 possibilities for trigger. Uses @ref XMC_VADC_TRIGGER_INPUT_SELECT_t */ uint32_t : 1; uint32_t trigger_edge : 2; /**< Edge selection for trigger signal. Uses @ref XMC_VADC_TRIGGER_EDGE_t */ uint32_t : 1; uint32_t gate_signal : 4; /**< Select one of the 16 possibilities for gating. Uses @ref XMC_VADC_GATE_INPUT_SELECT_t */ uint32_t : 8; uint32_t timer_mode : 1; /**< Timer mode for equi-distant sampling shall be activated or not? */ uint32_t : 3; }; uint32_t qctrl0; }; union { struct { uint32_t : 2; uint32_t external_trigger : 1; /**< Are external triggers supported? */ uint32_t : 29; }; uint32_t qmr0; }; } XMC_VADC_QUEUE_CONFIG_t; /** * Structure to initialize the global input class configuration. Configured parameters are sample time and * conversion Mode. */ typedef struct XMC_VADC_GLOBAL_CLASS { union { struct { uint32_t sample_time_std_conv : 5; /**< Sample time for channels directly connected to VADC
Range: [0x0 to 0x1F] */ uint32_t : 3; uint32_t conversion_mode_standard : 3; /**< Conversion mode for channels directly connected to VADC. Uses @ref XMC_VADC_CONVMODE_t */ uint32_t : 5; #if(XMC_VADC_EMUX_AVAILABLE == 1U) uint32_t sampling_phase_emux_channel : 5; /**< Sample time for channels connected via EMUX
Range: [0x0 to 0x1F] */ uint32_t : 3; uint32_t conversion_mode_emux : 3; /**< Conversion mode for channels connected via EMUX to VADC. Uses @ref XMC_VADC_CONVMODE_t */ uint32_t : 5; #else uint32_t : 16; #endif }; uint32_t globiclass; }; } XMC_VADC_GLOBAL_CLASS_t; #if (XMC_VADC_GROUP_AVAILABLE != 0U) /** * Structure to initialize converter and arbiter clock configuration */ typedef struct XMC_VADC_GLOBAL_CLOCK { union { struct { uint32_t analog_clock_divider : 5; /**< Clock for the converter.
Range: [0x0 to 0x1F] */ uint32_t : 2; uint32_t msb_conversion_clock : 1; /**< Additional clock cycle for analog converter */ uint32_t arbiter_clock_divider : 2; /**< Request source arbiter clock divider.
Range: [0x0 to 0x3] */ uint32_t : 5; uint32_t : 17; }; uint32_t globcfg; }; } XMC_VADC_GLOBAL_CLOCK_t; #endif /** * Structure to initialize the VADC Global functions */ typedef struct XMC_VADC_GLOBAL_CONFIG { union { struct { uint32_t boundary0 : 12; /**< Boundary value for results comparison*/ uint32_t : 4; uint32_t boundary1 : 12; /**< Boundary value for results comparison*/ uint32_t : 4; }; uint32_t globbound; }; #if (XMC_VADC_GROUP_AVAILABLE != 0U) XMC_VADC_GLOBAL_CLOCK_t clock_config; /**< ADC clock configurations*/ #endif XMC_VADC_GLOBAL_CLASS_t class0; /**< ADC input conversion configurations for GLOBICLASS[0]*/ XMC_VADC_GLOBAL_CLASS_t class1; /**< ADC input conversion configurations for GLOBICLASS[1]*/ union { struct { uint32_t : 16; uint32_t data_reduction_control : 4; /**< Data reduction stages */ uint32_t : 4; uint32_t wait_for_read_mode : 1; /**< Results of the next conversion will not be overwritten in the result register until the previous value is read*/ uint32_t : 6; uint32_t event_gen_enable : 1; /**< Generates an event on availability of new result. */ }; uint32_t globrcr; }; union { struct { uint32_t module_disable : 1; /**< Disables the module clock.*/ uint32_t : 2; uint32_t disable_sleep_mode_control : 1; /**< Set it to true in order to disable the Sleep mode */ uint32_t : 28; }; uint32_t clc; }; } XMC_VADC_GLOBAL_CONFIG_t; /** * Structure to initialize the group input class configuration. Configured parameters are sample time and * conversion Mode. */ typedef struct XMC_VADC_GROUP_CLASS { union { struct { uint32_t sample_time_std_conv : 5; /**< Sample time for channels directly connected to VADC
Range: [0x0 to 0x1F] */ uint32_t : 3; uint32_t conversion_mode_standard : 3; /**< Conversion mode for channels directly connected to VADC. Uses @ref XMC_VADC_CONVMODE_t */ uint32_t : 5; uint32_t sampling_phase_emux_channel : 5; /**< Sample time for channels connected via EMUX
Range: [0x0 to 0x1F] */ uint32_t : 3; uint32_t conversion_mode_emux : 3; /**< Conversion mode for channels connected via EMUX to VADC. Uses @ref XMC_VADC_CONVMODE_t */ uint32_t : 5; }; uint32_t g_iclass0; }; } XMC_VADC_GROUP_CLASS_t; /** * EMUX related configuration structure. */ typedef struct XMC_VADC_GROUP_EMUXCFG { union { struct { uint32_t starting_external_channel : 3; /**< External channel number to which the VADC will generate a control signal (needed to select the analog input in the analog multiplexer)*/ uint32_t : 13; #if (XMC_VADC_EMUX_CH_SEL_STYLE == 1U) uint32_t connected_channel : 10; /**< The Channel to which the EMUX is connected. */ #else uint32_t connected_channel : 5; /**< The Channel to which the EMUX is connected. */ uint32_t : 5; #endif uint32_t emux_mode : 2; /**< Selects the external multiplexer modes: Steady, Single Mode, step etc Uses @ref XMC_VADC_GROUP_EMUXMODE_t*/ uint32_t emux_coding : 1; /**< Select Binary or Gray coding. Uses @ref XMC_VADC_GROUP_EMUXCODE_t*/ uint32_t stce_usage : 1; /**< Use STCE for each conversion of an external channel */ #if (XMC_VADC_EMUX_CH_SEL_STYLE == 1U) uint32_t emux_channel_select_style : 1; /**< Selects the style of configuring the \b connected_channel (Each bit represents the channel or entire field represents the channel number ) */ uint32_t : 1; #else uint32_t : 2; #endif }; uint32_t g_emuxctr; }; } XMC_VADC_GROUP_EMUXCFG_t; /** * Group Configuration Data Structures */ typedef struct XMC_VADC_GROUP_CONFIG { XMC_VADC_GROUP_EMUXCFG_t emux_config; /**< External multiplexer related configurations */ XMC_VADC_GROUP_CLASS_t class0; /**< ADC input conversion configurations for GxICLASS[0]*/ XMC_VADC_GROUP_CLASS_t class1; /**< ADC input conversion configurations for GxICLASS[1]*/ union { struct { uint32_t boundary0 : 12; /**< Boundary value for results comparison*/ uint32_t : 4; uint32_t boundary1 : 12; /**< Boundary value for results comparison*/ uint32_t : 4; }; uint32_t g_bound; }; union { struct { uint32_t : 4; uint32_t arbitration_round_length : 2; /**< Number of arbiter slots to be considered */ uint32_t : 1; uint32_t arbiter_mode : 1; /**< Arbiter mode - Select either Continuous mode or Demand based. Uses @ref XMC_VADC_GROUP_ARBMODE_t */ uint32_t : 24; }; uint32_t g_arbcfg; }; } XMC_VADC_GROUP_CONFIG_t; /** * Structure to initialize VADC Group result register. */ typedef struct XMC_VADC_RESULT_CONFIG { union { struct { uint32_t : 16; uint32_t data_reduction_control : 4; /**< Configures the data reduction stages */ uint32_t post_processing_mode : 2; /**< Result data processing mode. Uses @ref XMC_VADC_DMM_t For normal operation select XMC_VADC_DMM_t::XMC_VADC_DMM_REDUCTION_MODE and data_reduction_control as 0*/ uint32_t : 2; uint32_t wait_for_read_mode : 1; /**< Allow the conversion only after previous results are read*/ uint32_t part_of_fifo : 2; /**< Make the result register a part of Result FIFO? */ uint32_t : 4; uint32_t event_gen_enable : 1; /**< Generates an event on availability of new result. */ }; uint32_t g_rcr; }; } XMC_VADC_RESULT_CONFIG_t; #if(XMC_VADC_SHS_AVAILABLE == 1U) #if(XMC_VADC_SHS_FULL_SET_REG == 1U) /** * Structure to initialize the Stepper configurations */ typedef struct XMC_VADC_GLOBAL_SHS_STEP_CONFIG { union { struct { uint32_t sh_unit_step0 :3; /**< Select a Sample and hold unit for the stepper's step number 0. Uses @ref XMC_VADC_GROUP_INDEX_t*/ uint32_t enable_step0 :1; /**< Should the step be added to the sequence */ uint32_t sh_unit_step1 :3; /**< Select a Sample and hold unit for the stepper's step number 1. Uses @ref XMC_VADC_GROUP_INDEX_t*/ uint32_t enable_step1 :1; /**< Should the step be added to the sequence */ uint32_t sh_unit_step2 :3; /**< Select a Sample and hold unit for the stepper's step number 2. Uses @ref XMC_VADC_GROUP_INDEX_t*/ uint32_t enable_step2 :1; /**< Should the step be added to the sequence */ uint32_t sh_unit_step3 :3; /**< Select a Sample and hold unit for the stepper's step number 3. Uses @ref XMC_VADC_GROUP_INDEX_t*/ uint32_t enable_step3 :1; /**< Should the step be added to the sequence */ uint32_t sh_unit_step4 :3; /**< Select a Sample and hold unit for the stepper's step number 4. Uses @ref XMC_VADC_GROUP_INDEX_t*/ uint32_t enable_step4 :1; /**< Should the step be added to the sequence */ uint32_t sh_unit_step5 :3; /**< Select a Sample and hold unit for the stepper's step number 5. Uses @ref XMC_VADC_GROUP_INDEX_t*/ uint32_t enable_step5 :1; /**< Should the step be added to the sequence */ uint32_t sh_unit_step6 :3; /**< Select a Sample and hold unit for the stepper's step number 6. Uses @ref XMC_VADC_GROUP_INDEX_t*/ uint32_t enable_step6 :1; /**< Should the step be added to the sequence */ uint32_t sh_unit_step7 :3; /**< Select a Sample and hold unit for the stepper's step number 7. Uses @ref XMC_VADC_GROUP_INDEX_t*/ uint32_t enable_step7 :1; /**< Should the step be added to the sequence */ }; uint32_t stepcfg; }; }XMC_VADC_GLOBAL_SHS_STEP_CONFIG_t; #endif /** * Sample and hold Initialization structure */ typedef struct XMC_VADC_GLOBAL_SHS_CONFIG { union { struct { uint32_t shs_clock_divider :4; /**< The divider value for the SHS clock. Range: [0x0 to 0xF]*/ uint32_t :6; uint32_t analog_reference_select :2; /**< It is possible to different reference voltage for the SHS module */ uint32_t :20; }; uint32_t shscfg; }; #if(XMC_VADC_SHS_FULL_SET_REG == 1U) XMC_VADC_GLOBAL_SHS_CALIBRATION_ORDER_t calibration_order; /**< order in which the calibration should be taken up*/ #endif }XMC_VADC_GLOBAL_SHS_CONFIG_t; #endif /** * Detailed result structure */ typedef struct XMC_VADC_DETAILED_RESULT { union { struct { uint32_t result :16; /**< Result of the Analog to digital conversion*/ uint32_t data_reduction_counter :4; /**< Results reduction counter value*/ uint32_t channel_number :5; /**< Converted channel number*/ uint32_t emux_channel_number :3; /**< Converted external multiplexer channel number. Only applicable for GxRES[0] result register*/ uint32_t converted_request_source :2; /**< Converted request source*/ uint32_t fast_compare_result :1; /**< Fast compare result if conversion mode is fast compare mode.*/ uint32_t vaild_result :1; /**< Valid flag is set when a new result is available*/ }; uint32_t res; }; }XMC_VADC_DETAILED_RESULT_t; /*Anonymous structure/union guard end*/ #if defined(__CC_ARM) #pragma pop #elif defined(__TASKING__) #pragma warning restore #endif /********************************************************************************************************************* * static inline functions ********************************************************************************************************************/ #if (XMC_VADC_GROUP_AVAILABLE == 1U) __STATIC_INLINE bool XMC_VADC_CHECK_GROUP_PTR(XMC_VADC_GROUP_t *const group_ptr) { #if (XMC_VADC_MAXIMUM_NUM_GROUPS == 4U) return((group_ptr == VADC_G0) || (group_ptr == VADC_G1) || (group_ptr == VADC_G2) || (group_ptr == VADC_G3)); #else return((group_ptr == VADC_G0) || (group_ptr == VADC_G1)); #endif } #endif /********************************************************************************************************************* * API Prototypes ********************************************************************************************************************/ #ifdef __cplusplus extern "C" { #endif /** * @param None * * @return None * * \parDescription:
* Enables the VADC module.
\n * This API would ungate the clock to the VADC module (if applicable). Also this API would bring * the VADC module out of reset state(if applicable), by asserting the appropriate registers. * This API would invoke XMC_SCU_CLOCK_UngatePeripheralClock() and XMC_SCU_RESET_DeassertPeripheralReset() * if needed. Directly accessed register is COMPARATOR.ORCCTRL (Refer to the errata for XMC1100). * * \parRelated APIs:
* XMC_VADC_GLOBAL_DisableModule(). */ void XMC_VADC_GLOBAL_EnableModule(void); /** * @param None * * @return None * * \parDescription:
* Disables the VADC module.
\n * This API would gate the clock to the VADC module (if applicable). Also this API would put * the VADC module into the reset state(if applicable) by asserting the appropriate registers. * This API would invoke XMC_SCU_CLOCK_GatePeripheralClock() and XMC_SCU_RESET_AssertPeripheralReset() if needed. * * \parRelated APIs:
* XMC_VADC_GLOBAL_EnableModule(). */ void XMC_VADC_GLOBAL_DisableModule(void); /** * * @param global_ptr Constant pointer to the VADC module. * @param config Pointer to initialization data structure * * @return None * * \parDescription:
* Initializes the VADC global module with the associated configuration structure pointed by \a config.\n\n It * enables the global access to registers by configuring reset and clock un-gating for selected devices. It * initializes global class, boundary , result resources by setting GLOBICLASS,GLOBBOUND,GLOBRCR registers. It also * configures the global analog and digital clock dividers by setting GLOBCFG register. Refer related API's to change * the configurations later in the program. * * \parRelated APIs:
* XMC_VADC_GLOBAL_ClockInit()
*/ void XMC_VADC_GLOBAL_Init(XMC_VADC_GLOBAL_t *const global_ptr, const XMC_VADC_GLOBAL_CONFIG_t *config); /** * * @param global_ptr Constant pointer to the VADC module. * * @return None * * \parDescription:
* Enables the VADC module clock.\n\n Call this API before any further configuration of VADC. It sets the DISR bit of CLC * register to enable. * * \parRelated APIs:
* XMC_VADC_GLOBAL_Init() * */ __STATIC_INLINE void XMC_VADC_GLOBAL_EnableModuleClock(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_Enable:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->CLC &= ~((uint32_t)VADC_CLC_DISR_Msk); } /** * * @param global_ptr Constant pointer to the VADC module. * * @return None * * \parDescription:
* Disables the VADC module clock.\n\n After this API call, no conversion will occur. Call * XMC_VADC_GLOBAL_EnableModuleClock() to enable the VADC module later in the program. * * \parRelated APIs:
* XMC_VADC_GLOBAL_Init() * */ __STATIC_INLINE void XMC_VADC_GLOBAL_DisableModuleClock(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_Disable:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->CLC |= (uint32_t) ((uint32_t)1 << VADC_CLC_DISR_Pos); } /** * * @param global_ptr Constant pointer to the VADC module. * * @return None * * \parDescription:
* Enables VADC module to sleep if a sleep request comes.\n\n * It resets the EDIS bit of CLC register for enabling the sleep mode. * * \parRelated APIs:
* XMC_VADC_GLOBAL_DisableSleepMode(). */ __STATIC_INLINE void XMC_VADC_GLOBAL_EnableSleepMode(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_EnableSleepMode:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->CLC &= ~((uint32_t)VADC_CLC_EDIS_Msk); } /** * * @param global_ptr Constant pointer to the VADC module. * * @return None * * \parDescription:
* Ignores the sleep mode request for the VADC.\n\n * With the sleep feature enabled, the module will respond to sleep * requests by going into a low power mode. It resets the EDIS bit of CLC register for enabling the sleep mode. * * \parRelated APIs:
* XMC_VADC_GLOBAL_EnableSleepMode(). */ __STATIC_INLINE void XMC_VADC_GLOBAL_DisableSleepMode(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_DisableSleepMode:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->CLC |= (uint32_t) ((uint32_t)1 << VADC_CLC_EDIS_Pos); } #if (XMC_VADC_GROUP_AVAILABLE == 1U) /** * * @param global_ptr Constant pointer to the VADC module. * @param config Pointer to the data structure containing clock configuration data * * @return None * * \parDescription:
* Configures the VADC clock.
\n * Sets up the clock configuration of the VADC module using the config structure pointed by \a config. * The clock to the analog converter and to the request source arbiter is configured by setting the GLOBCFG register. * * \parRelated APIs:
* None * */ __STATIC_INLINE void XMC_VADC_GLOBAL_ClockInit(XMC_VADC_GLOBAL_t *const global_ptr, const XMC_VADC_GLOBAL_CLOCK_t *config) { XMC_ASSERT("XMC_VADC_GLOBAL_ClockInit:Wrong Module Pointer", (global_ptr == VADC)) /* Write the Clock configuration into the GLOBCFG register */ global_ptr->GLOBCFG = (uint32_t)(config->globcfg | (VADC_GLOBCFG_DIVWC_Msk)); } #endif /** * * @param global_ptr Constant pointer to the VADC module. * @param config Conversion class parameter structure * @param conv_type configure the input call for either standard conversion or EMUX related conversion. * @param set_num Conversion class set
* Range: [0x0, 0x1] * * \parDescription:
* Configures the ADC conversion settings like sample time and resolution.
\n * Sets up the conversion settings for vadc global resource associated with \a config structure. It configures the * conversion class properties like sampling time and resolution for selected \a conv_type channels. It initializes * the GLOBALICLASS register specified by \a set_num with the required settings. * * * \parRelated APIs:
* None * */ void XMC_VADC_GLOBAL_InputClassInit(XMC_VADC_GLOBAL_t *const global_ptr, const XMC_VADC_GLOBAL_CLASS_t config, const XMC_VADC_GROUP_CONV_t conv_type, const uint32_t set_num); /** * * @param global_ptr Constant pointer to the VADC global module * @param config Pointer to result configuration data structure * * @return None * * \parDescription:
* Initializes global result register.
\n * Initializes Global Result Register with specified settings configured in the \a config structure.\n\n This API * results in configuration of GLOBRCR register. This helps in configuring the Data reduction mode, global result event * , wait for read mode on the GLOBRES register. * * * \parRelated APIs:
* None * */ __STATIC_INLINE void XMC_VADC_GLOBAL_ResultInit(XMC_VADC_GLOBAL_t *const global_ptr, const XMC_VADC_RESULT_CONFIG_t *config) { XMC_ASSERT("XMC_VADC_GLOBAL_ResultInit:Wrong Module Pointer", (global_ptr == VADC)) /* Configure GLOBRCR*/ global_ptr->GLOBRCR = config->g_rcr; } /** * * @param global_ptr Constant pointer to the VADC module. * * @return None * * \parDescription:
* Enables the startup calibration feature of the VADC module.\n\n It configures the SUCAL bit of GLOBCFG register to * enable the startup calibration feature. After turning it on, it loops until all active groups finish calibration. * Call XMC_VADC_GLOBAL_Enable() and XMC_VADC_GLOBAL_ClockInit() before calling this API in sequence. Calling the API * XMC_VADC_GLOBAL_DisableStartupCalibration() can disable the calibration feature at runtime. * * \parRelated APIs:
* XMC_VADC_GLOBAL_Enable()
* XMC_VADC_GLOBAL_ClockInit()
* None */ void XMC_VADC_GLOBAL_StartupCalibration(XMC_VADC_GLOBAL_t *const global_ptr); /** * * @param global_ptr Constant pointer to the VADC module. * * @return None * * \parDescription:
* Disables the startup calibration feature of the VADC module.\n\n It configures the SUCAL bit of GLOBCFG register to * disable the startup calibration feature. Calling the API XMC_VADC_GLOBAL_EnsableStartupCalibration() can enable the * calibration feature at runtime. * * \parRelated APIs:
* None */ __STATIC_INLINE void XMC_VADC_GLOBAL_DisableStartupCalibration(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_DisableStartupCalibration:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->GLOBCFG &= ~((uint32_t)VADC_GLOBCFG_SUCAL_Msk); } #if (XMC_VADC_GROUP_AVAILABLE == 1U) /** * * @param global_ptr Constant pointer to the VADC module * @param group_number group number whose post calibration feature is to be disabled.
* Range[0x0 to 0x3] Accepts the enum ::XMC_VADC_GROUP_INDEX_t * * @return None * * \parDescription:
* Disables the post calibration for a particular group specified as \a group_number.\n\n It configures the DPCAL0 bit * of GLOBCFG register to disable the post calibration feature. Call XMC_VADC_GLOBAL_Enable() and * XMC_VADC_GLOBAL_ClockInit() before calling this API in sequence. Calling the API * XMC_VADC_GLOBAL_EnablePostCalibration() can enable back the calibration feature at runtime. * * \parRelated APIs:
* XMC_VADC_GLOBAL_Enable()
* XMC_VADC_GLOBAL_ClockInit()
* XMC_VADC_GLOBAL_DisablePostCalibration()
* None */ __STATIC_INLINE void XMC_VADC_GLOBAL_DisablePostCalibration(XMC_VADC_GLOBAL_t *const global_ptr, uint32_t group_number) { XMC_ASSERT("XMC_VADC_GLOBAL_DisablePostCalibration:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->GLOBCFG |= (uint32_t)((uint32_t)1 << ((uint32_t)VADC_GLOBCFG_DPCAL0_Pos + group_number)); } /** * * @param global_ptr Constant pointer to the VADC module * @param group_number group number whose post calibration feature is to be enabled.
* Range[0x0 to 0x3] Accepts the enum ::XMC_VADC_GROUP_INDEX_t * * @return None * * \parDescription:
* Enables the post calibration for a particular group specified as \a group_number.\n\n It configures the DPCAL0 bit * of GLOBCFG register to enable the post calibration feature. Calling the API XMC_VADC_GLOBAL_DisablePostCalibration() * can disable the calibration feature at runtime. * * \parRelated APIs:
* XMC_VADC_GLOBAL_DisablePostCalibration()
* None */ __STATIC_INLINE void XMC_VADC_GLOBAL_EnablePostCalibration(XMC_VADC_GLOBAL_t *const global_ptr, uint32_t group_number) { XMC_ASSERT("XMC_VADC_GLOBAL_EnablePostCalibration:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->GLOBCFG &= (~ (uint32_t)((uint32_t)1 << ((uint32_t)VADC_GLOBCFG_DPCAL0_Pos + group_number))); } #endif #if (XMC_VADC_BOUNDARY_AVAILABLE == 1U) /** * * @param global_ptr Constant pointer to the VADC module. * @param boundary0 Boundary-0 Value
Range[0 - 4095] * @param boundary1 Boundary-1 Value
Range[0 - 4095] * * @return None * * \parDescription:
* Programs the boundaries with \a boundary0 and boundary1 for result comparison.\n\n These two boundaries can serve as * absolute boundaries. They define a range against which the result of a conversion can be compared. In the * fast compare mode, the two boundaries provide hysteresis capability to a compare value. In any case, these boundary * values entered here form a boundary pallete. There are dedicated upper and lower boundary registers GLOBBOUND0 and * GLOBBOUND1 who will derive their values from this palette. * * \parRelated APIs:
* None * */ void XMC_VADC_GLOBAL_SetBoundaries(XMC_VADC_GLOBAL_t *const global_ptr, const uint32_t boundary0, const uint32_t boundary1); /** * * @param global_ptr Constant pointer to the VADC module. * @param selection The boundary value selected for \b boundary_value. * @param boundary_value Boundary Value
Range[0 - 4095] * * @return None * * \parDescription:
* Programs either the boundary 0 or boundary 1 for result comparison.\n\n This defines a range against which * the result of a conversion can be compared. In the fast compare mode, the two boundaries provide hysteresis * capability to a compare value. * * \parRelated APIs:
* None * */ void XMC_VADC_GLOBAL_SetIndividualBoundary(XMC_VADC_GLOBAL_t *const global_ptr, const XMC_VADC_CHANNEL_BOUNDARY_t selection, const uint16_t boundary_value); #endif #if (XMC_VADC_EMUX_AVAILABLE== 1U) /** * * @param global_ptr Constant pointer to the VADC module * @param emuxif The EMUX interface
Range[0x0 - 0x1] * @param group The VADC group which must be bound to the desired emux * * @return None * * \parDescription:
* Binds a VADC \a group to an EMUX interface specified in \a emuxif.
\n * Selects which group's scan request source will control the EMUX interface (set of control select lines for the EMUX). * By passing \b group it would configure that group's scan request source to control the EMUX select lines of the set * \b emuxif. * * \parRelated APIs:
* None */ void XMC_VADC_GLOBAL_BindGroupToEMux(XMC_VADC_GLOBAL_t *const global_ptr, const uint32_t emuxif, const uint32_t group); #endif /** * * @param global_ptr Constant pointer to the VADC module. * * @return uint32_t Complete global result register value GLOBRES * * \parDescription:
* Retrieves the complete result from the global result register associated with the \a global_ptr.\n\n This API audits * the result register GLOBRES for the validity of the data. If the validity is assured, data is first read * the global result register, cached locally next and subsequently returned to the caller. * * \parRelated APIs:
* XMC_VADC_GLOBAL_GetResult() */ __STATIC_INLINE uint32_t XMC_VADC_GLOBAL_GetDetailedResult(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_GetDetailedResult:Wrong Module Pointer", (global_ptr == VADC)) return(global_ptr->GLOBRES); } /** * * @param global_ptr Constant pointer to the VADC module. * * @return XMC_VADC_RESULT_SIZE_t 16 bit result register value.
* Range[0x0 - 0X0FFF] * * \parDescription:
* Retrieves the conversion result from the global result register associated with the \a global_ptr.\n\n This is a * lightweight version of XMC_VADC_GLOBAL_GetDetailedResult(). The behavior is exactly the same, just that it is * only the 16 bit numeric result returned back to the application instead of the complete GLOBRES register value. * * \parRelated APIs:
* XMC_VADC_GLOBAL_GetDetailedResult() */ __STATIC_INLINE XMC_VADC_RESULT_SIZE_t XMC_VADC_GLOBAL_GetResult(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_GetResult:Wrong Module Pointer", (global_ptr == VADC)) return ((XMC_VADC_RESULT_SIZE_t)global_ptr->GLOBRES); } /** * * @param global_ptr Constant pointer to the VADC module * @param compare_val Compare value which the result of a conversion will be compared against. *
Range[0x0 - 0X0FFF] * * @return None * * \parDescription:
* Set compare value in the global result register for fast compare mode.\n\n The result of a conversion will directly * be compared to the compare value entered as part of \a compare_val. The prerequisite is that the channel associated * with this global register must select an ICLASS which has the conversion mode configured as fast compare mode. Call * @ref XMC_VADC_GLOBAL_GetCompareResult() after this API to * * \parRelated APIs:
* None */ void XMC_VADC_GLOBAL_SetCompareValue(XMC_VADC_GLOBAL_t *const global_ptr, const XMC_VADC_RESULT_SIZE_t compare_val); /** * * @param global_ptr Constant pointer to the VADC module * @return compare high or low. Refer @ref XMC_VADC_FAST_COMPARE_t enum * * @return None * * \parDescription:
* Determines the result of fast compare operation.\n\n This API returns the result of fast compare operation provided * the valid flag in the global result register GLOBRES is set. * * \parRelated APIs:
* None */ XMC_VADC_FAST_COMPARE_t XMC_VADC_GLOBAL_GetCompareResult(XMC_VADC_GLOBAL_t *const global_ptr); /** * * @param global_ptr Constant pointer to the VADC module * @param event_type Desired event that must be manually asserted * Use the enum ::XMC_VADC_GLOBAL_EVENT_t to create a mask to be used with this argument * @return None * * \parDescription:
* Manually asserts an event that can lead to an interrupt.\n\n This API manually asserts the requested event * (Background request source event or a global result event) by setting the GLOBEVFLAG register with the specified * \a event_type. * * \parRelated APIs:
* None */ __STATIC_INLINE void XMC_VADC_GLOBAL_TriggerEvent(XMC_VADC_GLOBAL_t *const global_ptr, const uint32_t event_type) { XMC_ASSERT("XMC_VADC_GLOBAL_TriggerEvent:Wrong Module Pointer", (global_ptr == VADC)) XMC_ASSERT("XMC_VADC_GLOBAL_TriggerEvent:Wrong Global Event", ((XMC_VADC_GLOBAL_EVENT_BKGNDSOURCE == event_type) || (XMC_VADC_GLOBAL_EVENT_RESULT == event_type))) global_ptr->GLOBEFLAG = event_type; } /** * * @param global_ptr Constant pointer to the VADC module * @param event_type Event that must be acknowledged * Use the enum ::XMC_VADC_GLOBAL_EVENT_t to create a mask to be used with this argument * * @return None * * \parDescription:
* Acknowledges an event that has been asserted manually or automatically.\n\n This API acknowledges the requested event * by clearing GLOBEFLAG sticky flag. * * \parRelated APIs:
* None */ __STATIC_INLINE void XMC_VADC_GLOBAL_ClearEvent(XMC_VADC_GLOBAL_t *const global_ptr, const uint32_t event_type) { XMC_ASSERT("XMC_VADC_GLOBAL_ClearEvent:Wrong Module Pointer", (global_ptr == VADC)) XMC_ASSERT("XMC_VADC_GLOBAL_ClearEvent:Wrong Global Event", ((XMC_VADC_GLOBAL_EVENT_BKGNDSOURCE == event_type) || (XMC_VADC_GLOBAL_EVENT_RESULT == event_type))) global_ptr->GLOBEFLAG = ((uint32_t)(event_type << (uint32_t)16)); } /** * * @param global_ptr Constant pointer to the VADC module * @param sr The service request to which the global result event is connected. Refer @ref XMC_VADC_SR_t enum * * @return None * * \parDescription:
* Binds the global result event to one of the 4 shared service requests.\n\n This API binds the global result event * to one of the 4 module wide shared service requests .Sets GLOBEVNP register with the corresponding \a sr line. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundSetReqSrcEventInterruptNode() */ void XMC_VADC_GLOBAL_SetResultEventInterruptNode(XMC_VADC_GLOBAL_t *const global_ptr, XMC_VADC_SR_t sr); /** * * @param global_ptr Constant pointer to the VADC module * @param sr The service request to which the global request source event is connected. Refer @ref XMC_VADC_SR_t enum * * @return None * * \parDescription:
* Binds the background request source event to one of the 4 shared service requests.\n\n This API binds the background * request source event to one of the 4 module wide shared service requests. Sets GLOBEVNP register with the * corresponding \a sr line. * * \parRelated APIs:
* XMC_VADC_GLOBAL_SetResultEventInterruptNode() */ void XMC_VADC_GLOBAL_BackgroundSetReqSrcEventInterruptNode(XMC_VADC_GLOBAL_t *const global_ptr, XMC_VADC_SR_t sr); #if(XMC_VADC_SHS_AVAILABLE == 1U) /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param config Struct consisting of various SHS related configurations. * * @return None * * \parDescription:
* Configure the basic SHS parameters.
\n * API would initialize the clock divider configuration, the analog reference selection and * the calibration order for the Sample and Hold unit. * * \parRelated APIs:
* None. */ void XMC_VADC_GLOBAL_SHS_Init(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, const XMC_VADC_GLOBAL_SHS_CONFIG_t *config); #if(XMC_VADC_SHS_FULL_SET_REG == 1U) /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param config Struct consisting of various step configurations. * * @return None * * \parDescription:
* Configures the stepper sequence for the converter.
\n * Stepper of the SHS can be configured to take up a specific sequence of groups for conversion. * The stepper sequence is configured using this API. * * \parRelated APIs:
* None. */ __STATIC_INLINE void XMC_VADC_GLOBAL_SHS_SetStepperSequence(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, const XMC_VADC_GLOBAL_SHS_STEP_CONFIG_t *config) { XMC_ASSERT("XMC_VADC_GLOBAL_SHS_StepperInit:Wrong SHS Pointer", (shs_ptr == (XMC_VADC_GLOBAL_SHS_t*)(void*)SHS0)) XMC_ASSERT("XMC_VADC_GLOBAL_SHS_StepperInit:Wrong config pointer", (config == (XMC_VADC_GLOBAL_SHS_STEP_CONFIG_t*)NULL)) shs_ptr->STEPCFG = (uint32_t) config->stepcfg; } #endif /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * * @return bool returns true if the analog converter is operable * returns false if the analog converter is powered down * * \parDescription:
* Returns the converter status.
\n * Returns the ANRDY bit field of the SHSCFG register. * * \parRelated APIs:
* None. */ __STATIC_INLINE bool XMC_VADC_GLOBAL_SHS_IsConverterReady(XMC_VADC_GLOBAL_SHS_t *const shs_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_SHS_IsConverterReady:Wrong SHS Pointer",(shs_ptr == (XMC_VADC_GLOBAL_SHS_t*)(void*)SHS0)) return((bool)((shs_ptr->SHSCFG >> (uint32_t)SHS_SHSCFG_ANRDY_Pos) & (uint32_t)0x1)); } #if(XMC_VADC_SHS_FULL_SET_REG == 1U) /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param group_num group number for which the accelerated mode needs to be enabled.
Range: [0x0 to 0x1] * * @return None * * \parDescription:
* Enables the Accelerated timing mode.
\n * This API is needed when a switch from compatible mode to accelerated mode of conversion is needed. In * this mode the ADC module will convert the input depending on the value stored in the SST bit of the SHS0_TIMCFGx. * This API would configure the accelerated mode in the SHS0_TIMCFG0 and SHS0_TIMCFG1 registers. * * \parRelated APIs:
* None. */ void XMC_VADC_GLOBAL_SHS_EnableAcceleratedMode(XMC_VADC_GLOBAL_SHS_t *const shs_ptr,XMC_VADC_GROUP_INDEX_t group_num); /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param group_num group number for which the accelerated mode needs to be disabled.
Range: [0x0 to 0x1] * * @return None * * \parDescription:
* Enables the Accelerated timing mode.
\n * This API is needed when a switch from accelerated mode to compatible mode of conversion is needed. * This API would clear the accelerated mode in the SHS0_TIMCFG0 and SHS0_TIMCFG1 registers. * * \parRelated APIs:
* None. */ void XMC_VADC_GLOBAL_SHS_DisableAcceleratedMode(XMC_VADC_GLOBAL_SHS_t *const shs_ptr,XMC_VADC_GROUP_INDEX_t group_num); /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param group_num group number for which the accelerated mode needs to be enabled.
Range: [0x0 to 0x1] * @param sst_value Value of short sample time that needs to be configured.
* Range: [0x0 to 0x3F] * * @return None * * \parDescription:
* Configures the Accelerated timing mode sample time.
\n * This API is needed when a switch from compatible mode to accelerated mode of conversion is needed. In * Accelerated mode the ADC module will convert the input depending on the value stored in the SST bit of the * SHS0_TIMCFGx. This API would configure the shot sample time either in SHS0_TIMCFG0.SST or SHS0_TIMCFG1.SST . * * \parRelated APIs:
* None. */ void XMC_VADC_GLOBAL_SHS_SetShortSampleTime(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, XMC_VADC_GROUP_INDEX_t group_num, uint8_t sst_value); #endif /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param divs_value The clock divider value that is possible *
Range:[0x0 to 0xF] * @return None * * \parDescription:
* Configure Sample and hold clock divider value.
\n * API would initialize the clock divider configuration. This determines the frequency of conversion * of the Sample and hold converter. * * \parRelated APIs:
* None. */ __STATIC_INLINE void XMC_VADC_GLOBAL_SHS_SetClockDivider(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, uint8_t divs_value) { XMC_ASSERT("XMC_VADC_GLOBAL_SHS_SetClockDivider:Wrong SHS Pointer", (shs_ptr == (XMC_VADC_GLOBAL_SHS_t*)(void*)SHS0)) XMC_ASSERT("XMC_VADC_GLOBAL_SHS_SetClockDivider:Wrong divide factor selected", (divs_value < (uint32_t)0x10)) shs_ptr->SHSCFG = (shs_ptr->SHSCFG & (~(uint32_t)SHS_SHSCFG_DIVS_Msk)) | (uint32_t)SHS_SHSCFG_SCWC_Msk; shs_ptr->SHSCFG |= ((uint32_t)divs_value << SHS_SHSCFG_DIVS_Pos) | (uint32_t)SHS_SHSCFG_SCWC_Msk; } /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param gain_value gain value possible * Range:[0x0 to 0x3] * @param group_num The Group number for which the configurations applies * @param ch_num The channel number for which the gain has to be configured * @return None * * \parDescription:
* Configure the gain value for SHS.
\n * API would set the gain factor for a selected channel. * * \parRelated APIs:
* None. */ void XMC_VADC_GLOBAL_SHS_SetGainFactor(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, uint8_t gain_value, XMC_VADC_GROUP_INDEX_t group_num, uint8_t ch_num); #if(XMC_VADC_SHS_FULL_SET_REG == 1U) /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param max_calibration_time calibration time * Range:[0x0 to 0x3F] * @return None * * \parDescription:
* Configure the Maximum calibration timing.
\n * API would initialize the Maximum time after which the calibration should occur. If no adc conversion * occur during this duration then the calibration would run irrespective of conversions. The max time the * converter can go without a calibration is set in this API. * * \parRelated APIs:
* None. */ __STATIC_INLINE void XMC_VADC_GLOBAL_SHS_SetMaxCalTime(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, uint32_t max_calibration_time) { XMC_ASSERT("XMC_VADC_GLOBAL_SHS_SetMaxCalTime:Wrong SHS Pointer", (shs_ptr == (XMC_VADC_GLOBAL_SHS_t*)(void*)SHS0)) shs_ptr->CALCTR &= ~((uint32_t)SHS_CALCTR_CALMAX_Msk); shs_ptr->CALCTR |= ((uint32_t)max_calibration_time << SHS_CALCTR_CALMAX_Pos); } /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param group_num The Group number for which the configurations applies * @return None * * \parDescription:
* Enable the Gain and offset calibration.
\n * Enable the gain and offset calibration for all the Sample and hold units. * * \parRelated APIs:
* XMC_VADC_GLOBAL_SHS_DisableGainAndOffsetCalibrations()
. */ void XMC_VADC_GLOBAL_SHS_EnableGainAndOffsetCalibrations(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, XMC_VADC_GROUP_INDEX_t group_num); /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param group_num The Group number for which the configurations applies * @return None * * \parDescription:
* Disable the Gain and offset calibration.
\n * Disable the gain and offset calibration for all the Sample and hold units. * * \parRelated APIs:
* XMC_VADC_GLOBAL_SHS_EnableGainAndOffsetCalibrations()
. */ void XMC_VADC_GLOBAL_SHS_DisableGainAndOffsetCalibrations(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, XMC_VADC_GROUP_INDEX_t group_num); /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param group_num The Group number for which the configurations applies * @param gain_level The gain level whose calibration value has to read. * @return None * * \parDescription:
* Read the calibration value for the selected gain level.
\n * Each gain value has a offset calibration value, this API would return the offset calibration value of the * selected gain level. This is applicable for all the channels in the group that use the particular gain level. * * \parRelated APIs:
* XMC_VADC_GLOBAL_SHS_SetOffsetCalibrationValue()
. */ uint8_t XMC_VADC_GLOBAL_SHS_GetOffsetCalibrationValue(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, XMC_VADC_GROUP_INDEX_t group_num, XMC_VADC_SHS_GAIN_LEVEL_t gain_level); /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param group_num The Group number for which the configurations applies * @param gain_level The gain level whose calibration value has to read. * @param offset_calibration_value The offset calibration value to be set. * @return None * * \parDescription:
* Set the calibration value for the selected gain level.
\n * Each gain value has a offset calibration value, this API would set the offset value of the selected gain level. * * \parRelated APIs:
* XMC_VADC_GLOBAL_SHS_GetOffsetCalibrationValue()
. */ void XMC_VADC_GLOBAL_SHS_SetOffsetCalibrationValue(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, XMC_VADC_GROUP_INDEX_t group_num, XMC_VADC_SHS_GAIN_LEVEL_t gain_level, uint8_t offset_calibration_value); #endif /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param group_num The Group number for which the configurations applies * @param loop_select The delta sigma loop number for which the configurations applies * @param ch_num Channel number for which the configurations applies * @return None * * \parDescription:
* Configures the delta sigma loop of the SHS.
\n * There are 2 Delta-Sigma loops that can be configured. This API would configure the loop (loop_select) * with the appropriate group_num and channel_num. * Configures the SHS_LOOP bit fields. * * \parRelated APIs:
* XMC_VADC_GLOBAL_SHS_EnableSigmaDeltaLoop()
. */ void XMC_VADC_GLOBAL_SHS_SetSigmaDeltaLoop(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, XMC_VADC_GROUP_INDEX_t group_num, XMC_VADC_SHS_LOOP_CH_t loop_select, uint8_t ch_num); /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param loop_select The delta sigma loop number for which the configurations applies * @return None * * \parDescription:
* Enable the selected Delta-Sigma loop.
\n * Configures the SHS_LOOP.LPENx bit field. * * \parRelated APIs:
* XMC_VADC_GLOBAL_SHS_SetSigmaDeltaLoop()
. * XMC_VADC_GLOBAL_SHS_EnableGainAndOffsetCalibrations()
. */ __STATIC_INLINE void XMC_VADC_GLOBAL_SHS_EnableSigmaDeltaLoop(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, XMC_VADC_SHS_LOOP_CH_t loop_select) { XMC_ASSERT("XMC_VADC_GLOBAL_SHS_EnableSigmaDeltaLoop:Wrong SHS Pointer", (shs_ptr == (XMC_VADC_GLOBAL_SHS_t*)(void*)SHS0)) XMC_ASSERT("XMC_VADC_GLOBAL_SHS_EnableSigmaDeltaLoop:Wrong Delta sigma loop selected", (loop_select == XMC_VADC_SHS_LOOP_CH_0)||(loop_select == XMC_VADC_SHS_LOOP_CH_1)) shs_ptr->LOOP |= (uint32_t)SHS_LOOP_LPEN0_Msk << (uint32_t)loop_select; } /** * @param shs_ptr Constant pointer to the VADC Sample and hold module * @param loop_select The delta sigma loop number for which the configurations applies * @return None * * \parDescription:
* Disable the selected delta sigma loop.
\n * Configures the SHS_LOOP.LPENx bit field. * * \parRelated APIs:
* XMC_VADC_GLOBAL_SHS_SetSigmaDeltaLoop()
. * XMC_VADC_GLOBAL_SHS_EnableGainAndOffsetCalibrations()
. */ __STATIC_INLINE void XMC_VADC_GLOBAL_SHS_DisableSigmaDeltaLoop(XMC_VADC_GLOBAL_SHS_t *const shs_ptr, XMC_VADC_SHS_LOOP_CH_t loop_select) { XMC_ASSERT("XMC_VADC_GLOBAL_SHS_DisableSigmaDeltaLoop:Wrong SHS Pointer", (shs_ptr == (XMC_VADC_GLOBAL_SHS_t*)(void*)SHS0)) XMC_ASSERT("XMC_VADC_GLOBAL_SHS_DisableSigmaDeltaLoop:Wrong Delta sigma loop selected", (loop_select == XMC_VADC_SHS_LOOP_CH_0)||(loop_select == XMC_VADC_SHS_LOOP_CH_1)) shs_ptr->LOOP &= ~((uint32_t)SHS_LOOP_LPEN0_Msk << (uint32_t)loop_select); } #endif #if (XMC_VADC_GROUP_AVAILABLE == 1U) /** * * @param group_ptr Constant pointer to the VADC group. * @param config Pointer to the initialization data structure * * @return None * * \parDescription:
* Initializes the VADC group module with the associated configuration structure pointed by \a config.\n\n It * initializes the group specified as part of the \a group_ptr. It initializes group conversion class, arbiter * configuration , boundary configuration by setting GxICLASS,GxARBCFG,GxBOUND, registers. It also * configures the EMUX control register if applicable. Refer related API's to change the configurations later in the * program. * * \parRelated APIs:
* XMC_VADC_GROUP_InputClassInit()
* XMC_VADC_GROUP_SetPowerMode()
* XMC_VADC_GROUP_SetBoundaries()
* XMC_VADC_GROUP_ExternalMuxControlInit()
*/ void XMC_VADC_GROUP_Init(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_GROUP_CONFIG_t *config); /** * * @param group_ptr Constant pointer to the VADC group. * @param config group related conversion class parameter structure * @param conv_type Use direct channels or EMUX channels. Refer @ref XMC_VADC_GROUP_CONV_t enum * @param set_num Conversion class set
* Range[0x0, 0x1] * * @return None * * \parDescription:
* Sets up the conversion settings for vadc group resource associated with \a config structure. It configures the * conversion class properties like sampling time and resolution for selected \a conv_type channels. It initializes * the G_ICLASS register specified by \a set_num with the required settings. * * * \parRelated APIs:
* XMC_VADC_GROUP_Init() * */ void XMC_VADC_GROUP_InputClassInit(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_GROUP_CLASS_t config, const XMC_VADC_GROUP_CONV_t conv_type, const uint32_t set_num); /** * * @param group_ptr Constant pointer to the VADC Group which must be set as a slave * @param master_grp The master group number
* Range: [0x0 - 0x3] * @param slave_group The slave group number
* Range: [0x0 - 0x3] * * @return None * * \parDescription:
* Configures a VADC Group as a slave group.\n\n Conversion of identically numbered channels across groups can be * synchronized. For example, when the trigger to convert CH-1 of Group-2 is received, it is possible to * simultaneously request conversion of CH-1 of Group-0 and Group-3. Group-2 in this example is therefore the * master group while Groups-0 and 3 are the slave groups. It uses the SYNCCTR register for the configuration settings. * * \parRelated APIs:
* XMC_VADC_GROUP_SetSyncMaster()
* XMC_VADC_GROUP_CheckSlaveReadiness()
* XMC_VADC_GROUP_EnableChannelSyncRequest()
* */ void XMC_VADC_GROUP_SetSyncSlave(XMC_VADC_GROUP_t *const group_ptr, uint32_t master_grp, uint32_t slave_group); /** * * @param group_ptr Constant pointer to the VADC Group. * @param power_mode Desired power mode * * @return None * * \parDescription:
* Configures the power mode of a VADC group.\n\n For a VADC group to actually convert an analog signal, its analog * converter must be turned on. * * \parRelated APIs:
* None */ void XMC_VADC_GROUP_SetPowerMode(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_GROUP_POWERMODE_t power_mode); /** * * @param group_ptr Constant pointer to the VADC group. * * @return None * * \parDescription:
* Configures a VADC Group as a master group.
\n * Conversion of identically numbered channels across groups can be * synchronized. For example, when the trigger to convert CH-1 of Group-2 is received, it is possible to simultaneously * request conversion of CH-1 of Group-0 and Group-3. Group-2 in this example is therefore the master group while * Groups-0 and 3 are the slave groups. * * \parRelated APIs:
* None */ void XMC_VADC_GROUP_SetSyncMaster(XMC_VADC_GROUP_t *const group_ptr); /** * @param group_ptr Pointer to the master VADC Group * @param slave_group The slave VADC Group number *
Range: [0x0 to 0x3] * @return None * * \parDescription:
* Configures the ready signal for master group.
\n * This API would read the \b slave_group number and determine which EVAL configuration to apply for the given master * slave set. Checks the readiness of slaves in synchronized conversions. Conversion of identically numbered channels * across groups can be synchronized. For example, when the trigger to convert CH-1 of Group-2 is received, it is * possible to simultaneously request conversion of CH-1 of Group-0 and Group-3. Group-2 in this example is * therefore the master group while Groups-0 and 3 are the slave groups. Before the master can request its slaves * for synchronized conversion, it has the option of checking the readiness of the slaves. * * \parRelated APIs:
* XMC_VADC_GROUP_IgnoreSlaveReadiness()
XMC_VADC_GROUP_SetSyncMaster() */ void XMC_VADC_GROUP_CheckSlaveReadiness(XMC_VADC_GROUP_t *const group_ptr, uint32_t slave_group); /** * * @param group_ptr Constant Pointer to the master VADC Group * @param slave_group The slave VADC Group number * @return None * * \parDescription:
* Clears the ready signal for master group.
\n * Ignores the readiness of slaves in synchronized conversions.This API would read the \b slave_group number and * determine which EVAL configuration to apply for the given master slave set. Then clears the configuration if present. * This API is called when the master should issue the conversion request without waiting for the slave to * assert a ready signal. The ready signal is asserted by the slave group(s) when the conversion is completed * in these channels. * * \parRelated APIs:
* XMC_VADC_GROUP_CheckSlaveReadiness()
XMC_VADC_GROUP_SetSyncMaster()
*/ void XMC_VADC_GROUP_IgnoreSlaveReadiness(XMC_VADC_GROUP_t *const group_ptr, uint32_t slave_group); /** * * @param group_ptr Constant Pointer to the VADC Group waiting for ready signal * @param eval_waiting_group The VADC Group which expects a ready signal to start it's conversion. * @param eval_origin_group The VADC Group from which the eval_waiting_group will expect a ready signal * @return None * * \parDescription:
* Sets the ready signal in the eval_waiting_group .
\n * For Synchronized conversion all the slaves participating need to configure the ready signal. * A slave group will also need to configure the ready signals coming from the other slave groups. * A call to this API would configure the Sync.slave's EVAL Bits (GxSYNCTR.EVALy). * * \parRelated APIs:
* XMC_VADC_GROUP_CheckSlaveReadiness()
XMC_VADC_GROUP_IgnoreSlaveReadiness()
*/ void XMC_VADC_GROUP_SetSyncSlaveReadySignal(XMC_VADC_GROUP_t *const group_ptr, uint32_t eval_waiting_group, uint32_t eval_origin_group); /** * * @param group_ptr Constant Pointer to the VADC Group * @return * uint32_t EVAL bits for the group * * \parDescription:
* Get the Eval bits of the group.
\n * For Synchronized conversion the master's ready signal configuration must be copied onto the slaves. * A call to this API would return the Sync EVAL Bits (GxSYNCTR.EVALy) which can be used to set in the slaves. * * \parRelated APIs:
* XMC_VADC_GROUP_CheckSlaveReadiness()
XMC_VADC_GROUP_IgnoreSlaveReadiness()
*/ __STATIC_INLINE uint32_t XMC_VADC_GROUP_GetSyncReadySignal(XMC_VADC_GROUP_t *const group_ptr) { uint32_t eval_mask; XMC_ASSERT("XMC_VADC_GROUP_GetSyncReadySignal:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) #if (XMC_VADC_MAXIMUM_NUM_GROUPS > 2U) eval_mask = VADC_G_SYNCTR_EVALR1_Msk | VADC_G_SYNCTR_EVALR2_Msk | VADC_G_SYNCTR_EVALR3_Msk; #else eval_mask = VADC_G_SYNCTR_EVALR1_Msk; #endif return( group_ptr->SYNCTR & eval_mask); } /** * @param group_ptr Constant Pointer to the VADC Group * @param eval_mask mask to configure the eval bits * Use XMC_VADC_SYNCTR_EVAL_t to create the mask. * @return None * * \parDescription:
* Set the Eval bits of the group.
\n * For Synchronized conversion the master's ready signal configuration must be copied onto the slaves. * A call to this API would configure the Sync EVAL Bits (GxSYNCTR.EVALy). * * \parRelated APIs:
* XMC_VADC_GROUP_CheckSlaveReadiness()
XMC_VADC_GROUP_IgnoreSlaveReadiness()
*/ __STATIC_INLINE void XMC_VADC_GROUP_SetSyncReadySignal(XMC_VADC_GROUP_t *const group_ptr, uint32_t mask) { uint32_t eval_mask; XMC_ASSERT("XMC_VADC_GROUP_SetSyncReadySignal:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) #if (XMC_VADC_MAXIMUM_NUM_GROUPS > 2U) eval_mask = VADC_G_SYNCTR_EVALR1_Msk | VADC_G_SYNCTR_EVALR2_Msk | VADC_G_SYNCTR_EVALR3_Msk; #else eval_mask = VADC_G_SYNCTR_EVALR1_Msk; #endif group_ptr->SYNCTR &= ~(eval_mask); group_ptr->SYNCTR |= mask; } /** * * @param group_ptr Constant pointer to the master VADC Group * @param ch_num Channel whose conversion triggers conversion in slave groups * @return None * * \parDescription:
* Sets up a channel for synchronized conversion.\n\n Conversion of identically numbered channels across groups * can be synchronized. For example, when the trigger to * convert CH-1 of Group-2 is received, it is possible to simultaneously request conversion of CH-1 of Group-0 and * Group-3. Group-2 in this example is therefore the master group while Groups-0 and 3 are the slave groups.
* Before the master can request its slaves for synchronized conversion, it has the option of checking the readiness * of the slaves. * * \parRelated APIs:
* None */ void XMC_VADC_GROUP_EnableChannelSyncRequest(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num); /** * * @param group_ptr Pointer to the master VADC Group * @param ch_num Channel whose conversion triggers conversion in slave groups * @return None * * \parDescription:
* Disable the synchronization request for the particular channel specified as ch_num. To enable the synchronization * call the API @ref XMC_VADC_GROUP_EnableChannelSyncRequest(). * * \parRelated APIs:
* None */ void XMC_VADC_GROUP_DisableChannelSyncRequest(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num); /** * * @param group_ptr Constant pointer to the VADC group. * * @return retuns IDLE if converter is free else returns busy. Refer @ref XMC_VADC_GROUP_STATE_t enum * * \parDescription:
* Checks the live status of the analog to digital converter. The converter can either idle doing nothing or busy * sampling + converting. * * \parRelated APIs:
* None */ XMC_VADC_GROUP_STATE_t XMC_VADC_GROUP_IsConverterBusy(XMC_VADC_GROUP_t *const group_ptr); /** * * @param group_ptr Constant pointer to the VADC group whose global boundary registers are to be programmed * @param boundary0 Boundary-0 Value
* Range: [0x0 - 0x0FFF] * @param boundary1 Boundary-1 Value
* Range: [0x0 - 0x0FFF] * * @return None * * \parDescription:
* Programs the boundaries with \a boundary0 and boundary1 for result comparison.\n\n These two boundaries can serve as * absolute boundaries. They defines a range against which the result of a conversion can be compared. In the * fast compare mode, the two boundaries provide hysteresis capability to a compare value. In any case, these boundary * values entered here form a boundary pallete. There are dedicated upper and lower boundary registers G_BOUND0 and * G_BOUND1 who will derive their values from this palette. * * \parRelated APIs:
* None * */ void XMC_VADC_GROUP_SetBoundaries(XMC_VADC_GROUP_t *const group_ptr, const uint32_t boundary0, const uint32_t boundary1); /** * @param group_ptr Constant pointer to the VADC group * @param selection The boundary value selected for \b boundary_value. * @param boundary_value Select the boundary value. * @return * None * * \parDescription:
* Programs the boundary with \a boundary_value for result comparison.\n\n This defines a range against which * the result of a conversion can be compared. In the fast compare mode, the two boundaries provide hysteresis * capability to a compare value. * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_SetIndividualBoundary(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_CHANNEL_BOUNDARY_t selection, const uint16_t boundary_value); /** * @param group_ptr Constant pointer to the VADC group * @param sr_num The service request number (0 through 3) * @param type IRQ type (Kernel specific interrupt vs Module wide shared interrupt ) * @return None * * \parDescription:
* Activates a Service Request line(manually trigger).
\n * VADC provides few SR lines for each group and a few more which is shared across all the groups. * These SR lines can be connected to an NVIC node which in-turn would generate an interrupt. * This API would manually trigger the given SR line. Could be used for evaluation and testing purposes. * * \parRelated APIs:
* None */ void XMC_VADC_GROUP_TriggerServiceRequest(XMC_VADC_GROUP_t *const group_ptr, const uint32_t sr_num, const XMC_VADC_GROUP_IRQ_t type); /** * * @param group_ptr Constant pointer to the VADC group * @param emux_cfg EMUX configuration structure * @return None * * \parDescription:
* Configures group EMUX parameters associated with the \a emux_cfg configuration structure.\n\n An external emux * interface allows additional channels to be connected to a VADC group. The conversion properties * of such channels can be different from the standard channels which are directly connected to the VADC group. * This API configures conversion properties of channels connected via EMUX interface. * * \parRelated APIs:
* None */ __STATIC_INLINE void XMC_VADC_GROUP_ExternalMuxControlInit(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_GROUP_EMUXCFG_t emux_cfg) { uint32_t emux_config; XMC_ASSERT("XMC_VADC_GROUP_ExternalMuxControlInit:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) emux_config = ((uint32_t)emux_cfg.starting_external_channel << (uint32_t)VADC_G_EMUXCTR_EMUXSET_Pos) | ((uint32_t)emux_cfg.connected_channel << (uint32_t)VADC_G_EMUXCTR_EMUXCH_Pos); group_ptr->EMUXCTR = emux_config; emux_config = ((uint32_t)emux_cfg.emux_coding << (uint32_t)VADC_G_EMUXCTR_EMXCOD_Pos) | ((uint32_t)emux_cfg.emux_mode << (uint32_t)VADC_G_EMUXCTR_EMUXMODE_Pos)| ((uint32_t)emux_cfg.stce_usage << (uint32_t)VADC_G_EMUXCTR_EMXST_Pos); #if (XMC_VADC_EMUX_CH_SEL_STYLE == 1U) emux_config |= ((uint32_t)emux_cfg.emux_channel_select_style << (uint32_t)VADC_G_EMUXCTR_EMXCSS_Pos); #endif group_ptr->EMUXCTR |= (emux_config | ((uint32_t)VADC_G_EMUXCTR_EMXWC_Msk)) ; } #if XMC_VADC_BOUNDARY_FLAG_SELECT == 1U /** * @param group_ptr Constant pointer to the VADC group * @param boundary_flag_num The Boundary flag for which the interrupt node needs to be configured. * Range: [0x0 to 0x3] * @param node Service Request node Id * @return * None * * \parDescription:
* Connects the boundary event to the SR line of VADC or to a common boundary flag.
\n * This API will connect a Service Request line(SR) to a boundary event. Hence to get a interrupt on this * Service request line one has to enable the required NVIC node. A call to this API would configure the register bit * field GxBFLNP.BFLxNP. * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_SetBoundaryEventInterruptNode(XMC_VADC_GROUP_t *const group_ptr, const uint8_t boundary_flag_num, const XMC_VADC_BOUNDARY_NODE_t node); #endif /** * @param group_ptr Constant pointer to the VADC group * @return * uint32_t The complete GxALIAS register * * \parDescription:
* Returns the ALIAS values.\n The ALIAS value that is configured for Channel-0 and channel-1 are returned. * * \parRelated APIs:
* None. */ __STATIC_INLINE uint32_t XMC_VADC_GROUP_GetAlias(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_GetAliasWrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) return (group_ptr->ALIAS); } /** * @param group_ptr Constant pointer to the VADC group * @param conv_class conversion property to be extracted * @return * XMC_VADC_GROUP_CLASS_t The complete GxICLASSy register * * \parDescription:
* Returns the input class configuration values.\n * This returns the sampling time configuration and resolution configured in the appropriate group input class * \b conv_class. A call to this API would return the register GxICLASSy. * * \parRelated APIs:
* None. */ __STATIC_INLINE XMC_VADC_GROUP_CLASS_t XMC_VADC_GROUP_GetInputClass(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_CHANNEL_CONV_t conv_class) { XMC_VADC_GROUP_CLASS_t input_value; XMC_ASSERT("XMC_VADC_GROUP_GetInputClass:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_GetInputClass:Wrong conv_class selected", (XMC_VADC_CHANNEL_CONV_GROUP_CLASS0 == conv_class) || (XMC_VADC_CHANNEL_CONV_GROUP_CLASS1 == conv_class)) input_value.g_iclass0 = (uint32_t) 0xFFFFFFFF; if ((XMC_VADC_CHANNEL_CONV_GROUP_CLASS0 == conv_class) || (XMC_VADC_CHANNEL_CONV_GROUP_CLASS1 == conv_class)) { input_value.g_iclass0 = group_ptr->ICLASS[(uint32_t)conv_class]; } return (input_value); } #endif #if (XMC_VADC_GSCAN_AVAILABLE == 1U) /** * @param group_ptr Pointer to the VADC group * @param config Pointer to Scan configuration * @return None * * \parDescription:
* Initializes the VADC SCAN functional block.
\n * The GROUP SCAN request source functional block converts channels sequentially starting with the highest numbered * channel to the lowest. Channels must register themselves as being part of the the scan sequence. * A call to this API will first disable the arbitration slot for queue (XMC_VADC_GROUP_ScanEnableArbitrationSlot()) * and then it would configure all the related registers with the required configuration values. * The arbitration slot is re-enabled at the end of init by invoking XMC_VADC_GROUP_ScanDisableArbitrationSlot(). * A call to this API would configure the registers GxARBPR, GxASCTRL, GxASMR needed scan request source. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanEnableArbitrationSlot()
XMC_VADC_GROUP_ScanDisableArbitrationSlot()
* XMC_VADC_GROUP_ScanSelectTrigger()
XMC_VADC_GROUP_ScanSelectGating()
*/ void XMC_VADC_GROUP_ScanInit(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_SCAN_CONFIG_t *config); /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Enables arbitration slot of the scan request source.
\n * If the scan request source must have its conversion request considered by the arbiter, it must participate in * the arbitration rounds. Even if a load event occurs the scan channel can only be converted when the arbiter comes * to the scan slot. Thus this must be enabled if any conversion need to take place. * A call to this API would configure the register bit field GxARBPR.ASEN1. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanDisableArbitrationSlot()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ScanEnableArbitrationSlot(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanEnableArbitrationSlot:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ARBPR |= (uint32_t)VADC_G_ARBPR_ASEN1_Msk; } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Disables arbitration slot of the scan request source.
\n * If the scan request source must have its conversion request considered by the arbiter, it must participate in * the arbitration rounds. Even if a load event occurs the scan channel can only be converted when the arbiter comes * to the scan slot.A call to this API will lead to all conversions request by scan to be blocked. * A call to this API would configure the register bit field GxARBPR.ASEN1. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanEnableArbitrationSlot()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ScanDisableArbitrationSlot(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanDisableArbitrationSlot:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ARBPR &= ~((uint32_t)VADC_G_ARBPR_ASEN1_Msk); } /** * @param group_ptr Constant pointer to the VADC group * @return * bool returns true if the arbitration is enabled else returns false. * * \parDescription:
* Returns the arbitration status of the scan request source.
\n * If the scan request source must have its conversion request considered by the arbiter, it must participate in * the arbitration rounds. Even if a load event occurs the scan channel can only be converted when the arbiter comes * to the scan slot. A call to this API would return the status of the arbitration slot of scan. * A call to this API would read the register bit field GxARBPR.ASEN1. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanEnableArbitrationSlot(),
XMC_VADC_GROUP_ScanDisableArbitrationSlot()
*/ __STATIC_INLINE bool XMC_VADC_GROUP_ScanIsArbitrationSlotEnabled(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanIsArbitrationSlotEnabled:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) return ((group_ptr->ARBPR & (uint32_t)VADC_G_ARBPR_ASEN1_Msk) >> VADC_G_ARBPR_ASEN1_Pos); } /** * @param group_ptr Constant pointer to the VADC group * @param trigger_input Choice of the input earmarked as a trigger line * @return * None * * \parDescription:
* Select Trigger signal for scan request source.
\n * A scan request source will raise conversion request only if there were either a request from application or * occurrence of a hardware trigger. This API selects one of the 16 input lines as a trigger line. This is * needed when a hardware trigger is needed for the conversion of the scan request source. * Refer to the reference manual to determine the signal that needs to be connected. * A call to this API would configure the register bit field GxASCTRL.XTSEL. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanSelectGating()
XMC_VADC_GROUP_ScanEnableExternalTrigger()
*/ void XMC_VADC_GROUP_ScanSelectTrigger(XMC_VADC_GROUP_t *const group_ptr, XMC_VADC_TRIGGER_INPUT_SELECT_t trigger_input); /** * @param group_ptr Constant pointer to the VADC group * @param trigger_edge Trigger edge selection * @return * None * * \parDescription:
* Selects the trigger edge for scan request source.
\n * A scan request source will raise conversion request only if there were either a request from application or * occurrence of a hardware trigger. This API selects one of the 4 possible trigger edges. This is * needed when a hardware trigger is needed for the conversion of the scan request source. * A call to this API would configure the register bit field GxASCTRL.XTMODE. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanSelectTrigger()
*/ void XMC_VADC_GROUP_ScanSelectTriggerEdge(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_TRIGGER_EDGE_t trigger_edge); /** * @param group_ptr Constant pointer to the VADC group * @param gating_input Module input signal meant to be selected as gating input * @return * None * * \parDescription:
* Select Gating signal for scan request source.
\n * Passage of the trigger input to the request source can be controlled via a gating signal. Any one of the 16 input * lines can be chosen as a gating signal. Trigger signal can be given to the scan request source only * when the gating signal's active level is detected. Additionally the GxASMR.ENGT has to be configured for * the gating signal's active level. A call to this API would configure the register bit field GxASCTRL.GTSEL. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanSelectTrigger()
*/ void XMC_VADC_GROUP_ScanSelectGating(XMC_VADC_GROUP_t *const group_ptr, XMC_VADC_GATE_INPUT_SELECT_t gating_input); /** * @param group_ptr Constant pointer to the VADC group * @param mode_sel Select how the gating is applied to the scan request source * @return * None * * \parDescription:
* Selects the gating mode of scan request source.
\n * Passage of the trigger input to the request source can be controlled via a gating signal. * This API determines how the gating signal behaves, either active low or active high. * If gating signal needs to ignored XMC_VADC_GATEMODE_IGNORE should be used as the \a mode_sel. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanSelectGating(); */ __STATIC_INLINE void XMC_VADC_GROUP_ScanSetGatingMode(XMC_VADC_GROUP_t *const group_ptr, XMC_VADC_GATEMODE_t mode_sel) { XMC_ASSERT("XMC_VADC_GROUP_ScanSetGatingMode:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_ScanSetGatingMode:Wrong mode selected", (mode_sel <= XMC_VADC_GATEMODE_ACTIVELOW)) /* Clear the existing gate configuration */ group_ptr->ASMR &= (uint32_t) (~((uint32_t)VADC_G_ASMR_ENGT_Msk)); /* Set the new gating mode */ group_ptr->ASMR |= (uint32_t)((uint32_t)mode_sel << VADC_G_ASMR_ENGT_Pos); } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Enables continuous conversion mode.
\n * Typically for a scan request source to generate conversion request, either a hardware trigger or a software * request is a pre-requisite. Using autoscan feature it is possible to start the conversion once and allow the * sequence to repeat without any further triggers. Once all channels belonging to a scan request source have * been converted, a request source completion event is generated. Generation of this event can restart the scan * sequence. Every request source event will cause a load event to occur. A call to this API would configure * the register bit field GxASMR.SCAN. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanDisableContinuousMode()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ScanEnableContinuousMode(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanEnableContinuousMode:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ASMR |= (uint32_t)VADC_G_ASMR_SCAN_Msk; } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Disables continuous conversion mode.
\n * Typically for a scan request source to generate conversion request, either a hardware trigger or a software * request is a pre-requisite. Using autoscan feature it is possible to start the conversion once and allow the * sequence to repeat without any further triggers. Once all channels belonging to a scan request source have * been converted, a request source completion event is generated. Generation of this event can restart the scan * sequence. By invoking this feature the Autoscan mode of operations is disabled. A call to this API would configure * the register bit field GxASMR.SCAN. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanEnableContinuousMode()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ScanDisableContinuousMode(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanDisableContinuousMode:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ASMR &= ~((uint32_t)VADC_G_ASMR_SCAN_Msk); } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Generates conversion request (Software initiated conversion).
\n * A conversion request can be raised either upon detection of a hardware trigger, or by software. This API forces * the scan unit to generate a conversion request to the analog converter. It is assumed that the scan has already * been filled up with entries. A call to this API would configure the register bit field GxASMR.LDEV. * * \parRelated APIs:
* None. */ __STATIC_INLINE void XMC_VADC_GROUP_ScanTriggerConversion(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanTriggerConversion:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ASMR |= (uint32_t)VADC_G_ASMR_LDEV_Msk; } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Aborts an ongoing scan sequence conversion.
\n * An ongoing sequence can be aborted at any time. The scan unit picks the pending channels one by one from a * pending register and requests for their conversion. This API essentially clears the channel pending register thus * creating an illusion that there are no more channels left in the sequence. * A call to this API would configure the registers GxASMR, GxASCTRL, GxARBPR to achieve the sequence abort. * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_ScanSequenceAbort(XMC_VADC_GROUP_t *const group_ptr); /** * @param group_ptr Constant pointer to the VADC group * @param ch_num The channel meant to be added to scan sequence *
Range: [0x0 to 0x7] * @return * None * * \parDescription:
* Adds a channel to the scan sequence.
\n * Call this API to insert a new single channel into the scan request source. This will be added to the scan * sequence. The added channel will be part of the conversion sequence when the next load event occurs. * A call to this API would configure the register bit fields of GxASSEL. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanAddMultipleChannels()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ScanAddChannelToSequence(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num) { XMC_ASSERT("VADC_GSCAN_AddSingleChannel:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_ScanAddChannelToSequence:Wrong Channel Number", ((ch_num) < XMC_VADC_NUM_CHANNELS_PER_GROUP)) group_ptr->ASSEL |= (uint32_t)((uint32_t)1 << ch_num); } /** * @param group_ptr Constant pointer to the VADC group * @param ch_mask Mask word indicating channels which form part of scan conversion sequence * Bit location 0/1/2/3/4/5/6/7 represents channels-0/1/2/3/4/5/6/7 respectively. * To Add the channel to the scan sequence enable the respective bit. * Passing a 0x0 will clear all the selected channels *
Range: [0x0 to 0xFF] * @return * None * * \parDescription:
* Adds multiple channels to the scan sequence.
\n * Call this API to insert a multiple channels into the scan request source. This will be added to a scan * sequence. The added channels will be a part of the conversion sequence when the next load event occurs. * A call to this API would configure the register bit fields of GxASSEL. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanAddChannelToSequence()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ScanAddMultipleChannels(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_mask) { XMC_ASSERT("XMC_VADC_GROUP_ScanAddMultipleChannels:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ASSEL = ch_mask; } /** * @param group_ptr Constant pointer to the VADC group * @param ch_num The channel being audited for completion of conversion *
Range: [0x0 to 0x7] * @return * bool returns true if the channel is pending conversion else returns false * * \parDescription:
* Determine if the channel is pending for conversion.
\n * This API will check if the Channel in question is awaiting conversion in the current arbitration round. * When a load event occurs the scan sequence is pushed to a pending conversion register. * From the pending register the channels are taken up by the converter. This API would return true * if the channel is found in the pending register (GxASPND). * * \parRelated APIs:
* XMC_VADC_GROUP_ScanGetNumChannelsPending()
*/ __STATIC_INLINE bool XMC_VADC_GROUP_ScanIsChannelPending(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num) { XMC_ASSERT("XMC_VADC_GROUP_ScanIsChannelPending:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_ScanIsChannelPending:Wrong Channel Number", ((ch_num) < XMC_VADC_NUM_CHANNELS_PER_GROUP)) return( (bool)((uint32_t)(group_ptr->ASPND >> ch_num) & 1U)); } /** * @param group_ptr Constant pointer to the VADC group * @return
* uint32_t Returns the total channels pending for conversion. *
Range: [0x0 to 0x8] * * \parDescription:
* Returns the total number of pending channels.
\n * This API will read the pending channels register and will return the number of channels that are awaiting conversion. * When a load event occurs the scan sequence is pushed to a pending conversion register. * From the pending register the channels are taken up by the converter. When the API is called it would * return the total number of channels pending (GxASPND). * * \parRelated APIs:
* XMC_VADC_GROUP_ScanIsChannelPending()
*/ uint32_t XMC_VADC_GROUP_ScanGetNumChannelsPending(XMC_VADC_GROUP_t *const group_ptr); /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Manually asserts the conversion complete request source event.
\n * This API will set the request source event for scan. This will trigger a interrupt if the * service node pointer for the scan has been configured. * A call to this API would configure the register bit field GxSEFLAG.SEV1. * * \parRelated APIs:
* None. */ __STATIC_INLINE void XMC_VADC_GROUP_ScanTriggerReqSrcEvent(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanTriggerReqSrcEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->SEFLAG |= (uint32_t)VADC_G_SEFLAG_SEV1_Msk; } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Acknowledges the scan conversion complete request source event.
\n * This API will clear the request source event that occurred. This will clear a interrupt if it was raised. * A call to this API would configure the register bit field GxSEFLAG.SEV1. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanTriggerReqSrcEvent()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ScanClearReqSrcEvent(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanClearReqSrcEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->SEFCLR |= (uint32_t)VADC_G_SEFCLR_SEV1_Msk; } /** * @param group_ptr Constant pointer to the VADC group * @return * bool returns true if the service request event is raised. * returns false if the service request event was not raised. * * \parDescription:
* Determines if the request source event is asserted.
* This API will get the status of the scan request source event. Will return a true * if the event has occurred for scan. A call to this API would access the register bit field GxSEFLAG.SEV1. * * \parRelated APIs:
* None. */ __STATIC_INLINE bool XMC_VADC_GROUP_ScanGetReqSrcEventStatus(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GSCAN_GetRSEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) return( (bool)(group_ptr->SEFLAG & (uint32_t)VADC_G_SEFLAG_SEV1_Msk)); } /** * @param group_ptr Constant pointer to the VADC group * @param sr Service Request Id * @return * None * * \parDescription:
* Connects the scan request source event to the SR line of VADC.
\n * This API will connect a Service Request line(SR) to a scan request source event. Hence to get a interrupt on this * Service request line one has to enable the required NVIC node. A call to this API would configure the register bit * field GxSEVNP.SEV1NP . * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_ScanSetReqSrcEventInterruptNode(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_SR_t sr); /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Enables the trigger for scan request source.
\n * By using this API, the trigger signal will be activated for the scan request source. The trigger signal and trigger * edge will be selected from the ASCTRL register. The Selection of a input will be done by * XMC_VADC_GROUP_ScanSelectTrigger(). A call to this API would configure the register bit field GxASMR.ENTR. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanSelectTrigger()
XMC_VADC_GROUP_ScanDisableExternalTrigger()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ScanEnableExternalTrigger(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanEnableExternalTrigger:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ASMR |= (uint32_t)VADC_G_ASMR_ENTR_Msk; } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Disables the trigger for scan request source.
* By using this API the trigger will be deactivated for the scan request source. * This will just deactivate the H/W trigger for the scan request source. If any configuration were done * to select the trigger input in GxASCTRL, it will be not be effected by this API. * A call to this API would configure the register bit field GxASMR.ENTR. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanEnableExternalTrigger()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ScanDisableExternalTrigger(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanDisableExternalTrigger:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ASMR &= ~((uint32_t)VADC_G_ASMR_ENTR_Msk); } /** * @param group_ptr Constant pointer to the VADC group * @param channel_num channel number to be removed from the scan sequence. * @return * None * * \parDescription:
* Removes a channel from the scan sequence.
* By using this API the it is possible to remove a single channel from the conversion sequence. * The remaining channels will continue however they are. * A call to this API would configure the register GxASSEL. * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_ScanRemoveChannel(XMC_VADC_GROUP_t *const group_ptr, const uint32_t channel_num); /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Enables the scan request source event .
* By using this API the request source event will be activated for the scan request source. * Other configurations w.r.t service node pointer are not done in this API. * A call to this API would configure the register bit field GxASMR.ENSI. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanDisableEvent(),
XMC_VADC_GROUP_ScanSetReqSrcEventInterruptNode()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ScanEnableEvent(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanEnableEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ASMR |= ((uint32_t)VADC_G_ASMR_ENSI_Msk); } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Disables the scan request source event .
* By using this API the request source event will be deactivated for the scan request source. * Other configurations w.r.t service node pointer are not done in this API. * A call to this API would configure the register bit field GxASMR.ENSI. * * \parRelated APIs:
* XMC_VADC_GROUP_ScanEnableEvent(),
XMC_VADC_GROUP_ScanSetReqSrcEventInterruptNode()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ScanDisableEvent(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ScanDisableEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ASMR &= ~((uint32_t)VADC_G_ASMR_ENSI_Msk); } #endif /** * @param global_ptr Pointer to the VADC module * @param config Pointer to initialization data structure * * \parDescription:
* Initializes the Background scan functional block.
\n * The BACKGROUND SCAN request source functional block converts channels of all VADC groups that have not * been assigned as a priority channel (priority channels can be converted only by queue and scan). Background Scan * request source converts the unprioritized channels. Unprioritized channels however can also be used with queue * and scan. But a channel which is prioritized can not be used with background request source. * * \parRelated APIs:
* XMC_VADC_GROUP_BackgroundEnableArbitrationSlot()
XMC_VADC_GROUP_BackgroundDisableArbitrationSlot()
* XMC_VADC_GLOBAL_BackgroundSelectTrigger()
XMC_VADC_GLOBAL_BackgroundSelectGating()
*/ void XMC_VADC_GLOBAL_BackgroundInit(XMC_VADC_GLOBAL_t *const global_ptr, const XMC_VADC_BACKGROUND_CONFIG_t *config); #if (XMC_VADC_GROUP_AVAILABLE == 1U) /** * @param group_ptr Constant pointer to the VADC group which may receive a * conversion request from background request source * * @return * None * * \parDescription:
* Enables arbitration slot of the Background request source.
\n * If the Background request source must have its conversion request considered by the arbiter, it must participate in * the arbitration rounds. Even if a load event occurs the Background channel can only be converted when the arbiter * comes to the Background slot. Thus this must be enabled if any conversion need to take place. * A call to this API would configure the register bit field GxARBPR.ASEN2. * * \parRelated APIs:
* XMC_VADC_GROUP_BackgroundDisableArbitrationSlot()
*/ __STATIC_INLINE void XMC_VADC_GROUP_BackgroundEnableArbitrationSlot(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_BackgroundEnableArbitrationSlot:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ARBPR |= (uint32_t)VADC_G_ARBPR_ASEN2_Msk; } /** * @param group_ptr Constant pointer to the VADC group which may receive a conversion request * from background request source * @return * None * * \parDescription:
* Disables arbitration slot of the Background request source.
\n * If the Background request source must have its conversion request considered by the arbiter, it must participate in * the arbitration rounds. Even if a load event occurs the Background channel can only be converted when the arbiter * comes to the Background slot.A call to this API will lead to all conversions request by Background to be blocked. * A call to this API would configure the register bit field GxARBPR.ASEN2 * * \parRelated APIs:
* XMC_VADC_GROUP_BackgroundEnableArbitrationSlot()
*/ __STATIC_INLINE void XMC_VADC_GROUP_BackgroundDisableArbitrationSlot(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_BackgroundDisableArbitrationSlot:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->ARBPR &= ~((uint32_t)VADC_G_ARBPR_ASEN2_Msk); } #endif /** * @param global_ptr Pointer to the VADC module * @param input_num Choice of the input earmarked as a trigger line * Accepts enum ::XMC_VADC_TRIGGER_INPUT_SELECT_t * @return * None * * \parDescription:
* Select Trigger signal for Background request source.
\n * A Background request source will raise conversion request only if there were either a request from application or * occurrence of a hardware trigger. This API selects one of the 16 input lines as a trigger line. This is * needed when a hardware trigger is needed for the conversion of the Background request source. * Refer to the reference manual to determine the signal that needs to be connected. * A call to this API would configure the register bit field BRSCTRL.XTSEL. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundSelectGating()
XMC_VADC_GLOBAL_BackgroundEnableExternalTrigger()
*/ void XMC_VADC_GLOBAL_BackgroundSelectTrigger(XMC_VADC_GLOBAL_t *const global_ptr, const uint32_t input_num); /** * @param global_ptr Pointer to the VADC module * @param trigger_edge Select the trigger edge * @return * None * * \parDescription:
* Select Trigger edge for Background request source.
\n * A Background request source will raise conversion request only if there were either a request from application or * occurrence of a hardware trigger. This API selects one of the 4 possible values for the trigger edge. This is * needed when a hardware trigger is needed for the conversion of the Background request source. * A call to this API would configure the register bit field BRSCTRL.XTMODE. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundSelectGating()
XMC_VADC_GLOBAL_BackgroundEnableExternalTrigger()
*/ void XMC_VADC_GLOBAL_BackgroundSelectTriggerEdge(XMC_VADC_GLOBAL_t *const global_ptr, const XMC_VADC_TRIGGER_EDGE_t trigger_edge); /** * @param global_ptr Pointer to the VADC module * @param input_num Module input signal meant to be selected as gating input * Accepts enum ::XMC_VADC_GATE_INPUT_SELECT_t * @return * None * * \parDescription:
* Select Gating signal for Background request source.
\n * Passage of the trigger input to the request source can be controlled via a gating signal. Any one of the 16 input * lines can be chosen as a gating signal. Trigger signal can be given to the Background request source only * when the gating signal's active level is detected. Additionally the GxBRSMR.ENGT has to be configured for * the gating signal's active level. A call to this API would configure the register bit field BRSCTRL.GTSEL. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundSelectTrigger()
*/ void XMC_VADC_GLOBAL_BackgroundSelectGating(XMC_VADC_GLOBAL_t *const global_ptr, const uint32_t input_num); /** * @param global_ptr Pointer to the VADC module * @param mode_sel Select how the gating is applied to the background scan request source * @return * None * * Details of function
* Selects the gating mode of background request source.
\n * Passage of the trigger input to the request source can be controlled via a gating signal. * This API determines how the gating signal behaves, either active low or active high. * If gating signal needs to ignored XMC_VADC_GATEMODE_IGNORE should be used as the \a mode_sel. * A call to this API would configure the register bit field BRSMR.ENGT. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundSelectGating(); */ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundSetGatingMode(XMC_VADC_GLOBAL_t *const global_ptr, XMC_VADC_GATEMODE_t mode_sel) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundSetGatingMode:Wrong Module Pointer", (global_ptr == VADC)) XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundSetGatingMode:Wrong mode selected", (mode_sel <= XMC_VADC_GATEMODE_ACTIVELOW)) /* Clear the existing gate configuration */ global_ptr->BRSMR &= (uint32_t)(~((uint32_t)VADC_BRSMR_ENGT_Msk)); /* Configure the new gating mode*/ global_ptr->BRSMR |= (uint32_t)((uint32_t)mode_sel << VADC_BRSMR_ENGT_Pos); } /** * @param global_ptr Pointer to the VADC module * @return * None * * \parDescription:
* Enables continuous conversion mode.
\n * Typically for a Background request source to generate conversion request, either a hardware trigger or a software * request is needed. Using autoscan (continuous conversion)feature it is possible to start the conversion * once and allow the sequence to repeat without any further triggers. Once all channels belonging to a Background * request source have been converted, a request source completion event is generated. Generation of this event * can restart the Background configure sequence. Every request source event will cause a load event to occur. * A call to this API would access the register bit field BRSMR.SCAN. * * \parRelated APIs:
* XMC_VADC_GROUP_BackgroundDisableContinuousMode()
*/ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundEnableContinuousMode(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundEnableContinuousMode:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->BRSMR |= (uint32_t)VADC_BRSMR_SCAN_Msk; } /** * @param global_ptr Pointer to the VADC module * @return * None * * \parDescription:
* Disables continuous conversion mode.
\n * Typically for a Background request source to generate conversion request, either a hardware trigger or a software * request is a pre-requisite. Using autoscan feature it is possible to start the conversion once and allow the * sequence to repeat without any further triggers. Once all channels belonging to a Background request source have * been converted, a request source completion event is generated. Generation of this event can restart the Background * sequence. By invoking this API the Autoscan mode of operations is disabled. A call to this API would configure the * register bit field BRSMR.SCAN. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundEnableContinuousMode()
*/ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundDisableContinuousMode(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundDisableContinuousMode:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->BRSMR &= ~((uint32_t)VADC_BRSMR_SCAN_Msk); } /** * @param global_ptr Pointer to the VADC module * @return * None * * \parDescription:
* Generates conversion request (Software initiated conversion).
\n * A conversion request can be raised either upon detection of a hardware trigger, or by software. This API forces * the scan unit to generate a conversion request to the analog converter. It is assumed that the background scan * has already been filled up with entries. A call to this API would set the register bit field BRSMR.LDEV. * * \parRelated APIs:
* None. */ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundTriggerConversion(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundTriggerConversion:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->BRSMR |= (uint32_t)VADC_BRSMR_LDEV_Msk; } /** * @param global_ptr Pointer to the VADC module * @return * None * * \parDescription:
* Aborts an ongoing background scan conversion(sequence).
\n * An ongoing sequence can be aborted at any time. The scan unit picks the pending channels one by one from a * pending register and requests for their conversion. This API essentially clears the channel pending register thus * creating an illusion that there are no more channels left in the sequence. * A call to this API would configure the registers BRSMR, BRSCTRL, GxARBPR(if group is available) to abort the * current scan sequence. * * \parRelated APIs:
* None. */ void XMC_VADC_GLOBAL_BackgroundAbortSequence(XMC_VADC_GLOBAL_t *const global_ptr); /** * @param global_ptr Pointer to the VADC module * @param grp_num ID of the VADC group whose unprioritized channels have been assigned to background scan * Request source * @param ch_num The unprioritized channel meant to be added to the scan sequence *
Range: [0x0 to 0x7] * @return * None * * \parDescription:
* Adds a channel to the background scan sequence.
\n * Call this API to insert a new single channel into the background scan request source. This will be added to the scan * sequence. The added channel will be part of the conversion sequence when the next load event occurs. * A call to this API would configure the register bit fields of BRSSEL. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundAddMultipleChannels()
*/ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundAddChannelToSequence(XMC_VADC_GLOBAL_t *const global_ptr, const uint32_t grp_num, const uint32_t ch_num) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundAddChannelToSequence:Wrong Module Pointer", (global_ptr == VADC)) XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundAddChannelToSequence:Wrong Group Number",((grp_num) < XMC_VADC_MAXIMUM_NUM_GROUPS)) XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundAddChannelToSequence:Wrong Channel Number", ((ch_num) < XMC_VADC_NUM_CHANNELS_PER_GROUP)) global_ptr->BRSSEL[grp_num] |= (uint32_t)((uint32_t)1 << ch_num); } /** * @param global_ptr Pointer to the VADC module * @param grp_num ID of the VADC group whose unprioritized channels have been assigned to background scan * @param ch_mask Mask word indicating channels which form part of scan conversion sequence * Bit location 0/1/2/3/4/5/6/7 represents channels-0/1/2/3/4/5/6/7 respectively. * To Add the channel to the scan sequence enable the respective bit. * Passing a 0x0 will clear all the previously selected channels *
Range: [0x0 to 0xFF] * @return * None * * \parDescription:
* Adds multiple channels to the scan sequence.
\n * Call this API to insert a multiple channels into the scan request source. This will be added to a scan * sequence. The added channels will be a part of the conversion sequence when the next load event occurs. * A call to this API would configure the register bit fields of BRSSEL. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundAddChannelToSequence()
*/ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgndAddMultipleChannels(XMC_VADC_GLOBAL_t *const global_ptr, const uint32_t grp_num, const uint32_t ch_mask) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgndAddMultipleChannels:Wrong Module Pointer", (global_ptr == VADC)) XMC_ASSERT("XMC_VADC_GLOBAL_BackgndAddMultipleChannels:Wrong Group Number", ((grp_num) < XMC_VADC_MAXIMUM_NUM_GROUPS)) global_ptr->BRSSEL[grp_num] |= ch_mask; } /** * @param global_ptr Pointer to the VADC module * @param grp_num ID of the VADC group whose unprioritized channels have been assigned to background scan * Request source * @param ch_num The unprioritized channel meant to be added to the scan sequence *
Range: [0x0 to 0x7] * @return * None * * \parDescription:
* Removes a channel to the background scan sequence.
\n * Call this API to insert a new single channel into the background scan request source. This will be added to the scan * sequence. The added channel will be part of the conversion sequence when the next load event occurs. * A call to this API would configure the register bit fields of BRSSEL. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundAddChannelToSequence()
*/ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundRemoveChannelFromSequence(XMC_VADC_GLOBAL_t *const global_ptr, const uint32_t grp_num, const uint32_t ch_num) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundAddChannelToSequence:Wrong Module Pointer", (global_ptr == VADC)) XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundAddChannelToSequence:Wrong Group Number",((grp_num) < XMC_VADC_MAXIMUM_NUM_GROUPS)) XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundAddChannelToSequence:Wrong Channel Number", ((ch_num) < XMC_VADC_NUM_CHANNELS_PER_GROUP)) global_ptr->BRSSEL[grp_num] &= (uint32_t)~((uint32_t)1 << ch_num); } /** * @param global_ptr Pointer to the VADC module * @param grp_num ID of the VADC group whose unprioritized channels have been assigned to background scan * @param ch_mask Mask word indicating channels which form part of scan conversion sequence * Bit location 0/1/2/3/4/5/6/7 represents channels-0/1/2/3/4/5/6/7 respectively. * To Add the channel to the scan sequence enable the respective bit. * Passing a 0x0 will clear all the previously selected channels *
Range: [0x0 to 0xFF] * @return * None * * \parDescription:
* Removes multiple channels to the scan sequence.
\n * Call this API to insert a multiple channels into the scan request source. This will be added to a scan * sequence. The added channels will be a part of the conversion sequence when the next load event occurs. * A call to this API would configure the register bit fields of BRSSEL. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundAddChannelToSequence()
*/ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgndRemoveMultipleChannels(XMC_VADC_GLOBAL_t *const global_ptr, const uint32_t grp_num, const uint32_t ch_mask) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgndAddMultipleChannels:Wrong Module Pointer", (global_ptr == VADC)) XMC_ASSERT("XMC_VADC_GLOBAL_BackgndAddMultipleChannels:Wrong Group Number", ((grp_num) < XMC_VADC_MAXIMUM_NUM_GROUPS)) global_ptr->BRSSEL[grp_num] &= (uint32_t)~ch_mask; } /** * @param global_ptr Pointer to the VADC module * @param grp_num ID of the VADC group whose unprioritized channels have been assigned to background scan RS * @param ch_num The channel being audited for completion of conversion *
Range: [0x0 to 0x7] * @return * bool returns true if the channel is pending conversion else returns false * * \parDescription:
* Determine if the channel is pending.
\n * This API will check if the Channel in question is awaiting conversion in the current arbitration round. * When a load event occurs the scan sequence is pushed to a pending conversion register. * From the pending register the channels are taken up by the converter. This API would return true * if the channel is found in the pending register (BRSPND[\b grp_num]). * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundGetNumChannelsPending()
*/ __STATIC_INLINE bool XMC_VADC_GLOBAL_BackgroundIsChannelPending(XMC_VADC_GLOBAL_t *const global_ptr, const uint32_t grp_num, const uint32_t ch_num) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundIsChannelPending:Wrong Module Pointer", (global_ptr == VADC)) XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundIsChannelPending:Wrong Group Number", ((grp_num) < XMC_VADC_MAXIMUM_NUM_GROUPS)) XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundIsChannelPending:Wrong Channel Number", ((ch_num) < XMC_VADC_NUM_CHANNELS_PER_GROUP)) return( (bool)(global_ptr->BRSPND[grp_num] & (uint32_t)((uint32_t)1 << ch_num))); } /** * @param global_ptr Pointer to the VADC module * @return
* uint32_t Returns the total channels pending for conversion. *
Range: [0x0 to (0x8*number of groups)] * * \parDescription:
* Returns the number of pending channels.
\n * This API will read the pending channels register and will return the number of channels that are awaiting conversion. * When a load event occurs the scan sequence is pushed to a pending conversion register. * From the pending register the channels are taken up by the converter. When the API is called it would * return the total number of channels pending (BRSPND[\b grp_num]). * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundIsChannelPending()
*/ uint32_t XMC_VADC_GLOBAL_BackgroundGetNumChannelsPending(XMC_VADC_GLOBAL_t *const global_ptr); /** * @param global_ptr Pointer to the VADC module * @return * None * * \parDescription:
* Manually asserts the conversion complete request source event.
\n * This API will set the request source event for background scan. This will trigger a interrupt if the * service node pointer for the scan has been configured. * A call to this API would configure the register bit field GLOBEFLAG.SEVGLB. * * \parRelated APIs:
* None. */ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundTriggerReqSrcEvent(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundTriggerReqSrcEvent:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->GLOBEFLAG |= (uint32_t)VADC_GLOBEFLAG_SEVGLB_Msk; } /** * @param global_ptr Pointer to the VADC module * @return * None * * \parDescription:
* Acknowledges the background scan conversion complete request source event.
\n * This API will clear the request source event that occurred. This will clear a interrupt if it was raised. * A call to this API would configure the register bit field GLOBEFLAG.SEVGLB * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundTriggerReqSrcEvent()
*/ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundClearReqSrcEvent(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundClearReqSrcEvent:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->GLOBEFLAG |= (uint32_t)VADC_GLOBEFLAG_SEVGLBCLR_Msk; } /** * @param global_ptr Pointer to the VADC module * @return * bool returns true if the service request event is raised. * returns false if the service request event was not raised. * * \parDescription:
* Determines if the request source event is asserted.
* This API will get the status of the background scan request source event. Will return a true * if the event has occurred for background scan. A call to this API would configure the register * bit field GLOBEFLAG.SEVGLB. * * \parRelated APIs:
* None. */ __STATIC_INLINE bool XMC_VADC_GLOBAL_BackgroundGetReqSrcEventStatus(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundGetReqSrcEventStatus:Wrong Module Pointer", (global_ptr == VADC)) return((bool)(global_ptr->GLOBEFLAG & (uint32_t)VADC_GLOBEFLAG_SEVGLB_Msk)); } /** * @param global_ptr Pointer to the VADC module * @return * None * * \parDescription:
* Enables the trigger for background scan request source.
\n * By using this API the trigger will be activated for the scan request source. The trigger signal and trigger * edge will be selected from the BRSCTRL register. The Selection of a input will be done by * XMC_VADC_GLOBAL_BackgroundSelectTrigger(). A call to this API would configure the register bit field BRSMR.ENTR. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundSelectTrigger()
XMC_VADC_GLOBAL_BackgroundDisableExternalTrigger()
*/ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundEnableExternalTrigger(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundEnableExternalTrigger:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->BRSMR |= (uint32_t)VADC_BRSMR_ENTR_Msk; } /** * @param global_ptr Pointer to the VADC module * @return * None * * \parDescription:
* Disables the trigger for background scan request source.
* By using this API the trigger will be deactivated for the background scan request source. * This will just deactivate the H/W trigger for the background scan request source. If any configuration was done * to select the trigger input in BRSCTRL will be not be effected. A call to this API would configure the register * bit field BRSMR.ENTR. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundEnableExternalTrigger()
*/ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundDisableExternalTrigger(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundDisableExternalTrigger:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->BRSMR &= ~((uint32_t)VADC_BRSMR_ENTR_Msk); } /** * @param global_ptr Pointer to the VADC module * @return * None * * \parDescription:
* Enables the background scan request source event .
* By using this API the request source event will be activated for the background scan request source. * Other configurations w.r.t service node pointer are not done in this API. * A call to this API would configure the register bit field BRSMR.ENSI. * * \parRelated APIs:
* XMC_VADC_GLOBAL_BackgroundEnableEvent(),
XMC_VADC_GLOBAL_BackgroundSetReqSrcEventInterruptNode()
*/ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundEnableEvent(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundEnableEvent:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->BRSMR |= ((uint32_t)VADC_BRSMR_ENSI_Msk); } /** * @param global_ptr Pointer to the VADC module * @return * None * * \parDescription:
* Disables the background scan request source event .
* By using this API the request source event will be deactivated for the background scan request source. * Other configurations w.r.t service node pointer are not done in this API. * A call to this API would configure the register bit field BRSMR.ENSI. * * \parRelated APIs:
* XMC_VADC_GROUP_BackgroundEnableEvent(),
XMC_VADC_GLOBAL_BackgroundSetReqSrcEventInterruptNode()
*/ __STATIC_INLINE void XMC_VADC_GLOBAL_BackgroundDisableEvent(XMC_VADC_GLOBAL_t *const global_ptr) { XMC_ASSERT("XMC_VADC_GLOBAL_BackgroundDisableEvent:Wrong Module Pointer", (global_ptr == VADC)) global_ptr->BRSMR &= ~((uint32_t)VADC_BRSMR_ENSI_Msk); } #if (XMC_VADC_QUEUE_AVAILABLE == 1U) /** * @param group_ptr Pointer to the VADC group * @param config Pointer to initialization data structure * @return * None * * \parDescription:
* Initializes VADC QUEUE functional block.
\n * The QUEUE request source functional block converts channels stored in a queue. The first channel entered into the * queue is converted first. A channel once converted, can be placed back into the queue if desired(refill). * A call to this API will first disable the arbitration slot for queue (XMC_VADC_GROUP_QueueEnableArbitrationSlot()) * and then it would configure all the related registers with the required configuration values. * The arbitration slot is re-enabled at the end of init by invoking XMC_VADC_GROUP_QueueDisableArbitrationSlot(). * A call to this API would configure the registers GxARBPR, GxQCTRL0, GxQMR0 to configure the queue request * source. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueEnableArbitrationSlot()
XMC_VADC_GROUP_QueueDisableArbitrationSlot()
* XMC_VADC_GROUP_QueueSelectTrigger()
XMC_VADC_GROUP_QueueSelectGating()
*/ void XMC_VADC_GROUP_QueueInit(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_QUEUE_CONFIG_t *config); /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Enables arbitration slot of the queue request source.
\n * If the QUEUE request source must have its conversion request considered by the arbiter, it must participate in * the arbitration rounds. Even if a load event occurs the queue channel can only be converted when the arbiter comes * to the queue slot. Thus this must be enabled if any conversion need to take place. * A call to this API would configure the register bit field GxARBPR.ASEN0. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueDisableArbitrationSlot()
*/ __STATIC_INLINE void XMC_VADC_GROUP_QueueEnableArbitrationSlot(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_QueueEnableArbitrationSlot:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)); group_ptr->ARBPR |= (uint32_t)((uint32_t)1 << VADC_G_ARBPR_ASEN0_Pos); } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Disables arbitration slot of the queue request source.
\n * If the QUEUE request source must have its conversion request considered by the arbiter, it must participate in * the arbitration rounds. Even if a load event occurs the queue channel can only be converted when the arbiter comes * to the queue slot.A call to this API will lead to all conversions request by queue to be blocked. * A call to this API would configure the register bit field GxARBPR.ASEN0. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueEnableArbitrationSlot()
*/ __STATIC_INLINE void XMC_VADC_GROUP_QueueDisableArbitrationSlot(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_QueueDisableArbitrationSlot:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)); group_ptr->ARBPR &= ~((uint32_t)VADC_G_ARBPR_ASEN0_Msk); } /** * @param group_ptr Constant pointer to the VADC group * @return * bool returns true if the arbitration is enabled else returns false. * * \parDescription:
* Returns the arbitration status of the queue request source.
\n * If the queue request source must have its conversion request considered by the arbiter, it must participate in * the arbitration rounds. Even if a load event occurs the queue channel can only be converted when the arbiter comes * to the queue slot. A call to this API would return the status of the arbitration slot of queue. * A call to this API would read the register bit field GxARBPR.ASEN1. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueEnableArbitrationSlot(),
XMC_VADC_GROUP_QueueDisableArbitrationSlot()
*/ __STATIC_INLINE bool XMC_VADC_GROUP_QueueIsArbitrationSlotEnabled(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_QueueIsArbitrationSlotEnabled:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) return ((group_ptr->ARBPR & (uint32_t)VADC_G_ARBPR_ASEN0_Msk) >> VADC_G_ARBPR_ASEN0_Pos); } /** * @param group_ptr Constant pointer to the VADC group * @param input_num Choice of the input earmarked as a trigger line * @return * None * * \parDescription:
* Select Trigger signal for queue request source.
\n * A queue request source will raise conversion request only if there were either a request from application or * occurrence of a hardware trigger. This API selects one of the 16 input lines as a trigger line. This is * needed when a hardware trigger is needed for the conversion of the queue request source. * Refer to the reference manual to determine the signal that needs to be connected. * A call to this API would configure the register bit field GxQCTRL0.XTSEL. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueSelectGating()
XMC_VADC_GROUP_QueueEnableExternalTrigger()
*/ void XMC_VADC_GROUP_QueueSelectTrigger(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_TRIGGER_INPUT_SELECT_t input_num); /** * @param group_ptr Constant pointer to the VADC group * @param trigger_edge Choice of the trigger edge * @return * None * * \parDescription:
* Select Trigger signal edge for queue request source.
\n * A queue request source will raise conversion request only if there were either a request from application or * occurrence of a hardware trigger. This API selects one of the 4 trigger edges. This is * needed when a hardware trigger is needed for the conversion of the queue request source. * Refer to the reference manual to determine the signal that needs to be connected. * A call to this API would configure the register bit field GxQCTRL0.XTMODE. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueSelectGating()
XMC_VADC_GROUP_QueueEnableExternalTrigger()
*/ void XMC_VADC_GROUP_QueueSelectTriggerEdge(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_TRIGGER_EDGE_t trigger_edge); /** * @param group_ptr Constant pointer to the VADC group * @param input_num Choice of the input earmarked as the gating line * @return * None * * \parDescription:
* Select Gating signal for queue request source.
\n * Passage of the trigger input to the request source can be controlled via a gating signal. Any one of the 16 input * lines can be chosen as a gating signal. Trigger signal can be given to the queue request source only * when the gating signal's active level is detected. Additionally the GxQMR0.ENGT has to be configured for * the gating signal's active level. A call to this API would configure the register bit field GxQCTRL0.GTSEL. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueSelectTrigger()
*/ void XMC_VADC_GROUP_QueueSelectGating(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_GATE_INPUT_SELECT_t input_num); /** * @param group_ptr Constant pointer to the VADC group * @param mode_sel Select how the gating is applied to the queue request source * @return * None * * Details of function
* Selects the gating mode of queue request source.
\n * Passage of the trigger input to the request source can be controlled via a gating signal. * This API determines how the gating signal behaves, either active low or active high. * If gating signal needs to ignored XMC_VADC_GATEMODE_IGNORE should be used as the \a mode_sel. * A call to this API would configure the register bit field GxQMR0.ENGT. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueSelectGating(); */ __STATIC_INLINE void XMC_VADC_GROUP_QueueSetGatingMode(XMC_VADC_GROUP_t *const group_ptr, XMC_VADC_GATEMODE_t mode_sel) { XMC_ASSERT("XMC_VADC_GROUP_QueueSetGatingMode:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_QueueSetGatingMode:Wrong mode selected", (mode_sel <= XMC_VADC_GATEMODE_ACTIVELOW)) /* Clear the existing gate configuration */ group_ptr->QMR0 &= (uint32_t)(~((uint32_t) VADC_G_QMR0_ENGT_Msk)); /* Set the new gating mode */ group_ptr->QMR0 |= (uint32_t)((uint32_t)mode_sel << VADC_G_QMR0_ENGT_Pos); } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Generates conversion request (Software initiated conversion).
* A conversion request can be raised either upon detection of a hardware trigger, or by software. This API forces * the queue unit to generate a conversion request to the analog converter. It is assumed that the queue has already * been filled up with entries. A call to this API would configure the register bit field GxQMR0.TREV. * * \parNote:
* The conversion of queue entry will start immediately after the entry has been loaded into GxQINR0. * This happens only if the queue entry has been loaded into the register without the need for the H/W trigger.\n * If a H/W Trigger is selected while loading the entry, the conversion will occur in one of the 2 ways: *
    *
  • The H/W generates a trigger needed for the queue request source. *
  • The Conversion is triggered manually by calling this API. *
* * \parRelated APIs:
* XMC_VADC_GROUP_QueueInsertChannel()
*/ __STATIC_INLINE void XMC_VADC_GROUP_QueueTriggerConversion(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_QueueTriggerConversion:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->QMR0 |= (uint32_t)((uint32_t)1 << VADC_G_QMR0_TREV_Pos); } /** * @param group_ptr Constant pointer to the VADC group * @return * uint32_t returns the total number of channels. *
Range: [0x0 to 0x8] * * \parDescription:
* Returns the number of channels present in the queue.
\n * This API will return the queue buffer size. This buffer will be consisting of valid queue entries which * will be converted when a trigger event occurs. All the entries that are loaded onto the GxQINR0 will * be added to the queue buffer. Hence if an application needs to get the number of valid queue entries * this API would provide the interface. A call to this API would access the registers GxQBUR0, GxQSR0 in order * to determine the queue length. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueInsertChannel()
*/ uint32_t XMC_VADC_GROUP_QueueGetLength(XMC_VADC_GROUP_t *const group_ptr); /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Aborts an ongoing conversion by flushing the queue.
\n * This API will flush the queue buffer. Ongoing conversion of the Queue request source will * not be effected by this API. This would clear all the contents that are present in the queue buffer. * A call to this API would configure the registers GxQCTRL0, GxQMR0, GxARBPR in order to abort * the queue sequence. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueRemoveChannel()
XMC_VADC_GROUP_QueueFlushEntries()
*/ void XMC_VADC_GROUP_QueueAbortSequence(XMC_VADC_GROUP_t *const group_ptr); /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Flushing the queue Entry.
\n * This API will flush one entry in the queue buffer. Ongoing conversion of the Queue request source will * not be effected by this API. This would clear all the contents that are present in the queue buffer. * A call to this API would configure the registers GxQMR0. This is a Blocking API, i.e will only exit when * all the entries are removed from the queue. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueRemoveChannel()
XMC_VADC_GROUP_QueueAbortSequence(0
*/ __STATIC_INLINE void XMC_VADC_GROUP_QueueFlushEntries(XMC_VADC_GROUP_t *const group_ptr) { /* Initiate flushing of the queue */ group_ptr->QMR0 |= (uint32_t)VADC_G_QMR0_FLUSH_Msk; while( !((group_ptr->QSR0)& (uint32_t)VADC_G_QSR0_EMPTY_Msk)) { /* Wait until the queue is indeed flushed */ } } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Clears the next valid channel in the queue buffer.
\n * A queue entry lined up for conversion can be removed and replaced by its successor. The call to this API will * first check if a valid queue entry is present in the queue backup register if present would clear its valid flag. * If no valid queue entries are present in the backup then the first channel * present in the queue buffer would be cleared. * A call to this API would configure the registers GxQCTRL0, GxQMR0, GxARBPR in order to clear a * channel from the queue. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueInsertChannel()
*/ void XMC_VADC_GROUP_QueueRemoveChannel(XMC_VADC_GROUP_t *const group_ptr); /** * * @param group_ptr Constant pointer to the VADC group * @param entry Details of the node being added * @return * None * * \parDescription:
* Inserts a queue entry to the tail of the queue buffer.
\n * This API will insert a new channel into the queue buffer. The Queue will start conversion of * the channels from the head of the buffer. This Insert will place the entry after the last valid entry. * If no valid entries are present then this API will place the Queue entry at the head of the buffer. * Then the successive call to the insert will place the new entry after the last entry. * A call to this API would configure the register GxQINR0 for a single queue entry. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueRemoveChannel()
*/ __STATIC_INLINE void XMC_VADC_GROUP_QueueInsertChannel(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_QUEUE_ENTRY_t entry) { XMC_ASSERT("XMC_VADC_GROUP_QueueInsertChannel:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) /* Insert the channel physically and get the length of the queue*/ group_ptr->QINR0 = entry.qinr0; } /** * @param group_ptr Constant pointer to the VADC group * @return * int32_t Returns -1 if there are no channels for conversion * Else would return the next valid channel for conversion. *
Range: [0x0 to 0x8] * * \parDescription:
* Returns the next entry in the queue request source for conversion.
\n * Identifies the channel in the queue lined up for conversion next. * API will return a valid queue entry from the queue buffer. First checks for the valid channel entry * in the backup register and returns if present. If the valid entry has not been found in the backup register * then the queue buffer is searched for a valid entry. A call to this API would access the registers GxQ0R0, * GxQBUR0 to determine the next channel. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueRemoveChannel()
XMC_VADC_GROUP_QueueInsertChannel()
*/ int32_t XMC_VADC_GROUP_QueueGetNextChannel(XMC_VADC_GROUP_t *const group_ptr); /** * @param group_ptr Constant pointer to the VADC group * @return * int32_t Returns -1 if there is no channel that have been interrupted. * Else would return the channel that is interrupted. *
Range: [0x0 to 0x8] * * \parDescription:
* Identifies the channel whose conversion was suspended.
\n * When using cancel inject repeat mode the canceled conversion will be placed in the backup register. * This API will return the valid queue channel number from the backup register. This happens when ever * there is a high priority conversion interrupts the conversion of queue request source. This forces the channel * to goto the backup register. A call to this API would access the register GxQBUR0 to determine the * interrupted channel. * * \parRelated APIs:
* None. */ int32_t XMC_VADC_GROUP_QueueGetInterruptedChannel(XMC_VADC_GROUP_t *const group_ptr); /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Manually asserts the conversion complete request source event.
\n * This API will set the request source event for queue. This will trigger a interrupt if the * service node pointer for the scan has been configured. * A call to this API would configure the register bit field GxSEFLAG.SEV0. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueClearReqSrcEvent()
*/ __STATIC_INLINE void XMC_VADC_GROUP_QueueTriggerReqSrcEvent(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_QueueTriggerReqSrcEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->SEFLAG |= 1U; } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Acknowledges the conversion complete request source event.
\n * This API will clear the request source event that occurred. This will clear a interrupt if it was raised. * A call to this API would configure the register bit field GxSEFCLR.SEV0. * * \parRelated APIs:
* XMC_VADC_GROUP_QueueTriggerReqSrcEvent()
*/ __STATIC_INLINE void XMC_VADC_GROUP_QueueClearReqSrcEvent(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_QueueClearReqSrcEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->SEFCLR = (uint32_t)VADC_G_SEFCLR_SEV0_Msk; } /** * @param group_ptr Constant pointer to the VADC group * @return * bool returns true if the service request event is raised. * returns false if the service request event was not raised. * * \parDescription:
* Determines if the request source event is asserted.
* This API will get the status of the queue request source event. Will return a true * if the event has occurred for queue. A call to this API would acces the register bit field GxSEFLAG.SEV0. * * \parRelated APIs:
* None. */ __STATIC_INLINE bool XMC_VADC_GROUP_QueueGetReqSrcEventStatus(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_QueueGetReqSrcEventStatus:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) return(group_ptr->SEFLAG & (uint32_t)VADC_G_SEFLAG_SEV0_Msk); } /** * @param group_ptr Constant pointer to the VADC group * @param sr The service request line (Common SR lines, Group specific SR lines) * @return * None * * \parDescription:
* Connects the event to the SR line of VADC.
\n * This API will connect a Service Request line(SR) to a queue request source event. Hence to get a interrupt on this * Service request line one has to enable the required NVIC node. A call to this API would configure the register * bit field GxSEVNP.SEVNP0. * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_QueueSetReqSrcEventInterruptNode(XMC_VADC_GROUP_t *const group_ptr, const XMC_VADC_SR_t sr); /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Enables the trigger for queue request source.
\n * By using this API the trigger will be activated for the queue request source. The trigger signal and trigger * edge will be selected from the QCTRL register. The Selection of a input will be done by * XMC_VADC_GROUP_QueueSelectTrigger(). A call to this API would configure the register bit field GxQMR0.ENTR * * \parRelated APIs:
* XMC_VADC_GROUP_QueueSelectTrigger()
XMC_VADC_GROUP_QueueDisableExternalTrigger()
*/ __STATIC_INLINE void XMC_VADC_GROUP_QueueEnableExternalTrigger(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_QueueEnableExternalTrigger:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->QMR0 |= (uint32_t)VADC_G_QMR0_ENTR_Msk; } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Disables the trigger for queue request source.
* By using this API the trigger will be deactivated for the queue request source. * This will just deactivate the H/W trigger for the queue request source. If any configuration was done * to select the trigger input in GxQCTRL0 will be not be effected. A call to this API would configure the * register bit field GxQMR0.ENTR * * \parRelated APIs:
* XMC_VADC_GROUP_QueueEnableExternalTrigger()
*/ __STATIC_INLINE void XMC_VADC_GROUP_QueueDisableExternalTrigger(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_QueueDisableExternalTrigger:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->QMR0 &= ~((uint32_t)VADC_G_QMR0_ENTR_Msk); } #endif #if (XMC_VADC_GROUP_AVAILABLE == 1U) /** * @param group_ptr Constant pointer to the VADC group * @param ch_num The channel being initialized *
Range: [0x0 to 0x7] * @param config Pointer to initialization data * @return * None * * \parDescription:
* Initializes the ADC channel for conversion.
\n * This API will do the channel related initializations. This includes configuration of the CHCTR settings * and boundary flag settings. This must be called in the application in order to enable the conversion of * a channel. After a request source has been initialized this API has to be called for each channel that * has to be converted. A call to this API would configure the registers GxCHCTR GxBFL GxALIAS GxCHASS * GxBFLC(depending on device) in order to configure the channel. * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_ChannelInit(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num, const XMC_VADC_CHANNEL_CONFIG_t *config); /** * @param group_ptr Constant pointer to the VADC group * @param src_ch_num Channel which will be converted by \b alias_ch_num, when called by the request source. *
Range:[0x0 to 0x7] * @param alias_ch_num This is the alias channel (Ch-0 or Ch-1) *
Range:[0x0, 0x1] * @return * None * * \parDescription:
* Sets the Alias channel(\b alias_ch_num) to convert from the source channel(\b src_ch_num).
\n * When a alias configuration takes place the request source(queue/scan/background) will not call channel \b src_ch_num. * The Request sources will call the channel \b alias_ch_num , this would invoke the conversion of * the pin associated with \b src_ch_num. The configuration of the alias channel (\b alias_ch_num) will be used * for the conversion.\n * When an alias channel (Ch-0 or Ch-1) receives a trigger, it converts the aliased channel (\b src_ch_num). * The properties of Ch-0 or Ch-1 (as indicated in \b alias_ch_num ) apply when \b src_ch_num is converted. * A call to this API would configure the register GxALIAS. * * \parNote:
* Alias Channel (\b alias_ch_num) and the source channel (\b src_ch_num) cannot be the same. * If they are, that alias feature is not used for the conversion. In order to Reset the alias * feature that was previously selected this method can be used. * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_SetChannelAlias(XMC_VADC_GROUP_t *const group_ptr, const uint32_t src_ch_num, const uint32_t alias_ch_num); /** * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose input was converted *
Range: [0x0 to 0x7] * @return * bool Returns true if there was violation w.r.t the specified boundaries. * * \parDescription:
* Determines if the result of the channel confines with the specified boundaries.
\n * An application may not necessarily always need to know the exact value of the converted result, but merely * an indication if the generated result is within stipulated boundaries. Generation of Channel event can be subject * to channel event generation criteria (Generate always, Never generate, Generate if result is out of bounds, * Generate if result is within bounds). When interrupts are not enabled, this API can be used to determine the * nature of the result. A call to this API would access the registers GxCHCTR and GxCEFLAG in order to determine * if a violation has occured. * * \parRelated APIs:
* None */ bool XMC_VADC_GROUP_ChannelIsResultOutOfBounds(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num); /** * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose input is to be converted *
Range: [0x0 to 0x7] * @param ref Reference voltage * @return * None * * \parDescription:
* Selects the reference voltage for conversion.
\n * An internal voltage reference (VARef) or an external voltage reference fed to Ch-0 can serve as a voltage reference * for conversions. A call to this API would configure the register bit field GxCHCTR.REFSEL. * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_ChannelSetInputReference(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num, const XMC_VADC_CHANNEL_REF_t ref); /** * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose i/p is to be converted *
Range: [0x0 to 0x7] * @param result_reg_num Result Register associated with this channel * @return * None * * \parDescription:
* Selects the target result register.
\n * There are upto 16 result registers which a channel can choose from to store the results of conversion. * This selects only the group related result registers. A call to this API would configure the register * bit field GxCHCTR.RESREG. * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_ChannelSetResultRegister(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num, const uint32_t result_reg_num); /** * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose conversion class is to be configured *
Range: [0x0 to 0x7] * @param conversion_class conversion property to be associated with this channel * @return * None * * \parDescription:
* Selects the conversion class registers.
\n * It configures the channel to have a particular conversion class properties like sampling * time and resolution. A call to this API would configure the register * bit field GxCHCTR.ICLSEL. * * \parRelated APIs:
* XMC_VADC_GROUP_ChannelGetInputClass(). */ void XMC_VADC_GROUP_ChannelSetIclass(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num, const XMC_VADC_CHANNEL_CONV_t conversion_class); /** * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose result alignment is to be returned *
Range: [0x0 to 0x7] * @return * XMC_VADC_RESULT_ALIGN_LEFT if the result are aligned to the left * XMC_VADC_RESULT_ALIGN_RIGHT if the result are aligned to the right * * \parDescription:
* Returns the channel result alignment.
\n * The results are aligned either to the left or to the right. A left aligned 10bit resolution has its LSB * at bit2 where as a left aligned 8bit resolution starts at bit4. A call to this API would return the currently * configured alignment value. * A call to this API would read the register bit field GxCHCTR.RESPOS. * * \parRelated APIs:
* None. */ __STATIC_INLINE XMC_VADC_RESULT_ALIGN_t XMC_VADC_GROUP_ChannelGetResultAlignment(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num) { XMC_ASSERT("XMC_VADC_GROUP_ChannelGetResultAlignment:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_ChannelGetResultAlignment:Wrong Channel Number", ((ch_num) < XMC_VADC_NUM_CHANNELS_PER_GROUP)) return ((XMC_VADC_RESULT_ALIGN_t)((group_ptr->CHCTR[ch_num] & (uint32_t)VADC_G_CHCTR_RESPOS_Msk) >> (uint32_t)VADC_G_CHCTR_RESPOS_Pos) ); } /** * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose result alignment is to be returned *
Range: [0x0 to 0x7] * @return * XMC_VADC_CHANNEL_CONV_t Returns the configured input class for the \b ch_num * * \parDescription:
* Returns the channel's input class for conversion for the required channel.
\n * The sampling time and resolution can be taken from any of the 4 possible Input class registers. * This API would return the input class register that is taken up by \b ch_num for conversion. * A call to this API would read the register bit field GxCHCTR.RESPOS. * * \parRelated APIs:
* XMC_VADC_GROUP_ChannelSetIclass(). */ __STATIC_INLINE XMC_VADC_CHANNEL_CONV_t XMC_VADC_GROUP_ChannelGetInputClass(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num) { XMC_ASSERT("XMC_VADC_GROUP_ChannelGetInputClass:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_ChannelGetInputClass:Wrong Channel Number", ((ch_num) < XMC_VADC_NUM_CHANNELS_PER_GROUP)) return ((XMC_VADC_CHANNEL_CONV_t)((group_ptr->CHCTR[ch_num] & (uint32_t)VADC_G_CHCTR_ICLSEL_Msk) >> (uint32_t)VADC_G_CHCTR_ICLSEL_Pos) ); } /** * * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose associated result register is to be found *
Range: [0x0 to 0x7] * @return * uint8_t returns the Group result register to which it is linked to. *
Range: [0x0 to 0xF] * * \parDescription:
* Returns the result register associated with this channel.
\n * There are upto 16 result registers which a channel can choose from to store the results of conversion. * This returns only the group related result registers. A call to this API would access the register * bit field GxCHCTR.RESREG. * * \parRelated APIs:
* None. */ uint8_t XMC_VADC_GROUP_ChannelGetResultRegister(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num); /** * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose channel event is to be asserted *
Range: [0x0 to 0x7] * @return * None * * \parDescription:
* Manually asserts a Channel event.
\n * It is merely the channel event which is asserted. For this asserted event to lead to an interrupt, it must * have been bound to an SR and that SR must have been enabled. It can potentially lead to an interrupt if the * SR line is connected to an NVIC node. A call to this API would configure the register bit fields of GxCEFLAG. * * \parRelated APIs:
* XMC_VADC_GROUP_ChannelClearEvent(). */ void XMC_VADC_GROUP_ChannelTriggerEvent(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num); /** * @param group_ptr Constant pointer to the VADC group * @return * uint32_t returns the asserted channel events * * \parDescription:
* Returns the Channel event flag register.
\n * The return is merely the channel events which are asserted. * A call to this API would read the register bit fields of GxCEFLAG. * * \parRelated APIs:
* XMC_VADC_GROUP_ChannelClearEvent(). */ __STATIC_INLINE uint32_t XMC_VADC_GROUP_ChannelGetAssertedEvents(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_ChannelGetAssertedEvents:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) return(group_ptr->CEFLAG); } /** * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose channel event is to be acknowledged *
Range: [0x0 to 0x7] * @return * None * * \parDescription:
* Acknowledges a Channel event.
\n * When a channel event is raised after the conversion of that channel, it has to be cleared. This API would clear * the Channel event of a particular channel if it has occurred. A call to this API would configure the register * bit fields of GxCEFCLR. * * \parRelated APIs:
* XMC_VADC_GROUP_ChannelTriggerEvent(). */ __STATIC_INLINE void XMC_VADC_GROUP_ChannelClearEvent(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num) { XMC_ASSERT("XMC_VADC_GROUP_ChannelClearEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_ChannelClearEvent:Wrong Channel Number", ((ch_num) < XMC_VADC_NUM_CHANNELS_PER_GROUP)) group_ptr->CEFCLR = (uint32_t)((uint32_t)1 << ch_num); } /** * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose channel event is to be connected to a service request line *
Range: [0x0 to 0x7] * @param sr The service request line to which the channel event is to be connected * @return * None * * \parDescription:
* Binds a channel event to a requested Service Request line.
\n * The channel event is connected to a service request line. For an event to result in an interrupt, this service * request line must be enabled in VADC and the NVIC node which this service request line is connected to must have * interrupt generation enabled. A call to this API would configure the register bit fields of GxCEVNP0. * * \parRelated APIs:
* XMC_VADC_GROUP_ChannelTriggerEvent()
XMC_VADC_GROUP_ChannelClearEvent() */ void XMC_VADC_GROUP_ChannelSetEventInterruptNode(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num, const XMC_VADC_SR_t sr); /** * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose channel event is being configured *
Range: [0x0 to 0x7] * @param criteria The condition under which the channel may assert its channel event * @return * None * * \parDescription:
* Defines the conditions under which a channel may assert its channel event.
\n * The channel event can be generated under the following conditions - Always, Never, Result Out of bounds and Result * inside the boundaries. A call to this API would configure the register bit field GxCHCTR.CHEVMODE. * * \parRelated APIs:
* XMC_VADC_GROUP_ChannelTriggerEvent()
XMC_VADC_GROUP_ChannelClearEvent()
* XMC_VADC_GROUP_ChannelSetEventInterruptNode()
*/ void XMC_VADC_GROUP_ChannelTriggerEventGenCriteria(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num, const XMC_VADC_CHANNEL_EVGEN_t criteria); /** * @param group_ptr Constant pointer to the VADC group * @param ch_num Channel whose channel event is being configured *
Range: [0x0 to 0x7] * @param boundary_sel Select the upper/lower boundary configuration . * @param selection The boundary value selected for \b boundary_sel. * @return * None * * \parDescription:
* Configure the boundary selection for the given channel
\n * The channel event can be generated under the following conditions - Always, Never, Result Out of bounds and Result * inside the boundaries. The boundary values to which results are compared can be selected from several sources. * A call to this API would configure the register bit field GxCHCTR.BNDSELL or GxCHCTR.BNDSELU . * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_ChannelSetBoundarySelection(XMC_VADC_GROUP_t *const group_ptr, const uint32_t ch_num, XMC_VADC_BOUNDARY_SELECT_t boundary_sel, XMC_VADC_CHANNEL_BOUNDARY_t selection); /** * @param group_ptr Constant pointer to the VADC group * @param res_reg_num Result register which is intended to be initialized *
Range: [0x0 to 0xF] * @param config Pointer to initialization data * @return * None * * \parDescription:
* Initializes a Group Result Register.
* Various options needed for the working of the result result will be configured with this API. * This would determine the result handling of the group registers. This API must be called after * the channel Init (XMC_VADC_GROUP_ChannelInit())to initialize the result register that is selected for the channel. * This API would also determine if the result register that is being configured has to a part of a FIFO buffer. * In this API one can also configure the various result handling options line FIR/IIR filters and it order. * Also configures the Data reduction to accumulate 2/3/4 results need to be done. This API will also configure * the result event generation. A call to this API would configure the register GxRCR with the \b config . * * \parRelated APIs:
* XMC_VADC_GROUP_AddResultToFifo()
XMC_VADC_GROUP_EnableResultEvent()
XMC_VADC_GROUP_DisableResultEvent()
*/ __STATIC_INLINE void XMC_VADC_GROUP_ResultInit(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg_num, const XMC_VADC_RESULT_CONFIG_t *config) { XMC_ASSERT("XMC_VADC_GROUP_ResultInit:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->RCR[res_reg_num] = config->g_rcr; } /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Register which is required to be a part of results FIFO *
Range: [0x0 to 0xF] * @return * None * * \parDescription:
* Adds result register to Result FIFO.
\n * Sometimes, the rate of consumption of results by application software may not match the rate at which the * results are produced. A Result FIFO thus helps a slow consumer to read out results without loss of data. * When a result register is added to fifo, it is in fact chained to its higher numbered neighbor. For example, if * Result Register-5 is to be added to FIFO, it gets chained to Result Register-6. Results are written to Register-6 * while the same can be read out of Register-5 leisurely by software. * A call to this API would configure the register bit field GxRCR.FEN. * * \parNote:
* The FIFO is always read by the software with the lowest numbered result register. * The hardware will write the results from the highest numbered result register. * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_AddResultToFifo(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg); /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register for which event generation is to be enabled *
Range: [0x0 to 0xF] * @return * None * * \parDescription:
* Enables result event generation.
\n * Once the results of conversion are available, the result event (which is being enabled in this function) * if connected to a service request line(Group or Shared service request) can lead to an interrupt. It is therefore * not only necessary to enable the event, but also to connect it to a service request line. The * service request generation capability must also be enabled and so should the corresponding NVIC node. * A call to this API would configure the register bit field GxRCR.SRGEN. * * \parRelated APIs:
* XMC_VADC_GROUP_SetResultInterruptNode(). */ __STATIC_INLINE void XMC_VADC_GROUP_EnableResultEvent(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg) { XMC_ASSERT("XMC_VADC_GROUP_EnableResultEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_EnableResultEvent:Wrong Result Register", ((res_reg) < XMC_VADC_NUM_RESULT_REGISTERS)) group_ptr->RCR[res_reg] |= (uint32_t)VADC_G_RCR_SRGEN_Msk; } /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register for which event generation is to be disabled *
Range: [0x0 to 0xF] * @return * None * * \parDescription:
* Disable result event generation.
\n * This would just disable the event. It would not alter anything w.r.t the SR line if it was configured. * A call to this API would configure the register bit field GxRCR.SRGEN. * * \parRelated APIs:
* XMC_VADC_GROUP_EnableResultEvent(). */ __STATIC_INLINE void XMC_VADC_GROUP_DisableResultEvent(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg) { XMC_ASSERT("XMC_VADC_GROUP_DisableResultEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_DisableResultEvent:Wrong Result Register", ((res_reg) < XMC_VADC_NUM_RESULT_REGISTERS)) group_ptr->RCR[res_reg] &= ~((uint32_t)VADC_G_RCR_SRGEN_Msk); } /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register from which the result of conversion is to be read out *
Range: [0x0 to 0xF] * @return * uint32_t returns the complete result register GxRESy. * * \parDescription:
* Returns the result register completely (result of conversion as well as other info).
\n * The Result register will have information regarding the channel that is requesting the conversion, * if the result is valid, if the fast compare bit, Data Reduction Counter, and the request source information. * All these information will be returned back. And if the user is polling for the result he can use the * result if the valid bit is set. A call to this API would return the complete register GxRES. * * \parRelated APIs:
* XMC_VADC_GROUP_GetResult(). */ __STATIC_INLINE uint32_t XMC_VADC_GROUP_GetDetailedResult(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg) { XMC_ASSERT("XMC_VADC_GROUP_GetDetailedResult:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_GetDetailedResult:Wrong Result Register", ((res_reg) < XMC_VADC_NUM_RESULT_REGISTERS)) return(group_ptr->RES[res_reg]); } /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register from which the result of conversion is to be read out *
Range: [0x0 to 0xF] * @return * XMC_VADC_RESULT_SIZE_t Result register values. *
Range:[ 0x0 to 0xFFF] (Result of single conversion. Accumulated results not considered for range) * * \parDescription:
* Returns the result of the conversion.
\n * This API will only return the result of the conversion and will strip out the other information that is present * in the result register. A call to this API would access the register bit field GxRES.RESULT. * * \parRelated APIs:
* XMC_VADC_GROUP_GetDetailedResult(). */ __STATIC_INLINE XMC_VADC_RESULT_SIZE_t XMC_VADC_GROUP_GetResult(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg) { XMC_ASSERT("XMC_VADC_GROUP_GetResult:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_GetResult:Wrong Result Register", ((res_reg) < XMC_VADC_NUM_RESULT_REGISTERS)) return ((XMC_VADC_RESULT_SIZE_t)group_ptr->RES[res_reg]); } /** * * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register for which the compare value is being set *
Range: [0x0 to 0xF] * @param compare_val The compare value itself *
Range: [0x0 to 0xFFF] * @return * None * * \parDescription:
* Configures the compare value (relevant to the Fast Compare Mode).
\n * A channel input can be converted and its value stored in its result register. Alternatively, the channel input can * be converted and compared against a compare value. This is the fast compare mode typically utilized by applications * that are not interested in absolute converted value of an analog input, but rather a binary decision on how the * input fares against a preset compare value. The channel should have had already chosen the correct ICLASS with * the fast compare mode enabled. \b compare_val would be the compare value on which FCM bit in the result * register will be set. The FCM bit will be set if the analog voltage is greater than the compare value. * A call to this API would configure the register bit field GxRES.RESULT. * * \parRelated APIs:
* XMC_VADC_GROUP_GetFastCompareResult(). */ void XMC_VADC_GROUP_SetResultFastCompareValue(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg, const XMC_VADC_RESULT_SIZE_t compare_val); /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register for which the compare value is being set *
Range: [0x0 to 0xF] * @return * ::XMC_VADC_FAST_COMPARE_t If the input is greater or lower than the compare value returns the appropriate enum. * if the valid flag was not set then it would return XMC_VADC_FAST_COMPARE_UNKNOWN. * * \parDescription:
* Determines the input is greater/lower than the compare value.
\n * This API determines if the input is greater/lower than the preset compare value. * A call to this API would access the register bit field GxRES.FCM. * * \parRelated APIs:
* XMC_VADC_GROUP_SetResultFastCompareValue(). */ XMC_VADC_FAST_COMPARE_t XMC_VADC_GROUP_GetFastCompareResult(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg); /** * * @param group_ptr Constant pointer to the VADC group * @param subtraction_val 12 bit subtraction value *
Range: [0x0 to 0xFFF] * @return * None * * \parDescription:
* Configures the subtraction value (relevant to the Difference Mode).
\n * A channel input can be converted and its value stored in its result register. Alternatively, the channel input can * be converted and subtracted with the value stored in GxRES[0]. This Difference Mode typically utilized by * applications that are not interested in absolute converted value of an analog input, but rather a difference of * converted values. Subtraction value will always be present in the GxRES[0] and thus this API would configure * that register. * * \parRelated APIs:
* None. */ void XMC_VADC_GROUP_SetResultSubtractionValue(XMC_VADC_GROUP_t *const group_ptr, const uint16_t subtraction_val); /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register for which the result event is being asserted *
Range: [0x0 to 0xF] * @return * None * * \parDescription:
* Manually asserts the result event.
\n * The result event must necessarily be connected to a SR line. The SR in turn must have been enabled along with the * corresponding NVIC node. Only then will the assertion of RES event lead to an interrupt. * A call to this API would access the register bit fieldS OF GxREFLAG. * * \parRelated APIs:
* XMC_VADC_GROUP_ClearResultEvent(). */ __STATIC_INLINE void XMC_VADC_GROUP_TriggerResultEvent(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg) { XMC_ASSERT("XMC_VADC_GROUP_TriggerResultEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_TriggerResultEvent:Wrong Result Register", ((res_reg) < XMC_VADC_NUM_RESULT_REGISTERS)) group_ptr->REFLAG = (uint32_t)((uint32_t)1 << res_reg); } /** * @param group_ptr Constant pointer to the VADC group * @return * uint32_t returns the asserted result events * * \parDescription:
* Returns the Result event flag register.
\n * The return is merely the result events which are asserted. * A call to this API would read the register bit fields of GxREFLAG. * * \parRelated APIs:
* XMC_VADC_GROUP_TriggerResultEvent(). */ __STATIC_INLINE uint32_t XMC_VADC_GROUP_GetAssertedResultEvents(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_GetAssertedResultEvents:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) return(group_ptr->REFLAG); } /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register for which the result event is being acknowledged *
Range: [0x0 to 0xF] * @return * None * * \parDescription:
* Acknowledges a Result event.
\n * When a Result event is raised after the conversion of that associated channel has produced a result and * it has to be cleared. This API would clear the Channel event of a particular channel if it has occurred. * A call to this API would access the register bit fields of GxREFCLR. * * \parRelated APIs:
* XMC_VADC_GROUP_ChannelTriggerEvent(). */ __STATIC_INLINE void XMC_VADC_GROUP_ClearResultEvent(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg) { XMC_ASSERT("XMC_VADC_GROUP_ClearResultEvent:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_ClearResultEvent:Wrong Result Register", ((res_reg) < XMC_VADC_NUM_RESULT_REGISTERS)) group_ptr->REFCLR = (uint32_t)((uint32_t)1 << res_reg); } /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register for which the result event is being asserted *
Range: [0x0 to 0xF] * @param sr The SR line to which the result event must be connected * @return * None * * \parDescription:
* Binds a result event to a requested Service Request line.
\n * The result event is connected to a service request line. For an event to result in an interrupt, this service * request line must be enabled in VADC and the NVIC node which this service request line is connected to must have * interrupt generation enabled. A call to this API would access the registers GxREVNP0 GxREVNP1. * * \parRelated APIs:
* XMC_VADC_GROUP_TriggerResultEvent()
XMC_VADC_GROUP_ClearResultEvent() */ void XMC_VADC_GROUP_SetResultInterruptNode(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg, const XMC_VADC_SR_t sr); /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register which forms a part of FIFO *
Range: [0x0 to 0xF] * @return * uint32_t returns the Result register number which is the tail of the FIFO,\b res_reg is apart of this FIFO. * * \parDescription:
* Returns the the FIFO tail (register from where to read the results).
\n * The analog converter writes to the head of the FIFO. It is the head of the FIFO which is bound to the channel. * Applications read the result from the tail of the FIFO. This API would return the result * register from where a user can call the API XMC_VADC_GROUP_GetResult() to read the result stored in the FIFO. * A call to this API would access the register bit field GxRCR.FEN. * * \parRelated APIs:
* XMC_VADC_GROUP_GetResultFifoHead()
*/ uint32_t XMC_VADC_GROUP_GetResultFifoTail(XMC_VADC_GROUP_t *const group_ptr, uint32_t res_reg); /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register which forms a part of fifo *
Range: [0x0 to 0xF] * @return * uint32_t returns the Result register number which is the head of the FIFO,\b res_reg is apart of this FIFO. * * \parDescription:
* Returns the the FIFO head (register to which the results are written by H/W).
\n * The analog converter writes to the head of the FIFO. It is the head of the FIFO which is bound to the channel. * Applications read the result from the tail of the FIFO. This API would just return the head of the FIFO * from where the results are being added to the FIFO. * A call to this API would access the register bit field GxRCR.FEN. * * \parRelated APIs:
* XMC_VADC_GROUP_GetResultFifoHead()
*/ uint32_t XMC_VADC_GROUP_GetResultFifoHead(XMC_VADC_GROUP_t *const group_ptr,const uint32_t res_reg); /** * * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register in question *
Range: [0x0 to 0xF] * @return * bool returns true if the \b res_reg is the FIFO head. * * \parDescription:
* Determines if the requested register is the head of a FIFO.
\n * The analog converter writes to the head of the FIFO. It is the head of the FIFO which is bound to the channel. * Applications read the result from the tail of the FIFO. * A call to this API would access the register bit field GxRCR.FEN. * * \parRelated APIs:
* XMC_VADC_GROUP_GetResultFifoHead()
*/ bool XMC_VADC_GROUP_IsResultRegisterFifoHead(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg); /** * * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Register number
*
Range: [0x0 to 0xF] * @return * bool returns true if the \b res_reg is the FIFO member, else false. * * \parDescription:
* Determines whether the specified register is a FIFO member or not.
\n * The analog converter writes to the head of the FIFO. It is the head of the FIFO which is bound to the channel. * Applications read the result from the tail of the FIFO. * A call to this API would access the register bit field GxRCR.FEN. * */ __STATIC_INLINE bool XMC_VADC_GROUP_IsResultRegisterInFifo(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_reg) { XMC_ASSERT("XMC_VADC_GROUP_IsResultRegisterInFifo:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) XMC_ASSERT("XMC_VADC_GROUP_IsResultRegisterInFifo:Wrong Result Register", ((res_reg) < XMC_VADC_NUM_RESULT_REGISTERS)) return( (bool)(group_ptr->RCR[res_reg] & (uint32_t)VADC_G_RCR_FEN_Msk)); } #if XMC_VADC_RESULT_PRIORITY_AVAILABLE == 1U /** * @param group_ptr Constant pointer to the VADC group * @param res_reg Result Registers which need to be set for priority conversions * Bit location 0..15 represents Result Register-0..15 respectively. * To add the result register as priority. * Passing a 0x0 will clear all the selected channels *
Range: [0x0 to 0xFFFF] * @return * None * * \parDescription:
* Prioritize a Result register for group conversions.
\n * Applications that need to reserve certain result registers only for Queue and scan request sources should * use this API. A call to this API would access the register bit fields of GxRRASS. * * \parRelated APIs:
* XMC_VADC_GROUP_GetResultRegPriority(). */ __STATIC_INLINE void XMC_VADC_GROUP_SetResultRegPriority(XMC_VADC_GROUP_t *const group_ptr, const uint32_t res_mask) { XMC_ASSERT("XMC_VADC_GROUP_SetResultRegPriority:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) group_ptr->RRASS = (uint32_t)res_mask; } /** * @param group_ptr Constant pointer to the VADC group * @return * None * * \parDescription:
* Get the priority of all Result register.
\n * A call to this API would access the register bit fields of GxRRASS. * * \parRelated APIs:
* XMC_VADC_GROUP_SetResultRegPriority(). */ __STATIC_INLINE uint32_t XMC_VADC_GROUP_GetResultRegPriority(XMC_VADC_GROUP_t *const group_ptr) { XMC_ASSERT("XMC_VADC_GROUP_GetResultRegPriority:Wrong Group Pointer", XMC_VADC_CHECK_GROUP_PTR(group_ptr)) return(group_ptr->RRASS); } #endif #endif #ifdef __cplusplus } #endif /** * @} */ /** * @} */ #endif