efm32pg12_pac/i2c0/
ifs.rs1#[doc = "Writer for register IFS"]
2pub type W = crate::W<u32, super::IFS>;
3#[doc = "Register IFS `reset()`'s with value 0"]
4impl crate::ResetValue for super::IFS {
5 type Type = u32;
6 #[inline(always)]
7 fn reset_value() -> Self::Type {
8 0
9 }
10}
11#[doc = "Write proxy for field `START`"]
12pub struct START_W<'a> {
13 w: &'a mut W,
14}
15impl<'a> START_W<'a> {
16 #[doc = r"Sets the field bit"]
17 #[inline(always)]
18 pub fn set_bit(self) -> &'a mut W {
19 self.bit(true)
20 }
21 #[doc = r"Clears the field bit"]
22 #[inline(always)]
23 pub fn clear_bit(self) -> &'a mut W {
24 self.bit(false)
25 }
26 #[doc = r"Writes raw bits to the field"]
27 #[inline(always)]
28 pub fn bit(self, value: bool) -> &'a mut W {
29 self.w.bits = (self.w.bits & !0x01) | ((value as u32) & 0x01);
30 self.w
31 }
32}
33#[doc = "Write proxy for field `RSTART`"]
34pub struct RSTART_W<'a> {
35 w: &'a mut W,
36}
37impl<'a> RSTART_W<'a> {
38 #[doc = r"Sets the field bit"]
39 #[inline(always)]
40 pub fn set_bit(self) -> &'a mut W {
41 self.bit(true)
42 }
43 #[doc = r"Clears the field bit"]
44 #[inline(always)]
45 pub fn clear_bit(self) -> &'a mut W {
46 self.bit(false)
47 }
48 #[doc = r"Writes raw bits to the field"]
49 #[inline(always)]
50 pub fn bit(self, value: bool) -> &'a mut W {
51 self.w.bits = (self.w.bits & !(0x01 << 1)) | (((value as u32) & 0x01) << 1);
52 self.w
53 }
54}
55#[doc = "Write proxy for field `ADDR`"]
56pub struct ADDR_W<'a> {
57 w: &'a mut W,
58}
59impl<'a> ADDR_W<'a> {
60 #[doc = r"Sets the field bit"]
61 #[inline(always)]
62 pub fn set_bit(self) -> &'a mut W {
63 self.bit(true)
64 }
65 #[doc = r"Clears the field bit"]
66 #[inline(always)]
67 pub fn clear_bit(self) -> &'a mut W {
68 self.bit(false)
69 }
70 #[doc = r"Writes raw bits to the field"]
71 #[inline(always)]
72 pub fn bit(self, value: bool) -> &'a mut W {
73 self.w.bits = (self.w.bits & !(0x01 << 2)) | (((value as u32) & 0x01) << 2);
74 self.w
75 }
76}
77#[doc = "Write proxy for field `TXC`"]
78pub struct TXC_W<'a> {
79 w: &'a mut W,
80}
81impl<'a> TXC_W<'a> {
82 #[doc = r"Sets the field bit"]
83 #[inline(always)]
84 pub fn set_bit(self) -> &'a mut W {
85 self.bit(true)
86 }
87 #[doc = r"Clears the field bit"]
88 #[inline(always)]
89 pub fn clear_bit(self) -> &'a mut W {
90 self.bit(false)
91 }
92 #[doc = r"Writes raw bits to the field"]
93 #[inline(always)]
94 pub fn bit(self, value: bool) -> &'a mut W {
95 self.w.bits = (self.w.bits & !(0x01 << 3)) | (((value as u32) & 0x01) << 3);
96 self.w
97 }
98}
99#[doc = "Write proxy for field `ACK`"]
100pub struct ACK_W<'a> {
101 w: &'a mut W,
102}
103impl<'a> ACK_W<'a> {
104 #[doc = r"Sets the field bit"]
105 #[inline(always)]
106 pub fn set_bit(self) -> &'a mut W {
107 self.bit(true)
108 }
109 #[doc = r"Clears the field bit"]
110 #[inline(always)]
111 pub fn clear_bit(self) -> &'a mut W {
112 self.bit(false)
113 }
114 #[doc = r"Writes raw bits to the field"]
115 #[inline(always)]
116 pub fn bit(self, value: bool) -> &'a mut W {
117 self.w.bits = (self.w.bits & !(0x01 << 6)) | (((value as u32) & 0x01) << 6);
118 self.w
119 }
120}
121#[doc = "Write proxy for field `NACK`"]
122pub struct NACK_W<'a> {
123 w: &'a mut W,
124}
125impl<'a> NACK_W<'a> {
126 #[doc = r"Sets the field bit"]
127 #[inline(always)]
128 pub fn set_bit(self) -> &'a mut W {
129 self.bit(true)
130 }
131 #[doc = r"Clears the field bit"]
132 #[inline(always)]
133 pub fn clear_bit(self) -> &'a mut W {
134 self.bit(false)
135 }
136 #[doc = r"Writes raw bits to the field"]
137 #[inline(always)]
138 pub fn bit(self, value: bool) -> &'a mut W {
139 self.w.bits = (self.w.bits & !(0x01 << 7)) | (((value as u32) & 0x01) << 7);
140 self.w
141 }
142}
143#[doc = "Write proxy for field `MSTOP`"]
144pub struct MSTOP_W<'a> {
145 w: &'a mut W,
146}
147impl<'a> MSTOP_W<'a> {
148 #[doc = r"Sets the field bit"]
149 #[inline(always)]
150 pub fn set_bit(self) -> &'a mut W {
151 self.bit(true)
152 }
153 #[doc = r"Clears the field bit"]
154 #[inline(always)]
155 pub fn clear_bit(self) -> &'a mut W {
156 self.bit(false)
157 }
158 #[doc = r"Writes raw bits to the field"]
159 #[inline(always)]
160 pub fn bit(self, value: bool) -> &'a mut W {
161 self.w.bits = (self.w.bits & !(0x01 << 8)) | (((value as u32) & 0x01) << 8);
162 self.w
163 }
164}
165#[doc = "Write proxy for field `ARBLOST`"]
166pub struct ARBLOST_W<'a> {
167 w: &'a mut W,
168}
169impl<'a> ARBLOST_W<'a> {
170 #[doc = r"Sets the field bit"]
171 #[inline(always)]
172 pub fn set_bit(self) -> &'a mut W {
173 self.bit(true)
174 }
175 #[doc = r"Clears the field bit"]
176 #[inline(always)]
177 pub fn clear_bit(self) -> &'a mut W {
178 self.bit(false)
179 }
180 #[doc = r"Writes raw bits to the field"]
181 #[inline(always)]
182 pub fn bit(self, value: bool) -> &'a mut W {
183 self.w.bits = (self.w.bits & !(0x01 << 9)) | (((value as u32) & 0x01) << 9);
184 self.w
185 }
186}
187#[doc = "Write proxy for field `BUSERR`"]
188pub struct BUSERR_W<'a> {
189 w: &'a mut W,
190}
191impl<'a> BUSERR_W<'a> {
192 #[doc = r"Sets the field bit"]
193 #[inline(always)]
194 pub fn set_bit(self) -> &'a mut W {
195 self.bit(true)
196 }
197 #[doc = r"Clears the field bit"]
198 #[inline(always)]
199 pub fn clear_bit(self) -> &'a mut W {
200 self.bit(false)
201 }
202 #[doc = r"Writes raw bits to the field"]
203 #[inline(always)]
204 pub fn bit(self, value: bool) -> &'a mut W {
205 self.w.bits = (self.w.bits & !(0x01 << 10)) | (((value as u32) & 0x01) << 10);
206 self.w
207 }
208}
209#[doc = "Write proxy for field `BUSHOLD`"]
210pub struct BUSHOLD_W<'a> {
211 w: &'a mut W,
212}
213impl<'a> BUSHOLD_W<'a> {
214 #[doc = r"Sets the field bit"]
215 #[inline(always)]
216 pub fn set_bit(self) -> &'a mut W {
217 self.bit(true)
218 }
219 #[doc = r"Clears the field bit"]
220 #[inline(always)]
221 pub fn clear_bit(self) -> &'a mut W {
222 self.bit(false)
223 }
224 #[doc = r"Writes raw bits to the field"]
225 #[inline(always)]
226 pub fn bit(self, value: bool) -> &'a mut W {
227 self.w.bits = (self.w.bits & !(0x01 << 11)) | (((value as u32) & 0x01) << 11);
228 self.w
229 }
230}
231#[doc = "Write proxy for field `TXOF`"]
232pub struct TXOF_W<'a> {
233 w: &'a mut W,
234}
235impl<'a> TXOF_W<'a> {
236 #[doc = r"Sets the field bit"]
237 #[inline(always)]
238 pub fn set_bit(self) -> &'a mut W {
239 self.bit(true)
240 }
241 #[doc = r"Clears the field bit"]
242 #[inline(always)]
243 pub fn clear_bit(self) -> &'a mut W {
244 self.bit(false)
245 }
246 #[doc = r"Writes raw bits to the field"]
247 #[inline(always)]
248 pub fn bit(self, value: bool) -> &'a mut W {
249 self.w.bits = (self.w.bits & !(0x01 << 12)) | (((value as u32) & 0x01) << 12);
250 self.w
251 }
252}
253#[doc = "Write proxy for field `RXUF`"]
254pub struct RXUF_W<'a> {
255 w: &'a mut W,
256}
257impl<'a> RXUF_W<'a> {
258 #[doc = r"Sets the field bit"]
259 #[inline(always)]
260 pub fn set_bit(self) -> &'a mut W {
261 self.bit(true)
262 }
263 #[doc = r"Clears the field bit"]
264 #[inline(always)]
265 pub fn clear_bit(self) -> &'a mut W {
266 self.bit(false)
267 }
268 #[doc = r"Writes raw bits to the field"]
269 #[inline(always)]
270 pub fn bit(self, value: bool) -> &'a mut W {
271 self.w.bits = (self.w.bits & !(0x01 << 13)) | (((value as u32) & 0x01) << 13);
272 self.w
273 }
274}
275#[doc = "Write proxy for field `BITO`"]
276pub struct BITO_W<'a> {
277 w: &'a mut W,
278}
279impl<'a> BITO_W<'a> {
280 #[doc = r"Sets the field bit"]
281 #[inline(always)]
282 pub fn set_bit(self) -> &'a mut W {
283 self.bit(true)
284 }
285 #[doc = r"Clears the field bit"]
286 #[inline(always)]
287 pub fn clear_bit(self) -> &'a mut W {
288 self.bit(false)
289 }
290 #[doc = r"Writes raw bits to the field"]
291 #[inline(always)]
292 pub fn bit(self, value: bool) -> &'a mut W {
293 self.w.bits = (self.w.bits & !(0x01 << 14)) | (((value as u32) & 0x01) << 14);
294 self.w
295 }
296}
297#[doc = "Write proxy for field `CLTO`"]
298pub struct CLTO_W<'a> {
299 w: &'a mut W,
300}
301impl<'a> CLTO_W<'a> {
302 #[doc = r"Sets the field bit"]
303 #[inline(always)]
304 pub fn set_bit(self) -> &'a mut W {
305 self.bit(true)
306 }
307 #[doc = r"Clears the field bit"]
308 #[inline(always)]
309 pub fn clear_bit(self) -> &'a mut W {
310 self.bit(false)
311 }
312 #[doc = r"Writes raw bits to the field"]
313 #[inline(always)]
314 pub fn bit(self, value: bool) -> &'a mut W {
315 self.w.bits = (self.w.bits & !(0x01 << 15)) | (((value as u32) & 0x01) << 15);
316 self.w
317 }
318}
319#[doc = "Write proxy for field `SSTOP`"]
320pub struct SSTOP_W<'a> {
321 w: &'a mut W,
322}
323impl<'a> SSTOP_W<'a> {
324 #[doc = r"Sets the field bit"]
325 #[inline(always)]
326 pub fn set_bit(self) -> &'a mut W {
327 self.bit(true)
328 }
329 #[doc = r"Clears the field bit"]
330 #[inline(always)]
331 pub fn clear_bit(self) -> &'a mut W {
332 self.bit(false)
333 }
334 #[doc = r"Writes raw bits to the field"]
335 #[inline(always)]
336 pub fn bit(self, value: bool) -> &'a mut W {
337 self.w.bits = (self.w.bits & !(0x01 << 16)) | (((value as u32) & 0x01) << 16);
338 self.w
339 }
340}
341#[doc = "Write proxy for field `RXFULL`"]
342pub struct RXFULL_W<'a> {
343 w: &'a mut W,
344}
345impl<'a> RXFULL_W<'a> {
346 #[doc = r"Sets the field bit"]
347 #[inline(always)]
348 pub fn set_bit(self) -> &'a mut W {
349 self.bit(true)
350 }
351 #[doc = r"Clears the field bit"]
352 #[inline(always)]
353 pub fn clear_bit(self) -> &'a mut W {
354 self.bit(false)
355 }
356 #[doc = r"Writes raw bits to the field"]
357 #[inline(always)]
358 pub fn bit(self, value: bool) -> &'a mut W {
359 self.w.bits = (self.w.bits & !(0x01 << 17)) | (((value as u32) & 0x01) << 17);
360 self.w
361 }
362}
363#[doc = "Write proxy for field `CLERR`"]
364pub struct CLERR_W<'a> {
365 w: &'a mut W,
366}
367impl<'a> CLERR_W<'a> {
368 #[doc = r"Sets the field bit"]
369 #[inline(always)]
370 pub fn set_bit(self) -> &'a mut W {
371 self.bit(true)
372 }
373 #[doc = r"Clears the field bit"]
374 #[inline(always)]
375 pub fn clear_bit(self) -> &'a mut W {
376 self.bit(false)
377 }
378 #[doc = r"Writes raw bits to the field"]
379 #[inline(always)]
380 pub fn bit(self, value: bool) -> &'a mut W {
381 self.w.bits = (self.w.bits & !(0x01 << 18)) | (((value as u32) & 0x01) << 18);
382 self.w
383 }
384}
385impl W {
386 #[doc = "Bit 0 - Set START Interrupt Flag"]
387 #[inline(always)]
388 pub fn start(&mut self) -> START_W {
389 START_W { w: self }
390 }
391 #[doc = "Bit 1 - Set RSTART Interrupt Flag"]
392 #[inline(always)]
393 pub fn rstart(&mut self) -> RSTART_W {
394 RSTART_W { w: self }
395 }
396 #[doc = "Bit 2 - Set ADDR Interrupt Flag"]
397 #[inline(always)]
398 pub fn addr(&mut self) -> ADDR_W {
399 ADDR_W { w: self }
400 }
401 #[doc = "Bit 3 - Set TXC Interrupt Flag"]
402 #[inline(always)]
403 pub fn txc(&mut self) -> TXC_W {
404 TXC_W { w: self }
405 }
406 #[doc = "Bit 6 - Set ACK Interrupt Flag"]
407 #[inline(always)]
408 pub fn ack(&mut self) -> ACK_W {
409 ACK_W { w: self }
410 }
411 #[doc = "Bit 7 - Set NACK Interrupt Flag"]
412 #[inline(always)]
413 pub fn nack(&mut self) -> NACK_W {
414 NACK_W { w: self }
415 }
416 #[doc = "Bit 8 - Set MSTOP Interrupt Flag"]
417 #[inline(always)]
418 pub fn mstop(&mut self) -> MSTOP_W {
419 MSTOP_W { w: self }
420 }
421 #[doc = "Bit 9 - Set ARBLOST Interrupt Flag"]
422 #[inline(always)]
423 pub fn arblost(&mut self) -> ARBLOST_W {
424 ARBLOST_W { w: self }
425 }
426 #[doc = "Bit 10 - Set BUSERR Interrupt Flag"]
427 #[inline(always)]
428 pub fn buserr(&mut self) -> BUSERR_W {
429 BUSERR_W { w: self }
430 }
431 #[doc = "Bit 11 - Set BUSHOLD Interrupt Flag"]
432 #[inline(always)]
433 pub fn bushold(&mut self) -> BUSHOLD_W {
434 BUSHOLD_W { w: self }
435 }
436 #[doc = "Bit 12 - Set TXOF Interrupt Flag"]
437 #[inline(always)]
438 pub fn txof(&mut self) -> TXOF_W {
439 TXOF_W { w: self }
440 }
441 #[doc = "Bit 13 - Set RXUF Interrupt Flag"]
442 #[inline(always)]
443 pub fn rxuf(&mut self) -> RXUF_W {
444 RXUF_W { w: self }
445 }
446 #[doc = "Bit 14 - Set BITO Interrupt Flag"]
447 #[inline(always)]
448 pub fn bito(&mut self) -> BITO_W {
449 BITO_W { w: self }
450 }
451 #[doc = "Bit 15 - Set CLTO Interrupt Flag"]
452 #[inline(always)]
453 pub fn clto(&mut self) -> CLTO_W {
454 CLTO_W { w: self }
455 }
456 #[doc = "Bit 16 - Set SSTOP Interrupt Flag"]
457 #[inline(always)]
458 pub fn sstop(&mut self) -> SSTOP_W {
459 SSTOP_W { w: self }
460 }
461 #[doc = "Bit 17 - Set RXFULL Interrupt Flag"]
462 #[inline(always)]
463 pub fn rxfull(&mut self) -> RXFULL_W {
464 RXFULL_W { w: self }
465 }
466 #[doc = "Bit 18 - Set CLERR Interrupt Flag"]
467 #[inline(always)]
468 pub fn clerr(&mut self) -> CLERR_W {
469 CLERR_W { w: self }
470 }
471}