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;