atsamd11c/tcc0/
pattb.rs

1#[doc = "Register `PATTB` reader"]
2pub type R = crate::R<PattbSpec>;
3#[doc = "Register `PATTB` writer"]
4pub type W = crate::W<PattbSpec>;
5#[doc = "Field `PGEB0` reader - Pattern Generator 0 Output Enable Buffer"]
6pub type Pgeb0R = crate::BitReader;
7#[doc = "Field `PGEB0` writer - Pattern Generator 0 Output Enable Buffer"]
8pub type Pgeb0W<'a, REG> = crate::BitWriter<'a, REG>;
9#[doc = "Field `PGEB1` reader - Pattern Generator 1 Output Enable Buffer"]
10pub type Pgeb1R = crate::BitReader;
11#[doc = "Field `PGEB1` writer - Pattern Generator 1 Output Enable Buffer"]
12pub type Pgeb1W<'a, REG> = crate::BitWriter<'a, REG>;
13#[doc = "Field `PGEB2` reader - Pattern Generator 2 Output Enable Buffer"]
14pub type Pgeb2R = crate::BitReader;
15#[doc = "Field `PGEB2` writer - Pattern Generator 2 Output Enable Buffer"]
16pub type Pgeb2W<'a, REG> = crate::BitWriter<'a, REG>;
17#[doc = "Field `PGEB3` reader - Pattern Generator 3 Output Enable Buffer"]
18pub type Pgeb3R = crate::BitReader;
19#[doc = "Field `PGEB3` writer - Pattern Generator 3 Output Enable Buffer"]
20pub type Pgeb3W<'a, REG> = crate::BitWriter<'a, REG>;
21#[doc = "Field `PGEB4` reader - Pattern Generator 4 Output Enable Buffer"]
22pub type Pgeb4R = crate::BitReader;
23#[doc = "Field `PGEB4` writer - Pattern Generator 4 Output Enable Buffer"]
24pub type Pgeb4W<'a, REG> = crate::BitWriter<'a, REG>;
25#[doc = "Field `PGEB5` reader - Pattern Generator 5 Output Enable Buffer"]
26pub type Pgeb5R = crate::BitReader;
27#[doc = "Field `PGEB5` writer - Pattern Generator 5 Output Enable Buffer"]
28pub type Pgeb5W<'a, REG> = crate::BitWriter<'a, REG>;
29#[doc = "Field `PGEB6` reader - Pattern Generator 6 Output Enable Buffer"]
30pub type Pgeb6R = crate::BitReader;
31#[doc = "Field `PGEB6` writer - Pattern Generator 6 Output Enable Buffer"]
32pub type Pgeb6W<'a, REG> = crate::BitWriter<'a, REG>;
33#[doc = "Field `PGEB7` reader - Pattern Generator 7 Output Enable Buffer"]
34pub type Pgeb7R = crate::BitReader;
35#[doc = "Field `PGEB7` writer - Pattern Generator 7 Output Enable Buffer"]
36pub type Pgeb7W<'a, REG> = crate::BitWriter<'a, REG>;
37#[doc = "Field `PGVB0` reader - Pattern Generator 0 Output Enable"]
38pub type Pgvb0R = crate::BitReader;
39#[doc = "Field `PGVB0` writer - Pattern Generator 0 Output Enable"]
40pub type Pgvb0W<'a, REG> = crate::BitWriter<'a, REG>;
41#[doc = "Field `PGVB1` reader - Pattern Generator 1 Output Enable"]
42pub type Pgvb1R = crate::BitReader;
43#[doc = "Field `PGVB1` writer - Pattern Generator 1 Output Enable"]
44pub type Pgvb1W<'a, REG> = crate::BitWriter<'a, REG>;
45#[doc = "Field `PGVB2` reader - Pattern Generator 2 Output Enable"]
46pub type Pgvb2R = crate::BitReader;
47#[doc = "Field `PGVB2` writer - Pattern Generator 2 Output Enable"]
48pub type Pgvb2W<'a, REG> = crate::BitWriter<'a, REG>;
49#[doc = "Field `PGVB3` reader - Pattern Generator 3 Output Enable"]
50pub type Pgvb3R = crate::BitReader;
51#[doc = "Field `PGVB3` writer - Pattern Generator 3 Output Enable"]
52pub type Pgvb3W<'a, REG> = crate::BitWriter<'a, REG>;
53#[doc = "Field `PGVB4` reader - Pattern Generator 4 Output Enable"]
54pub type Pgvb4R = crate::BitReader;
55#[doc = "Field `PGVB4` writer - Pattern Generator 4 Output Enable"]
56pub type Pgvb4W<'a, REG> = crate::BitWriter<'a, REG>;
57#[doc = "Field `PGVB5` reader - Pattern Generator 5 Output Enable"]
58pub type Pgvb5R = crate::BitReader;
59#[doc = "Field `PGVB5` writer - Pattern Generator 5 Output Enable"]
60pub type Pgvb5W<'a, REG> = crate::BitWriter<'a, REG>;
61#[doc = "Field `PGVB6` reader - Pattern Generator 6 Output Enable"]
62pub type Pgvb6R = crate::BitReader;
63#[doc = "Field `PGVB6` writer - Pattern Generator 6 Output Enable"]
64pub type Pgvb6W<'a, REG> = crate::BitWriter<'a, REG>;
65#[doc = "Field `PGVB7` reader - Pattern Generator 7 Output Enable"]
66pub type Pgvb7R = crate::BitReader;
67#[doc = "Field `PGVB7` writer - Pattern Generator 7 Output Enable"]
68pub type Pgvb7W<'a, REG> = crate::BitWriter<'a, REG>;
69impl R {
70    #[doc = "Bit 0 - Pattern Generator 0 Output Enable Buffer"]
71    #[inline(always)]
72    pub fn pgeb0(&self) -> Pgeb0R {
73        Pgeb0R::new((self.bits & 1) != 0)
74    }
75    #[doc = "Bit 1 - Pattern Generator 1 Output Enable Buffer"]
76    #[inline(always)]
77    pub fn pgeb1(&self) -> Pgeb1R {
78        Pgeb1R::new(((self.bits >> 1) & 1) != 0)
79    }
80    #[doc = "Bit 2 - Pattern Generator 2 Output Enable Buffer"]
81    #[inline(always)]
82    pub fn pgeb2(&self) -> Pgeb2R {
83        Pgeb2R::new(((self.bits >> 2) & 1) != 0)
84    }
85    #[doc = "Bit 3 - Pattern Generator 3 Output Enable Buffer"]
86    #[inline(always)]
87    pub fn pgeb3(&self) -> Pgeb3R {
88        Pgeb3R::new(((self.bits >> 3) & 1) != 0)
89    }
90    #[doc = "Bit 4 - Pattern Generator 4 Output Enable Buffer"]
91    #[inline(always)]
92    pub fn pgeb4(&self) -> Pgeb4R {
93        Pgeb4R::new(((self.bits >> 4) & 1) != 0)
94    }
95    #[doc = "Bit 5 - Pattern Generator 5 Output Enable Buffer"]
96    #[inline(always)]
97    pub fn pgeb5(&self) -> Pgeb5R {
98        Pgeb5R::new(((self.bits >> 5) & 1) != 0)
99    }
100    #[doc = "Bit 6 - Pattern Generator 6 Output Enable Buffer"]
101    #[inline(always)]
102    pub fn pgeb6(&self) -> Pgeb6R {
103        Pgeb6R::new(((self.bits >> 6) & 1) != 0)
104    }
105    #[doc = "Bit 7 - Pattern Generator 7 Output Enable Buffer"]
106    #[inline(always)]
107    pub fn pgeb7(&self) -> Pgeb7R {
108        Pgeb7R::new(((self.bits >> 7) & 1) != 0)
109    }
110    #[doc = "Bit 8 - Pattern Generator 0 Output Enable"]
111    #[inline(always)]
112    pub fn pgvb0(&self) -> Pgvb0R {
113        Pgvb0R::new(((self.bits >> 8) & 1) != 0)
114    }
115    #[doc = "Bit 9 - Pattern Generator 1 Output Enable"]
116    #[inline(always)]
117    pub fn pgvb1(&self) -> Pgvb1R {
118        Pgvb1R::new(((self.bits >> 9) & 1) != 0)
119    }
120    #[doc = "Bit 10 - Pattern Generator 2 Output Enable"]
121    #[inline(always)]
122    pub fn pgvb2(&self) -> Pgvb2R {
123        Pgvb2R::new(((self.bits >> 10) & 1) != 0)
124    }
125    #[doc = "Bit 11 - Pattern Generator 3 Output Enable"]
126    #[inline(always)]
127    pub fn pgvb3(&self) -> Pgvb3R {
128        Pgvb3R::new(((self.bits >> 11) & 1) != 0)
129    }
130    #[doc = "Bit 12 - Pattern Generator 4 Output Enable"]
131    #[inline(always)]
132    pub fn pgvb4(&self) -> Pgvb4R {
133        Pgvb4R::new(((self.bits >> 12) & 1) != 0)
134    }
135    #[doc = "Bit 13 - Pattern Generator 5 Output Enable"]
136    #[inline(always)]
137    pub fn pgvb5(&self) -> Pgvb5R {
138        Pgvb5R::new(((self.bits >> 13) & 1) != 0)
139    }
140    #[doc = "Bit 14 - Pattern Generator 6 Output Enable"]
141    #[inline(always)]
142    pub fn pgvb6(&self) -> Pgvb6R {
143        Pgvb6R::new(((self.bits >> 14) & 1) != 0)
144    }
145    #[doc = "Bit 15 - Pattern Generator 7 Output Enable"]
146    #[inline(always)]
147    pub fn pgvb7(&self) -> Pgvb7R {
148        Pgvb7R::new(((self.bits >> 15) & 1) != 0)
149    }
150}
151impl W {
152    #[doc = "Bit 0 - Pattern Generator 0 Output Enable Buffer"]
153    #[inline(always)]
154    #[must_use]
155    pub fn pgeb0(&mut self) -> Pgeb0W<PattbSpec> {
156        Pgeb0W::new(self, 0)
157    }
158    #[doc = "Bit 1 - Pattern Generator 1 Output Enable Buffer"]
159    #[inline(always)]
160    #[must_use]
161    pub fn pgeb1(&mut self) -> Pgeb1W<PattbSpec> {
162        Pgeb1W::new(self, 1)
163    }
164    #[doc = "Bit 2 - Pattern Generator 2 Output Enable Buffer"]
165    #[inline(always)]
166    #[must_use]
167    pub fn pgeb2(&mut self) -> Pgeb2W<PattbSpec> {
168        Pgeb2W::new(self, 2)
169    }
170    #[doc = "Bit 3 - Pattern Generator 3 Output Enable Buffer"]
171    #[inline(always)]
172    #[must_use]
173    pub fn pgeb3(&mut self) -> Pgeb3W<PattbSpec> {
174        Pgeb3W::new(self, 3)
175    }
176    #[doc = "Bit 4 - Pattern Generator 4 Output Enable Buffer"]
177    #[inline(always)]
178    #[must_use]
179    pub fn pgeb4(&mut self) -> Pgeb4W<PattbSpec> {
180        Pgeb4W::new(self, 4)
181    }
182    #[doc = "Bit 5 - Pattern Generator 5 Output Enable Buffer"]
183    #[inline(always)]
184    #[must_use]
185    pub fn pgeb5(&mut self) -> Pgeb5W<PattbSpec> {
186        Pgeb5W::new(self, 5)
187    }
188    #[doc = "Bit 6 - Pattern Generator 6 Output Enable Buffer"]
189    #[inline(always)]
190    #[must_use]
191    pub fn pgeb6(&mut self) -> Pgeb6W<PattbSpec> {
192        Pgeb6W::new(self, 6)
193    }
194    #[doc = "Bit 7 - Pattern Generator 7 Output Enable Buffer"]
195    #[inline(always)]
196    #[must_use]
197    pub fn pgeb7(&mut self) -> Pgeb7W<PattbSpec> {
198        Pgeb7W::new(self, 7)
199    }
200    #[doc = "Bit 8 - Pattern Generator 0 Output Enable"]
201    #[inline(always)]
202    #[must_use]
203    pub fn pgvb0(&mut self) -> Pgvb0W<PattbSpec> {
204        Pgvb0W::new(self, 8)
205    }
206    #[doc = "Bit 9 - Pattern Generator 1 Output Enable"]
207    #[inline(always)]
208    #[must_use]
209    pub fn pgvb1(&mut self) -> Pgvb1W<PattbSpec> {
210        Pgvb1W::new(self, 9)
211    }
212    #[doc = "Bit 10 - Pattern Generator 2 Output Enable"]
213    #[inline(always)]
214    #[must_use]
215    pub fn pgvb2(&mut self) -> Pgvb2W<PattbSpec> {
216        Pgvb2W::new(self, 10)
217    }
218    #[doc = "Bit 11 - Pattern Generator 3 Output Enable"]
219    #[inline(always)]
220    #[must_use]
221    pub fn pgvb3(&mut self) -> Pgvb3W<PattbSpec> {
222        Pgvb3W::new(self, 11)
223    }
224    #[doc = "Bit 12 - Pattern Generator 4 Output Enable"]
225    #[inline(always)]
226    #[must_use]
227    pub fn pgvb4(&mut self) -> Pgvb4W<PattbSpec> {
228        Pgvb4W::new(self, 12)
229    }
230    #[doc = "Bit 13 - Pattern Generator 5 Output Enable"]
231    #[inline(always)]
232    #[must_use]
233    pub fn pgvb5(&mut self) -> Pgvb5W<PattbSpec> {
234        Pgvb5W::new(self, 13)
235    }
236    #[doc = "Bit 14 - Pattern Generator 6 Output Enable"]
237    #[inline(always)]
238    #[must_use]
239    pub fn pgvb6(&mut self) -> Pgvb6W<PattbSpec> {
240        Pgvb6W::new(self, 14)
241    }
242    #[doc = "Bit 15 - Pattern Generator 7 Output Enable"]
243    #[inline(always)]
244    #[must_use]
245    pub fn pgvb7(&mut self) -> Pgvb7W<PattbSpec> {
246        Pgvb7W::new(self, 15)
247    }
248}
249#[doc = "Pattern Buffer\n\nYou can [`read`](crate::Reg::read) this register and get [`pattb::R`](R). You can [`reset`](crate::Reg::reset), [`write`](crate::Reg::write), [`write_with_zero`](crate::Reg::write_with_zero) this register using [`pattb::W`](W). You can also [`modify`](crate::Reg::modify) this register. See [API](https://docs.rs/svd2rust/#read--modify--write-api)."]
250pub struct PattbSpec;
251impl crate::RegisterSpec for PattbSpec {
252    type Ux = u16;
253}
254#[doc = "`read()` method returns [`pattb::R`](R) reader structure"]
255impl crate::Readable for PattbSpec {}
256#[doc = "`write(|w| ..)` method takes [`pattb::W`](W) writer structure"]
257impl crate::Writable for PattbSpec {
258    type Safety = crate::Unsafe;
259    const ZERO_TO_MODIFY_FIELDS_BITMAP: u16 = 0;
260    const ONE_TO_MODIFY_FIELDS_BITMAP: u16 = 0;
261}
262#[doc = "`reset()` method sets PATTB to value 0"]
263impl crate::Resettable for PattbSpec {
264    const RESET_VALUE: u16 = 0;
265}