You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
This repo is archived. You can view files and clone it, but cannot push or open issues/pull-requests.

2537 lines
66 KiB
C

/**
* \file
*
* \brief SAM PM
*
* 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 _SAMD21_PM_COMPONENT_
#ifndef _HRI_PM_D21_H_INCLUDED_
#define _HRI_PM_D21_H_INCLUDED_
#ifdef __cplusplus
extern "C" {
#endif
#include <stdbool.h>
#include <hal_atomic.h>
#if defined(ENABLE_PM_CRITICAL_SECTIONS)
#define PM_CRITICAL_SECTION_ENTER() CRITICAL_SECTION_ENTER()
#define PM_CRITICAL_SECTION_LEAVE() CRITICAL_SECTION_LEAVE()
#else
#define PM_CRITICAL_SECTION_ENTER()
#define PM_CRITICAL_SECTION_LEAVE()
#endif
typedef uint32_t hri_pm_ahbmask_reg_t;
typedef uint32_t hri_pm_apbamask_reg_t;
typedef uint32_t hri_pm_apbbmask_reg_t;
typedef uint32_t hri_pm_apbcmask_reg_t;
typedef uint8_t hri_pm_apbasel_reg_t;
typedef uint8_t hri_pm_apbbsel_reg_t;
typedef uint8_t hri_pm_apbcsel_reg_t;
typedef uint8_t hri_pm_cpusel_reg_t;
typedef uint8_t hri_pm_ctrl_reg_t;
typedef uint8_t hri_pm_intenset_reg_t;
typedef uint8_t hri_pm_intflag_reg_t;
typedef uint8_t hri_pm_rcause_reg_t;
typedef uint8_t hri_pm_sleep_reg_t;
static inline bool hri_pm_get_INTFLAG_CKRDY_bit(const void *const hw)
{
return (((Pm *)hw)->INTFLAG.reg & PM_INTFLAG_CKRDY) >> PM_INTFLAG_CKRDY_Pos;
}
static inline void hri_pm_clear_INTFLAG_CKRDY_bit(const void *const hw)
{
((Pm *)hw)->INTFLAG.reg = PM_INTFLAG_CKRDY;
}
static inline bool hri_pm_get_interrupt_CKRDY_bit(const void *const hw)
{
return (((Pm *)hw)->INTFLAG.reg & PM_INTFLAG_CKRDY) >> PM_INTFLAG_CKRDY_Pos;
}
static inline void hri_pm_clear_interrupt_CKRDY_bit(const void *const hw)
{
((Pm *)hw)->INTFLAG.reg = PM_INTFLAG_CKRDY;
}
static inline hri_pm_intflag_reg_t hri_pm_get_INTFLAG_reg(const void *const hw, hri_pm_intflag_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->INTFLAG.reg;
tmp &= mask;
return tmp;
}
static inline hri_pm_intflag_reg_t hri_pm_read_INTFLAG_reg(const void *const hw)
{
return ((Pm *)hw)->INTFLAG.reg;
}
static inline void hri_pm_clear_INTFLAG_reg(const void *const hw, hri_pm_intflag_reg_t mask)
{
((Pm *)hw)->INTFLAG.reg = mask;
}
static inline void hri_pm_set_INTEN_CKRDY_bit(const void *const hw)
{
((Pm *)hw)->INTENSET.reg = PM_INTENSET_CKRDY;
}
static inline bool hri_pm_get_INTEN_CKRDY_bit(const void *const hw)
{
return (((Pm *)hw)->INTENSET.reg & PM_INTENSET_CKRDY) >> PM_INTENSET_CKRDY_Pos;
}
static inline void hri_pm_write_INTEN_CKRDY_bit(const void *const hw, bool value)
{
if (value == 0x0) {
((Pm *)hw)->INTENCLR.reg = PM_INTENSET_CKRDY;
} else {
((Pm *)hw)->INTENSET.reg = PM_INTENSET_CKRDY;
}
}
static inline void hri_pm_clear_INTEN_CKRDY_bit(const void *const hw)
{
((Pm *)hw)->INTENCLR.reg = PM_INTENSET_CKRDY;
}
static inline void hri_pm_set_INTEN_reg(const void *const hw, hri_pm_intenset_reg_t mask)
{
((Pm *)hw)->INTENSET.reg = mask;
}
static inline hri_pm_intenset_reg_t hri_pm_get_INTEN_reg(const void *const hw, hri_pm_intenset_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->INTENSET.reg;
tmp &= mask;
return tmp;
}
static inline hri_pm_intenset_reg_t hri_pm_read_INTEN_reg(const void *const hw)
{
return ((Pm *)hw)->INTENSET.reg;
}
static inline void hri_pm_write_INTEN_reg(const void *const hw, hri_pm_intenset_reg_t data)
{
((Pm *)hw)->INTENSET.reg = data;
((Pm *)hw)->INTENCLR.reg = ~data;
}
static inline void hri_pm_clear_INTEN_reg(const void *const hw, hri_pm_intenset_reg_t mask)
{
((Pm *)hw)->INTENCLR.reg = mask;
}
static inline bool hri_pm_get_RCAUSE_POR_bit(const void *const hw)
{
return (((Pm *)hw)->RCAUSE.reg & PM_RCAUSE_POR) >> PM_RCAUSE_POR_Pos;
}
static inline bool hri_pm_get_RCAUSE_BOD12_bit(const void *const hw)
{
return (((Pm *)hw)->RCAUSE.reg & PM_RCAUSE_BOD12) >> PM_RCAUSE_BOD12_Pos;
}
static inline bool hri_pm_get_RCAUSE_BOD33_bit(const void *const hw)
{
return (((Pm *)hw)->RCAUSE.reg & PM_RCAUSE_BOD33) >> PM_RCAUSE_BOD33_Pos;
}
static inline bool hri_pm_get_RCAUSE_EXT_bit(const void *const hw)
{
return (((Pm *)hw)->RCAUSE.reg & PM_RCAUSE_EXT) >> PM_RCAUSE_EXT_Pos;
}
static inline bool hri_pm_get_RCAUSE_WDT_bit(const void *const hw)
{
return (((Pm *)hw)->RCAUSE.reg & PM_RCAUSE_WDT) >> PM_RCAUSE_WDT_Pos;
}
static inline bool hri_pm_get_RCAUSE_SYST_bit(const void *const hw)
{
return (((Pm *)hw)->RCAUSE.reg & PM_RCAUSE_SYST) >> PM_RCAUSE_SYST_Pos;
}
static inline hri_pm_rcause_reg_t hri_pm_get_RCAUSE_reg(const void *const hw, hri_pm_rcause_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->RCAUSE.reg;
tmp &= mask;
return tmp;
}
static inline hri_pm_rcause_reg_t hri_pm_read_RCAUSE_reg(const void *const hw)
{
return ((Pm *)hw)->RCAUSE.reg;
}
static inline void hri_pm_set_CTRL_reg(const void *const hw, hri_pm_ctrl_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->CTRL.reg |= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_ctrl_reg_t hri_pm_get_CTRL_reg(const void *const hw, hri_pm_ctrl_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->CTRL.reg;
tmp &= mask;
return tmp;
}
static inline void hri_pm_write_CTRL_reg(const void *const hw, hri_pm_ctrl_reg_t data)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->CTRL.reg = data;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_CTRL_reg(const void *const hw, hri_pm_ctrl_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->CTRL.reg &= ~mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_CTRL_reg(const void *const hw, hri_pm_ctrl_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->CTRL.reg ^= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_ctrl_reg_t hri_pm_read_CTRL_reg(const void *const hw)
{
return ((Pm *)hw)->CTRL.reg;
}
static inline void hri_pm_set_SLEEP_IDLE_bf(const void *const hw, hri_pm_sleep_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->SLEEP.reg |= PM_SLEEP_IDLE(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_sleep_reg_t hri_pm_get_SLEEP_IDLE_bf(const void *const hw, hri_pm_sleep_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->SLEEP.reg;
tmp = (tmp & PM_SLEEP_IDLE(mask)) >> PM_SLEEP_IDLE_Pos;
return tmp;
}
static inline void hri_pm_write_SLEEP_IDLE_bf(const void *const hw, hri_pm_sleep_reg_t data)
{
uint8_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->SLEEP.reg;
tmp &= ~PM_SLEEP_IDLE_Msk;
tmp |= PM_SLEEP_IDLE(data);
((Pm *)hw)->SLEEP.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_SLEEP_IDLE_bf(const void *const hw, hri_pm_sleep_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->SLEEP.reg &= ~PM_SLEEP_IDLE(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_SLEEP_IDLE_bf(const void *const hw, hri_pm_sleep_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->SLEEP.reg ^= PM_SLEEP_IDLE(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_sleep_reg_t hri_pm_read_SLEEP_IDLE_bf(const void *const hw)
{
uint8_t tmp;
tmp = ((Pm *)hw)->SLEEP.reg;
tmp = (tmp & PM_SLEEP_IDLE_Msk) >> PM_SLEEP_IDLE_Pos;
return tmp;
}
static inline void hri_pm_set_SLEEP_reg(const void *const hw, hri_pm_sleep_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->SLEEP.reg |= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_sleep_reg_t hri_pm_get_SLEEP_reg(const void *const hw, hri_pm_sleep_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->SLEEP.reg;
tmp &= mask;
return tmp;
}
static inline void hri_pm_write_SLEEP_reg(const void *const hw, hri_pm_sleep_reg_t data)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->SLEEP.reg = data;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_SLEEP_reg(const void *const hw, hri_pm_sleep_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->SLEEP.reg &= ~mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_SLEEP_reg(const void *const hw, hri_pm_sleep_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->SLEEP.reg ^= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_sleep_reg_t hri_pm_read_SLEEP_reg(const void *const hw)
{
return ((Pm *)hw)->SLEEP.reg;
}
static inline void hri_pm_set_CPUSEL_CPUDIV_bf(const void *const hw, hri_pm_cpusel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->CPUSEL.reg |= PM_CPUSEL_CPUDIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_cpusel_reg_t hri_pm_get_CPUSEL_CPUDIV_bf(const void *const hw, hri_pm_cpusel_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->CPUSEL.reg;
tmp = (tmp & PM_CPUSEL_CPUDIV(mask)) >> PM_CPUSEL_CPUDIV_Pos;
return tmp;
}
static inline void hri_pm_write_CPUSEL_CPUDIV_bf(const void *const hw, hri_pm_cpusel_reg_t data)
{
uint8_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->CPUSEL.reg;
tmp &= ~PM_CPUSEL_CPUDIV_Msk;
tmp |= PM_CPUSEL_CPUDIV(data);
((Pm *)hw)->CPUSEL.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_CPUSEL_CPUDIV_bf(const void *const hw, hri_pm_cpusel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->CPUSEL.reg &= ~PM_CPUSEL_CPUDIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_CPUSEL_CPUDIV_bf(const void *const hw, hri_pm_cpusel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->CPUSEL.reg ^= PM_CPUSEL_CPUDIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_cpusel_reg_t hri_pm_read_CPUSEL_CPUDIV_bf(const void *const hw)
{
uint8_t tmp;
tmp = ((Pm *)hw)->CPUSEL.reg;
tmp = (tmp & PM_CPUSEL_CPUDIV_Msk) >> PM_CPUSEL_CPUDIV_Pos;
return tmp;
}
static inline void hri_pm_set_CPUSEL_reg(const void *const hw, hri_pm_cpusel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->CPUSEL.reg |= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_cpusel_reg_t hri_pm_get_CPUSEL_reg(const void *const hw, hri_pm_cpusel_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->CPUSEL.reg;
tmp &= mask;
return tmp;
}
static inline void hri_pm_write_CPUSEL_reg(const void *const hw, hri_pm_cpusel_reg_t data)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->CPUSEL.reg = data;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_CPUSEL_reg(const void *const hw, hri_pm_cpusel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->CPUSEL.reg &= ~mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_CPUSEL_reg(const void *const hw, hri_pm_cpusel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->CPUSEL.reg ^= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_cpusel_reg_t hri_pm_read_CPUSEL_reg(const void *const hw)
{
return ((Pm *)hw)->CPUSEL.reg;
}
static inline void hri_pm_set_APBASEL_APBADIV_bf(const void *const hw, hri_pm_apbasel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBASEL.reg |= PM_APBASEL_APBADIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbasel_reg_t hri_pm_get_APBASEL_APBADIV_bf(const void *const hw, hri_pm_apbasel_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->APBASEL.reg;
tmp = (tmp & PM_APBASEL_APBADIV(mask)) >> PM_APBASEL_APBADIV_Pos;
return tmp;
}
static inline void hri_pm_write_APBASEL_APBADIV_bf(const void *const hw, hri_pm_apbasel_reg_t data)
{
uint8_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBASEL.reg;
tmp &= ~PM_APBASEL_APBADIV_Msk;
tmp |= PM_APBASEL_APBADIV(data);
((Pm *)hw)->APBASEL.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBASEL_APBADIV_bf(const void *const hw, hri_pm_apbasel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBASEL.reg &= ~PM_APBASEL_APBADIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBASEL_APBADIV_bf(const void *const hw, hri_pm_apbasel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBASEL.reg ^= PM_APBASEL_APBADIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbasel_reg_t hri_pm_read_APBASEL_APBADIV_bf(const void *const hw)
{
uint8_t tmp;
tmp = ((Pm *)hw)->APBASEL.reg;
tmp = (tmp & PM_APBASEL_APBADIV_Msk) >> PM_APBASEL_APBADIV_Pos;
return tmp;
}
static inline void hri_pm_set_APBASEL_reg(const void *const hw, hri_pm_apbasel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBASEL.reg |= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbasel_reg_t hri_pm_get_APBASEL_reg(const void *const hw, hri_pm_apbasel_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->APBASEL.reg;
tmp &= mask;
return tmp;
}
static inline void hri_pm_write_APBASEL_reg(const void *const hw, hri_pm_apbasel_reg_t data)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBASEL.reg = data;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBASEL_reg(const void *const hw, hri_pm_apbasel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBASEL.reg &= ~mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBASEL_reg(const void *const hw, hri_pm_apbasel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBASEL.reg ^= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbasel_reg_t hri_pm_read_APBASEL_reg(const void *const hw)
{
return ((Pm *)hw)->APBASEL.reg;
}
static inline void hri_pm_set_APBBSEL_APBBDIV_bf(const void *const hw, hri_pm_apbbsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBSEL.reg |= PM_APBBSEL_APBBDIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbbsel_reg_t hri_pm_get_APBBSEL_APBBDIV_bf(const void *const hw, hri_pm_apbbsel_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->APBBSEL.reg;
tmp = (tmp & PM_APBBSEL_APBBDIV(mask)) >> PM_APBBSEL_APBBDIV_Pos;
return tmp;
}
static inline void hri_pm_write_APBBSEL_APBBDIV_bf(const void *const hw, hri_pm_apbbsel_reg_t data)
{
uint8_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBBSEL.reg;
tmp &= ~PM_APBBSEL_APBBDIV_Msk;
tmp |= PM_APBBSEL_APBBDIV(data);
((Pm *)hw)->APBBSEL.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBBSEL_APBBDIV_bf(const void *const hw, hri_pm_apbbsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBSEL.reg &= ~PM_APBBSEL_APBBDIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBBSEL_APBBDIV_bf(const void *const hw, hri_pm_apbbsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBSEL.reg ^= PM_APBBSEL_APBBDIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbbsel_reg_t hri_pm_read_APBBSEL_APBBDIV_bf(const void *const hw)
{
uint8_t tmp;
tmp = ((Pm *)hw)->APBBSEL.reg;
tmp = (tmp & PM_APBBSEL_APBBDIV_Msk) >> PM_APBBSEL_APBBDIV_Pos;
return tmp;
}
static inline void hri_pm_set_APBBSEL_reg(const void *const hw, hri_pm_apbbsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBSEL.reg |= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbbsel_reg_t hri_pm_get_APBBSEL_reg(const void *const hw, hri_pm_apbbsel_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->APBBSEL.reg;
tmp &= mask;
return tmp;
}
static inline void hri_pm_write_APBBSEL_reg(const void *const hw, hri_pm_apbbsel_reg_t data)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBSEL.reg = data;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBBSEL_reg(const void *const hw, hri_pm_apbbsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBSEL.reg &= ~mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBBSEL_reg(const void *const hw, hri_pm_apbbsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBSEL.reg ^= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbbsel_reg_t hri_pm_read_APBBSEL_reg(const void *const hw)
{
return ((Pm *)hw)->APBBSEL.reg;
}
static inline void hri_pm_set_APBCSEL_APBCDIV_bf(const void *const hw, hri_pm_apbcsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCSEL.reg |= PM_APBCSEL_APBCDIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbcsel_reg_t hri_pm_get_APBCSEL_APBCDIV_bf(const void *const hw, hri_pm_apbcsel_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->APBCSEL.reg;
tmp = (tmp & PM_APBCSEL_APBCDIV(mask)) >> PM_APBCSEL_APBCDIV_Pos;
return tmp;
}
static inline void hri_pm_write_APBCSEL_APBCDIV_bf(const void *const hw, hri_pm_apbcsel_reg_t data)
{
uint8_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCSEL.reg;
tmp &= ~PM_APBCSEL_APBCDIV_Msk;
tmp |= PM_APBCSEL_APBCDIV(data);
((Pm *)hw)->APBCSEL.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCSEL_APBCDIV_bf(const void *const hw, hri_pm_apbcsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCSEL.reg &= ~PM_APBCSEL_APBCDIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCSEL_APBCDIV_bf(const void *const hw, hri_pm_apbcsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCSEL.reg ^= PM_APBCSEL_APBCDIV(mask);
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbcsel_reg_t hri_pm_read_APBCSEL_APBCDIV_bf(const void *const hw)
{
uint8_t tmp;
tmp = ((Pm *)hw)->APBCSEL.reg;
tmp = (tmp & PM_APBCSEL_APBCDIV_Msk) >> PM_APBCSEL_APBCDIV_Pos;
return tmp;
}
static inline void hri_pm_set_APBCSEL_reg(const void *const hw, hri_pm_apbcsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCSEL.reg |= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbcsel_reg_t hri_pm_get_APBCSEL_reg(const void *const hw, hri_pm_apbcsel_reg_t mask)
{
uint8_t tmp;
tmp = ((Pm *)hw)->APBCSEL.reg;
tmp &= mask;
return tmp;
}
static inline void hri_pm_write_APBCSEL_reg(const void *const hw, hri_pm_apbcsel_reg_t data)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCSEL.reg = data;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCSEL_reg(const void *const hw, hri_pm_apbcsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCSEL.reg &= ~mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCSEL_reg(const void *const hw, hri_pm_apbcsel_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCSEL.reg ^= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbcsel_reg_t hri_pm_read_APBCSEL_reg(const void *const hw)
{
return ((Pm *)hw)->APBCSEL.reg;
}
static inline void hri_pm_set_AHBMASK_HPB0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg |= PM_AHBMASK_HPB0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_AHBMASK_HPB0_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp = (tmp & PM_AHBMASK_HPB0) >> PM_AHBMASK_HPB0_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_AHBMASK_HPB0_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp &= ~PM_AHBMASK_HPB0;
tmp |= value << PM_AHBMASK_HPB0_Pos;
((Pm *)hw)->AHBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_AHBMASK_HPB0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg &= ~PM_AHBMASK_HPB0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_AHBMASK_HPB0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg ^= PM_AHBMASK_HPB0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_AHBMASK_HPB1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg |= PM_AHBMASK_HPB1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_AHBMASK_HPB1_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp = (tmp & PM_AHBMASK_HPB1) >> PM_AHBMASK_HPB1_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_AHBMASK_HPB1_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp &= ~PM_AHBMASK_HPB1;
tmp |= value << PM_AHBMASK_HPB1_Pos;
((Pm *)hw)->AHBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_AHBMASK_HPB1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg &= ~PM_AHBMASK_HPB1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_AHBMASK_HPB1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg ^= PM_AHBMASK_HPB1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_AHBMASK_HPB2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg |= PM_AHBMASK_HPB2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_AHBMASK_HPB2_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp = (tmp & PM_AHBMASK_HPB2) >> PM_AHBMASK_HPB2_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_AHBMASK_HPB2_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp &= ~PM_AHBMASK_HPB2;
tmp |= value << PM_AHBMASK_HPB2_Pos;
((Pm *)hw)->AHBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_AHBMASK_HPB2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg &= ~PM_AHBMASK_HPB2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_AHBMASK_HPB2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg ^= PM_AHBMASK_HPB2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_AHBMASK_DSU_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg |= PM_AHBMASK_DSU;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_AHBMASK_DSU_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp = (tmp & PM_AHBMASK_DSU) >> PM_AHBMASK_DSU_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_AHBMASK_DSU_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp &= ~PM_AHBMASK_DSU;
tmp |= value << PM_AHBMASK_DSU_Pos;
((Pm *)hw)->AHBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_AHBMASK_DSU_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg &= ~PM_AHBMASK_DSU;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_AHBMASK_DSU_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg ^= PM_AHBMASK_DSU;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_AHBMASK_NVMCTRL_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg |= PM_AHBMASK_NVMCTRL;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_AHBMASK_NVMCTRL_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp = (tmp & PM_AHBMASK_NVMCTRL) >> PM_AHBMASK_NVMCTRL_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_AHBMASK_NVMCTRL_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp &= ~PM_AHBMASK_NVMCTRL;
tmp |= value << PM_AHBMASK_NVMCTRL_Pos;
((Pm *)hw)->AHBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_AHBMASK_NVMCTRL_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg &= ~PM_AHBMASK_NVMCTRL;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_AHBMASK_NVMCTRL_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg ^= PM_AHBMASK_NVMCTRL;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_AHBMASK_DMAC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg |= PM_AHBMASK_DMAC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_AHBMASK_DMAC_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp = (tmp & PM_AHBMASK_DMAC) >> PM_AHBMASK_DMAC_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_AHBMASK_DMAC_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp &= ~PM_AHBMASK_DMAC;
tmp |= value << PM_AHBMASK_DMAC_Pos;
((Pm *)hw)->AHBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_AHBMASK_DMAC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg &= ~PM_AHBMASK_DMAC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_AHBMASK_DMAC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg ^= PM_AHBMASK_DMAC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_AHBMASK_USB_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg |= PM_AHBMASK_USB;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_AHBMASK_USB_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp = (tmp & PM_AHBMASK_USB) >> PM_AHBMASK_USB_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_AHBMASK_USB_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp &= ~PM_AHBMASK_USB;
tmp |= value << PM_AHBMASK_USB_Pos;
((Pm *)hw)->AHBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_AHBMASK_USB_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg &= ~PM_AHBMASK_USB;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_AHBMASK_USB_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg ^= PM_AHBMASK_USB;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_AHBMASK_reg(const void *const hw, hri_pm_ahbmask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg |= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_ahbmask_reg_t hri_pm_get_AHBMASK_reg(const void *const hw, hri_pm_ahbmask_reg_t mask)
{
uint32_t tmp;
tmp = ((Pm *)hw)->AHBMASK.reg;
tmp &= mask;
return tmp;
}
static inline void hri_pm_write_AHBMASK_reg(const void *const hw, hri_pm_ahbmask_reg_t data)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg = data;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_AHBMASK_reg(const void *const hw, hri_pm_ahbmask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg &= ~mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_AHBMASK_reg(const void *const hw, hri_pm_ahbmask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->AHBMASK.reg ^= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_ahbmask_reg_t hri_pm_read_AHBMASK_reg(const void *const hw)
{
return ((Pm *)hw)->AHBMASK.reg;
}
static inline void hri_pm_set_APBAMASK_PAC0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg |= PM_APBAMASK_PAC0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBAMASK_PAC0_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp = (tmp & PM_APBAMASK_PAC0) >> PM_APBAMASK_PAC0_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBAMASK_PAC0_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp &= ~PM_APBAMASK_PAC0;
tmp |= value << PM_APBAMASK_PAC0_Pos;
((Pm *)hw)->APBAMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBAMASK_PAC0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg &= ~PM_APBAMASK_PAC0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBAMASK_PAC0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg ^= PM_APBAMASK_PAC0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBAMASK_PM_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg |= PM_APBAMASK_PM;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBAMASK_PM_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp = (tmp & PM_APBAMASK_PM) >> PM_APBAMASK_PM_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBAMASK_PM_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp &= ~PM_APBAMASK_PM;
tmp |= value << PM_APBAMASK_PM_Pos;
((Pm *)hw)->APBAMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBAMASK_PM_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg &= ~PM_APBAMASK_PM;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBAMASK_PM_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg ^= PM_APBAMASK_PM;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBAMASK_SYSCTRL_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg |= PM_APBAMASK_SYSCTRL;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBAMASK_SYSCTRL_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp = (tmp & PM_APBAMASK_SYSCTRL) >> PM_APBAMASK_SYSCTRL_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBAMASK_SYSCTRL_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp &= ~PM_APBAMASK_SYSCTRL;
tmp |= value << PM_APBAMASK_SYSCTRL_Pos;
((Pm *)hw)->APBAMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBAMASK_SYSCTRL_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg &= ~PM_APBAMASK_SYSCTRL;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBAMASK_SYSCTRL_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg ^= PM_APBAMASK_SYSCTRL;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBAMASK_GCLK_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg |= PM_APBAMASK_GCLK;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBAMASK_GCLK_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp = (tmp & PM_APBAMASK_GCLK) >> PM_APBAMASK_GCLK_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBAMASK_GCLK_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp &= ~PM_APBAMASK_GCLK;
tmp |= value << PM_APBAMASK_GCLK_Pos;
((Pm *)hw)->APBAMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBAMASK_GCLK_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg &= ~PM_APBAMASK_GCLK;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBAMASK_GCLK_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg ^= PM_APBAMASK_GCLK;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBAMASK_WDT_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg |= PM_APBAMASK_WDT;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBAMASK_WDT_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp = (tmp & PM_APBAMASK_WDT) >> PM_APBAMASK_WDT_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBAMASK_WDT_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp &= ~PM_APBAMASK_WDT;
tmp |= value << PM_APBAMASK_WDT_Pos;
((Pm *)hw)->APBAMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBAMASK_WDT_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg &= ~PM_APBAMASK_WDT;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBAMASK_WDT_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg ^= PM_APBAMASK_WDT;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBAMASK_RTC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg |= PM_APBAMASK_RTC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBAMASK_RTC_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp = (tmp & PM_APBAMASK_RTC) >> PM_APBAMASK_RTC_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBAMASK_RTC_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp &= ~PM_APBAMASK_RTC;
tmp |= value << PM_APBAMASK_RTC_Pos;
((Pm *)hw)->APBAMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBAMASK_RTC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg &= ~PM_APBAMASK_RTC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBAMASK_RTC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg ^= PM_APBAMASK_RTC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBAMASK_EIC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg |= PM_APBAMASK_EIC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBAMASK_EIC_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp = (tmp & PM_APBAMASK_EIC) >> PM_APBAMASK_EIC_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBAMASK_EIC_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp &= ~PM_APBAMASK_EIC;
tmp |= value << PM_APBAMASK_EIC_Pos;
((Pm *)hw)->APBAMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBAMASK_EIC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg &= ~PM_APBAMASK_EIC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBAMASK_EIC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg ^= PM_APBAMASK_EIC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBAMASK_reg(const void *const hw, hri_pm_apbamask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg |= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbamask_reg_t hri_pm_get_APBAMASK_reg(const void *const hw, hri_pm_apbamask_reg_t mask)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBAMASK.reg;
tmp &= mask;
return tmp;
}
static inline void hri_pm_write_APBAMASK_reg(const void *const hw, hri_pm_apbamask_reg_t data)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg = data;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBAMASK_reg(const void *const hw, hri_pm_apbamask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg &= ~mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBAMASK_reg(const void *const hw, hri_pm_apbamask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBAMASK.reg ^= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbamask_reg_t hri_pm_read_APBAMASK_reg(const void *const hw)
{
return ((Pm *)hw)->APBAMASK.reg;
}
static inline void hri_pm_set_APBBMASK_PAC1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg |= PM_APBBMASK_PAC1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBBMASK_PAC1_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp = (tmp & PM_APBBMASK_PAC1) >> PM_APBBMASK_PAC1_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBBMASK_PAC1_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp &= ~PM_APBBMASK_PAC1;
tmp |= value << PM_APBBMASK_PAC1_Pos;
((Pm *)hw)->APBBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBBMASK_PAC1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg &= ~PM_APBBMASK_PAC1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBBMASK_PAC1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg ^= PM_APBBMASK_PAC1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBBMASK_DSU_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg |= PM_APBBMASK_DSU;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBBMASK_DSU_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp = (tmp & PM_APBBMASK_DSU) >> PM_APBBMASK_DSU_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBBMASK_DSU_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp &= ~PM_APBBMASK_DSU;
tmp |= value << PM_APBBMASK_DSU_Pos;
((Pm *)hw)->APBBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBBMASK_DSU_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg &= ~PM_APBBMASK_DSU;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBBMASK_DSU_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg ^= PM_APBBMASK_DSU;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBBMASK_NVMCTRL_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg |= PM_APBBMASK_NVMCTRL;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBBMASK_NVMCTRL_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp = (tmp & PM_APBBMASK_NVMCTRL) >> PM_APBBMASK_NVMCTRL_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBBMASK_NVMCTRL_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp &= ~PM_APBBMASK_NVMCTRL;
tmp |= value << PM_APBBMASK_NVMCTRL_Pos;
((Pm *)hw)->APBBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBBMASK_NVMCTRL_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg &= ~PM_APBBMASK_NVMCTRL;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBBMASK_NVMCTRL_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg ^= PM_APBBMASK_NVMCTRL;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBBMASK_PORT_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg |= PM_APBBMASK_PORT;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBBMASK_PORT_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp = (tmp & PM_APBBMASK_PORT) >> PM_APBBMASK_PORT_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBBMASK_PORT_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp &= ~PM_APBBMASK_PORT;
tmp |= value << PM_APBBMASK_PORT_Pos;
((Pm *)hw)->APBBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBBMASK_PORT_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg &= ~PM_APBBMASK_PORT;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBBMASK_PORT_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg ^= PM_APBBMASK_PORT;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBBMASK_DMAC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg |= PM_APBBMASK_DMAC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBBMASK_DMAC_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp = (tmp & PM_APBBMASK_DMAC) >> PM_APBBMASK_DMAC_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBBMASK_DMAC_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp &= ~PM_APBBMASK_DMAC;
tmp |= value << PM_APBBMASK_DMAC_Pos;
((Pm *)hw)->APBBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBBMASK_DMAC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg &= ~PM_APBBMASK_DMAC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBBMASK_DMAC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg ^= PM_APBBMASK_DMAC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBBMASK_USB_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg |= PM_APBBMASK_USB;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBBMASK_USB_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp = (tmp & PM_APBBMASK_USB) >> PM_APBBMASK_USB_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBBMASK_USB_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp &= ~PM_APBBMASK_USB;
tmp |= value << PM_APBBMASK_USB_Pos;
((Pm *)hw)->APBBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBBMASK_USB_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg &= ~PM_APBBMASK_USB;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBBMASK_USB_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg ^= PM_APBBMASK_USB;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBBMASK_HMATRIX_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg |= PM_APBBMASK_HMATRIX;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBBMASK_HMATRIX_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp = (tmp & PM_APBBMASK_HMATRIX) >> PM_APBBMASK_HMATRIX_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBBMASK_HMATRIX_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp &= ~PM_APBBMASK_HMATRIX;
tmp |= value << PM_APBBMASK_HMATRIX_Pos;
((Pm *)hw)->APBBMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBBMASK_HMATRIX_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg &= ~PM_APBBMASK_HMATRIX;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBBMASK_HMATRIX_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg ^= PM_APBBMASK_HMATRIX;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBBMASK_reg(const void *const hw, hri_pm_apbbmask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg |= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbbmask_reg_t hri_pm_get_APBBMASK_reg(const void *const hw, hri_pm_apbbmask_reg_t mask)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBBMASK.reg;
tmp &= mask;
return tmp;
}
static inline void hri_pm_write_APBBMASK_reg(const void *const hw, hri_pm_apbbmask_reg_t data)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg = data;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBBMASK_reg(const void *const hw, hri_pm_apbbmask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg &= ~mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBBMASK_reg(const void *const hw, hri_pm_apbbmask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBBMASK.reg ^= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbbmask_reg_t hri_pm_read_APBBMASK_reg(const void *const hw)
{
return ((Pm *)hw)->APBBMASK.reg;
}
static inline void hri_pm_set_APBCMASK_PAC2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_PAC2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_PAC2_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_PAC2) >> PM_APBCMASK_PAC2_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_PAC2_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_PAC2;
tmp |= value << PM_APBCMASK_PAC2_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_PAC2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_PAC2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_PAC2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_PAC2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_EVSYS_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_EVSYS;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_EVSYS_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_EVSYS) >> PM_APBCMASK_EVSYS_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_EVSYS_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_EVSYS;
tmp |= value << PM_APBCMASK_EVSYS_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_EVSYS_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_EVSYS;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_EVSYS_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_EVSYS;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_SERCOM0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_SERCOM0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_SERCOM0_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_SERCOM0) >> PM_APBCMASK_SERCOM0_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_SERCOM0_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_SERCOM0;
tmp |= value << PM_APBCMASK_SERCOM0_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_SERCOM0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_SERCOM0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_SERCOM0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_SERCOM0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_SERCOM1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_SERCOM1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_SERCOM1_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_SERCOM1) >> PM_APBCMASK_SERCOM1_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_SERCOM1_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_SERCOM1;
tmp |= value << PM_APBCMASK_SERCOM1_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_SERCOM1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_SERCOM1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_SERCOM1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_SERCOM1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_SERCOM2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_SERCOM2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_SERCOM2_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_SERCOM2) >> PM_APBCMASK_SERCOM2_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_SERCOM2_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_SERCOM2;
tmp |= value << PM_APBCMASK_SERCOM2_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_SERCOM2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_SERCOM2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_SERCOM2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_SERCOM2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_SERCOM3_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_SERCOM3;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_SERCOM3_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_SERCOM3) >> PM_APBCMASK_SERCOM3_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_SERCOM3_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_SERCOM3;
tmp |= value << PM_APBCMASK_SERCOM3_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_SERCOM3_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_SERCOM3;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_SERCOM3_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_SERCOM3;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_SERCOM4_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_SERCOM4;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_SERCOM4_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_SERCOM4) >> PM_APBCMASK_SERCOM4_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_SERCOM4_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_SERCOM4;
tmp |= value << PM_APBCMASK_SERCOM4_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_SERCOM4_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_SERCOM4;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_SERCOM4_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_SERCOM4;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_SERCOM5_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_SERCOM5;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_SERCOM5_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_SERCOM5) >> PM_APBCMASK_SERCOM5_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_SERCOM5_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_SERCOM5;
tmp |= value << PM_APBCMASK_SERCOM5_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_SERCOM5_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_SERCOM5;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_SERCOM5_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_SERCOM5;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_TCC0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_TCC0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_TCC0_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_TCC0) >> PM_APBCMASK_TCC0_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_TCC0_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_TCC0;
tmp |= value << PM_APBCMASK_TCC0_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_TCC0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_TCC0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_TCC0_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_TCC0;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_TCC1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_TCC1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_TCC1_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_TCC1) >> PM_APBCMASK_TCC1_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_TCC1_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_TCC1;
tmp |= value << PM_APBCMASK_TCC1_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_TCC1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_TCC1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_TCC1_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_TCC1;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_TCC2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_TCC2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_TCC2_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_TCC2) >> PM_APBCMASK_TCC2_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_TCC2_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_TCC2;
tmp |= value << PM_APBCMASK_TCC2_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_TCC2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_TCC2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_TCC2_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_TCC2;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_TC3_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_TC3;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_TC3_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_TC3) >> PM_APBCMASK_TC3_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_TC3_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_TC3;
tmp |= value << PM_APBCMASK_TC3_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_TC3_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_TC3;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_TC3_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_TC3;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_TC4_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_TC4;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_TC4_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_TC4) >> PM_APBCMASK_TC4_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_TC4_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_TC4;
tmp |= value << PM_APBCMASK_TC4_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_TC4_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_TC4;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_TC4_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_TC4;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_TC5_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_TC5;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_TC5_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_TC5) >> PM_APBCMASK_TC5_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_TC5_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_TC5;
tmp |= value << PM_APBCMASK_TC5_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_TC5_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_TC5;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_TC5_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_TC5;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_TC6_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_TC6;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_TC6_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_TC6) >> PM_APBCMASK_TC6_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_TC6_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_TC6;
tmp |= value << PM_APBCMASK_TC6_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_TC6_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_TC6;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_TC6_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_TC6;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_TC7_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_TC7;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_TC7_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_TC7) >> PM_APBCMASK_TC7_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_TC7_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_TC7;
tmp |= value << PM_APBCMASK_TC7_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_TC7_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_TC7;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_TC7_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_TC7;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_ADC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_ADC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_ADC_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_ADC) >> PM_APBCMASK_ADC_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_ADC_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_ADC;
tmp |= value << PM_APBCMASK_ADC_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_ADC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_ADC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_ADC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_ADC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_AC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_AC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_AC_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_AC) >> PM_APBCMASK_AC_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_AC_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_AC;
tmp |= value << PM_APBCMASK_AC_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_AC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_AC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_AC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_AC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_DAC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_DAC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_DAC_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_DAC) >> PM_APBCMASK_DAC_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_DAC_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_DAC;
tmp |= value << PM_APBCMASK_DAC_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_DAC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_DAC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_DAC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_DAC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_PTC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_PTC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_PTC_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_PTC) >> PM_APBCMASK_PTC_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_PTC_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_PTC;
tmp |= value << PM_APBCMASK_PTC_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_PTC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_PTC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_PTC_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_PTC;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_I2S_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= PM_APBCMASK_I2S;
PM_CRITICAL_SECTION_LEAVE();
}
static inline bool hri_pm_get_APBCMASK_I2S_bit(const void *const hw)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp = (tmp & PM_APBCMASK_I2S) >> PM_APBCMASK_I2S_Pos;
return (bool)tmp;
}
static inline void hri_pm_write_APBCMASK_I2S_bit(const void *const hw, bool value)
{
uint32_t tmp;
PM_CRITICAL_SECTION_ENTER();
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= ~PM_APBCMASK_I2S;
tmp |= value << PM_APBCMASK_I2S_Pos;
((Pm *)hw)->APBCMASK.reg = tmp;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_I2S_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~PM_APBCMASK_I2S;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_I2S_bit(const void *const hw)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= PM_APBCMASK_I2S;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_set_APBCMASK_reg(const void *const hw, hri_pm_apbcmask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg |= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbcmask_reg_t hri_pm_get_APBCMASK_reg(const void *const hw, hri_pm_apbcmask_reg_t mask)
{
uint32_t tmp;
tmp = ((Pm *)hw)->APBCMASK.reg;
tmp &= mask;
return tmp;
}
static inline void hri_pm_write_APBCMASK_reg(const void *const hw, hri_pm_apbcmask_reg_t data)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg = data;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_clear_APBCMASK_reg(const void *const hw, hri_pm_apbcmask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg &= ~mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline void hri_pm_toggle_APBCMASK_reg(const void *const hw, hri_pm_apbcmask_reg_t mask)
{
PM_CRITICAL_SECTION_ENTER();
((Pm *)hw)->APBCMASK.reg ^= mask;
PM_CRITICAL_SECTION_LEAVE();
}
static inline hri_pm_apbcmask_reg_t hri_pm_read_APBCMASK_reg(const void *const hw)
{
return ((Pm *)hw)->APBCMASK.reg;
}
#ifdef __cplusplus
}
#endif
#endif /* _HRI_PM_D21_H_INCLUDED */
#endif /* _SAMD21_PM_COMPONENT_ */