rp2040_pac/resets/
reset.rs

1#[doc = "Register `RESET` reader"]
2pub type R = crate::R<RESET_SPEC>;
3#[doc = "Register `RESET` writer"]
4pub type W = crate::W<RESET_SPEC>;
5#[doc = "Field `adc` reader - "]
6pub type ADC_R = crate::BitReader;
7#[doc = "Field `adc` writer - "]
8pub type ADC_W<'a, REG> = crate::BitWriter<'a, REG>;
9#[doc = "Field `busctrl` reader - "]
10pub type BUSCTRL_R = crate::BitReader;
11#[doc = "Field `busctrl` writer - "]
12pub type BUSCTRL_W<'a, REG> = crate::BitWriter<'a, REG>;
13#[doc = "Field `dma` reader - "]
14pub type DMA_R = crate::BitReader;
15#[doc = "Field `dma` writer - "]
16pub type DMA_W<'a, REG> = crate::BitWriter<'a, REG>;
17#[doc = "Field `i2c0` reader - "]
18pub type I2C0_R = crate::BitReader;
19#[doc = "Field `i2c0` writer - "]
20pub type I2C0_W<'a, REG> = crate::BitWriter<'a, REG>;
21#[doc = "Field `i2c1` reader - "]
22pub type I2C1_R = crate::BitReader;
23#[doc = "Field `i2c1` writer - "]
24pub type I2C1_W<'a, REG> = crate::BitWriter<'a, REG>;
25#[doc = "Field `io_bank0` reader - "]
26pub type IO_BANK0_R = crate::BitReader;
27#[doc = "Field `io_bank0` writer - "]
28pub type IO_BANK0_W<'a, REG> = crate::BitWriter<'a, REG>;
29#[doc = "Field `io_qspi` reader - "]
30pub type IO_QSPI_R = crate::BitReader;
31#[doc = "Field `io_qspi` writer - "]
32pub type IO_QSPI_W<'a, REG> = crate::BitWriter<'a, REG>;
33#[doc = "Field `jtag` reader - "]
34pub type JTAG_R = crate::BitReader;
35#[doc = "Field `jtag` writer - "]
36pub type JTAG_W<'a, REG> = crate::BitWriter<'a, REG>;
37#[doc = "Field `pads_bank0` reader - "]
38pub type PADS_BANK0_R = crate::BitReader;
39#[doc = "Field `pads_bank0` writer - "]
40pub type PADS_BANK0_W<'a, REG> = crate::BitWriter<'a, REG>;
41#[doc = "Field `pads_qspi` reader - "]
42pub type PADS_QSPI_R = crate::BitReader;
43#[doc = "Field `pads_qspi` writer - "]
44pub type PADS_QSPI_W<'a, REG> = crate::BitWriter<'a, REG>;
45#[doc = "Field `pio0` reader - "]
46pub type PIO0_R = crate::BitReader;
47#[doc = "Field `pio0` writer - "]
48pub type PIO0_W<'a, REG> = crate::BitWriter<'a, REG>;
49#[doc = "Field `pio1` reader - "]
50pub type PIO1_R = crate::BitReader;
51#[doc = "Field `pio1` writer - "]
52pub type PIO1_W<'a, REG> = crate::BitWriter<'a, REG>;
53#[doc = "Field `pll_sys` reader - "]
54pub type PLL_SYS_R = crate::BitReader;
55#[doc = "Field `pll_sys` writer - "]
56pub type PLL_SYS_W<'a, REG> = crate::BitWriter<'a, REG>;
57#[doc = "Field `pll_usb` reader - "]
58pub type PLL_USB_R = crate::BitReader;
59#[doc = "Field `pll_usb` writer - "]
60pub type PLL_USB_W<'a, REG> = crate::BitWriter<'a, REG>;
61#[doc = "Field `pwm` reader - "]
62pub type PWM_R = crate::BitReader;
63#[doc = "Field `pwm` writer - "]
64pub type PWM_W<'a, REG> = crate::BitWriter<'a, REG>;
65#[doc = "Field `rtc` reader - "]
66pub type RTC_R = crate::BitReader;
67#[doc = "Field `rtc` writer - "]
68pub type RTC_W<'a, REG> = crate::BitWriter<'a, REG>;
69#[doc = "Field `spi0` reader - "]
70pub type SPI0_R = crate::BitReader;
71#[doc = "Field `spi0` writer - "]
72pub type SPI0_W<'a, REG> = crate::BitWriter<'a, REG>;
73#[doc = "Field `spi1` reader - "]
74pub type SPI1_R = crate::BitReader;
75#[doc = "Field `spi1` writer - "]
76pub type SPI1_W<'a, REG> = crate::BitWriter<'a, REG>;
77#[doc = "Field `syscfg` reader - "]
78pub type SYSCFG_R = crate::BitReader;
79#[doc = "Field `syscfg` writer - "]
80pub type SYSCFG_W<'a, REG> = crate::BitWriter<'a, REG>;
81#[doc = "Field `sysinfo` reader - "]
82pub type SYSINFO_R = crate::BitReader;
83#[doc = "Field `sysinfo` writer - "]
84pub type SYSINFO_W<'a, REG> = crate::BitWriter<'a, REG>;
85#[doc = "Field `tbman` reader - "]
86pub type TBMAN_R = crate::BitReader;
87#[doc = "Field `tbman` writer - "]
88pub type TBMAN_W<'a, REG> = crate::BitWriter<'a, REG>;
89#[doc = "Field `timer` reader - "]
90pub type TIMER_R = crate::BitReader;
91#[doc = "Field `timer` writer - "]
92pub type TIMER_W<'a, REG> = crate::BitWriter<'a, REG>;
93#[doc = "Field `uart0` reader - "]
94pub type UART0_R = crate::BitReader;
95#[doc = "Field `uart0` writer - "]
96pub type UART0_W<'a, REG> = crate::BitWriter<'a, REG>;
97#[doc = "Field `uart1` reader - "]
98pub type UART1_R = crate::BitReader;
99#[doc = "Field `uart1` writer - "]
100pub type UART1_W<'a, REG> = crate::BitWriter<'a, REG>;
101#[doc = "Field `usbctrl` reader - "]
102pub type USBCTRL_R = crate::BitReader;
103#[doc = "Field `usbctrl` writer - "]
104pub type USBCTRL_W<'a, REG> = crate::BitWriter<'a, REG>;
105impl R {
106    #[doc = "Bit 0"]
107    #[inline(always)]
108    pub fn adc(&self) -> ADC_R {
109        ADC_R::new((self.bits & 1) != 0)
110    }
111    #[doc = "Bit 1"]
112    #[inline(always)]
113    pub fn busctrl(&self) -> BUSCTRL_R {
114        BUSCTRL_R::new(((self.bits >> 1) & 1) != 0)
115    }
116    #[doc = "Bit 2"]
117    #[inline(always)]
118    pub fn dma(&self) -> DMA_R {
119        DMA_R::new(((self.bits >> 2) & 1) != 0)
120    }
121    #[doc = "Bit 3"]
122    #[inline(always)]
123    pub fn i2c0(&self) -> I2C0_R {
124        I2C0_R::new(((self.bits >> 3) & 1) != 0)
125    }
126    #[doc = "Bit 4"]
127    #[inline(always)]
128    pub fn i2c1(&self) -> I2C1_R {
129        I2C1_R::new(((self.bits >> 4) & 1) != 0)
130    }
131    #[doc = "Bit 5"]
132    #[inline(always)]
133    pub fn io_bank0(&self) -> IO_BANK0_R {
134        IO_BANK0_R::new(((self.bits >> 5) & 1) != 0)
135    }
136    #[doc = "Bit 6"]
137    #[inline(always)]
138    pub fn io_qspi(&self) -> IO_QSPI_R {
139        IO_QSPI_R::new(((self.bits >> 6) & 1) != 0)
140    }
141    #[doc = "Bit 7"]
142    #[inline(always)]
143    pub fn jtag(&self) -> JTAG_R {
144        JTAG_R::new(((self.bits >> 7) & 1) != 0)
145    }
146    #[doc = "Bit 8"]
147    #[inline(always)]
148    pub fn pads_bank0(&self) -> PADS_BANK0_R {
149        PADS_BANK0_R::new(((self.bits >> 8) & 1) != 0)
150    }
151    #[doc = "Bit 9"]
152    #[inline(always)]
153    pub fn pads_qspi(&self) -> PADS_QSPI_R {
154        PADS_QSPI_R::new(((self.bits >> 9) & 1) != 0)
155    }
156    #[doc = "Bit 10"]
157    #[inline(always)]
158    pub fn pio0(&self) -> PIO0_R {
159        PIO0_R::new(((self.bits >> 10) & 1) != 0)
160    }
161    #[doc = "Bit 11"]
162    #[inline(always)]
163    pub fn pio1(&self) -> PIO1_R {
164        PIO1_R::new(((self.bits >> 11) & 1) != 0)
165    }
166    #[doc = "Bit 12"]
167    #[inline(always)]
168    pub fn pll_sys(&self) -> PLL_SYS_R {
169        PLL_SYS_R::new(((self.bits >> 12) & 1) != 0)
170    }
171    #[doc = "Bit 13"]
172    #[inline(always)]
173    pub fn pll_usb(&self) -> PLL_USB_R {
174        PLL_USB_R::new(((self.bits >> 13) & 1) != 0)
175    }
176    #[doc = "Bit 14"]
177    #[inline(always)]
178    pub fn pwm(&self) -> PWM_R {
179        PWM_R::new(((self.bits >> 14) & 1) != 0)
180    }
181    #[doc = "Bit 15"]
182    #[inline(always)]
183    pub fn rtc(&self) -> RTC_R {
184        RTC_R::new(((self.bits >> 15) & 1) != 0)
185    }
186    #[doc = "Bit 16"]
187    #[inline(always)]
188    pub fn spi0(&self) -> SPI0_R {
189        SPI0_R::new(((self.bits >> 16) & 1) != 0)
190    }
191    #[doc = "Bit 17"]
192    #[inline(always)]
193    pub fn spi1(&self) -> SPI1_R {
194        SPI1_R::new(((self.bits >> 17) & 1) != 0)
195    }
196    #[doc = "Bit 18"]
197    #[inline(always)]
198    pub fn syscfg(&self) -> SYSCFG_R {
199        SYSCFG_R::new(((self.bits >> 18) & 1) != 0)
200    }
201    #[doc = "Bit 19"]
202    #[inline(always)]
203    pub fn sysinfo(&self) -> SYSINFO_R {
204        SYSINFO_R::new(((self.bits >> 19) & 1) != 0)
205    }
206    #[doc = "Bit 20"]
207    #[inline(always)]
208    pub fn tbman(&self) -> TBMAN_R {
209        TBMAN_R::new(((self.bits >> 20) & 1) != 0)
210    }
211    #[doc = "Bit 21"]
212    #[inline(always)]
213    pub fn timer(&self) -> TIMER_R {
214        TIMER_R::new(((self.bits >> 21) & 1) != 0)
215    }
216    #[doc = "Bit 22"]
217    #[inline(always)]
218    pub fn uart0(&self) -> UART0_R {
219        UART0_R::new(((self.bits >> 22) & 1) != 0)
220    }
221    #[doc = "Bit 23"]
222    #[inline(always)]
223    pub fn uart1(&self) -> UART1_R {
224        UART1_R::new(((self.bits >> 23) & 1) != 0)
225    }
226    #[doc = "Bit 24"]
227    #[inline(always)]
228    pub fn usbctrl(&self) -> USBCTRL_R {
229        USBCTRL_R::new(((self.bits >> 24) & 1) != 0)
230    }
231}
232impl W {
233    #[doc = "Bit 0"]
234    #[inline(always)]
235    #[must_use]
236    pub fn adc(&mut self) -> ADC_W<RESET_SPEC> {
237        ADC_W::new(self, 0)
238    }
239    #[doc = "Bit 1"]
240    #[inline(always)]
241    #[must_use]
242    pub fn busctrl(&mut self) -> BUSCTRL_W<RESET_SPEC> {
243        BUSCTRL_W::new(self, 1)
244    }
245    #[doc = "Bit 2"]
246    #[inline(always)]
247    #[must_use]
248    pub fn dma(&mut self) -> DMA_W<RESET_SPEC> {
249        DMA_W::new(self, 2)
250    }
251    #[doc = "Bit 3"]
252    #[inline(always)]
253    #[must_use]
254    pub fn i2c0(&mut self) -> I2C0_W<RESET_SPEC> {
255        I2C0_W::new(self, 3)
256    }
257    #[doc = "Bit 4"]
258    #[inline(always)]
259    #[must_use]
260    pub fn i2c1(&mut self) -> I2C1_W<RESET_SPEC> {
261        I2C1_W::new(self, 4)
262    }
263    #[doc = "Bit 5"]
264    #[inline(always)]
265    #[must_use]
266    pub fn io_bank0(&mut self) -> IO_BANK0_W<RESET_SPEC> {
267        IO_BANK0_W::new(self, 5)
268    }
269    #[doc = "Bit 6"]
270    #[inline(always)]
271    #[must_use]
272    pub fn io_qspi(&mut self) -> IO_QSPI_W<RESET_SPEC> {
273        IO_QSPI_W::new(self, 6)
274    }
275    #[doc = "Bit 7"]
276    #[inline(always)]
277    #[must_use]
278    pub fn jtag(&mut self) -> JTAG_W<RESET_SPEC> {
279        JTAG_W::new(self, 7)
280    }
281    #[doc = "Bit 8"]
282    #[inline(always)]
283    #[must_use]
284    pub fn pads_bank0(&mut self) -> PADS_BANK0_W<RESET_SPEC> {
285        PADS_BANK0_W::new(self, 8)
286    }
287    #[doc = "Bit 9"]
288    #[inline(always)]
289    #[must_use]
290    pub fn pads_qspi(&mut self) -> PADS_QSPI_W<RESET_SPEC> {
291        PADS_QSPI_W::new(self, 9)
292    }
293    #[doc = "Bit 10"]
294    #[inline(always)]
295    #[must_use]
296    pub fn pio0(&mut self) -> PIO0_W<RESET_SPEC> {
297        PIO0_W::new(self, 10)
298    }
299    #[doc = "Bit 11"]
300    #[inline(always)]
301    #[must_use]
302    pub fn pio1(&mut self) -> PIO1_W<RESET_SPEC> {
303        PIO1_W::new(self, 11)
304    }
305    #[doc = "Bit 12"]
306    #[inline(always)]
307    #[must_use]
308    pub fn pll_sys(&mut self) -> PLL_SYS_W<RESET_SPEC> {
309        PLL_SYS_W::new(self, 12)
310    }
311    #[doc = "Bit 13"]
312    #[inline(always)]
313    #[must_use]
314    pub fn pll_usb(&mut self) -> PLL_USB_W<RESET_SPEC> {
315        PLL_USB_W::new(self, 13)
316    }
317    #[doc = "Bit 14"]
318    #[inline(always)]
319    #[must_use]
320    pub fn pwm(&mut self) -> PWM_W<RESET_SPEC> {
321        PWM_W::new(self, 14)
322    }
323    #[doc = "Bit 15"]
324    #[inline(always)]
325    #[must_use]
326    pub fn rtc(&mut self) -> RTC_W<RESET_SPEC> {
327        RTC_W::new(self, 15)
328    }
329    #[doc = "Bit 16"]
330    #[inline(always)]
331    #[must_use]
332    pub fn spi0(&mut self) -> SPI0_W<RESET_SPEC> {
333        SPI0_W::new(self, 16)
334    }
335    #[doc = "Bit 17"]
336    #[inline(always)]
337    #[must_use]
338    pub fn spi1(&mut self) -> SPI1_W<RESET_SPEC> {
339        SPI1_W::new(self, 17)
340    }
341    #[doc = "Bit 18"]
342    #[inline(always)]
343    #[must_use]
344    pub fn syscfg(&mut self) -> SYSCFG_W<RESET_SPEC> {
345        SYSCFG_W::new(self, 18)
346    }
347    #[doc = "Bit 19"]
348    #[inline(always)]
349    #[must_use]
350    pub fn sysinfo(&mut self) -> SYSINFO_W<RESET_SPEC> {
351        SYSINFO_W::new(self, 19)
352    }
353    #[doc = "Bit 20"]
354    #[inline(always)]
355    #[must_use]
356    pub fn tbman(&mut self) -> TBMAN_W<RESET_SPEC> {
357        TBMAN_W::new(self, 20)
358    }
359    #[doc = "Bit 21"]
360    #[inline(always)]
361    #[must_use]
362    pub fn timer(&mut self) -> TIMER_W<RESET_SPEC> {
363        TIMER_W::new(self, 21)
364    }
365    #[doc = "Bit 22"]
366    #[inline(always)]
367    #[must_use]
368    pub fn uart0(&mut self) -> UART0_W<RESET_SPEC> {
369        UART0_W::new(self, 22)
370    }
371    #[doc = "Bit 23"]
372    #[inline(always)]
373    #[must_use]
374    pub fn uart1(&mut self) -> UART1_W<RESET_SPEC> {
375        UART1_W::new(self, 23)
376    }
377    #[doc = "Bit 24"]
378    #[inline(always)]
379    #[must_use]
380    pub fn usbctrl(&mut self) -> USBCTRL_W<RESET_SPEC> {
381        USBCTRL_W::new(self, 24)
382    }
383    #[doc = r" Writes raw bits to the register."]
384    #[doc = r""]
385    #[doc = r" # Safety"]
386    #[doc = r""]
387    #[doc = r" Passing incorrect value can cause undefined behaviour. See reference manual"]
388    #[inline(always)]
389    pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
390        self.bits = bits;
391        self
392    }
393}
394#[doc = "Reset control. If a bit is set it means the peripheral is in reset. 0 means the peripheral's reset is deasserted.  
395
396You can [`read`](crate::generic::Reg::read) this register and get [`reset::R`](R).  You can [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`write_with_zero`](crate::generic::Reg::write_with_zero) this register using [`reset::W`](W). You can also [`modify`](crate::generic::Reg::modify) this register. See [API](https://docs.rs/svd2rust/#read--modify--write-api)."]
397pub struct RESET_SPEC;
398impl crate::RegisterSpec for RESET_SPEC {
399    type Ux = u32;
400}
401#[doc = "`read()` method returns [`reset::R`](R) reader structure"]
402impl crate::Readable for RESET_SPEC {}
403#[doc = "`write(|w| ..)` method takes [`reset::W`](W) writer structure"]
404impl crate::Writable for RESET_SPEC {
405    const ZERO_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
406    const ONE_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
407}
408#[doc = "`reset()` method sets RESET to value 0x01ff_ffff"]
409impl crate::Resettable for RESET_SPEC {
410    const RESET_VALUE: u32 = 0x01ff_ffff;
411}