nrf52840_pac/
qspi.rs

1#[doc = r"Register block"]
2#[repr(C)]
3pub struct RegisterBlock {
4    #[doc = "0x00 - Activate QSPI interface"]
5    pub tasks_activate: TASKS_ACTIVATE,
6    #[doc = "0x04 - Start transfer from external flash memory to internal RAM"]
7    pub tasks_readstart: TASKS_READSTART,
8    #[doc = "0x08 - Start transfer from internal RAM to external flash memory"]
9    pub tasks_writestart: TASKS_WRITESTART,
10    #[doc = "0x0c - Start external flash memory erase operation"]
11    pub tasks_erasestart: TASKS_ERASESTART,
12    #[doc = "0x10 - Deactivate QSPI interface"]
13    pub tasks_deactivate: TASKS_DEACTIVATE,
14    _reserved5: [u8; 0xec],
15    #[doc = "0x100 - QSPI peripheral is ready. This event will be generated as a response to any QSPI task."]
16    pub events_ready: EVENTS_READY,
17    _reserved6: [u8; 0x01fc],
18    #[doc = "0x300 - Enable or disable interrupt"]
19    pub inten: INTEN,
20    #[doc = "0x304 - Enable interrupt"]
21    pub intenset: INTENSET,
22    #[doc = "0x308 - Disable interrupt"]
23    pub intenclr: INTENCLR,
24    _reserved9: [u8; 0x01f4],
25    #[doc = "0x500 - Enable QSPI peripheral and acquire the pins selected in PSELn registers"]
26    pub enable: ENABLE,
27    #[doc = "0x504..0x510 - Unspecified"]
28    pub read: READ,
29    #[doc = "0x510..0x51c - Unspecified"]
30    pub write: WRITE,
31    #[doc = "0x51c..0x524 - Unspecified"]
32    pub erase: ERASE,
33    #[doc = "0x524..0x540 - Unspecified"]
34    pub psel: PSEL,
35    #[doc = "0x540 - Address offset into the external memory for Execute in Place operation."]
36    pub xipoffset: XIPOFFSET,
37    #[doc = "0x544 - Interface configuration."]
38    pub ifconfig0: IFCONFIG0,
39    _reserved16: [u8; 0xb8],
40    #[doc = "0x600 - Interface configuration."]
41    pub ifconfig1: IFCONFIG1,
42    #[doc = "0x604 - Status register."]
43    pub status: STATUS,
44    _reserved18: [u8; 0x0c],
45    #[doc = "0x614 - Set the duration required to enter/exit deep power-down mode (DPM)."]
46    pub dpmdur: DPMDUR,
47    _reserved19: [u8; 0x0c],
48    #[doc = "0x624 - Extended address configuration."]
49    pub addrconf: ADDRCONF,
50    _reserved20: [u8; 0x0c],
51    #[doc = "0x634 - Custom instruction configuration register."]
52    pub cinstrconf: CINSTRCONF,
53    #[doc = "0x638 - Custom instruction data register 0."]
54    pub cinstrdat0: CINSTRDAT0,
55    #[doc = "0x63c - Custom instruction data register 1."]
56    pub cinstrdat1: CINSTRDAT1,
57    #[doc = "0x640 - SPI interface timing."]
58    pub iftiming: IFTIMING,
59}
60#[doc = "TASKS_ACTIVATE (w) register accessor: an alias for `Reg<TASKS_ACTIVATE_SPEC>`"]
61pub type TASKS_ACTIVATE = crate::Reg<tasks_activate::TASKS_ACTIVATE_SPEC>;
62#[doc = "Activate QSPI interface"]
63pub mod tasks_activate;
64#[doc = "TASKS_READSTART (w) register accessor: an alias for `Reg<TASKS_READSTART_SPEC>`"]
65pub type TASKS_READSTART = crate::Reg<tasks_readstart::TASKS_READSTART_SPEC>;
66#[doc = "Start transfer from external flash memory to internal RAM"]
67pub mod tasks_readstart;
68#[doc = "TASKS_WRITESTART (w) register accessor: an alias for `Reg<TASKS_WRITESTART_SPEC>`"]
69pub type TASKS_WRITESTART = crate::Reg<tasks_writestart::TASKS_WRITESTART_SPEC>;
70#[doc = "Start transfer from internal RAM to external flash memory"]
71pub mod tasks_writestart;
72#[doc = "TASKS_ERASESTART (w) register accessor: an alias for `Reg<TASKS_ERASESTART_SPEC>`"]
73pub type TASKS_ERASESTART = crate::Reg<tasks_erasestart::TASKS_ERASESTART_SPEC>;
74#[doc = "Start external flash memory erase operation"]
75pub mod tasks_erasestart;
76#[doc = "TASKS_DEACTIVATE (w) register accessor: an alias for `Reg<TASKS_DEACTIVATE_SPEC>`"]
77pub type TASKS_DEACTIVATE = crate::Reg<tasks_deactivate::TASKS_DEACTIVATE_SPEC>;
78#[doc = "Deactivate QSPI interface"]
79pub mod tasks_deactivate;
80#[doc = "EVENTS_READY (rw) register accessor: an alias for `Reg<EVENTS_READY_SPEC>`"]
81pub type EVENTS_READY = crate::Reg<events_ready::EVENTS_READY_SPEC>;
82#[doc = "QSPI peripheral is ready. This event will be generated as a response to any QSPI task."]
83pub mod events_ready;
84#[doc = "INTEN (rw) register accessor: an alias for `Reg<INTEN_SPEC>`"]
85pub type INTEN = crate::Reg<inten::INTEN_SPEC>;
86#[doc = "Enable or disable interrupt"]
87pub mod inten;
88#[doc = "INTENSET (rw) register accessor: an alias for `Reg<INTENSET_SPEC>`"]
89pub type INTENSET = crate::Reg<intenset::INTENSET_SPEC>;
90#[doc = "Enable interrupt"]
91pub mod intenset;
92#[doc = "INTENCLR (rw) register accessor: an alias for `Reg<INTENCLR_SPEC>`"]
93pub type INTENCLR = crate::Reg<intenclr::INTENCLR_SPEC>;
94#[doc = "Disable interrupt"]
95pub mod intenclr;
96#[doc = "ENABLE (rw) register accessor: an alias for `Reg<ENABLE_SPEC>`"]
97pub type ENABLE = crate::Reg<enable::ENABLE_SPEC>;
98#[doc = "Enable QSPI peripheral and acquire the pins selected in PSELn registers"]
99pub mod enable;
100#[doc = "Unspecified"]
101pub use read::READ;
102#[doc = r"Cluster"]
103#[doc = "Unspecified"]
104pub mod read;
105#[doc = "Unspecified"]
106pub use write::WRITE;
107#[doc = r"Cluster"]
108#[doc = "Unspecified"]
109pub mod write;
110#[doc = "Unspecified"]
111pub use erase::ERASE;
112#[doc = r"Cluster"]
113#[doc = "Unspecified"]
114pub mod erase;
115#[doc = "Unspecified"]
116pub use psel::PSEL;
117#[doc = r"Cluster"]
118#[doc = "Unspecified"]
119pub mod psel;
120#[doc = "XIPOFFSET (rw) register accessor: an alias for `Reg<XIPOFFSET_SPEC>`"]
121pub type XIPOFFSET = crate::Reg<xipoffset::XIPOFFSET_SPEC>;
122#[doc = "Address offset into the external memory for Execute in Place operation."]
123pub mod xipoffset;
124#[doc = "IFCONFIG0 (rw) register accessor: an alias for `Reg<IFCONFIG0_SPEC>`"]
125pub type IFCONFIG0 = crate::Reg<ifconfig0::IFCONFIG0_SPEC>;
126#[doc = "Interface configuration."]
127pub mod ifconfig0;
128#[doc = "IFCONFIG1 (rw) register accessor: an alias for `Reg<IFCONFIG1_SPEC>`"]
129pub type IFCONFIG1 = crate::Reg<ifconfig1::IFCONFIG1_SPEC>;
130#[doc = "Interface configuration."]
131pub mod ifconfig1;
132#[doc = "STATUS (r) register accessor: an alias for `Reg<STATUS_SPEC>`"]
133pub type STATUS = crate::Reg<status::STATUS_SPEC>;
134#[doc = "Status register."]
135pub mod status;
136#[doc = "DPMDUR (rw) register accessor: an alias for `Reg<DPMDUR_SPEC>`"]
137pub type DPMDUR = crate::Reg<dpmdur::DPMDUR_SPEC>;
138#[doc = "Set the duration required to enter/exit deep power-down mode (DPM)."]
139pub mod dpmdur;
140#[doc = "ADDRCONF (rw) register accessor: an alias for `Reg<ADDRCONF_SPEC>`"]
141pub type ADDRCONF = crate::Reg<addrconf::ADDRCONF_SPEC>;
142#[doc = "Extended address configuration."]
143pub mod addrconf;
144#[doc = "CINSTRCONF (rw) register accessor: an alias for `Reg<CINSTRCONF_SPEC>`"]
145pub type CINSTRCONF = crate::Reg<cinstrconf::CINSTRCONF_SPEC>;
146#[doc = "Custom instruction configuration register."]
147pub mod cinstrconf;
148#[doc = "CINSTRDAT0 (rw) register accessor: an alias for `Reg<CINSTRDAT0_SPEC>`"]
149pub type CINSTRDAT0 = crate::Reg<cinstrdat0::CINSTRDAT0_SPEC>;
150#[doc = "Custom instruction data register 0."]
151pub mod cinstrdat0;
152#[doc = "CINSTRDAT1 (rw) register accessor: an alias for `Reg<CINSTRDAT1_SPEC>`"]
153pub type CINSTRDAT1 = crate::Reg<cinstrdat1::CINSTRDAT1_SPEC>;
154#[doc = "Custom instruction data register 1."]
155pub mod cinstrdat1;
156#[doc = "IFTIMING (rw) register accessor: an alias for `Reg<IFTIMING_SPEC>`"]
157pub type IFTIMING = crate::Reg<iftiming::IFTIMING_SPEC>;
158#[doc = "SPI interface timing."]
159pub mod iftiming;