1#[doc = r"Register block"]
2#[repr(C)]
3pub struct RegisterBlock {
4 #[doc = "0x00 - Channel Control Register Channel"]
5 pub ccr0: CCR,
6 _reserved_1_capture_cmr0: [u8; 0x04],
7 #[doc = "0x08 - Stepper Motor Mode Register"]
8 pub smmr0: SMMR,
9 _reserved3: [u8; 0x04],
10 #[doc = "0x10 - Counter Value Channel"]
11 pub cv0: CV,
12 #[doc = "0x14 - Register A Channel"]
13 pub ra0: RA,
14 #[doc = "0x18 - Register B Channel"]
15 pub rb0: RB,
16 #[doc = "0x1c - Register C Channel"]
17 pub rc0: RC,
18 #[doc = "0x20 - Status Register Channel"]
19 pub sr0: SR,
20 #[doc = "0x24 - Interrupt Enable Register Channel"]
21 pub ier0: IER,
22 #[doc = "0x28 - Interrupt Disable Register Channel"]
23 pub idr0: IDR,
24 #[doc = "0x2c - Interrupt Mask Register Channel"]
25 pub imr0: IMR,
26 _reserved11: [u8; 0x10],
27 #[doc = "0x40 - Channel Control Register Channel"]
28 pub ccr1: CCR,
29 _reserved_12_capture_cmr1: [u8; 0x04],
30 #[doc = "0x48 - Stepper Motor Mode Register"]
31 pub smmr1: SMMR,
32 _reserved14: [u8; 0x04],
33 #[doc = "0x50 - Counter Value Channel"]
34 pub cv1: CV,
35 #[doc = "0x54 - Register A Channel"]
36 pub ra1: RA,
37 #[doc = "0x58 - Register B Channel"]
38 pub rb1: RB,
39 #[doc = "0x5c - Register C Channel"]
40 pub rc1: RC,
41 #[doc = "0x60 - Status Register Channel"]
42 pub sr1: SR,
43 #[doc = "0x64 - Interrupt Enable Register Channel"]
44 pub ier1: IER,
45 #[doc = "0x68 - Interrupt Disable Register Channel"]
46 pub idr1: IDR,
47 #[doc = "0x6c - Interrupt Mask Register Channel"]
48 pub imr1: IMR,
49 _reserved22: [u8; 0x10],
50 #[doc = "0x80 - Channel Control Register Channel"]
51 pub ccr2: CCR,
52 _reserved_23_capture_cmr2: [u8; 0x04],
53 #[doc = "0x88 - Stepper Motor Mode Register"]
54 pub smmr2: SMMR,
55 _reserved25: [u8; 0x04],
56 #[doc = "0x90 - Counter Value Channel"]
57 pub cv2: CV,
58 #[doc = "0x94 - Register A Channel"]
59 pub ra2: RA,
60 #[doc = "0x98 - Register B Channel"]
61 pub rb2: RB,
62 #[doc = "0x9c - Register C Channel"]
63 pub rc2: RC,
64 #[doc = "0xa0 - Status Register Channel"]
65 pub sr2: SR,
66 #[doc = "0xa4 - Interrupt Enable Register Channel"]
67 pub ier2: IER,
68 #[doc = "0xa8 - Interrupt Disable Register Channel"]
69 pub idr2: IDR,
70 #[doc = "0xac - Interrupt Mask Register Channel"]
71 pub imr2: IMR,
72 _reserved33: [u8; 0x10],
73 #[doc = "0xc0 - TC Block Control Register"]
74 pub bcr: BCR,
75 #[doc = "0xc4 - TC Block Mode Register"]
76 pub bmr: BMR,
77 _reserved35: [u8; 0x1c],
78 #[doc = "0xe4 - Write Protect Mode Register"]
79 pub wpmr: WPMR,
80 _reserved36: [u8; 0x10],
81 #[doc = "0xf8 - Features Register"]
82 pub features: FEATURES,
83 #[doc = "0xfc - Version Register"]
84 pub version: VERSION,
85}
86impl RegisterBlock {
87 #[doc = "0x04 - Channel Mode Register Channel"]
88 #[inline(always)]
89 pub const fn waveform_cmr0_alt(&self) -> &WAVEFORM_CMR_ALT {
90 unsafe { &*(self as *const Self).cast::<u8>().add(4usize).cast() }
91 }
92 #[doc = "0x04 - Channel Mode Register Channel"]
93 #[inline(always)]
94 pub const fn capture_cmr0(&self) -> &CAPTURE_CMR {
95 unsafe { &*(self as *const Self).cast::<u8>().add(4usize).cast() }
96 }
97 #[doc = "0x44 - Channel Mode Register Channel"]
98 #[inline(always)]
99 pub const fn waveform_cmr1_alt(&self) -> &WAVEFORM_CMR_ALT {
100 unsafe { &*(self as *const Self).cast::<u8>().add(68usize).cast() }
101 }
102 #[doc = "0x44 - Channel Mode Register Channel"]
103 #[inline(always)]
104 pub const fn capture_cmr1(&self) -> &CAPTURE_CMR {
105 unsafe { &*(self as *const Self).cast::<u8>().add(68usize).cast() }
106 }
107 #[doc = "0x84 - Channel Mode Register Channel"]
108 #[inline(always)]
109 pub const fn waveform_cmr2_alt(&self) -> &WAVEFORM_CMR_ALT {
110 unsafe { &*(self as *const Self).cast::<u8>().add(132usize).cast() }
111 }
112 #[doc = "0x84 - Channel Mode Register Channel"]
113 #[inline(always)]
114 pub const fn capture_cmr2(&self) -> &CAPTURE_CMR {
115 unsafe { &*(self as *const Self).cast::<u8>().add(132usize).cast() }
116 }
117}
118#[doc = "BCR (w) register accessor: an alias for `Reg<BCR_SPEC>`"]
119pub type BCR = crate::Reg<bcr::BCR_SPEC>;
120#[doc = "TC Block Control Register"]
121pub mod bcr;
122#[doc = "BMR (rw) register accessor: an alias for `Reg<BMR_SPEC>`"]
123pub type BMR = crate::Reg<bmr::BMR_SPEC>;
124#[doc = "TC Block Mode Register"]
125pub mod bmr;
126#[doc = "CCR (w) register accessor: an alias for `Reg<CCR_SPEC>`"]
127pub type CCR = crate::Reg<ccr::CCR_SPEC>;
128#[doc = "Channel Control Register Channel"]
129pub mod ccr;
130#[doc = "CAPTURE_CMR (rw) register accessor: an alias for `Reg<CAPTURE_CMR_SPEC>`"]
131pub type CAPTURE_CMR = crate::Reg<capture_cmr::CAPTURE_CMR_SPEC>;
132#[doc = "Channel Mode Register Channel"]
133pub mod capture_cmr;
134#[doc = "WAVEFORM_CMR_ALT (rw) register accessor: an alias for `Reg<WAVEFORM_CMR_ALT_SPEC>`"]
135pub type WAVEFORM_CMR_ALT = crate::Reg<waveform_cmr_alt::WAVEFORM_CMR_ALT_SPEC>;
136#[doc = "Channel Mode Register Channel"]
137pub mod waveform_cmr_alt;
138#[doc = "CV (r) register accessor: an alias for `Reg<CV_SPEC>`"]
139pub type CV = crate::Reg<cv::CV_SPEC>;
140#[doc = "Counter Value Channel"]
141pub mod cv;
142#[doc = "FEATURES (r) register accessor: an alias for `Reg<FEATURES_SPEC>`"]
143pub type FEATURES = crate::Reg<features::FEATURES_SPEC>;
144#[doc = "Features Register"]
145pub mod features;
146#[doc = "IDR (w) register accessor: an alias for `Reg<IDR_SPEC>`"]
147pub type IDR = crate::Reg<idr::IDR_SPEC>;
148#[doc = "Interrupt Disable Register Channel"]
149pub mod idr;
150#[doc = "IER (w) register accessor: an alias for `Reg<IER_SPEC>`"]
151pub type IER = crate::Reg<ier::IER_SPEC>;
152#[doc = "Interrupt Enable Register Channel"]
153pub mod ier;
154#[doc = "IMR (r) register accessor: an alias for `Reg<IMR_SPEC>`"]
155pub type IMR = crate::Reg<imr::IMR_SPEC>;
156#[doc = "Interrupt Mask Register Channel"]
157pub mod imr;
158#[doc = "RA (rw) register accessor: an alias for `Reg<RA_SPEC>`"]
159pub type RA = crate::Reg<ra::RA_SPEC>;
160#[doc = "Register A Channel"]
161pub mod ra;
162#[doc = "RB (rw) register accessor: an alias for `Reg<RB_SPEC>`"]
163pub type RB = crate::Reg<rb::RB_SPEC>;
164#[doc = "Register B Channel"]
165pub mod rb;
166#[doc = "RC (rw) register accessor: an alias for `Reg<RC_SPEC>`"]
167pub type RC = crate::Reg<rc::RC_SPEC>;
168#[doc = "Register C Channel"]
169pub mod rc;
170#[doc = "SMMR (rw) register accessor: an alias for `Reg<SMMR_SPEC>`"]
171pub type SMMR = crate::Reg<smmr::SMMR_SPEC>;
172#[doc = "Stepper Motor Mode Register"]
173pub mod smmr;
174#[doc = "SR (r) register accessor: an alias for `Reg<SR_SPEC>`"]
175pub type SR = crate::Reg<sr::SR_SPEC>;
176#[doc = "Status Register Channel"]
177pub mod sr;
178#[doc = "VERSION (r) register accessor: an alias for `Reg<VERSION_SPEC>`"]
179pub type VERSION = crate::Reg<version::VERSION_SPEC>;
180#[doc = "Version Register"]
181pub mod version;
182#[doc = "WPMR (rw) register accessor: an alias for `Reg<WPMR_SPEC>`"]
183pub type WPMR = crate::Reg<wpmr::WPMR_SPEC>;
184#[doc = "Write Protect Mode Register"]
185pub mod wpmr;