efm32pg12_pac/msc/
writecmd.rs1#[doc = "Writer for register WRITECMD"]
2pub type W = crate::W<u32, super::WRITECMD>;
3#[doc = "Register WRITECMD `reset()`'s with value 0"]
4impl crate::ResetValue for super::WRITECMD {
5 type Type = u32;
6 #[inline(always)]
7 fn reset_value() -> Self::Type {
8 0
9 }
10}
11#[doc = "Write proxy for field `LADDRIM`"]
12pub struct LADDRIM_W<'a> {
13 w: &'a mut W,
14}
15impl<'a> LADDRIM_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 `ERASEPAGE`"]
34pub struct ERASEPAGE_W<'a> {
35 w: &'a mut W,
36}
37impl<'a> ERASEPAGE_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 `WRITEEND`"]
56pub struct WRITEEND_W<'a> {
57 w: &'a mut W,
58}
59impl<'a> WRITEEND_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 `WRITEONCE`"]
78pub struct WRITEONCE_W<'a> {
79 w: &'a mut W,
80}
81impl<'a> WRITEONCE_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 `WRITETRIG`"]
100pub struct WRITETRIG_W<'a> {
101 w: &'a mut W,
102}
103impl<'a> WRITETRIG_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 << 4)) | (((value as u32) & 0x01) << 4);
118 self.w
119 }
120}
121#[doc = "Write proxy for field `ERASEABORT`"]
122pub struct ERASEABORT_W<'a> {
123 w: &'a mut W,
124}
125impl<'a> ERASEABORT_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 << 5)) | (((value as u32) & 0x01) << 5);
140 self.w
141 }
142}
143#[doc = "Write proxy for field `ERASEMAIN0`"]
144pub struct ERASEMAIN0_W<'a> {
145 w: &'a mut W,
146}
147impl<'a> ERASEMAIN0_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 `ERASEMAIN1`"]
166pub struct ERASEMAIN1_W<'a> {
167 w: &'a mut W,
168}
169impl<'a> ERASEMAIN1_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 `CLEARWDATA`"]
188pub struct CLEARWDATA_W<'a> {
189 w: &'a mut W,
190}
191impl<'a> CLEARWDATA_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 << 12)) | (((value as u32) & 0x01) << 12);
206 self.w
207 }
208}
209impl W {
210 #[doc = "Bit 0 - Load MSC_ADDRB Into ADDR"]
211 #[inline(always)]
212 pub fn laddrim(&mut self) -> LADDRIM_W {
213 LADDRIM_W { w: self }
214 }
215 #[doc = "Bit 1 - Erase Page"]
216 #[inline(always)]
217 pub fn erasepage(&mut self) -> ERASEPAGE_W {
218 ERASEPAGE_W { w: self }
219 }
220 #[doc = "Bit 2 - End Write Mode"]
221 #[inline(always)]
222 pub fn writeend(&mut self) -> WRITEEND_W {
223 WRITEEND_W { w: self }
224 }
225 #[doc = "Bit 3 - Word Write-Once Trigger"]
226 #[inline(always)]
227 pub fn writeonce(&mut self) -> WRITEONCE_W {
228 WRITEONCE_W { w: self }
229 }
230 #[doc = "Bit 4 - Word Write Sequence Trigger"]
231 #[inline(always)]
232 pub fn writetrig(&mut self) -> WRITETRIG_W {
233 WRITETRIG_W { w: self }
234 }
235 #[doc = "Bit 5 - Abort Erase Sequence"]
236 #[inline(always)]
237 pub fn eraseabort(&mut self) -> ERASEABORT_W {
238 ERASEABORT_W { w: self }
239 }
240 #[doc = "Bit 8 - Mass Erase Region 0"]
241 #[inline(always)]
242 pub fn erasemain0(&mut self) -> ERASEMAIN0_W {
243 ERASEMAIN0_W { w: self }
244 }
245 #[doc = "Bit 9 - Mass Erase Region 1"]
246 #[inline(always)]
247 pub fn erasemain1(&mut self) -> ERASEMAIN1_W {
248 ERASEMAIN1_W { w: self }
249 }
250 #[doc = "Bit 12 - Clear WDATA State"]
251 #[inline(always)]
252 pub fn clearwdata(&mut self) -> CLEARWDATA_W {
253 CLEARWDATA_W { w: self }
254 }
255}