nrf52840_pac/
saadc.rs

1#[doc = r"Register block"]
2#[repr(C)]
3pub struct RegisterBlock {
4    #[doc = "0x00 - Starts the SAADC and prepares the result buffer in RAM"]
5    pub tasks_start: TASKS_START,
6    #[doc = "0x04 - Takes one SAADC sample"]
7    pub tasks_sample: TASKS_SAMPLE,
8    #[doc = "0x08 - Stops the SAADC and terminates all on-going conversions"]
9    pub tasks_stop: TASKS_STOP,
10    #[doc = "0x0c - Starts offset auto-calibration"]
11    pub tasks_calibrateoffset: TASKS_CALIBRATEOFFSET,
12    _reserved4: [u8; 0xf0],
13    #[doc = "0x100 - The SAADC has started"]
14    pub events_started: EVENTS_STARTED,
15    #[doc = "0x104 - The SAADC has filled up the result buffer"]
16    pub events_end: EVENTS_END,
17    #[doc = "0x108 - A conversion task has been completed. Depending on the configuration, multiple conversions might be needed for a result to be transferred to RAM."]
18    pub events_done: EVENTS_DONE,
19    #[doc = "0x10c - Result ready for transfer to RAM"]
20    pub events_resultdone: EVENTS_RESULTDONE,
21    #[doc = "0x110 - Calibration is complete"]
22    pub events_calibratedone: EVENTS_CALIBRATEDONE,
23    #[doc = "0x114 - The SAADC has stopped"]
24    pub events_stopped: EVENTS_STOPPED,
25    #[doc = "0x118..0x158 - Unspecified"]
26    pub events_ch: [EVENTS_CH; 8],
27    _reserved11: [u8; 0x01a8],
28    #[doc = "0x300 - Enable or disable interrupt"]
29    pub inten: INTEN,
30    #[doc = "0x304 - Enable interrupt"]
31    pub intenset: INTENSET,
32    #[doc = "0x308 - Disable interrupt"]
33    pub intenclr: INTENCLR,
34    _reserved14: [u8; 0xf4],
35    #[doc = "0x400 - Status"]
36    pub status: STATUS,
37    _reserved15: [u8; 0xfc],
38    #[doc = "0x500 - Enable or disable SAADC"]
39    pub enable: ENABLE,
40    _reserved16: [u8; 0x0c],
41    #[doc = "0x510..0x590 - Unspecified"]
42    pub ch: [CH; 8],
43    _reserved17: [u8; 0x60],
44    #[doc = "0x5f0 - Resolution configuration"]
45    pub resolution: RESOLUTION,
46    #[doc = "0x5f4 - Oversampling configuration. The RESOLUTION is applied before averaging, thus for high OVERSAMPLE a higher RESOLUTION should be used."]
47    pub oversample: OVERSAMPLE,
48    #[doc = "0x5f8 - Controls normal or continuous sample rate"]
49    pub samplerate: SAMPLERATE,
50    _reserved20: [u8; 0x30],
51    #[doc = "0x62c..0x638 - RESULT EasyDMA channel"]
52    pub result: RESULT,
53}
54#[doc = "TASKS_START (w) register accessor: an alias for `Reg<TASKS_START_SPEC>`"]
55pub type TASKS_START = crate::Reg<tasks_start::TASKS_START_SPEC>;
56#[doc = "Starts the SAADC and prepares the result buffer in RAM"]
57pub mod tasks_start;
58#[doc = "TASKS_SAMPLE (w) register accessor: an alias for `Reg<TASKS_SAMPLE_SPEC>`"]
59pub type TASKS_SAMPLE = crate::Reg<tasks_sample::TASKS_SAMPLE_SPEC>;
60#[doc = "Takes one SAADC sample"]
61pub mod tasks_sample;
62#[doc = "TASKS_STOP (w) register accessor: an alias for `Reg<TASKS_STOP_SPEC>`"]
63pub type TASKS_STOP = crate::Reg<tasks_stop::TASKS_STOP_SPEC>;
64#[doc = "Stops the SAADC and terminates all on-going conversions"]
65pub mod tasks_stop;
66#[doc = "TASKS_CALIBRATEOFFSET (w) register accessor: an alias for `Reg<TASKS_CALIBRATEOFFSET_SPEC>`"]
67pub type TASKS_CALIBRATEOFFSET = crate::Reg<tasks_calibrateoffset::TASKS_CALIBRATEOFFSET_SPEC>;
68#[doc = "Starts offset auto-calibration"]
69pub mod tasks_calibrateoffset;
70#[doc = "EVENTS_STARTED (rw) register accessor: an alias for `Reg<EVENTS_STARTED_SPEC>`"]
71pub type EVENTS_STARTED = crate::Reg<events_started::EVENTS_STARTED_SPEC>;
72#[doc = "The SAADC has started"]
73pub mod events_started;
74#[doc = "EVENTS_END (rw) register accessor: an alias for `Reg<EVENTS_END_SPEC>`"]
75pub type EVENTS_END = crate::Reg<events_end::EVENTS_END_SPEC>;
76#[doc = "The SAADC has filled up the result buffer"]
77pub mod events_end;
78#[doc = "EVENTS_DONE (rw) register accessor: an alias for `Reg<EVENTS_DONE_SPEC>`"]
79pub type EVENTS_DONE = crate::Reg<events_done::EVENTS_DONE_SPEC>;
80#[doc = "A conversion task has been completed. Depending on the configuration, multiple conversions might be needed for a result to be transferred to RAM."]
81pub mod events_done;
82#[doc = "EVENTS_RESULTDONE (rw) register accessor: an alias for `Reg<EVENTS_RESULTDONE_SPEC>`"]
83pub type EVENTS_RESULTDONE = crate::Reg<events_resultdone::EVENTS_RESULTDONE_SPEC>;
84#[doc = "Result ready for transfer to RAM"]
85pub mod events_resultdone;
86#[doc = "EVENTS_CALIBRATEDONE (rw) register accessor: an alias for `Reg<EVENTS_CALIBRATEDONE_SPEC>`"]
87pub type EVENTS_CALIBRATEDONE = crate::Reg<events_calibratedone::EVENTS_CALIBRATEDONE_SPEC>;
88#[doc = "Calibration is complete"]
89pub mod events_calibratedone;
90#[doc = "EVENTS_STOPPED (rw) register accessor: an alias for `Reg<EVENTS_STOPPED_SPEC>`"]
91pub type EVENTS_STOPPED = crate::Reg<events_stopped::EVENTS_STOPPED_SPEC>;
92#[doc = "The SAADC has stopped"]
93pub mod events_stopped;
94#[doc = "Unspecified"]
95pub use events_ch::EVENTS_CH;
96#[doc = r"Cluster"]
97#[doc = "Unspecified"]
98pub mod events_ch;
99#[doc = "INTEN (rw) register accessor: an alias for `Reg<INTEN_SPEC>`"]
100pub type INTEN = crate::Reg<inten::INTEN_SPEC>;
101#[doc = "Enable or disable interrupt"]
102pub mod inten;
103#[doc = "INTENSET (rw) register accessor: an alias for `Reg<INTENSET_SPEC>`"]
104pub type INTENSET = crate::Reg<intenset::INTENSET_SPEC>;
105#[doc = "Enable interrupt"]
106pub mod intenset;
107#[doc = "INTENCLR (rw) register accessor: an alias for `Reg<INTENCLR_SPEC>`"]
108pub type INTENCLR = crate::Reg<intenclr::INTENCLR_SPEC>;
109#[doc = "Disable interrupt"]
110pub mod intenclr;
111#[doc = "STATUS (r) register accessor: an alias for `Reg<STATUS_SPEC>`"]
112pub type STATUS = crate::Reg<status::STATUS_SPEC>;
113#[doc = "Status"]
114pub mod status;
115#[doc = "ENABLE (rw) register accessor: an alias for `Reg<ENABLE_SPEC>`"]
116pub type ENABLE = crate::Reg<enable::ENABLE_SPEC>;
117#[doc = "Enable or disable SAADC"]
118pub mod enable;
119#[doc = "Unspecified"]
120pub use ch::CH;
121#[doc = r"Cluster"]
122#[doc = "Unspecified"]
123pub mod ch;
124#[doc = "RESOLUTION (rw) register accessor: an alias for `Reg<RESOLUTION_SPEC>`"]
125pub type RESOLUTION = crate::Reg<resolution::RESOLUTION_SPEC>;
126#[doc = "Resolution configuration"]
127pub mod resolution;
128#[doc = "OVERSAMPLE (rw) register accessor: an alias for `Reg<OVERSAMPLE_SPEC>`"]
129pub type OVERSAMPLE = crate::Reg<oversample::OVERSAMPLE_SPEC>;
130#[doc = "Oversampling configuration. The RESOLUTION is applied before averaging, thus for high OVERSAMPLE a higher RESOLUTION should be used."]
131pub mod oversample;
132#[doc = "SAMPLERATE (rw) register accessor: an alias for `Reg<SAMPLERATE_SPEC>`"]
133pub type SAMPLERATE = crate::Reg<samplerate::SAMPLERATE_SPEC>;
134#[doc = "Controls normal or continuous sample rate"]
135pub mod samplerate;
136#[doc = "RESULT EasyDMA channel"]
137pub use result::RESULT;
138#[doc = r"Cluster"]
139#[doc = "RESULT EasyDMA channel"]
140pub mod result;