commit 4b784e8e68938d5479219c39b8b75f867d6ff5b0 Author: cfif Date: Mon May 26 14:41:45 2025 +0300 Init diff --git a/Inc/Flash_EN25QH128A_104HIP.h b/Inc/Flash_EN25QH128A_104HIP.h new file mode 100644 index 0000000..71e60c9 --- /dev/null +++ b/Inc/Flash_EN25QH128A_104HIP.h @@ -0,0 +1,16 @@ +// +// Created by cfif on 28.09.22. +// + +#ifndef Flash_EN25QH128A_104HIP_H +#define Flash_EN25QH128A_104HIP_H + +#include "inttypes.h" +#include "cmsis_os.h" + +extern void qspi_data_read(uint32_t addr, uint32_t total_len, uint8_t* buf); +extern void qspi_data_write(uint32_t addr, uint32_t total_len, uint8_t* buf); +extern void qspi_erase(uint32_t sec_addr); +extern void qspi_init(); + +#endif //Flash_EN25QH128A_104HIP_H diff --git a/Src/Flash_EN25QH128A_104HIP.c b/Src/Flash_EN25QH128A_104HIP.c new file mode 100644 index 0000000..c20defb --- /dev/null +++ b/Src/Flash_EN25QH128A_104HIP.c @@ -0,0 +1,70 @@ +// +// Created by cfif on 16.09.22. +// +#include "Flash_EN25QH128A_104HIP.h" + +void qspi_config(void) +{ + gpio_init_type gpio_init_struct; + + /* enable the qspi clock */ + crm_periph_clock_enable(CRM_QSPI1_PERIPH_CLOCK, TRUE); + + /* enable the pin clock */ + crm_periph_clock_enable(CRM_GPIOF_PERIPH_CLOCK, TRUE); + crm_periph_clock_enable(CRM_GPIOG_PERIPH_CLOCK, TRUE); + + /* set default parameter */ + gpio_default_para_init(&gpio_init_struct); + + /* configure the io0 gpio */ + gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER; + gpio_init_struct.gpio_out_type = GPIO_OUTPUT_PUSH_PULL; + gpio_init_struct.gpio_mode = GPIO_MODE_MUX; + gpio_init_struct.gpio_pins = GPIO_PINS_8; + gpio_init_struct.gpio_pull = GPIO_PULL_NONE; + gpio_init(GPIOF, &gpio_init_struct); + gpio_pin_mux_config(GPIOF, GPIO_PINS_SOURCE8, GPIO_MUX_10); + + /* configure the io1 gpio */ + gpio_init_struct.gpio_pins = GPIO_PINS_9; + gpio_init(GPIOF, &gpio_init_struct); + gpio_pin_mux_config(GPIOF, GPIO_PINS_SOURCE9, GPIO_MUX_10); + + /* configure the io2 gpio */ + gpio_init_struct.gpio_pins = GPIO_PINS_7; + gpio_init(GPIOF, &gpio_init_struct); + gpio_pin_mux_config(GPIOF, GPIO_PINS_SOURCE7, GPIO_MUX_9); + + /* configure the io3 gpio */ + gpio_init_struct.gpio_pins = GPIO_PINS_6; + gpio_init(GPIOF, &gpio_init_struct); + gpio_pin_mux_config(GPIOF, GPIO_PINS_SOURCE6, GPIO_MUX_9); + + /* configure the sck gpio */ + gpio_init_struct.gpio_pins = GPIO_PINS_10; + gpio_init(GPIOF, &gpio_init_struct); + gpio_pin_mux_config(GPIOF, GPIO_PINS_SOURCE10, GPIO_MUX_9); + + /* configure the cs gpio */ + gpio_init_struct.gpio_pins = GPIO_PINS_6; + gpio_init(GPIOG, &gpio_init_struct); + gpio_pin_mux_config(GPIOG, GPIO_PINS_SOURCE6, GPIO_MUX_10); +} + +void qspi_init() { + /* qspi config */ + qspi_config(); + + /* switch to cmd port */ + qspi_xip_enable(QSPI1, FALSE); + + /* set sclk */ + qspi_clk_division_set(QSPI1, QSPI_CLK_DIV_4); + + /* set sck idle mode 0 */ + qspi_sck_mode_set(QSPI1, QSPI_SCK_MODE_0); + + /* set wip in bit 0 */ + qspi_busy_config(QSPI1, QSPI_BUSY_OFFSET_0); +} \ No newline at end of file diff --git a/Src/qspi_cmd_esmt32m.c b/Src/qspi_cmd_esmt32m.c new file mode 100644 index 0000000..90f4261 --- /dev/null +++ b/Src/qspi_cmd_esmt32m.c @@ -0,0 +1,294 @@ +// +// Created by cfif on 14.12.22. +// + +/** + ************************************************************************** + * @file qspi_cmd_esmt32m.c + * @version v2.0.4 + * @date 2021-12-31 + * @brief qspi_cmd_esmt32m program + ************************************************************************** + * Copyright notice & Disclaimer + * + * The software Board Support Package (BSP) that is made available to + * download from Artery official website is the copyrighted work of Artery. + * Artery authorizes customers to use, copy, and distribute the BSP + * software and its related documentation for the purpose of design and + * development in conjunction with Artery microcontrollers. Use of the + * software is governed by this copyright notice and the following disclaimer. + * + * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES, + * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS, + * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR + * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS, + * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. + * + ************************************************************************** + */ + +#include "cmsis_os.h" + +/** @addtogroup AT32F435_periph_examples + * @{ + */ + +/** @addtogroup 435_QSPI_command_port_using_polling + * @{ + */ + +#define QSPI_FIFO_DEPTH (32*4) +#define FLASH_PAGE_PROGRAM_SIZE 256 + +qspi_cmd_type esmt32m_cmd_config; + +void qspi_busy_check(void); +void qspi_write_enable(void); + +/** + * @brief esmt32m cmd read config + * @param qspi_cmd_struct: the pointer for qspi_cmd_type parameter + * @param addr: read start address + * @param counter: read data counter + * @retval none + */ +void esmt32m_cmd_read_config(qspi_cmd_type *qspi_cmd_struct, uint32_t addr, uint32_t counter) +{ + qspi_cmd_struct->pe_mode_enable = FALSE; + qspi_cmd_struct->pe_mode_operate_code = 0; + qspi_cmd_struct->instruction_code = 0xEB; + qspi_cmd_struct->instruction_length = QSPI_CMD_INSLEN_1_BYTE; + qspi_cmd_struct->address_code = addr; + qspi_cmd_struct->address_length = QSPI_CMD_ADRLEN_3_BYTE; + qspi_cmd_struct->data_counter = counter; + qspi_cmd_struct->second_dummy_cycle_num = 6; + qspi_cmd_struct->operation_mode = QSPI_OPERATE_MODE_144; + qspi_cmd_struct->read_status_config = QSPI_RSTSC_HW_AUTO; + qspi_cmd_struct->read_status_enable = FALSE; + qspi_cmd_struct->write_data_enable = FALSE; +} + +/** + * @brief esmt32m cmd write config + * @param qspi_cmd_struct: the pointer for qspi_cmd_type parameter + * @param addr: write start address + * @param counter: write data counter + * @retval none + */ +void esmt32m_cmd_write_config(qspi_cmd_type *qspi_cmd_struct, uint32_t addr, uint32_t counter) +{ + qspi_cmd_struct->pe_mode_enable = FALSE; + qspi_cmd_struct->pe_mode_operate_code = 0; + qspi_cmd_struct->instruction_code = 0x32; + qspi_cmd_struct->instruction_length = QSPI_CMD_INSLEN_1_BYTE; + qspi_cmd_struct->address_code = addr; + qspi_cmd_struct->address_length = QSPI_CMD_ADRLEN_3_BYTE; + qspi_cmd_struct->data_counter = counter; + qspi_cmd_struct->second_dummy_cycle_num = 0; + qspi_cmd_struct->operation_mode = QSPI_OPERATE_MODE_114; + qspi_cmd_struct->read_status_config = QSPI_RSTSC_HW_AUTO; + qspi_cmd_struct->read_status_enable = FALSE; + qspi_cmd_struct->write_data_enable = TRUE; +} + +/** + * @brief esmt32m cmd erase config + * @param qspi_cmd_struct: the pointer for qspi_cmd_type parameter + * @param addr: erase address + * @retval none + */ +void esmt32m_cmd_erase_config(qspi_cmd_type *qspi_cmd_struct, uint32_t addr) +{ + qspi_cmd_struct->pe_mode_enable = FALSE; + qspi_cmd_struct->pe_mode_operate_code = 0; + qspi_cmd_struct->instruction_code = 0x20; + qspi_cmd_struct->instruction_length = QSPI_CMD_INSLEN_1_BYTE; + qspi_cmd_struct->address_code = addr; + qspi_cmd_struct->address_length = QSPI_CMD_ADRLEN_3_BYTE; + qspi_cmd_struct->data_counter = 0; + qspi_cmd_struct->second_dummy_cycle_num = 0; + qspi_cmd_struct->operation_mode = QSPI_OPERATE_MODE_111; + qspi_cmd_struct->read_status_config = QSPI_RSTSC_HW_AUTO; + qspi_cmd_struct->read_status_enable = FALSE; + qspi_cmd_struct->write_data_enable = TRUE; +} + +/** + * @brief esmt32m cmd wren config + * @param qspi_cmd_struct: the pointer for qspi_cmd_type parameter + * @retval none + */ +void esmt32m_cmd_wren_config(qspi_cmd_type *qspi_cmd_struct) +{ + qspi_cmd_struct->pe_mode_enable = FALSE; + qspi_cmd_struct->pe_mode_operate_code = 0; + qspi_cmd_struct->instruction_code = 0x06; + qspi_cmd_struct->instruction_length = QSPI_CMD_INSLEN_1_BYTE; + qspi_cmd_struct->address_code = 0; + qspi_cmd_struct->address_length = QSPI_CMD_ADRLEN_0_BYTE; + qspi_cmd_struct->data_counter = 0; + qspi_cmd_struct->second_dummy_cycle_num = 0; + qspi_cmd_struct->operation_mode = QSPI_OPERATE_MODE_111; + qspi_cmd_struct->read_status_config = QSPI_RSTSC_HW_AUTO; + qspi_cmd_struct->read_status_enable = FALSE; + qspi_cmd_struct->write_data_enable = TRUE; +} + +/** + * @brief esmt32m cmd rdsr config + * @param qspi_cmd_struct: the pointer for qspi_cmd_type parameter + * @retval none + */ +void esmt32m_cmd_rdsr_config(qspi_cmd_type *qspi_cmd_struct) +{ + qspi_cmd_struct->pe_mode_enable = FALSE; + qspi_cmd_struct->pe_mode_operate_code = 0; + qspi_cmd_struct->instruction_code = 0x05; + qspi_cmd_struct->instruction_length = QSPI_CMD_INSLEN_1_BYTE; + qspi_cmd_struct->address_code = 0; + qspi_cmd_struct->address_length = QSPI_CMD_ADRLEN_0_BYTE; + qspi_cmd_struct->data_counter = 0; + qspi_cmd_struct->second_dummy_cycle_num = 0; + qspi_cmd_struct->operation_mode = QSPI_OPERATE_MODE_111; + qspi_cmd_struct->read_status_config = QSPI_RSTSC_HW_AUTO; + qspi_cmd_struct->read_status_enable = TRUE; + qspi_cmd_struct->write_data_enable = FALSE; +} + +/** + * @brief qspi read data + * @param addr: the address for read + * @param total_len: the length for read + * @param buf: the pointer for read data + * @retval none + */ +void qspi_data_read(uint32_t addr, uint32_t total_len, uint8_t* buf) +{ + uint32_t i, len = total_len; + + esmt32m_cmd_read_config(&esmt32m_cmd_config, addr, total_len); + qspi_cmd_operation_kick(QSPI1, &esmt32m_cmd_config); + + /* read data */ + do + { + if(total_len >= QSPI_FIFO_DEPTH) + { + len = QSPI_FIFO_DEPTH; + } + else + { + len = total_len; + } + while(qspi_flag_get(QSPI1, QSPI_RXFIFORDY_FLAG) == RESET); + for(i = 0; i < len; ++i) + { + *buf++ = qspi_byte_read(QSPI1); + } + total_len -= len; + }while(total_len); + + /* wait command completed */ + while(qspi_flag_get(QSPI1, QSPI_CMDSTS_FLAG) == RESET); + qspi_flag_clear(QSPI1, QSPI_CMDSTS_FLAG); +} + +/** + * @brief qspi write data + * @param addr: the address for write + * @param total_len: the length for write + * @param buf: the pointer for write data + * @retval none + */ +void qspi_data_write(uint32_t addr, uint32_t total_len, uint8_t* buf) +{ + uint32_t i, len = total_len; + + do + { + qspi_write_enable(); + if(total_len >= FLASH_PAGE_PROGRAM_SIZE) + { + len = FLASH_PAGE_PROGRAM_SIZE; + } + else + { + len = total_len; + } + esmt32m_cmd_write_config(&esmt32m_cmd_config, addr, len); + qspi_cmd_operation_kick(QSPI1, &esmt32m_cmd_config); + + for(i = 0; i < len; ++i) + { + while(qspi_flag_get(QSPI1, QSPI_TXFIFORDY_FLAG) == RESET); + qspi_byte_write(QSPI1, *buf++); + } + total_len -= len; + addr += len; + + /* wait command completed */ + while(qspi_flag_get(QSPI1, QSPI_CMDSTS_FLAG) == RESET); + qspi_flag_clear(QSPI1, QSPI_CMDSTS_FLAG); + + qspi_busy_check(); + + }while(total_len); +} + +/** + * @brief qspi erase data + * @param sec_addr: the sector address for erase + * @retval none + */ +void qspi_erase(uint32_t sec_addr) +{ + qspi_write_enable(); + + esmt32m_cmd_erase_config(&esmt32m_cmd_config, sec_addr); + qspi_cmd_operation_kick(QSPI1, &esmt32m_cmd_config); + + /* wait command completed */ + while(qspi_flag_get(QSPI1, QSPI_CMDSTS_FLAG) == RESET); + qspi_flag_clear(QSPI1, QSPI_CMDSTS_FLAG); + + qspi_busy_check(); +} + +/** + * @brief qspi check busy + * @param none + * @retval none + */ +void qspi_busy_check(void) +{ + esmt32m_cmd_rdsr_config(&esmt32m_cmd_config); + qspi_cmd_operation_kick(QSPI1, &esmt32m_cmd_config); + + /* wait command completed */ + while(qspi_flag_get(QSPI1, QSPI_CMDSTS_FLAG) == RESET); + qspi_flag_clear(QSPI1, QSPI_CMDSTS_FLAG); +} + +/** + * @brief qspi write enable + * @param none + * @retval none + */ +void qspi_write_enable(void) +{ + esmt32m_cmd_wren_config(&esmt32m_cmd_config); + qspi_cmd_operation_kick(QSPI1, &esmt32m_cmd_config); + + /* wait command completed */ + while(qspi_flag_get(QSPI1, QSPI_CMDSTS_FLAG) == RESET); + qspi_flag_clear(QSPI1, QSPI_CMDSTS_FLAG); +} + +/** + * @} + */ + +/** + * @} + */ diff --git a/modular.json b/modular.json new file mode 100644 index 0000000..9892a66 --- /dev/null +++ b/modular.json @@ -0,0 +1,17 @@ +{ + "dep": [ + { + "type": "git", + "provider": "GONEC_NEW", + "repo": "SpiPort" + } + ], + "cmake": { + "inc_dirs": [ + "Inc" + ], + "srcs": [ + "Src/**.c" + ] + } +} \ No newline at end of file