atsam4lc8b_pac/
tc0.rs

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;