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.
2537 lines
66 KiB
C
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_ */
|