atsamd51j/evsys/
user.rs

1#[doc = "Register `USER[%s]` reader"]
2pub type R = crate::R<UserSpec>;
3#[doc = "Register `USER[%s]` writer"]
4pub type W = crate::W<UserSpec>;
5#[doc = "Field `CHANNEL` reader - Channel Event Selection"]
6pub type ChannelR = crate::FieldReader;
7#[doc = "Field `CHANNEL` writer - Channel Event Selection"]
8pub type ChannelW<'a, REG> = crate::FieldWriter<'a, REG, 6>;
9impl R {
10    #[doc = "Bits 0:5 - Channel Event Selection"]
11    #[inline(always)]
12    pub fn channel(&self) -> ChannelR {
13        ChannelR::new((self.bits & 0x3f) as u8)
14    }
15}
16impl W {
17    #[doc = "Bits 0:5 - Channel Event Selection"]
18    #[inline(always)]
19    #[must_use]
20    pub fn channel(&mut self) -> ChannelW<UserSpec> {
21        ChannelW::new(self, 0)
22    }
23}
24#[doc = "User Multiplexer n\n\nYou can [`read`](crate::Reg::read) this register and get [`user::R`](R). You can [`reset`](crate::Reg::reset), [`write`](crate::Reg::write), [`write_with_zero`](crate::Reg::write_with_zero) this register using [`user::W`](W). You can also [`modify`](crate::Reg::modify) this register. See [API](https://docs.rs/svd2rust/#read--modify--write-api)."]
25pub struct UserSpec;
26impl crate::RegisterSpec for UserSpec {
27    type Ux = u32;
28}
29#[doc = "`read()` method returns [`user::R`](R) reader structure"]
30impl crate::Readable for UserSpec {}
31#[doc = "`write(|w| ..)` method takes [`user::W`](W) writer structure"]
32impl crate::Writable for UserSpec {
33    type Safety = crate::Unsafe;
34    const ZERO_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
35    const ONE_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
36}
37#[doc = "`reset()` method sets USER[%s]
38to value 0"]
39impl crate::Resettable for UserSpec {
40    const RESET_VALUE: u32 = 0;
41}