/**
 * \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_ */