rp2040_pac/busctrl/
perfsel1.rs

1#[doc = "Register `PERFSEL1` reader"]
2pub type R = crate::R<PERFSEL1_SPEC>;
3#[doc = "Register `PERFSEL1` writer"]
4pub type W = crate::W<PERFSEL1_SPEC>;
5#[doc = "Field `PERFSEL1` reader - Select an event for PERFCTR1. Count either contested accesses, or all accesses, on a downstream port of the main crossbar."]
6pub type PERFSEL1_R = crate::FieldReader<PERFSEL1_A>;
7#[doc = "Select an event for PERFCTR1. Count either contested accesses, or all accesses, on a downstream port of the main crossbar.  
8
9Value on reset: 31"]
10#[derive(Clone, Copy, Debug, PartialEq, Eq)]
11#[repr(u8)]
12pub enum PERFSEL1_A {
13    #[doc = "0: `0`"]
14    APB_CONTESTED = 0,
15    #[doc = "1: `1`"]
16    APB = 1,
17    #[doc = "2: `10`"]
18    FASTPERI_CONTESTED = 2,
19    #[doc = "3: `11`"]
20    FASTPERI = 3,
21    #[doc = "4: `100`"]
22    SRAM5_CONTESTED = 4,
23    #[doc = "5: `101`"]
24    SRAM5 = 5,
25    #[doc = "6: `110`"]
26    SRAM4_CONTESTED = 6,
27    #[doc = "7: `111`"]
28    SRAM4 = 7,
29    #[doc = "8: `1000`"]
30    SRAM3_CONTESTED = 8,
31    #[doc = "9: `1001`"]
32    SRAM3 = 9,
33    #[doc = "10: `1010`"]
34    SRAM2_CONTESTED = 10,
35    #[doc = "11: `1011`"]
36    SRAM2 = 11,
37    #[doc = "12: `1100`"]
38    SRAM1_CONTESTED = 12,
39    #[doc = "13: `1101`"]
40    SRAM1 = 13,
41    #[doc = "14: `1110`"]
42    SRAM0_CONTESTED = 14,
43    #[doc = "15: `1111`"]
44    SRAM0 = 15,
45    #[doc = "16: `10000`"]
46    XIP_MAIN_CONTESTED = 16,
47    #[doc = "17: `10001`"]
48    XIP_MAIN = 17,
49    #[doc = "18: `10010`"]
50    ROM_CONTESTED = 18,
51    #[doc = "19: `10011`"]
52    ROM = 19,
53}
54impl From<PERFSEL1_A> for u8 {
55    #[inline(always)]
56    fn from(variant: PERFSEL1_A) -> Self {
57        variant as _
58    }
59}
60impl crate::FieldSpec for PERFSEL1_A {
61    type Ux = u8;
62}
63impl PERFSEL1_R {
64    #[doc = "Get enumerated values variant"]
65    #[inline(always)]
66    pub const fn variant(&self) -> Option<PERFSEL1_A> {
67        match self.bits {
68            0 => Some(PERFSEL1_A::APB_CONTESTED),
69            1 => Some(PERFSEL1_A::APB),
70            2 => Some(PERFSEL1_A::FASTPERI_CONTESTED),
71            3 => Some(PERFSEL1_A::FASTPERI),
72            4 => Some(PERFSEL1_A::SRAM5_CONTESTED),
73            5 => Some(PERFSEL1_A::SRAM5),
74            6 => Some(PERFSEL1_A::SRAM4_CONTESTED),
75            7 => Some(PERFSEL1_A::SRAM4),
76            8 => Some(PERFSEL1_A::SRAM3_CONTESTED),
77            9 => Some(PERFSEL1_A::SRAM3),
78            10 => Some(PERFSEL1_A::SRAM2_CONTESTED),
79            11 => Some(PERFSEL1_A::SRAM2),
80            12 => Some(PERFSEL1_A::SRAM1_CONTESTED),
81            13 => Some(PERFSEL1_A::SRAM1),
82            14 => Some(PERFSEL1_A::SRAM0_CONTESTED),
83            15 => Some(PERFSEL1_A::SRAM0),
84            16 => Some(PERFSEL1_A::XIP_MAIN_CONTESTED),
85            17 => Some(PERFSEL1_A::XIP_MAIN),
86            18 => Some(PERFSEL1_A::ROM_CONTESTED),
87            19 => Some(PERFSEL1_A::ROM),
88            _ => None,
89        }
90    }
91    #[doc = "`0`"]
92    #[inline(always)]
93    pub fn is_apb_contested(&self) -> bool {
94        *self == PERFSEL1_A::APB_CONTESTED
95    }
96    #[doc = "`1`"]
97    #[inline(always)]
98    pub fn is_apb(&self) -> bool {
99        *self == PERFSEL1_A::APB
100    }
101    #[doc = "`10`"]
102    #[inline(always)]
103    pub fn is_fastperi_contested(&self) -> bool {
104        *self == PERFSEL1_A::FASTPERI_CONTESTED
105    }
106    #[doc = "`11`"]
107    #[inline(always)]
108    pub fn is_fastperi(&self) -> bool {
109        *self == PERFSEL1_A::FASTPERI
110    }
111    #[doc = "`100`"]
112    #[inline(always)]
113    pub fn is_sram5_contested(&self) -> bool {
114        *self == PERFSEL1_A::SRAM5_CONTESTED
115    }
116    #[doc = "`101`"]
117    #[inline(always)]
118    pub fn is_sram5(&self) -> bool {
119        *self == PERFSEL1_A::SRAM5
120    }
121    #[doc = "`110`"]
122    #[inline(always)]
123    pub fn is_sram4_contested(&self) -> bool {
124        *self == PERFSEL1_A::SRAM4_CONTESTED
125    }
126    #[doc = "`111`"]
127    #[inline(always)]
128    pub fn is_sram4(&self) -> bool {
129        *self == PERFSEL1_A::SRAM4
130    }
131    #[doc = "`1000`"]
132    #[inline(always)]
133    pub fn is_sram3_contested(&self) -> bool {
134        *self == PERFSEL1_A::SRAM3_CONTESTED
135    }
136    #[doc = "`1001`"]
137    #[inline(always)]
138    pub fn is_sram3(&self) -> bool {
139        *self == PERFSEL1_A::SRAM3
140    }
141    #[doc = "`1010`"]
142    #[inline(always)]
143    pub fn is_sram2_contested(&self) -> bool {
144        *self == PERFSEL1_A::SRAM2_CONTESTED
145    }
146    #[doc = "`1011`"]
147    #[inline(always)]
148    pub fn is_sram2(&self) -> bool {
149        *self == PERFSEL1_A::SRAM2
150    }
151    #[doc = "`1100`"]
152    #[inline(always)]
153    pub fn is_sram1_contested(&self) -> bool {
154        *self == PERFSEL1_A::SRAM1_CONTESTED
155    }
156    #[doc = "`1101`"]
157    #[inline(always)]
158    pub fn is_sram1(&self) -> bool {
159        *self == PERFSEL1_A::SRAM1
160    }
161    #[doc = "`1110`"]
162    #[inline(always)]
163    pub fn is_sram0_contested(&self) -> bool {
164        *self == PERFSEL1_A::SRAM0_CONTESTED
165    }
166    #[doc = "`1111`"]
167    #[inline(always)]
168    pub fn is_sram0(&self) -> bool {
169        *self == PERFSEL1_A::SRAM0
170    }
171    #[doc = "`10000`"]
172    #[inline(always)]
173    pub fn is_xip_main_contested(&self) -> bool {
174        *self == PERFSEL1_A::XIP_MAIN_CONTESTED
175    }
176    #[doc = "`10001`"]
177    #[inline(always)]
178    pub fn is_xip_main(&self) -> bool {
179        *self == PERFSEL1_A::XIP_MAIN
180    }
181    #[doc = "`10010`"]
182    #[inline(always)]
183    pub fn is_rom_contested(&self) -> bool {
184        *self == PERFSEL1_A::ROM_CONTESTED
185    }
186    #[doc = "`10011`"]
187    #[inline(always)]
188    pub fn is_rom(&self) -> bool {
189        *self == PERFSEL1_A::ROM
190    }
191}
192#[doc = "Field `PERFSEL1` writer - Select an event for PERFCTR1. Count either contested accesses, or all accesses, on a downstream port of the main crossbar."]
193pub type PERFSEL1_W<'a, REG> = crate::FieldWriter<'a, REG, 5, PERFSEL1_A>;
194impl<'a, REG> PERFSEL1_W<'a, REG>
195where
196    REG: crate::Writable + crate::RegisterSpec,
197    REG::Ux: From<u8>,
198{
199    #[doc = "`0`"]
200    #[inline(always)]
201    pub fn apb_contested(self) -> &'a mut crate::W<REG> {
202        self.variant(PERFSEL1_A::APB_CONTESTED)
203    }
204    #[doc = "`1`"]
205    #[inline(always)]
206    pub fn apb(self) -> &'a mut crate::W<REG> {
207        self.variant(PERFSEL1_A::APB)
208    }
209    #[doc = "`10`"]
210    #[inline(always)]
211    pub fn fastperi_contested(self) -> &'a mut crate::W<REG> {
212        self.variant(PERFSEL1_A::FASTPERI_CONTESTED)
213    }
214    #[doc = "`11`"]
215    #[inline(always)]
216    pub fn fastperi(self) -> &'a mut crate::W<REG> {
217        self.variant(PERFSEL1_A::FASTPERI)
218    }
219    #[doc = "`100`"]
220    #[inline(always)]
221    pub fn sram5_contested(self) -> &'a mut crate::W<REG> {
222        self.variant(PERFSEL1_A::SRAM5_CONTESTED)
223    }
224    #[doc = "`101`"]
225    #[inline(always)]
226    pub fn sram5(self) -> &'a mut crate::W<REG> {
227        self.variant(PERFSEL1_A::SRAM5)
228    }
229    #[doc = "`110`"]
230    #[inline(always)]
231    pub fn sram4_contested(self) -> &'a mut crate::W<REG> {
232        self.variant(PERFSEL1_A::SRAM4_CONTESTED)
233    }
234    #[doc = "`111`"]
235    #[inline(always)]
236    pub fn sram4(self) -> &'a mut crate::W<REG> {
237        self.variant(PERFSEL1_A::SRAM4)
238    }
239    #[doc = "`1000`"]
240    #[inline(always)]
241    pub fn sram3_contested(self) -> &'a mut crate::W<REG> {
242        self.variant(PERFSEL1_A::SRAM3_CONTESTED)
243    }
244    #[doc = "`1001`"]
245    #[inline(always)]
246    pub fn sram3(self) -> &'a mut crate::W<REG> {
247        self.variant(PERFSEL1_A::SRAM3)
248    }
249    #[doc = "`1010`"]
250    #[inline(always)]
251    pub fn sram2_contested(self) -> &'a mut crate::W<REG> {
252        self.variant(PERFSEL1_A::SRAM2_CONTESTED)
253    }
254    #[doc = "`1011`"]
255    #[inline(always)]
256    pub fn sram2(self) -> &'a mut crate::W<REG> {
257        self.variant(PERFSEL1_A::SRAM2)
258    }
259    #[doc = "`1100`"]
260    #[inline(always)]
261    pub fn sram1_contested(self) -> &'a mut crate::W<REG> {
262        self.variant(PERFSEL1_A::SRAM1_CONTESTED)
263    }
264    #[doc = "`1101`"]
265    #[inline(always)]
266    pub fn sram1(self) -> &'a mut crate::W<REG> {
267        self.variant(PERFSEL1_A::SRAM1)
268    }
269    #[doc = "`1110`"]
270    #[inline(always)]
271    pub fn sram0_contested(self) -> &'a mut crate::W<REG> {
272        self.variant(PERFSEL1_A::SRAM0_CONTESTED)
273    }
274    #[doc = "`1111`"]
275    #[inline(always)]
276    pub fn sram0(self) -> &'a mut crate::W<REG> {
277        self.variant(PERFSEL1_A::SRAM0)
278    }
279    #[doc = "`10000`"]
280    #[inline(always)]
281    pub fn xip_main_contested(self) -> &'a mut crate::W<REG> {
282        self.variant(PERFSEL1_A::XIP_MAIN_CONTESTED)
283    }
284    #[doc = "`10001`"]
285    #[inline(always)]
286    pub fn xip_main(self) -> &'a mut crate::W<REG> {
287        self.variant(PERFSEL1_A::XIP_MAIN)
288    }
289    #[doc = "`10010`"]
290    #[inline(always)]
291    pub fn rom_contested(self) -> &'a mut crate::W<REG> {
292        self.variant(PERFSEL1_A::ROM_CONTESTED)
293    }
294    #[doc = "`10011`"]
295    #[inline(always)]
296    pub fn rom(self) -> &'a mut crate::W<REG> {
297        self.variant(PERFSEL1_A::ROM)
298    }
299}
300impl R {
301    #[doc = "Bits 0:4 - Select an event for PERFCTR1. Count either contested accesses, or all accesses, on a downstream port of the main crossbar."]
302    #[inline(always)]
303    pub fn perfsel1(&self) -> PERFSEL1_R {
304        PERFSEL1_R::new((self.bits & 0x1f) as u8)
305    }
306}
307impl W {
308    #[doc = "Bits 0:4 - Select an event for PERFCTR1. Count either contested accesses, or all accesses, on a downstream port of the main crossbar."]
309    #[inline(always)]
310    #[must_use]
311    pub fn perfsel1(&mut self) -> PERFSEL1_W<PERFSEL1_SPEC> {
312        PERFSEL1_W::new(self, 0)
313    }
314    #[doc = r" Writes raw bits to the register."]
315    #[doc = r""]
316    #[doc = r" # Safety"]
317    #[doc = r""]
318    #[doc = r" Passing incorrect value can cause undefined behaviour. See reference manual"]
319    #[inline(always)]
320    pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
321        self.bits = bits;
322        self
323    }
324}
325#[doc = "Bus fabric performance event select for PERFCTR1  
326
327You can [`read`](crate::generic::Reg::read) this register and get [`perfsel1::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 [`perfsel1::W`](W). You can also [`modify`](crate::generic::Reg::modify) this register. See [API](https://docs.rs/svd2rust/#read--modify--write-api)."]
328pub struct PERFSEL1_SPEC;
329impl crate::RegisterSpec for PERFSEL1_SPEC {
330    type Ux = u32;
331}
332#[doc = "`read()` method returns [`perfsel1::R`](R) reader structure"]
333impl crate::Readable for PERFSEL1_SPEC {}
334#[doc = "`write(|w| ..)` method takes [`perfsel1::W`](W) writer structure"]
335impl crate::Writable for PERFSEL1_SPEC {
336    const ZERO_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
337    const ONE_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
338}
339#[doc = "`reset()` method sets PERFSEL1 to value 0x1f"]
340impl crate::Resettable for PERFSEL1_SPEC {
341    const RESET_VALUE: u32 = 0x1f;
342}