#[doc = "Register `TIMBCR` reader"]
pub struct R(crate::R<TIMBCR_SPEC>);
impl core::ops::Deref for R {
type Target = crate::R<TIMBCR_SPEC>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
impl From<crate::R<TIMBCR_SPEC>> for R {
#[inline(always)]
fn from(reader: crate::R<TIMBCR_SPEC>) -> Self {
R(reader)
}
}
#[doc = "Register `TIMBCR` writer"]
pub struct W(crate::W<TIMBCR_SPEC>);
impl core::ops::Deref for W {
type Target = crate::W<TIMBCR_SPEC>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
impl core::ops::DerefMut for W {
#[inline(always)]
fn deref_mut(&mut self) -> &mut Self::Target {
&mut self.0
}
}
impl From<crate::W<TIMBCR_SPEC>> for W {
#[inline(always)]
fn from(writer: crate::W<TIMBCR_SPEC>) -> Self {
W(writer)
}
}
#[doc = "Field `UPDGAT` reader - Update Gating"]
pub type UPDGAT_R = crate::FieldReader<u8, u8>;
#[doc = "Field `UPDGAT` writer - Update Gating"]
pub type UPDGAT_W<'a, const O: u8> = crate::FieldWriter<'a, u32, TIMBCR_SPEC, u8, u8, 4, O>;
#[doc = "Field `PREEN` reader - Preload enable"]
pub type PREEN_R = crate::BitReader<bool>;
#[doc = "Field `PREEN` writer - Preload enable"]
pub type PREEN_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `DACSYNC` reader - AC Synchronization"]
pub type DACSYNC_R = crate::FieldReader<u8, u8>;
#[doc = "Field `DACSYNC` writer - AC Synchronization"]
pub type DACSYNC_W<'a, const O: u8> = crate::FieldWriter<'a, u32, TIMBCR_SPEC, u8, u8, 2, O>;
#[doc = "Field `MSTU` reader - Master Timer update"]
pub type MSTU_R = crate::BitReader<bool>;
#[doc = "Field `MSTU` writer - Master Timer update"]
pub type MSTU_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `TEU` reader - TEU"]
pub type TEU_R = crate::BitReader<bool>;
#[doc = "Field `TEU` writer - TEU"]
pub type TEU_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `TDU` reader - TDU"]
pub type TDU_R = crate::BitReader<bool>;
#[doc = "Field `TDU` writer - TDU"]
pub type TDU_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `TCU` reader - TCU"]
pub type TCU_R = crate::BitReader<bool>;
#[doc = "Field `TCU` writer - TCU"]
pub type TCU_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `TBU` reader - TBU"]
pub type TBU_R = crate::BitReader<bool>;
#[doc = "Field `TBU` writer - TBU"]
pub type TBU_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `TxRSTU` reader - Timerx reset update"]
pub type TXRSTU_R = crate::BitReader<bool>;
#[doc = "Field `TxRSTU` writer - Timerx reset update"]
pub type TXRSTU_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `TxREPU` reader - Timer x Repetition update"]
pub type TXREPU_R = crate::BitReader<bool>;
#[doc = "Field `TxREPU` writer - Timer x Repetition update"]
pub type TXREPU_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `DELCMP4` reader - Delayed CMP4 mode"]
pub type DELCMP4_R = crate::FieldReader<u8, u8>;
#[doc = "Field `DELCMP4` writer - Delayed CMP4 mode"]
pub type DELCMP4_W<'a, const O: u8> = crate::FieldWriter<'a, u32, TIMBCR_SPEC, u8, u8, 2, O>;
#[doc = "Field `DELCMP2` reader - Delayed CMP2 mode"]
pub type DELCMP2_R = crate::FieldReader<u8, u8>;
#[doc = "Field `DELCMP2` writer - Delayed CMP2 mode"]
pub type DELCMP2_W<'a, const O: u8> = crate::FieldWriter<'a, u32, TIMBCR_SPEC, u8, u8, 2, O>;
#[doc = "Field `SYNCSTRTx` reader - Synchronization Starts Timer x"]
pub type SYNCSTRTX_R = crate::BitReader<bool>;
#[doc = "Field `SYNCSTRTx` writer - Synchronization Starts Timer x"]
pub type SYNCSTRTX_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `SYNCRSTx` reader - Synchronization Resets Timer x"]
pub type SYNCRSTX_R = crate::BitReader<bool>;
#[doc = "Field `SYNCRSTx` writer - Synchronization Resets Timer x"]
pub type SYNCRSTX_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `PSHPLL` reader - Push-Pull mode enable"]
pub type PSHPLL_R = crate::BitReader<bool>;
#[doc = "Field `PSHPLL` writer - Push-Pull mode enable"]
pub type PSHPLL_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `HALF` reader - Half mode enable"]
pub type HALF_R = crate::BitReader<bool>;
#[doc = "Field `HALF` writer - Half mode enable"]
pub type HALF_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `RETRIG` reader - Re-triggerable mode"]
pub type RETRIG_R = crate::BitReader<bool>;
#[doc = "Field `RETRIG` writer - Re-triggerable mode"]
pub type RETRIG_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `CONT` reader - Continuous mode"]
pub type CONT_R = crate::BitReader<bool>;
#[doc = "Field `CONT` writer - Continuous mode"]
pub type CONT_W<'a, const O: u8> = crate::BitWriter<'a, u32, TIMBCR_SPEC, bool, O>;
#[doc = "Field `CK_PSCx` reader - HRTIM Timer x Clock prescaler"]
pub type CK_PSCX_R = crate::FieldReader<u8, u8>;
#[doc = "Field `CK_PSCx` writer - HRTIM Timer x Clock prescaler"]
pub type CK_PSCX_W<'a, const O: u8> = crate::FieldWriter<'a, u32, TIMBCR_SPEC, u8, u8, 3, O>;
impl R {
#[doc = "Bits 28:31 - Update Gating"]
#[inline(always)]
pub fn updgat(&self) -> UPDGAT_R {
UPDGAT_R::new(((self.bits >> 28) & 0x0f) as u8)
}
#[doc = "Bit 27 - Preload enable"]
#[inline(always)]
pub fn preen(&self) -> PREEN_R {
PREEN_R::new(((self.bits >> 27) & 1) != 0)
}
#[doc = "Bits 25:26 - AC Synchronization"]
#[inline(always)]
pub fn dacsync(&self) -> DACSYNC_R {
DACSYNC_R::new(((self.bits >> 25) & 3) as u8)
}
#[doc = "Bit 24 - Master Timer update"]
#[inline(always)]
pub fn mstu(&self) -> MSTU_R {
MSTU_R::new(((self.bits >> 24) & 1) != 0)
}
#[doc = "Bit 23 - TEU"]
#[inline(always)]
pub fn teu(&self) -> TEU_R {
TEU_R::new(((self.bits >> 23) & 1) != 0)
}
#[doc = "Bit 22 - TDU"]
#[inline(always)]
pub fn tdu(&self) -> TDU_R {
TDU_R::new(((self.bits >> 22) & 1) != 0)
}
#[doc = "Bit 21 - TCU"]
#[inline(always)]
pub fn tcu(&self) -> TCU_R {
TCU_R::new(((self.bits >> 21) & 1) != 0)
}
#[doc = "Bit 20 - TBU"]
#[inline(always)]
pub fn tbu(&self) -> TBU_R {
TBU_R::new(((self.bits >> 20) & 1) != 0)
}
#[doc = "Bit 18 - Timerx reset update"]
#[inline(always)]
pub fn tx_rstu(&self) -> TXRSTU_R {
TXRSTU_R::new(((self.bits >> 18) & 1) != 0)
}
#[doc = "Bit 17 - Timer x Repetition update"]
#[inline(always)]
pub fn tx_repu(&self) -> TXREPU_R {
TXREPU_R::new(((self.bits >> 17) & 1) != 0)
}
#[doc = "Bits 14:15 - Delayed CMP4 mode"]
#[inline(always)]
pub fn delcmp4(&self) -> DELCMP4_R {
DELCMP4_R::new(((self.bits >> 14) & 3) as u8)
}
#[doc = "Bits 12:13 - Delayed CMP2 mode"]
#[inline(always)]
pub fn delcmp2(&self) -> DELCMP2_R {
DELCMP2_R::new(((self.bits >> 12) & 3) as u8)
}
#[doc = "Bit 11 - Synchronization Starts Timer x"]
#[inline(always)]
pub fn syncstrtx(&self) -> SYNCSTRTX_R {
SYNCSTRTX_R::new(((self.bits >> 11) & 1) != 0)
}
#[doc = "Bit 10 - Synchronization Resets Timer x"]
#[inline(always)]
pub fn syncrstx(&self) -> SYNCRSTX_R {
SYNCRSTX_R::new(((self.bits >> 10) & 1) != 0)
}
#[doc = "Bit 6 - Push-Pull mode enable"]
#[inline(always)]
pub fn pshpll(&self) -> PSHPLL_R {
PSHPLL_R::new(((self.bits >> 6) & 1) != 0)
}
#[doc = "Bit 5 - Half mode enable"]
#[inline(always)]
pub fn half(&self) -> HALF_R {
HALF_R::new(((self.bits >> 5) & 1) != 0)
}
#[doc = "Bit 4 - Re-triggerable mode"]
#[inline(always)]
pub fn retrig(&self) -> RETRIG_R {
RETRIG_R::new(((self.bits >> 4) & 1) != 0)
}
#[doc = "Bit 3 - Continuous mode"]
#[inline(always)]
pub fn cont(&self) -> CONT_R {
CONT_R::new(((self.bits >> 3) & 1) != 0)
}
#[doc = "Bits 0:2 - HRTIM Timer x Clock prescaler"]
#[inline(always)]
pub fn ck_pscx(&self) -> CK_PSCX_R {
CK_PSCX_R::new((self.bits & 7) as u8)
}
}
impl W {
#[doc = "Bits 28:31 - Update Gating"]
#[inline(always)]
pub fn updgat(&mut self) -> UPDGAT_W<28> {
UPDGAT_W::new(self)
}
#[doc = "Bit 27 - Preload enable"]
#[inline(always)]
pub fn preen(&mut self) -> PREEN_W<27> {
PREEN_W::new(self)
}
#[doc = "Bits 25:26 - AC Synchronization"]
#[inline(always)]
pub fn dacsync(&mut self) -> DACSYNC_W<25> {
DACSYNC_W::new(self)
}
#[doc = "Bit 24 - Master Timer update"]
#[inline(always)]
pub fn mstu(&mut self) -> MSTU_W<24> {
MSTU_W::new(self)
}
#[doc = "Bit 23 - TEU"]
#[inline(always)]
pub fn teu(&mut self) -> TEU_W<23> {
TEU_W::new(self)
}
#[doc = "Bit 22 - TDU"]
#[inline(always)]
pub fn tdu(&mut self) -> TDU_W<22> {
TDU_W::new(self)
}
#[doc = "Bit 21 - TCU"]
#[inline(always)]
pub fn tcu(&mut self) -> TCU_W<21> {
TCU_W::new(self)
}
#[doc = "Bit 20 - TBU"]
#[inline(always)]
pub fn tbu(&mut self) -> TBU_W<20> {
TBU_W::new(self)
}
#[doc = "Bit 18 - Timerx reset update"]
#[inline(always)]
pub fn tx_rstu(&mut self) -> TXRSTU_W<18> {
TXRSTU_W::new(self)
}
#[doc = "Bit 17 - Timer x Repetition update"]
#[inline(always)]
pub fn tx_repu(&mut self) -> TXREPU_W<17> {
TXREPU_W::new(self)
}
#[doc = "Bits 14:15 - Delayed CMP4 mode"]
#[inline(always)]
pub fn delcmp4(&mut self) -> DELCMP4_W<14> {
DELCMP4_W::new(self)
}
#[doc = "Bits 12:13 - Delayed CMP2 mode"]
#[inline(always)]
pub fn delcmp2(&mut self) -> DELCMP2_W<12> {
DELCMP2_W::new(self)
}
#[doc = "Bit 11 - Synchronization Starts Timer x"]
#[inline(always)]
pub fn syncstrtx(&mut self) -> SYNCSTRTX_W<11> {
SYNCSTRTX_W::new(self)
}
#[doc = "Bit 10 - Synchronization Resets Timer x"]
#[inline(always)]
pub fn syncrstx(&mut self) -> SYNCRSTX_W<10> {
SYNCRSTX_W::new(self)
}
#[doc = "Bit 6 - Push-Pull mode enable"]
#[inline(always)]
pub fn pshpll(&mut self) -> PSHPLL_W<6> {
PSHPLL_W::new(self)
}
#[doc = "Bit 5 - Half mode enable"]
#[inline(always)]
pub fn half(&mut self) -> HALF_W<5> {
HALF_W::new(self)
}
#[doc = "Bit 4 - Re-triggerable mode"]
#[inline(always)]
pub fn retrig(&mut self) -> RETRIG_W<4> {
RETRIG_W::new(self)
}
#[doc = "Bit 3 - Continuous mode"]
#[inline(always)]
pub fn cont(&mut self) -> CONT_W<3> {
CONT_W::new(self)
}
#[doc = "Bits 0:2 - HRTIM Timer x Clock prescaler"]
#[inline(always)]
pub fn ck_pscx(&mut self) -> CK_PSCX_W<0> {
CK_PSCX_W::new(self)
}
#[doc = "Writes raw bits to the register."]
#[inline(always)]
pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
self.0.bits(bits);
self
}
}
#[doc = "Timerx Control Register\n\nThis register you can [`read`](crate::generic::Reg::read), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [timbcr](index.html) module"]
pub struct TIMBCR_SPEC;
impl crate::RegisterSpec for TIMBCR_SPEC {
type Ux = u32;
}
#[doc = "`read()` method returns [timbcr::R](R) reader structure"]
impl crate::Readable for TIMBCR_SPEC {
type Reader = R;
}
#[doc = "`write(|w| ..)` method takes [timbcr::W](W) writer structure"]
impl crate::Writable for TIMBCR_SPEC {
type Writer = W;
}
#[doc = "`reset()` method sets TIMBCR to value 0"]
impl crate::Resettable for TIMBCR_SPEC {
#[inline(always)]
fn reset_value() -> Self::Ux {
0
}
}