1#[doc = "Register `ef_cfg_0` reader"]
2pub struct R(crate::R<EF_CFG_0_SPEC>);
3impl core::ops::Deref for R {
4 type Target = crate::R<EF_CFG_0_SPEC>;
5 #[inline(always)]
6 fn deref(&self) -> &Self::Target {
7 &self.0
8 }
9}
10impl From<crate::R<EF_CFG_0_SPEC>> for R {
11 #[inline(always)]
12 fn from(reader: crate::R<EF_CFG_0_SPEC>) -> Self {
13 R(reader)
14 }
15}
16#[doc = "Register `ef_cfg_0` writer"]
17pub struct W(crate::W<EF_CFG_0_SPEC>);
18impl core::ops::Deref for W {
19 type Target = crate::W<EF_CFG_0_SPEC>;
20 #[inline(always)]
21 fn deref(&self) -> &Self::Target {
22 &self.0
23 }
24}
25impl core::ops::DerefMut for W {
26 #[inline(always)]
27 fn deref_mut(&mut self) -> &mut Self::Target {
28 &mut self.0
29 }
30}
31impl From<crate::W<EF_CFG_0_SPEC>> for W {
32 #[inline(always)]
33 fn from(writer: crate::W<EF_CFG_0_SPEC>) -> Self {
34 W(writer)
35 }
36}
37#[doc = "Field `ef_sf_aes_mode` reader - "]
38pub type EF_SF_AES_MODE_R = crate::FieldReader<u8, u8>;
39#[doc = "Field `ef_sf_aes_mode` writer - "]
40pub type EF_SF_AES_MODE_W<'a, const O: u8> =
41 crate::FieldWriter<'a, u32, EF_CFG_0_SPEC, u8, u8, 2, O>;
42#[doc = "Field `ef_sboot_sign_mode` reader - "]
43pub type EF_SBOOT_SIGN_MODE_R = crate::FieldReader<u8, u8>;
44#[doc = "Field `ef_sboot_sign_mode` writer - "]
45pub type EF_SBOOT_SIGN_MODE_W<'a, const O: u8> =
46 crate::FieldWriter<'a, u32, EF_CFG_0_SPEC, u8, u8, 2, O>;
47#[doc = "Field `ef_sboot_en` reader - "]
48pub type EF_SBOOT_EN_R = crate::FieldReader<u8, u8>;
49#[doc = "Field `ef_sboot_en` writer - "]
50pub type EF_SBOOT_EN_W<'a, const O: u8> = crate::FieldWriter<'a, u32, EF_CFG_0_SPEC, u8, u8, 2, O>;
51#[doc = "Field `ef_cpu1_enc_en` reader - "]
52pub type EF_CPU1_ENC_EN_R = crate::BitReader<bool>;
53#[doc = "Field `ef_cpu1_enc_en` writer - "]
54pub type EF_CPU1_ENC_EN_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
55#[doc = "Field `ef_cpu0_enc_en` reader - "]
56pub type EF_CPU0_ENC_EN_R = crate::BitReader<bool>;
57#[doc = "Field `ef_cpu0_enc_en` writer - "]
58pub type EF_CPU0_ENC_EN_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
59#[doc = "Field `ef_boot_sel` reader - "]
60pub type EF_BOOT_SEL_R = crate::FieldReader<u8, u8>;
61#[doc = "Field `ef_boot_sel` writer - "]
62pub type EF_BOOT_SEL_W<'a, const O: u8> = crate::FieldWriter<'a, u32, EF_CFG_0_SPEC, u8, u8, 4, O>;
63#[doc = "Field `ef_sf_key_0_sel` reader - "]
64pub type EF_SF_KEY_0_SEL_R = crate::FieldReader<u8, u8>;
65#[doc = "Field `ef_sf_key_0_sel` writer - "]
66pub type EF_SF_KEY_0_SEL_W<'a, const O: u8> =
67 crate::FieldWriter<'a, u32, EF_CFG_0_SPEC, u8, u8, 2, O>;
68#[doc = "Field `ef_sdu_dis` reader - "]
69pub type EF_SDU_DIS_R = crate::BitReader<bool>;
70#[doc = "Field `ef_sdu_dis` writer - "]
71pub type EF_SDU_DIS_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
72#[doc = "Field `ef_ble_dis` reader - "]
73pub type EF_BLE_DIS_R = crate::BitReader<bool>;
74#[doc = "Field `ef_ble_dis` writer - "]
75pub type EF_BLE_DIS_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
76#[doc = "Field `ef_wifi_dis` reader - "]
77pub type EF_WIFI_DIS_R = crate::BitReader<bool>;
78#[doc = "Field `ef_wifi_dis` writer - "]
79pub type EF_WIFI_DIS_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
80#[doc = "Field `ef_0_key_enc_en` reader - "]
81pub type EF_0_KEY_ENC_EN_R = crate::BitReader<bool>;
82#[doc = "Field `ef_0_key_enc_en` writer - "]
83pub type EF_0_KEY_ENC_EN_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
84#[doc = "Field `ef_cam_dis` reader - "]
85pub type EF_CAM_DIS_R = crate::BitReader<bool>;
86#[doc = "Field `ef_cam_dis` writer - "]
87pub type EF_CAM_DIS_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
88#[doc = "Field `ef_sf_dis` reader - "]
89pub type EF_SF_DIS_R = crate::BitReader<bool>;
90#[doc = "Field `ef_sf_dis` writer - "]
91pub type EF_SF_DIS_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
92#[doc = "Field `ef_cpu1_dis` reader - "]
93pub type EF_CPU1_DIS_R = crate::BitReader<bool>;
94#[doc = "Field `ef_cpu1_dis` writer - "]
95pub type EF_CPU1_DIS_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
96#[doc = "Field `ef_cpu_rst_dbg_dis` reader - "]
97pub type EF_CPU_RST_DBG_DIS_R = crate::BitReader<bool>;
98#[doc = "Field `ef_cpu_rst_dbg_dis` writer - "]
99pub type EF_CPU_RST_DBG_DIS_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
100#[doc = "Field `ef_se_dbg_dis` reader - "]
101pub type EF_SE_DBG_DIS_R = crate::BitReader<bool>;
102#[doc = "Field `ef_se_dbg_dis` writer - "]
103pub type EF_SE_DBG_DIS_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
104#[doc = "Field `ef_efuse_dbg_dis` reader - "]
105pub type EF_EFUSE_DBG_DIS_R = crate::BitReader<bool>;
106#[doc = "Field `ef_efuse_dbg_dis` writer - "]
107pub type EF_EFUSE_DBG_DIS_W<'a, const O: u8> = crate::BitWriter<'a, u32, EF_CFG_0_SPEC, bool, O>;
108#[doc = "Field `ef_dbg_jtag_1_dis` reader - "]
109pub type EF_DBG_JTAG_1_DIS_R = crate::FieldReader<u8, u8>;
110#[doc = "Field `ef_dbg_jtag_1_dis` writer - "]
111pub type EF_DBG_JTAG_1_DIS_W<'a, const O: u8> =
112 crate::FieldWriter<'a, u32, EF_CFG_0_SPEC, u8, u8, 2, O>;
113#[doc = "Field `ef_dbg_jtag_0_dis` reader - "]
114pub type EF_DBG_JTAG_0_DIS_R = crate::FieldReader<u8, u8>;
115#[doc = "Field `ef_dbg_jtag_0_dis` writer - "]
116pub type EF_DBG_JTAG_0_DIS_W<'a, const O: u8> =
117 crate::FieldWriter<'a, u32, EF_CFG_0_SPEC, u8, u8, 2, O>;
118#[doc = "Field `ef_dbg_mode` reader - "]
119pub type EF_DBG_MODE_R = crate::FieldReader<u8, u8>;
120#[doc = "Field `ef_dbg_mode` writer - "]
121pub type EF_DBG_MODE_W<'a, const O: u8> = crate::FieldWriter<'a, u32, EF_CFG_0_SPEC, u8, u8, 4, O>;
122impl R {
123 #[doc = "Bits 0:1"]
124 #[inline(always)]
125 pub fn ef_sf_aes_mode(&self) -> EF_SF_AES_MODE_R {
126 EF_SF_AES_MODE_R::new((self.bits & 3) as u8)
127 }
128 #[doc = "Bits 2:3"]
129 #[inline(always)]
130 pub fn ef_sboot_sign_mode(&self) -> EF_SBOOT_SIGN_MODE_R {
131 EF_SBOOT_SIGN_MODE_R::new(((self.bits >> 2) & 3) as u8)
132 }
133 #[doc = "Bits 4:5"]
134 #[inline(always)]
135 pub fn ef_sboot_en(&self) -> EF_SBOOT_EN_R {
136 EF_SBOOT_EN_R::new(((self.bits >> 4) & 3) as u8)
137 }
138 #[doc = "Bit 6"]
139 #[inline(always)]
140 pub fn ef_cpu1_enc_en(&self) -> EF_CPU1_ENC_EN_R {
141 EF_CPU1_ENC_EN_R::new(((self.bits >> 6) & 1) != 0)
142 }
143 #[doc = "Bit 7"]
144 #[inline(always)]
145 pub fn ef_cpu0_enc_en(&self) -> EF_CPU0_ENC_EN_R {
146 EF_CPU0_ENC_EN_R::new(((self.bits >> 7) & 1) != 0)
147 }
148 #[doc = "Bits 8:11"]
149 #[inline(always)]
150 pub fn ef_boot_sel(&self) -> EF_BOOT_SEL_R {
151 EF_BOOT_SEL_R::new(((self.bits >> 8) & 0x0f) as u8)
152 }
153 #[doc = "Bits 12:13"]
154 #[inline(always)]
155 pub fn ef_sf_key_0_sel(&self) -> EF_SF_KEY_0_SEL_R {
156 EF_SF_KEY_0_SEL_R::new(((self.bits >> 12) & 3) as u8)
157 }
158 #[doc = "Bit 14"]
159 #[inline(always)]
160 pub fn ef_sdu_dis(&self) -> EF_SDU_DIS_R {
161 EF_SDU_DIS_R::new(((self.bits >> 14) & 1) != 0)
162 }
163 #[doc = "Bit 15"]
164 #[inline(always)]
165 pub fn ef_ble_dis(&self) -> EF_BLE_DIS_R {
166 EF_BLE_DIS_R::new(((self.bits >> 15) & 1) != 0)
167 }
168 #[doc = "Bit 16"]
169 #[inline(always)]
170 pub fn ef_wifi_dis(&self) -> EF_WIFI_DIS_R {
171 EF_WIFI_DIS_R::new(((self.bits >> 16) & 1) != 0)
172 }
173 #[doc = "Bit 17"]
174 #[inline(always)]
175 pub fn ef_0_key_enc_en(&self) -> EF_0_KEY_ENC_EN_R {
176 EF_0_KEY_ENC_EN_R::new(((self.bits >> 17) & 1) != 0)
177 }
178 #[doc = "Bit 18"]
179 #[inline(always)]
180 pub fn ef_cam_dis(&self) -> EF_CAM_DIS_R {
181 EF_CAM_DIS_R::new(((self.bits >> 18) & 1) != 0)
182 }
183 #[doc = "Bit 19"]
184 #[inline(always)]
185 pub fn ef_sf_dis(&self) -> EF_SF_DIS_R {
186 EF_SF_DIS_R::new(((self.bits >> 19) & 1) != 0)
187 }
188 #[doc = "Bit 20"]
189 #[inline(always)]
190 pub fn ef_cpu1_dis(&self) -> EF_CPU1_DIS_R {
191 EF_CPU1_DIS_R::new(((self.bits >> 20) & 1) != 0)
192 }
193 #[doc = "Bit 21"]
194 #[inline(always)]
195 pub fn ef_cpu_rst_dbg_dis(&self) -> EF_CPU_RST_DBG_DIS_R {
196 EF_CPU_RST_DBG_DIS_R::new(((self.bits >> 21) & 1) != 0)
197 }
198 #[doc = "Bit 22"]
199 #[inline(always)]
200 pub fn ef_se_dbg_dis(&self) -> EF_SE_DBG_DIS_R {
201 EF_SE_DBG_DIS_R::new(((self.bits >> 22) & 1) != 0)
202 }
203 #[doc = "Bit 23"]
204 #[inline(always)]
205 pub fn ef_efuse_dbg_dis(&self) -> EF_EFUSE_DBG_DIS_R {
206 EF_EFUSE_DBG_DIS_R::new(((self.bits >> 23) & 1) != 0)
207 }
208 #[doc = "Bits 24:25"]
209 #[inline(always)]
210 pub fn ef_dbg_jtag_1_dis(&self) -> EF_DBG_JTAG_1_DIS_R {
211 EF_DBG_JTAG_1_DIS_R::new(((self.bits >> 24) & 3) as u8)
212 }
213 #[doc = "Bits 26:27"]
214 #[inline(always)]
215 pub fn ef_dbg_jtag_0_dis(&self) -> EF_DBG_JTAG_0_DIS_R {
216 EF_DBG_JTAG_0_DIS_R::new(((self.bits >> 26) & 3) as u8)
217 }
218 #[doc = "Bits 28:31"]
219 #[inline(always)]
220 pub fn ef_dbg_mode(&self) -> EF_DBG_MODE_R {
221 EF_DBG_MODE_R::new(((self.bits >> 28) & 0x0f) as u8)
222 }
223}
224impl W {
225 #[doc = "Bits 0:1"]
226 #[inline(always)]
227 #[must_use]
228 pub fn ef_sf_aes_mode(&mut self) -> EF_SF_AES_MODE_W<0> {
229 EF_SF_AES_MODE_W::new(self)
230 }
231 #[doc = "Bits 2:3"]
232 #[inline(always)]
233 #[must_use]
234 pub fn ef_sboot_sign_mode(&mut self) -> EF_SBOOT_SIGN_MODE_W<2> {
235 EF_SBOOT_SIGN_MODE_W::new(self)
236 }
237 #[doc = "Bits 4:5"]
238 #[inline(always)]
239 #[must_use]
240 pub fn ef_sboot_en(&mut self) -> EF_SBOOT_EN_W<4> {
241 EF_SBOOT_EN_W::new(self)
242 }
243 #[doc = "Bit 6"]
244 #[inline(always)]
245 #[must_use]
246 pub fn ef_cpu1_enc_en(&mut self) -> EF_CPU1_ENC_EN_W<6> {
247 EF_CPU1_ENC_EN_W::new(self)
248 }
249 #[doc = "Bit 7"]
250 #[inline(always)]
251 #[must_use]
252 pub fn ef_cpu0_enc_en(&mut self) -> EF_CPU0_ENC_EN_W<7> {
253 EF_CPU0_ENC_EN_W::new(self)
254 }
255 #[doc = "Bits 8:11"]
256 #[inline(always)]
257 #[must_use]
258 pub fn ef_boot_sel(&mut self) -> EF_BOOT_SEL_W<8> {
259 EF_BOOT_SEL_W::new(self)
260 }
261 #[doc = "Bits 12:13"]
262 #[inline(always)]
263 #[must_use]
264 pub fn ef_sf_key_0_sel(&mut self) -> EF_SF_KEY_0_SEL_W<12> {
265 EF_SF_KEY_0_SEL_W::new(self)
266 }
267 #[doc = "Bit 14"]
268 #[inline(always)]
269 #[must_use]
270 pub fn ef_sdu_dis(&mut self) -> EF_SDU_DIS_W<14> {
271 EF_SDU_DIS_W::new(self)
272 }
273 #[doc = "Bit 15"]
274 #[inline(always)]
275 #[must_use]
276 pub fn ef_ble_dis(&mut self) -> EF_BLE_DIS_W<15> {
277 EF_BLE_DIS_W::new(self)
278 }
279 #[doc = "Bit 16"]
280 #[inline(always)]
281 #[must_use]
282 pub fn ef_wifi_dis(&mut self) -> EF_WIFI_DIS_W<16> {
283 EF_WIFI_DIS_W::new(self)
284 }
285 #[doc = "Bit 17"]
286 #[inline(always)]
287 #[must_use]
288 pub fn ef_0_key_enc_en(&mut self) -> EF_0_KEY_ENC_EN_W<17> {
289 EF_0_KEY_ENC_EN_W::new(self)
290 }
291 #[doc = "Bit 18"]
292 #[inline(always)]
293 #[must_use]
294 pub fn ef_cam_dis(&mut self) -> EF_CAM_DIS_W<18> {
295 EF_CAM_DIS_W::new(self)
296 }
297 #[doc = "Bit 19"]
298 #[inline(always)]
299 #[must_use]
300 pub fn ef_sf_dis(&mut self) -> EF_SF_DIS_W<19> {
301 EF_SF_DIS_W::new(self)
302 }
303 #[doc = "Bit 20"]
304 #[inline(always)]
305 #[must_use]
306 pub fn ef_cpu1_dis(&mut self) -> EF_CPU1_DIS_W<20> {
307 EF_CPU1_DIS_W::new(self)
308 }
309 #[doc = "Bit 21"]
310 #[inline(always)]
311 #[must_use]
312 pub fn ef_cpu_rst_dbg_dis(&mut self) -> EF_CPU_RST_DBG_DIS_W<21> {
313 EF_CPU_RST_DBG_DIS_W::new(self)
314 }
315 #[doc = "Bit 22"]
316 #[inline(always)]
317 #[must_use]
318 pub fn ef_se_dbg_dis(&mut self) -> EF_SE_DBG_DIS_W<22> {
319 EF_SE_DBG_DIS_W::new(self)
320 }
321 #[doc = "Bit 23"]
322 #[inline(always)]
323 #[must_use]
324 pub fn ef_efuse_dbg_dis(&mut self) -> EF_EFUSE_DBG_DIS_W<23> {
325 EF_EFUSE_DBG_DIS_W::new(self)
326 }
327 #[doc = "Bits 24:25"]
328 #[inline(always)]
329 #[must_use]
330 pub fn ef_dbg_jtag_1_dis(&mut self) -> EF_DBG_JTAG_1_DIS_W<24> {
331 EF_DBG_JTAG_1_DIS_W::new(self)
332 }
333 #[doc = "Bits 26:27"]
334 #[inline(always)]
335 #[must_use]
336 pub fn ef_dbg_jtag_0_dis(&mut self) -> EF_DBG_JTAG_0_DIS_W<26> {
337 EF_DBG_JTAG_0_DIS_W::new(self)
338 }
339 #[doc = "Bits 28:31"]
340 #[inline(always)]
341 #[must_use]
342 pub fn ef_dbg_mode(&mut self) -> EF_DBG_MODE_W<28> {
343 EF_DBG_MODE_W::new(self)
344 }
345 #[doc = "Writes raw bits to the register."]
346 #[inline(always)]
347 pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
348 self.0.bits(bits);
349 self
350 }
351}
352#[doc = "ef_cfg_0.\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 [ef_cfg_0](index.html) module"]
353pub struct EF_CFG_0_SPEC;
354impl crate::RegisterSpec for EF_CFG_0_SPEC {
355 type Ux = u32;
356}
357#[doc = "`read()` method returns [ef_cfg_0::R](R) reader structure"]
358impl crate::Readable for EF_CFG_0_SPEC {
359 type Reader = R;
360}
361#[doc = "`write(|w| ..)` method takes [ef_cfg_0::W](W) writer structure"]
362impl crate::Writable for EF_CFG_0_SPEC {
363 type Writer = W;
364 const ZERO_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0;
365 const ONE_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0;
366}
367#[doc = "`reset()` method sets ef_cfg_0 to value 0"]
368impl crate::Resettable for EF_CFG_0_SPEC {
369 const RESET_VALUE: Self::Ux = 0;
370}