167 PinName io1 = MBED_CONF_OSPIF_OSPI_IO1,
168 PinName io2 = MBED_CONF_OSPIF_OSPI_IO2,
169 PinName io3 = MBED_CONF_OSPIF_OSPI_IO3,
170 PinName io4 = MBED_CONF_OSPIF_OSPI_IO4,
171 PinName io5 = MBED_CONF_OSPIF_OSPI_IO5,
172 PinName io6 = MBED_CONF_OSPIF_OSPI_IO6,
173 PinName io7 = MBED_CONF_OSPIF_OSPI_IO7,
174 PinName sclk = MBED_CONF_OSPIF_OSPI_SCK,
175 PinName csel = MBED_CONF_OSPIF_OSPI_CSN,
176 PinName dqs = MBED_CONF_OSPIF_OSPI_DQS,
177 int clock_mode = MBED_CONF_OSPIF_OSPI_POLARITY_MODE,
178 int freq = MBED_CONF_OSPIF_OSPI_FREQ);
311 int add_new_csel_instance(PinName csel);
314 int remove_csel_instance(PinName csel);
320 ospi_status_t _ospi_send_program_command(
mbed::ospi_inst_t prog_instruction,
const void *buffer,
334 int _ospi_send_read_sfdp_command(
mbed::bd_addr_t addr, mbed::sfdp_cmd_addr_size_t addr_size,
335 uint8_t inst, uint8_t dummy_cycles,
339 ospi_status_t _ospi_read_status_registers(uint8_t *reg_buffer);
342 ospi_status_t _ospi_write_status_registers(uint8_t *reg_buffer);
345 ospi_status_t _ospi_set_frequency(
int freq);
354 int _clear_block_protection();
357 int _set_write_enable();
360 bool _is_mem_ready();
363 int _enable_fast_mode();
366 int _enable_opi_mdoe();
369 int _handle_vendor_quirks();
383 int _sfdp_detect_reset_protocol_and_reset(uint8_t *basic_param_table_ptr);
386 int _sfdp_detect_best_bus_read_mode(uint8_t *basic_param_table_ptr,
int basic_param_table_size,
387 bool &set_quad_enable,
bool &is_qpi_mode,
bool &is_opi_mode);
390 int _sfdp_set_quad_enabled(uint8_t *basic_param_table_ptr);
393 int _sfdp_set_qpi_enabled(uint8_t *basic_param_table_ptr);
396 int _sfdp_detect_and_enable_4byte_addressing(uint8_t *basic_param_table_ptr,
int basic_param_table_size);
398#ifdef MX_FLASH_SUPPORT_RWW
399 bool _is_mem_ready_rww(bd_addr_t addr, uint8_t rw);
403 enum ospif_clear_protection_method_t {
412 static int _number_of_active_ospif_flash_csel;
414 int _unique_device_status;
427 unsigned int _num_status_registers;
432 bool _attempt_4_byte_addressing;
437 bool _support_4_byte_inst;
440 int _quad_enable_register_idx;
441 int _quad_enable_bit;
443 bool _needs_fast_mode;
446 ospif_clear_protection_method_t _clear_protection_method;
451 unsigned int _page_size_bytes;
455 ospi_bus_width_t _inst_width;
456 ospi_inst_size_t _inst_size;
457 ospi_bus_width_t _address_width;
458 ospi_address_size_t _address_size;
459 ospi_alt_size_t _alt_size;
461 uint8_t _dummy_cycles;
462 ospi_bus_width_t _data_width;
464 uint32_t _init_ref_count;
465 bool _is_initialized;
466#ifdef MX_FLASH_SUPPORT_RWW
473 wait_flag _wait_flag;
OSPIFBlockDevice(PinName io0=NC, PinName io1=NC, PinName io2=NC, PinName io3=NC, PinName io4=NC, PinName io5=NC, PinName io6=NC, PinName io7=NC, PinName sclk=NC, PinName csel=NC, PinName dqs=NC, int clock_mode=0, int freq=40000000)
Create OSPIFBlockDevice - An SFDP based Flash Block Device over OSPI bus.