2019-11-21 07:14:09 +08:00
|
|
|
use volatile_register::{RO, WO, RW};
|
|
|
|
|
2019-12-18 06:35:58 +08:00
|
|
|
use libregister::{register, register_bit, register_bits};
|
2019-11-21 07:14:09 +08:00
|
|
|
|
|
|
|
#[repr(C)]
|
|
|
|
pub struct RegisterBlock {
|
|
|
|
pub config: Config,
|
2019-11-30 09:48:39 +08:00
|
|
|
pub intr_status: IntrStatus,
|
2019-12-03 09:41:49 +08:00
|
|
|
pub intr_en: IntrEn,
|
|
|
|
pub intr_dis: IntrDis,
|
2019-11-21 07:14:09 +08:00
|
|
|
pub intr_mask: RO<u32>,
|
2019-11-28 10:02:51 +08:00
|
|
|
pub enable: Enable,
|
2019-11-21 07:14:09 +08:00
|
|
|
pub delay: RW<u32>,
|
|
|
|
pub txd0: WO<u32>,
|
|
|
|
pub rx_data: RO<u32>,
|
|
|
|
pub slave_idle_count: RW<u32>,
|
|
|
|
pub tx_thres: RW<u32>,
|
2019-11-30 09:48:39 +08:00
|
|
|
pub rx_thres: RW<u32>,
|
2019-12-14 08:56:49 +08:00
|
|
|
pub gpio: QspiGpio,
|
2019-11-21 07:14:09 +08:00
|
|
|
pub _unused1: RO<u32>,
|
|
|
|
pub lpbk_dly_adj: RW<u32>,
|
|
|
|
pub _unused2: [RO<u32>; 17],
|
|
|
|
pub txd1: WO<u32>,
|
|
|
|
pub txd2: WO<u32>,
|
|
|
|
pub txd3: WO<u32>,
|
|
|
|
pub _unused3: [RO<u32>; 5],
|
2019-11-23 08:59:24 +08:00
|
|
|
pub lqspi_cfg: LqspiCfg,
|
2019-11-21 07:14:09 +08:00
|
|
|
pub lqspi_sts: RW<u32>,
|
|
|
|
pub _unused4: [RO<u32>; 21],
|
|
|
|
pub mod_id: RW<u32>,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl RegisterBlock {
|
|
|
|
const BASE_ADDRESS: *mut Self = 0xE000D000 as *mut _;
|
|
|
|
|
|
|
|
pub fn qspi() -> &'static mut Self {
|
|
|
|
unsafe { &mut *Self::BASE_ADDRESS }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
register!(config, Config, RW, u32);
|
|
|
|
register_bit!(config,
|
|
|
|
/// Enables master mode
|
|
|
|
mode_sel, 0);
|
|
|
|
register_bit!(config,
|
|
|
|
/// Clock polarity low/high
|
|
|
|
clk_pol, 1);
|
|
|
|
register_bit!(config,
|
|
|
|
/// Clock phase
|
|
|
|
clk_ph, 2);
|
|
|
|
register_bits!(config,
|
2019-11-23 08:59:24 +08:00
|
|
|
/// divider = 2 ** (1 + baud_rate_div)
|
2019-11-21 07:14:09 +08:00
|
|
|
baud_rate_div, u8, 3, 5);
|
|
|
|
register_bits!(config,
|
|
|
|
/// Must be set to 0b11
|
|
|
|
fifo_width, u8, 6, 7);
|
|
|
|
register_bit!(config,
|
|
|
|
/// Must be 0
|
|
|
|
ref_clk, 8);
|
|
|
|
register_bit!(config,
|
|
|
|
/// Peripheral Chip Select Line
|
|
|
|
pcs, 10);
|
|
|
|
register_bit!(config,
|
|
|
|
/// false: auto mode, true: manual CS mode
|
|
|
|
manual_cs, 14);
|
|
|
|
register_bit!(config,
|
|
|
|
/// false: auto mode, true: enables manual start enable
|
|
|
|
man_start_en, 15);
|
|
|
|
register_bit!(config,
|
|
|
|
/// false: auto mode, true: enables manual start command
|
|
|
|
man_start_com, 16);
|
|
|
|
register_bit!(config, holdb_dr, 19);
|
|
|
|
register_bit!(config,
|
|
|
|
/// false: little, true: endian
|
|
|
|
endian, 26);
|
|
|
|
register_bit!(config,
|
|
|
|
/// false: legacy SPI mode, true: Flash memory interface mode
|
|
|
|
leg_flsh, 31);
|
2019-11-23 08:59:24 +08:00
|
|
|
|
2019-11-30 09:48:39 +08:00
|
|
|
register!(intr_status, IntrStatus, RW, u32);
|
|
|
|
register_bit!(intr_status, rx_overflow, 0);
|
2019-12-12 07:13:02 +08:00
|
|
|
register_bit!(intr_status,
|
|
|
|
/// < tx_thres
|
|
|
|
tx_fifo_not_full, 2);
|
2019-11-30 09:48:39 +08:00
|
|
|
register_bit!(intr_status, tx_fifo_full, 3);
|
2019-12-12 07:13:02 +08:00
|
|
|
register_bit!(intr_status,
|
|
|
|
/// >= rx_thres
|
|
|
|
rx_fifo_not_empty, 4);
|
2019-11-30 09:48:39 +08:00
|
|
|
register_bit!(intr_status, rx_fifo_full, 5);
|
|
|
|
register_bit!(intr_status, tx_fifo_underflow, 6);
|
|
|
|
|
2019-12-03 09:41:49 +08:00
|
|
|
register!(intr_en, IntrEn, WO, u32);
|
|
|
|
register_bit!(intr_en, rx_overflow, 0);
|
|
|
|
register_bit!(intr_en, tx_fifo_not_full, 2);
|
|
|
|
register_bit!(intr_en, tx_fifo_full, 3);
|
|
|
|
register_bit!(intr_en, rx_fifo_not_empty, 4);
|
|
|
|
register_bit!(intr_en, rx_fifo_full, 5);
|
|
|
|
register_bit!(intr_en, tx_fifo_underflow, 6);
|
|
|
|
|
|
|
|
register!(intr_dis, IntrDis, WO, u32);
|
|
|
|
register_bit!(intr_dis, rx_overflow, 0);
|
|
|
|
register_bit!(intr_dis, tx_fifo_not_full, 2);
|
|
|
|
register_bit!(intr_dis, tx_fifo_full, 3);
|
|
|
|
register_bit!(intr_dis, rx_fifo_not_empty, 4);
|
|
|
|
register_bit!(intr_dis, rx_fifo_full, 5);
|
|
|
|
register_bit!(intr_dis, tx_fifo_underflow, 6);
|
|
|
|
|
2019-11-28 10:02:51 +08:00
|
|
|
register!(enable, Enable, RW, u32);
|
|
|
|
register_bit!(enable, spi_en, 0);
|
|
|
|
|
2019-12-14 08:56:49 +08:00
|
|
|
// named to avoid confusion with normal gpio
|
|
|
|
register!(qspi_gpio, QspiGpio, RW, u32);
|
|
|
|
register_bit!(qspi_gpio,
|
|
|
|
/// Write protect pin (inverted)
|
|
|
|
wp_n, 0);
|
|
|
|
|
2019-11-23 08:59:24 +08:00
|
|
|
register!(lqspi_cfg, LqspiCfg, RW, u32);
|
|
|
|
register_bits!(lqspi_cfg, inst_code, u8, 0, 7);
|
|
|
|
register_bits!(lqspi_cfg, dummy_byte, u8, 8, 10);
|
|
|
|
register_bits!(lqspi_cfg, mode_bits, u8, 16, 23);
|
|
|
|
register_bit!(lqspi_cfg, mode_on, 24);
|
|
|
|
register_bit!(lqspi_cfg, mode_en, 25);
|
|
|
|
register_bit!(lqspi_cfg, u_page, 28);
|
|
|
|
register_bit!(lqspi_cfg, sep_bus, 29);
|
|
|
|
register_bit!(lqspi_cfg, two_mem, 30);
|
|
|
|
register_bit!(lqspi_cfg, lq_mode, 31);
|