sensor-watch/watch-library/hri/hri_evsys_l22.h
2021-08-02 14:36:04 -04:00

1334 lines
39 KiB
C

/**
* \file
*
* \brief SAM EVSYS
*
* Copyright (c) 2017-2018 Microchip Technology Inc. and its subsidiaries.
*
* \asf_license_start
*
* \page License
*
* Subject to your compliance with these terms, you may use Microchip
* software and any derivatives exclusively with Microchip products.
* It is your responsibility to comply with third party license terms applicable
* to your use of third party software (including open source software) that
* may accompany Microchip software.
*
* THIS SOFTWARE IS SUPPLIED BY MICROCHIP "AS IS". NO WARRANTIES,
* WHETHER EXPRESS, IMPLIED OR STATUTORY, APPLY TO THIS SOFTWARE,
* INCLUDING ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY,
* AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT WILL MICROCHIP BE
* LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL OR CONSEQUENTIAL
* LOSS, DAMAGE, COST OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE
* SOFTWARE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE
* POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT
* ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY
* RELATED TO THIS SOFTWARE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY,
* THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THIS SOFTWARE.
*
* \asf_license_stop
*
*/
#ifdef _SAML22_EVSYS_COMPONENT_
#ifndef _HRI_EVSYS_L22_H_INCLUDED_
#define _HRI_EVSYS_L22_H_INCLUDED_
#ifdef __cplusplus
extern "C" {
#endif
#include <stdbool.h>
#include <hal_atomic.h>
#if defined(ENABLE_EVSYS_CRITICAL_SECTIONS)
#define EVSYS_CRITICAL_SECTION_ENTER() CRITICAL_SECTION_ENTER()
#define EVSYS_CRITICAL_SECTION_LEAVE() CRITICAL_SECTION_LEAVE()
#else
#define EVSYS_CRITICAL_SECTION_ENTER()
#define EVSYS_CRITICAL_SECTION_LEAVE()
#endif
typedef uint32_t hri_evsys_channel_reg_t;
typedef uint32_t hri_evsys_chstatus_reg_t;
typedef uint32_t hri_evsys_intenset_reg_t;
typedef uint32_t hri_evsys_intflag_reg_t;
typedef uint32_t hri_evsys_swevt_reg_t;
typedef uint32_t hri_evsys_user_reg_t;
typedef uint8_t hri_evsys_ctrla_reg_t;
static inline bool hri_evsys_get_INTFLAG_OVR0_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR0) >> EVSYS_INTFLAG_OVR0_Pos;
}
static inline void hri_evsys_clear_INTFLAG_OVR0_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR0;
}
static inline bool hri_evsys_get_INTFLAG_OVR1_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR1) >> EVSYS_INTFLAG_OVR1_Pos;
}
static inline void hri_evsys_clear_INTFLAG_OVR1_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR1;
}
static inline bool hri_evsys_get_INTFLAG_OVR2_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR2) >> EVSYS_INTFLAG_OVR2_Pos;
}
static inline void hri_evsys_clear_INTFLAG_OVR2_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR2;
}
static inline bool hri_evsys_get_INTFLAG_OVR3_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR3) >> EVSYS_INTFLAG_OVR3_Pos;
}
static inline void hri_evsys_clear_INTFLAG_OVR3_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR3;
}
static inline bool hri_evsys_get_INTFLAG_OVR4_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR4) >> EVSYS_INTFLAG_OVR4_Pos;
}
static inline void hri_evsys_clear_INTFLAG_OVR4_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR4;
}
static inline bool hri_evsys_get_INTFLAG_OVR5_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR5) >> EVSYS_INTFLAG_OVR5_Pos;
}
static inline void hri_evsys_clear_INTFLAG_OVR5_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR5;
}
static inline bool hri_evsys_get_INTFLAG_OVR6_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR6) >> EVSYS_INTFLAG_OVR6_Pos;
}
static inline void hri_evsys_clear_INTFLAG_OVR6_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR6;
}
static inline bool hri_evsys_get_INTFLAG_OVR7_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR7) >> EVSYS_INTFLAG_OVR7_Pos;
}
static inline void hri_evsys_clear_INTFLAG_OVR7_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR7;
}
static inline bool hri_evsys_get_INTFLAG_EVD0_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD0) >> EVSYS_INTFLAG_EVD0_Pos;
}
static inline void hri_evsys_clear_INTFLAG_EVD0_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD0;
}
static inline bool hri_evsys_get_INTFLAG_EVD1_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD1) >> EVSYS_INTFLAG_EVD1_Pos;
}
static inline void hri_evsys_clear_INTFLAG_EVD1_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD1;
}
static inline bool hri_evsys_get_INTFLAG_EVD2_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD2) >> EVSYS_INTFLAG_EVD2_Pos;
}
static inline void hri_evsys_clear_INTFLAG_EVD2_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD2;
}
static inline bool hri_evsys_get_INTFLAG_EVD3_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD3) >> EVSYS_INTFLAG_EVD3_Pos;
}
static inline void hri_evsys_clear_INTFLAG_EVD3_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD3;
}
static inline bool hri_evsys_get_INTFLAG_EVD4_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD4) >> EVSYS_INTFLAG_EVD4_Pos;
}
static inline void hri_evsys_clear_INTFLAG_EVD4_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD4;
}
static inline bool hri_evsys_get_INTFLAG_EVD5_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD5) >> EVSYS_INTFLAG_EVD5_Pos;
}
static inline void hri_evsys_clear_INTFLAG_EVD5_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD5;
}
static inline bool hri_evsys_get_INTFLAG_EVD6_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD6) >> EVSYS_INTFLAG_EVD6_Pos;
}
static inline void hri_evsys_clear_INTFLAG_EVD6_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD6;
}
static inline bool hri_evsys_get_INTFLAG_EVD7_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD7) >> EVSYS_INTFLAG_EVD7_Pos;
}
static inline void hri_evsys_clear_INTFLAG_EVD7_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD7;
}
static inline bool hri_evsys_get_interrupt_OVR0_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR0) >> EVSYS_INTFLAG_OVR0_Pos;
}
static inline void hri_evsys_clear_interrupt_OVR0_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR0;
}
static inline bool hri_evsys_get_interrupt_OVR1_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR1) >> EVSYS_INTFLAG_OVR1_Pos;
}
static inline void hri_evsys_clear_interrupt_OVR1_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR1;
}
static inline bool hri_evsys_get_interrupt_OVR2_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR2) >> EVSYS_INTFLAG_OVR2_Pos;
}
static inline void hri_evsys_clear_interrupt_OVR2_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR2;
}
static inline bool hri_evsys_get_interrupt_OVR3_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR3) >> EVSYS_INTFLAG_OVR3_Pos;
}
static inline void hri_evsys_clear_interrupt_OVR3_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR3;
}
static inline bool hri_evsys_get_interrupt_OVR4_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR4) >> EVSYS_INTFLAG_OVR4_Pos;
}
static inline void hri_evsys_clear_interrupt_OVR4_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR4;
}
static inline bool hri_evsys_get_interrupt_OVR5_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR5) >> EVSYS_INTFLAG_OVR5_Pos;
}
static inline void hri_evsys_clear_interrupt_OVR5_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR5;
}
static inline bool hri_evsys_get_interrupt_OVR6_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR6) >> EVSYS_INTFLAG_OVR6_Pos;
}
static inline void hri_evsys_clear_interrupt_OVR6_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR6;
}
static inline bool hri_evsys_get_interrupt_OVR7_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_OVR7) >> EVSYS_INTFLAG_OVR7_Pos;
}
static inline void hri_evsys_clear_interrupt_OVR7_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_OVR7;
}
static inline bool hri_evsys_get_interrupt_EVD0_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD0) >> EVSYS_INTFLAG_EVD0_Pos;
}
static inline void hri_evsys_clear_interrupt_EVD0_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD0;
}
static inline bool hri_evsys_get_interrupt_EVD1_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD1) >> EVSYS_INTFLAG_EVD1_Pos;
}
static inline void hri_evsys_clear_interrupt_EVD1_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD1;
}
static inline bool hri_evsys_get_interrupt_EVD2_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD2) >> EVSYS_INTFLAG_EVD2_Pos;
}
static inline void hri_evsys_clear_interrupt_EVD2_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD2;
}
static inline bool hri_evsys_get_interrupt_EVD3_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD3) >> EVSYS_INTFLAG_EVD3_Pos;
}
static inline void hri_evsys_clear_interrupt_EVD3_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD3;
}
static inline bool hri_evsys_get_interrupt_EVD4_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD4) >> EVSYS_INTFLAG_EVD4_Pos;
}
static inline void hri_evsys_clear_interrupt_EVD4_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD4;
}
static inline bool hri_evsys_get_interrupt_EVD5_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD5) >> EVSYS_INTFLAG_EVD5_Pos;
}
static inline void hri_evsys_clear_interrupt_EVD5_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD5;
}
static inline bool hri_evsys_get_interrupt_EVD6_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD6) >> EVSYS_INTFLAG_EVD6_Pos;
}
static inline void hri_evsys_clear_interrupt_EVD6_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD6;
}
static inline bool hri_evsys_get_interrupt_EVD7_bit(const void *const hw)
{
return (((Evsys *)hw)->INTFLAG.reg & EVSYS_INTFLAG_EVD7) >> EVSYS_INTFLAG_EVD7_Pos;
}
static inline void hri_evsys_clear_interrupt_EVD7_bit(const void *const hw)
{
((Evsys *)hw)->INTFLAG.reg = EVSYS_INTFLAG_EVD7;
}
static inline hri_evsys_intflag_reg_t hri_evsys_get_INTFLAG_reg(const void *const hw, hri_evsys_intflag_reg_t mask)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->INTFLAG.reg;
tmp &= mask;
return tmp;
}
static inline hri_evsys_intflag_reg_t hri_evsys_read_INTFLAG_reg(const void *const hw)
{
return ((Evsys *)hw)->INTFLAG.reg;
}
static inline void hri_evsys_clear_INTFLAG_reg(const void *const hw, hri_evsys_intflag_reg_t mask)
{
((Evsys *)hw)->INTFLAG.reg = mask;
}
static inline void hri_evsys_set_INTEN_OVR0_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR0;
}
static inline bool hri_evsys_get_INTEN_OVR0_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_OVR0) >> EVSYS_INTENSET_OVR0_Pos;
}
static inline void hri_evsys_write_INTEN_OVR0_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR0;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR0;
}
}
static inline void hri_evsys_clear_INTEN_OVR0_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR0;
}
static inline void hri_evsys_set_INTEN_OVR1_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR1;
}
static inline bool hri_evsys_get_INTEN_OVR1_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_OVR1) >> EVSYS_INTENSET_OVR1_Pos;
}
static inline void hri_evsys_write_INTEN_OVR1_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR1;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR1;
}
}
static inline void hri_evsys_clear_INTEN_OVR1_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR1;
}
static inline void hri_evsys_set_INTEN_OVR2_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR2;
}
static inline bool hri_evsys_get_INTEN_OVR2_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_OVR2) >> EVSYS_INTENSET_OVR2_Pos;
}
static inline void hri_evsys_write_INTEN_OVR2_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR2;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR2;
}
}
static inline void hri_evsys_clear_INTEN_OVR2_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR2;
}
static inline void hri_evsys_set_INTEN_OVR3_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR3;
}
static inline bool hri_evsys_get_INTEN_OVR3_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_OVR3) >> EVSYS_INTENSET_OVR3_Pos;
}
static inline void hri_evsys_write_INTEN_OVR3_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR3;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR3;
}
}
static inline void hri_evsys_clear_INTEN_OVR3_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR3;
}
static inline void hri_evsys_set_INTEN_OVR4_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR4;
}
static inline bool hri_evsys_get_INTEN_OVR4_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_OVR4) >> EVSYS_INTENSET_OVR4_Pos;
}
static inline void hri_evsys_write_INTEN_OVR4_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR4;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR4;
}
}
static inline void hri_evsys_clear_INTEN_OVR4_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR4;
}
static inline void hri_evsys_set_INTEN_OVR5_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR5;
}
static inline bool hri_evsys_get_INTEN_OVR5_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_OVR5) >> EVSYS_INTENSET_OVR5_Pos;
}
static inline void hri_evsys_write_INTEN_OVR5_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR5;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR5;
}
}
static inline void hri_evsys_clear_INTEN_OVR5_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR5;
}
static inline void hri_evsys_set_INTEN_OVR6_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR6;
}
static inline bool hri_evsys_get_INTEN_OVR6_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_OVR6) >> EVSYS_INTENSET_OVR6_Pos;
}
static inline void hri_evsys_write_INTEN_OVR6_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR6;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR6;
}
}
static inline void hri_evsys_clear_INTEN_OVR6_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR6;
}
static inline void hri_evsys_set_INTEN_OVR7_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR7;
}
static inline bool hri_evsys_get_INTEN_OVR7_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_OVR7) >> EVSYS_INTENSET_OVR7_Pos;
}
static inline void hri_evsys_write_INTEN_OVR7_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR7;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_OVR7;
}
}
static inline void hri_evsys_clear_INTEN_OVR7_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_OVR7;
}
static inline void hri_evsys_set_INTEN_EVD0_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD0;
}
static inline bool hri_evsys_get_INTEN_EVD0_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_EVD0) >> EVSYS_INTENSET_EVD0_Pos;
}
static inline void hri_evsys_write_INTEN_EVD0_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD0;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD0;
}
}
static inline void hri_evsys_clear_INTEN_EVD0_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD0;
}
static inline void hri_evsys_set_INTEN_EVD1_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD1;
}
static inline bool hri_evsys_get_INTEN_EVD1_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_EVD1) >> EVSYS_INTENSET_EVD1_Pos;
}
static inline void hri_evsys_write_INTEN_EVD1_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD1;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD1;
}
}
static inline void hri_evsys_clear_INTEN_EVD1_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD1;
}
static inline void hri_evsys_set_INTEN_EVD2_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD2;
}
static inline bool hri_evsys_get_INTEN_EVD2_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_EVD2) >> EVSYS_INTENSET_EVD2_Pos;
}
static inline void hri_evsys_write_INTEN_EVD2_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD2;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD2;
}
}
static inline void hri_evsys_clear_INTEN_EVD2_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD2;
}
static inline void hri_evsys_set_INTEN_EVD3_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD3;
}
static inline bool hri_evsys_get_INTEN_EVD3_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_EVD3) >> EVSYS_INTENSET_EVD3_Pos;
}
static inline void hri_evsys_write_INTEN_EVD3_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD3;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD3;
}
}
static inline void hri_evsys_clear_INTEN_EVD3_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD3;
}
static inline void hri_evsys_set_INTEN_EVD4_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD4;
}
static inline bool hri_evsys_get_INTEN_EVD4_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_EVD4) >> EVSYS_INTENSET_EVD4_Pos;
}
static inline void hri_evsys_write_INTEN_EVD4_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD4;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD4;
}
}
static inline void hri_evsys_clear_INTEN_EVD4_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD4;
}
static inline void hri_evsys_set_INTEN_EVD5_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD5;
}
static inline bool hri_evsys_get_INTEN_EVD5_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_EVD5) >> EVSYS_INTENSET_EVD5_Pos;
}
static inline void hri_evsys_write_INTEN_EVD5_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD5;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD5;
}
}
static inline void hri_evsys_clear_INTEN_EVD5_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD5;
}
static inline void hri_evsys_set_INTEN_EVD6_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD6;
}
static inline bool hri_evsys_get_INTEN_EVD6_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_EVD6) >> EVSYS_INTENSET_EVD6_Pos;
}
static inline void hri_evsys_write_INTEN_EVD6_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD6;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD6;
}
}
static inline void hri_evsys_clear_INTEN_EVD6_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD6;
}
static inline void hri_evsys_set_INTEN_EVD7_bit(const void *const hw)
{
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD7;
}
static inline bool hri_evsys_get_INTEN_EVD7_bit(const void *const hw)
{
return (((Evsys *)hw)->INTENSET.reg & EVSYS_INTENSET_EVD7) >> EVSYS_INTENSET_EVD7_Pos;
}
static inline void hri_evsys_write_INTEN_EVD7_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD7;
} else {
((Evsys *)hw)->INTENSET.reg = EVSYS_INTENSET_EVD7;
}
}
static inline void hri_evsys_clear_INTEN_EVD7_bit(const void *const hw)
{
((Evsys *)hw)->INTENCLR.reg = EVSYS_INTENSET_EVD7;
}
static inline void hri_evsys_set_INTEN_reg(const void *const hw, hri_evsys_intenset_reg_t mask)
{
((Evsys *)hw)->INTENSET.reg = mask;
}
static inline hri_evsys_intenset_reg_t hri_evsys_get_INTEN_reg(const void *const hw, hri_evsys_intenset_reg_t mask)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->INTENSET.reg;
tmp &= mask;
return tmp;
}
static inline hri_evsys_intenset_reg_t hri_evsys_read_INTEN_reg(const void *const hw)
{
return ((Evsys *)hw)->INTENSET.reg;
}
static inline void hri_evsys_write_INTEN_reg(const void *const hw, hri_evsys_intenset_reg_t data)
{
((Evsys *)hw)->INTENSET.reg = data;
((Evsys *)hw)->INTENCLR.reg = ~data;
}
static inline void hri_evsys_clear_INTEN_reg(const void *const hw, hri_evsys_intenset_reg_t mask)
{
((Evsys *)hw)->INTENCLR.reg = mask;
}
static inline bool hri_evsys_get_CHSTATUS_USRRDY0_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_USRRDY0) >> EVSYS_CHSTATUS_USRRDY0_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_USRRDY1_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_USRRDY1) >> EVSYS_CHSTATUS_USRRDY1_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_USRRDY2_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_USRRDY2) >> EVSYS_CHSTATUS_USRRDY2_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_USRRDY3_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_USRRDY3) >> EVSYS_CHSTATUS_USRRDY3_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_USRRDY4_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_USRRDY4) >> EVSYS_CHSTATUS_USRRDY4_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_USRRDY5_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_USRRDY5) >> EVSYS_CHSTATUS_USRRDY5_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_USRRDY6_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_USRRDY6) >> EVSYS_CHSTATUS_USRRDY6_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_USRRDY7_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_USRRDY7) >> EVSYS_CHSTATUS_USRRDY7_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_CHBUSY0_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_CHBUSY0) >> EVSYS_CHSTATUS_CHBUSY0_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_CHBUSY1_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_CHBUSY1) >> EVSYS_CHSTATUS_CHBUSY1_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_CHBUSY2_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_CHBUSY2) >> EVSYS_CHSTATUS_CHBUSY2_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_CHBUSY3_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_CHBUSY3) >> EVSYS_CHSTATUS_CHBUSY3_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_CHBUSY4_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_CHBUSY4) >> EVSYS_CHSTATUS_CHBUSY4_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_CHBUSY5_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_CHBUSY5) >> EVSYS_CHSTATUS_CHBUSY5_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_CHBUSY6_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_CHBUSY6) >> EVSYS_CHSTATUS_CHBUSY6_Pos;
}
static inline bool hri_evsys_get_CHSTATUS_CHBUSY7_bit(const void *const hw)
{
return (((Evsys *)hw)->CHSTATUS.reg & EVSYS_CHSTATUS_CHBUSY7) >> EVSYS_CHSTATUS_CHBUSY7_Pos;
}
static inline hri_evsys_chstatus_reg_t hri_evsys_get_CHSTATUS_reg(const void *const hw, hri_evsys_chstatus_reg_t mask)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->CHSTATUS.reg;
tmp &= mask;
return tmp;
}
static inline hri_evsys_chstatus_reg_t hri_evsys_read_CHSTATUS_reg(const void *const hw)
{
return ((Evsys *)hw)->CHSTATUS.reg;
}
static inline void hri_evsys_set_CTRLA_SWRST_bit(const void *const hw)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CTRLA.reg |= EVSYS_CTRLA_SWRST;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_evsys_get_CTRLA_SWRST_bit(const void *const hw)
{
uint8_t tmp;
tmp = ((Evsys *)hw)->CTRLA.reg;
tmp = (tmp & EVSYS_CTRLA_SWRST) >> EVSYS_CTRLA_SWRST_Pos;
return (bool)tmp;
}
static inline void hri_evsys_set_CTRLA_reg(const void *const hw, hri_evsys_ctrla_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CTRLA.reg |= mask;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_ctrla_reg_t hri_evsys_get_CTRLA_reg(const void *const hw, hri_evsys_ctrla_reg_t mask)
{
uint8_t tmp;
tmp = ((Evsys *)hw)->CTRLA.reg;
tmp &= mask;
return tmp;
}
static inline void hri_evsys_write_CTRLA_reg(const void *const hw, hri_evsys_ctrla_reg_t data)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CTRLA.reg = data;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_clear_CTRLA_reg(const void *const hw, hri_evsys_ctrla_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CTRLA.reg &= ~mask;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_toggle_CTRLA_reg(const void *const hw, hri_evsys_ctrla_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CTRLA.reg ^= mask;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_ctrla_reg_t hri_evsys_read_CTRLA_reg(const void *const hw)
{
return ((Evsys *)hw)->CTRLA.reg;
}
static inline void hri_evsys_set_CHANNEL_RUNSTDBY_bit(const void *const hw, uint8_t index)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg |= EVSYS_CHANNEL_RUNSTDBY;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_evsys_get_CHANNEL_RUNSTDBY_bit(const void *const hw, uint8_t index)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp = (tmp & EVSYS_CHANNEL_RUNSTDBY) >> EVSYS_CHANNEL_RUNSTDBY_Pos;
return (bool)tmp;
}
static inline void hri_evsys_write_CHANNEL_RUNSTDBY_bit(const void *const hw, uint8_t index, bool value)
{
uint32_t tmp;
EVSYS_CRITICAL_SECTION_ENTER();
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp &= ~EVSYS_CHANNEL_RUNSTDBY;
tmp |= value << EVSYS_CHANNEL_RUNSTDBY_Pos;
((Evsys *)hw)->CHANNEL[index].reg = tmp;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_clear_CHANNEL_RUNSTDBY_bit(const void *const hw, uint8_t index)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg &= ~EVSYS_CHANNEL_RUNSTDBY;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_toggle_CHANNEL_RUNSTDBY_bit(const void *const hw, uint8_t index)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg ^= EVSYS_CHANNEL_RUNSTDBY;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_set_CHANNEL_ONDEMAND_bit(const void *const hw, uint8_t index)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg |= EVSYS_CHANNEL_ONDEMAND;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_evsys_get_CHANNEL_ONDEMAND_bit(const void *const hw, uint8_t index)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp = (tmp & EVSYS_CHANNEL_ONDEMAND) >> EVSYS_CHANNEL_ONDEMAND_Pos;
return (bool)tmp;
}
static inline void hri_evsys_write_CHANNEL_ONDEMAND_bit(const void *const hw, uint8_t index, bool value)
{
uint32_t tmp;
EVSYS_CRITICAL_SECTION_ENTER();
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp &= ~EVSYS_CHANNEL_ONDEMAND;
tmp |= value << EVSYS_CHANNEL_ONDEMAND_Pos;
((Evsys *)hw)->CHANNEL[index].reg = tmp;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_clear_CHANNEL_ONDEMAND_bit(const void *const hw, uint8_t index)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg &= ~EVSYS_CHANNEL_ONDEMAND;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_toggle_CHANNEL_ONDEMAND_bit(const void *const hw, uint8_t index)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg ^= EVSYS_CHANNEL_ONDEMAND;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_set_CHANNEL_EVGEN_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg |= EVSYS_CHANNEL_EVGEN(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_channel_reg_t hri_evsys_get_CHANNEL_EVGEN_bf(const void *const hw, uint8_t index,
hri_evsys_channel_reg_t mask)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp = (tmp & EVSYS_CHANNEL_EVGEN(mask)) >> EVSYS_CHANNEL_EVGEN_Pos;
return tmp;
}
static inline void hri_evsys_write_CHANNEL_EVGEN_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t data)
{
uint32_t tmp;
EVSYS_CRITICAL_SECTION_ENTER();
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp &= ~EVSYS_CHANNEL_EVGEN_Msk;
tmp |= EVSYS_CHANNEL_EVGEN(data);
((Evsys *)hw)->CHANNEL[index].reg = tmp;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_clear_CHANNEL_EVGEN_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg &= ~EVSYS_CHANNEL_EVGEN(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_toggle_CHANNEL_EVGEN_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg ^= EVSYS_CHANNEL_EVGEN(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_channel_reg_t hri_evsys_read_CHANNEL_EVGEN_bf(const void *const hw, uint8_t index)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp = (tmp & EVSYS_CHANNEL_EVGEN_Msk) >> EVSYS_CHANNEL_EVGEN_Pos;
return tmp;
}
static inline void hri_evsys_set_CHANNEL_PATH_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg |= EVSYS_CHANNEL_PATH(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_channel_reg_t hri_evsys_get_CHANNEL_PATH_bf(const void *const hw, uint8_t index,
hri_evsys_channel_reg_t mask)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp = (tmp & EVSYS_CHANNEL_PATH(mask)) >> EVSYS_CHANNEL_PATH_Pos;
return tmp;
}
static inline void hri_evsys_write_CHANNEL_PATH_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t data)
{
uint32_t tmp;
EVSYS_CRITICAL_SECTION_ENTER();
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp &= ~EVSYS_CHANNEL_PATH_Msk;
tmp |= EVSYS_CHANNEL_PATH(data);
((Evsys *)hw)->CHANNEL[index].reg = tmp;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_clear_CHANNEL_PATH_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg &= ~EVSYS_CHANNEL_PATH(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_toggle_CHANNEL_PATH_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg ^= EVSYS_CHANNEL_PATH(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_channel_reg_t hri_evsys_read_CHANNEL_PATH_bf(const void *const hw, uint8_t index)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp = (tmp & EVSYS_CHANNEL_PATH_Msk) >> EVSYS_CHANNEL_PATH_Pos;
return tmp;
}
static inline void hri_evsys_set_CHANNEL_EDGSEL_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg |= EVSYS_CHANNEL_EDGSEL(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_channel_reg_t hri_evsys_get_CHANNEL_EDGSEL_bf(const void *const hw, uint8_t index,
hri_evsys_channel_reg_t mask)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp = (tmp & EVSYS_CHANNEL_EDGSEL(mask)) >> EVSYS_CHANNEL_EDGSEL_Pos;
return tmp;
}
static inline void hri_evsys_write_CHANNEL_EDGSEL_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t data)
{
uint32_t tmp;
EVSYS_CRITICAL_SECTION_ENTER();
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp &= ~EVSYS_CHANNEL_EDGSEL_Msk;
tmp |= EVSYS_CHANNEL_EDGSEL(data);
((Evsys *)hw)->CHANNEL[index].reg = tmp;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_clear_CHANNEL_EDGSEL_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg &= ~EVSYS_CHANNEL_EDGSEL(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_toggle_CHANNEL_EDGSEL_bf(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg ^= EVSYS_CHANNEL_EDGSEL(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_channel_reg_t hri_evsys_read_CHANNEL_EDGSEL_bf(const void *const hw, uint8_t index)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp = (tmp & EVSYS_CHANNEL_EDGSEL_Msk) >> EVSYS_CHANNEL_EDGSEL_Pos;
return tmp;
}
static inline void hri_evsys_set_CHANNEL_reg(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg |= mask;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_channel_reg_t hri_evsys_get_CHANNEL_reg(const void *const hw, uint8_t index,
hri_evsys_channel_reg_t mask)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->CHANNEL[index].reg;
tmp &= mask;
return tmp;
}
static inline void hri_evsys_write_CHANNEL_reg(const void *const hw, uint8_t index, hri_evsys_channel_reg_t data)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg = data;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_clear_CHANNEL_reg(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg &= ~mask;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_toggle_CHANNEL_reg(const void *const hw, uint8_t index, hri_evsys_channel_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->CHANNEL[index].reg ^= mask;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_channel_reg_t hri_evsys_read_CHANNEL_reg(const void *const hw, uint8_t index)
{
return ((Evsys *)hw)->CHANNEL[index].reg;
}
static inline void hri_evsys_set_USER_CHANNEL_bf(const void *const hw, uint8_t index, hri_evsys_user_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->USER[index].reg |= EVSYS_USER_CHANNEL(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_user_reg_t hri_evsys_get_USER_CHANNEL_bf(const void *const hw, uint8_t index,
hri_evsys_user_reg_t mask)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->USER[index].reg;
tmp = (tmp & EVSYS_USER_CHANNEL(mask)) >> EVSYS_USER_CHANNEL_Pos;
return tmp;
}
static inline void hri_evsys_write_USER_CHANNEL_bf(const void *const hw, uint8_t index, hri_evsys_user_reg_t data)
{
uint32_t tmp;
EVSYS_CRITICAL_SECTION_ENTER();
tmp = ((Evsys *)hw)->USER[index].reg;
tmp &= ~EVSYS_USER_CHANNEL_Msk;
tmp |= EVSYS_USER_CHANNEL(data);
((Evsys *)hw)->USER[index].reg = tmp;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_clear_USER_CHANNEL_bf(const void *const hw, uint8_t index, hri_evsys_user_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->USER[index].reg &= ~EVSYS_USER_CHANNEL(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_toggle_USER_CHANNEL_bf(const void *const hw, uint8_t index, hri_evsys_user_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->USER[index].reg ^= EVSYS_USER_CHANNEL(mask);
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_user_reg_t hri_evsys_read_USER_CHANNEL_bf(const void *const hw, uint8_t index)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->USER[index].reg;
tmp = (tmp & EVSYS_USER_CHANNEL_Msk) >> EVSYS_USER_CHANNEL_Pos;
return tmp;
}
static inline void hri_evsys_set_USER_reg(const void *const hw, uint8_t index, hri_evsys_user_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->USER[index].reg |= mask;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_user_reg_t hri_evsys_get_USER_reg(const void *const hw, uint8_t index,
hri_evsys_user_reg_t mask)
{
uint32_t tmp;
tmp = ((Evsys *)hw)->USER[index].reg;
tmp &= mask;
return tmp;
}
static inline void hri_evsys_write_USER_reg(const void *const hw, uint8_t index, hri_evsys_user_reg_t data)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->USER[index].reg = data;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_clear_USER_reg(const void *const hw, uint8_t index, hri_evsys_user_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->USER[index].reg &= ~mask;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline void hri_evsys_toggle_USER_reg(const void *const hw, uint8_t index, hri_evsys_user_reg_t mask)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->USER[index].reg ^= mask;
EVSYS_CRITICAL_SECTION_LEAVE();
}
static inline hri_evsys_user_reg_t hri_evsys_read_USER_reg(const void *const hw, uint8_t index)
{
return ((Evsys *)hw)->USER[index].reg;
}
static inline void hri_evsys_write_SWEVT_reg(const void *const hw, hri_evsys_swevt_reg_t data)
{
EVSYS_CRITICAL_SECTION_ENTER();
((Evsys *)hw)->SWEVT.reg = data;
EVSYS_CRITICAL_SECTION_LEAVE();
}
#ifdef __cplusplus
}
#endif
#endif /* _HRI_EVSYS_L22_H_INCLUDED */
#endif /* _SAML22_EVSYS_COMPONENT_ */