first commit
This commit is contained in:
242
libraries/zf_device/zf_device_w25q32.h
Normal file
242
libraries/zf_device/zf_device_w25q32.h
Normal file
@@ -0,0 +1,242 @@
|
||||
/*********************************************************************************************************************
|
||||
* CH32V307VCT6 Opensourec Library <20><><EFBFBD><EFBFBD>CH32V307VCT6 <20><>Դ<EFBFBD>⣩<EFBFBD><E2A3A9>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD>ڹٷ<DAB9> SDK <20>ӿڵĵ<DAB5><C4B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Դ<EFBFBD><D4B4>
|
||||
* Copyright (c) 2022 SEEKFREE <20><><EFBFBD>ɿƼ<C9BF>
|
||||
*
|
||||
* <20><><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD>CH32V307VCT6 <20><>Դ<EFBFBD><D4B4><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD>
|
||||
*
|
||||
* CH32V307VCT6 <20><>Դ<EFBFBD><D4B4> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
* <20><><EFBFBD><EFBFBD><EFBFBD>Ը<EFBFBD><D4B8><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ᷢ<EFBFBD><E1B7A2><EFBFBD><EFBFBD> GPL<50><4C>GNU General Public License<73><65><EFBFBD><EFBFBD> GNUͨ<55>ù<EFBFBD><C3B9><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>֤<EFBFBD><D6A4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
* <20><> GPL <20>ĵ<EFBFBD>3<EFBFBD>棨<EFBFBD><E6A3A8> GPL3.0<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѡ<EFBFBD><EFBFBD><EFBFBD>ģ<EFBFBD><EFBFBD>κκ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>İ汾<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>/<2F><><EFBFBD><EFBFBD><DEB8><EFBFBD>
|
||||
*
|
||||
* <20><><EFBFBD><EFBFBD>Դ<EFBFBD><D4B4><EFBFBD>ķ<EFBFBD><C4B7><EFBFBD><EFBFBD><EFBFBD>ϣ<EFBFBD><CFA3><EFBFBD><EFBFBD><EFBFBD>ܷ<EFBFBD><DCB7><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ã<EFBFBD><C3A3><EFBFBD><EFBFBD><EFBFBD>δ<EFBFBD><CEB4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>κεı<CEB5>֤
|
||||
* <20><><EFBFBD><EFBFBD>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ի<EFBFBD><D4BB>ʺ<EFBFBD><CABA>ض<EFBFBD><D8B6><EFBFBD>;<EFBFBD>ı<EFBFBD>֤
|
||||
* <20><><EFBFBD><EFBFBD>ϸ<EFBFBD><CFB8><EFBFBD><EFBFBD><EFBFBD>μ<EFBFBD> GPL
|
||||
*
|
||||
* <20><>Ӧ<EFBFBD><D3A6><EFBFBD><EFBFBD><EFBFBD>յ<EFBFBD><D5B5><EFBFBD><EFBFBD><EFBFBD>Դ<EFBFBD><D4B4><EFBFBD><EFBFBD>ͬʱ<CDAC>յ<EFBFBD>һ<EFBFBD><D2BB> GPL <20>ĸ<EFBFBD><C4B8><EFBFBD>
|
||||
* <20><><EFBFBD><EFBFBD>û<EFBFBD>У<EFBFBD><D0A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><https://www.gnu.org/licenses/>
|
||||
*
|
||||
* <20><><EFBFBD><EFBFBD>ע<EFBFBD><D7A2><EFBFBD><EFBFBD>
|
||||
* <20><><EFBFBD><EFBFBD>Դ<EFBFBD><D4B4>ʹ<EFBFBD><CAB9> GPL3.0 <20><>Դ<EFBFBD><D4B4><EFBFBD><EFBFBD>֤Э<D6A4><D0AD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD>İ汾
|
||||
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ӣ<EFBFBD>İ<EFBFBD><C4B0><EFBFBD> libraries/doc <20>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD>µ<EFBFBD> GPL3_permission_statement.txt <20>ļ<EFBFBD><C4BC><EFBFBD>
|
||||
* <20><><EFBFBD><EFBFBD>֤<EFBFBD><D6A4><EFBFBD><EFBFBD><EFBFBD><EFBFBD> libraries <20>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD>µ<EFBFBD> LICENSE <20>ļ<EFBFBD>
|
||||
* <20><>ӭ<EFBFBD><D3AD>λʹ<CEBB>ò<EFBFBD><C3B2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><DEB8><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD>뱣<EFBFBD><EBB1A3><EFBFBD><EFBFBD><EFBFBD>ɿƼ<C9BF><C6BC>İ<EFBFBD>Ȩ<EFBFBD><C8A8><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
*
|
||||
* <20>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD><EFBFBD> zf_device_w25q32
|
||||
* <20><>˾<EFBFBD><CBBE><EFBFBD><EFBFBD> <20>ɶ<EFBFBD><C9B6><EFBFBD><EFBFBD>ɿƼ<C9BF><C6BC><EFBFBD><EFBFBD><EFBFBD>˾
|
||||
* <20>汾<EFBFBD><E6B1BE>Ϣ <20>鿴 libraries/doc <20>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD><EFBFBD> version <20>ļ<EFBFBD> <20>汾˵<E6B1BE><CBB5>
|
||||
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> MounRiver Studio V1.8.1
|
||||
* <20><><EFBFBD><EFBFBD>ƽ̨ CH32V307VCT6
|
||||
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> https://seekfree.taobao.com/
|
||||
*
|
||||
* <20>ļ<DEB8>¼
|
||||
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><>ע
|
||||
* 2022-09-15 <20><>W first version
|
||||
********************************************************************************************************************/
|
||||
/*********************************************************************************************************************
|
||||
* <20><><EFBFBD>߶<EFBFBD><DFB6>壺
|
||||
* ------------------------------------
|
||||
* ģ<><C4A3><EFBFBD>ܽ<EFBFBD> <20><>Ƭ<EFBFBD><C6AC><EFBFBD>ܽ<EFBFBD>
|
||||
* //------------------Ӳ<><D3B2> SPI <20><><EFBFBD><EFBFBD>------------------//
|
||||
* SPC <20>鿴 zf_device_w25q32.h <20><> W25Q32_SPC_PIN <20>궨<EFBFBD><EAB6A8>
|
||||
* SDI <20>鿴 zf_device_w25q32.h <20><> W25Q32_SDI_PIN <20>궨<EFBFBD><EAB6A8>
|
||||
* SDO <20>鿴 zf_device_w25q32.h <20><> W25Q32_SDO_PIN <20>궨<EFBFBD><EAB6A8>
|
||||
* CS <20>鿴 zf_device_w25q32.h <20><> W25Q32_CS_PIN <20>궨<EFBFBD><EAB6A8>
|
||||
* //------------------Ӳ<><D3B2> SPI <20><><EFBFBD><EFBFBD>------------------//
|
||||
* <20><>Դ<EFBFBD><D4B4><EFBFBD><EFBFBD>
|
||||
* VCC 3.3V<EFBFBD><EFBFBD>Դ
|
||||
* GND <20><>Դ<EFBFBD><D4B4>
|
||||
* ------------------------------------
|
||||
********************************************************************************************************************/
|
||||
|
||||
#ifndef _zf_device_w25q32_h_
|
||||
#define _zf_device_w25q32_h_
|
||||
|
||||
#include "zf_common_clock.h"
|
||||
#include "zf_common_debug.h"
|
||||
|
||||
#include "zf_driver_delay.h"
|
||||
#include "zf_driver_spi.h"
|
||||
#include "zf_driver_soft_iic.h"
|
||||
|
||||
|
||||
#define W25Q32_BASE_ADDR (0x00000000) // W25Q32FALSH<53><EFBFBD>ַ
|
||||
#define W25Q32_PAGE_SIZE (0x00000100) // 256 byte
|
||||
#define W25Q32_SECTION_SIZE (W25Q32_PAGE_SIZE *16) // 4K byte
|
||||
#define W25Q32_BLOCK_SIZE (W25Q32_SECTION_SIZE *16) // 64K byte
|
||||
|
||||
//W25Q32<33><32>64<36><34><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>64*65536 = 4194304 Byte<74><65>4194304/1024/1024 = 4MB,Ѱַ<D1B0>ռ䣺0x000000~0x3FFFFF<46><46>
|
||||
|
||||
//<2F><><EFBFBD><EFBFBD>W25QXXϵ<58><CFB5>FLASH<53><48>ͬ<EFBFBD><CDAC>
|
||||
//<2F><>ͬ<EFBFBD>ͺŵ<CDBA>flash<73>в<EFBFBD>ͬ<EFBFBD><CDAC><EFBFBD><EFBFBD><EFBFBD>Ŀ<EFBFBD><C4BF><EFBFBD><EFBFBD><EFBFBD>W25Q16<31><36>32<33><32><EFBFBD><EFBFBD><EFBFBD><EFBFBD>W25Q32<33><32>64<36><34><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Դ<EFBFBD><D4B4><EFBFBD><EFBFBD>ƣ<EFBFBD><C6A3><EFBFBD>ϸ<EFBFBD><CFB8><EFBFBD><EFBFBD><EFBFBD>ġ<EFBFBD>
|
||||
//3.2<EFBFBD><EFBFBD>W25QXXϵ<EFBFBD><EFBFBD>FLASHоƬ<EFBFBD><EFBFBD>ͬ<EFBFBD>ͺŵ<EFBFBD><EFBFBD><EFBFBD>ͬ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɶ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
//1<><31><EFBFBD><EFBFBD> = 16<31><36><EFBFBD><EFBFBD>
|
||||
//1<><31><EFBFBD><EFBFBD> = 16 * 16 * 256<35>ֽڣ<D6BD>Byte<74><65>= 65536Byte = 64KB<4B><42>65536Byte/1024=64KB<4B><42>
|
||||
//1<><31><EFBFBD><EFBFBD> = 16ҳ
|
||||
//1<><31><EFBFBD><EFBFBD> = 16 * 256<35><36>Byte<74><65>= 4096Byte = 4KB
|
||||
//1ҳ = 256<35>ֽ<EFBFBD>
|
||||
|
||||
|
||||
// ö<><C3B6> Flash <20><><EFBFBD><EFBFBD> <20><>ö<EFBFBD>ٶ<EFBFBD><D9B6>岻<EFBFBD><E5B2BB><EFBFBD><EFBFBD><EFBFBD>û<EFBFBD><C3BB><EFBFBD>
|
||||
typedef enum
|
||||
{
|
||||
W25Q32_BLOCK_00,
|
||||
W25Q32_BLOCK_01,
|
||||
W25Q32_BLOCK_02,
|
||||
W25Q32_BLOCK_03,
|
||||
W25Q32_BLOCK_04,
|
||||
W25Q32_BLOCK_05,
|
||||
W25Q32_BLOCK_06,
|
||||
W25Q32_BLOCK_07,
|
||||
W25Q32_BLOCK_08,
|
||||
W25Q32_BLOCK_09,
|
||||
W25Q32_BLOCK_10,
|
||||
W25Q32_BLOCK_11,
|
||||
W25Q32_BLOCK_12,
|
||||
W25Q32_BLOCK_13,
|
||||
W25Q32_BLOCK_14,
|
||||
W25Q32_BLOCK_15,
|
||||
W25Q32_BLOCK_16,
|
||||
W25Q32_BLOCK_17,
|
||||
W25Q32_BLOCK_18,
|
||||
W25Q32_BLOCK_19,
|
||||
W25Q32_BLOCK_20,
|
||||
W25Q32_BLOCK_21,
|
||||
W25Q32_BLOCK_22,
|
||||
W25Q32_BLOCK_23,
|
||||
W25Q32_BLOCK_24,
|
||||
W25Q32_BLOCK_25,
|
||||
W25Q32_BLOCK_26,
|
||||
W25Q32_BLOCK_27,
|
||||
W25Q32_BLOCK_28,
|
||||
W25Q32_BLOCK_29,
|
||||
W25Q32_BLOCK_30,
|
||||
W25Q32_BLOCK_31,
|
||||
W25Q32_BLOCK_32,
|
||||
W25Q32_BLOCK_33,
|
||||
W25Q32_BLOCK_34,
|
||||
W25Q32_BLOCK_35,
|
||||
W25Q32_BLOCK_36,
|
||||
W25Q32_BLOCK_37,
|
||||
W25Q32_BLOCK_38,
|
||||
W25Q32_BLOCK_39,
|
||||
W25Q32_BLOCK_40,
|
||||
W25Q32_BLOCK_41,
|
||||
W25Q32_BLOCK_42,
|
||||
W25Q32_BLOCK_43,
|
||||
W25Q32_BLOCK_44,
|
||||
W25Q32_BLOCK_45,
|
||||
W25Q32_BLOCK_46,
|
||||
W25Q32_BLOCK_47,
|
||||
W25Q32_BLOCK_48,
|
||||
W25Q32_BLOCK_49,
|
||||
W25Q32_BLOCK_50,
|
||||
W25Q32_BLOCK_51,
|
||||
W25Q32_BLOCK_52,
|
||||
W25Q32_BLOCK_53,
|
||||
W25Q32_BLOCK_54,
|
||||
W25Q32_BLOCK_55,
|
||||
W25Q32_BLOCK_56,
|
||||
W25Q32_BLOCK_57,
|
||||
W25Q32_BLOCK_58,
|
||||
W25Q32_BLOCK_59,
|
||||
W25Q32_BLOCK_60,
|
||||
W25Q32_BLOCK_61,
|
||||
W25Q32_BLOCK_62,
|
||||
W25Q32_BLOCK_63
|
||||
}w25q32_block_enum;
|
||||
|
||||
// ö<><C3B6> Flash <20><><EFBFBD><EFBFBD> <20><>ö<EFBFBD>ٶ<EFBFBD><D9B6>岻<EFBFBD><E5B2BB><EFBFBD><EFBFBD><EFBFBD>û<EFBFBD><C3BB><EFBFBD>
|
||||
typedef enum
|
||||
{
|
||||
W25Q32_SECTION_00,
|
||||
W25Q32_SECTION_01,
|
||||
W25Q32_SECTION_02,
|
||||
W25Q32_SECTION_03,
|
||||
W25Q32_SECTION_04,
|
||||
W25Q32_SECTION_05,
|
||||
W25Q32_SECTION_06,
|
||||
W25Q32_SECTION_07,
|
||||
W25Q32_SECTION_08,
|
||||
W25Q32_SECTION_09,
|
||||
W25Q32_SECTION_10,
|
||||
W25Q32_SECTION_11,
|
||||
W25Q32_SECTION_12,
|
||||
W25Q32_SECTION_13,
|
||||
W25Q32_SECTION_14,
|
||||
W25Q32_SECTION_15,
|
||||
}w25q32_section_enum;
|
||||
|
||||
// ö<><C3B6> Flash ҳ<><D2B3><EFBFBD><EFBFBD> <20><>ö<EFBFBD>ٶ<EFBFBD><D9B6>岻<EFBFBD><E5B2BB><EFBFBD><EFBFBD><EFBFBD>û<EFBFBD><C3BB><EFBFBD>
|
||||
typedef enum
|
||||
{
|
||||
W25Q32_PAGE_00,
|
||||
W25Q32_PAGE_01,
|
||||
W25Q32_PAGE_02,
|
||||
W25Q32_PAGE_03,
|
||||
W25Q32_PAGE_04,
|
||||
W25Q32_PAGE_05,
|
||||
W25Q32_PAGE_06,
|
||||
W25Q32_PAGE_07,
|
||||
W25Q32_PAGE_08,
|
||||
W25Q32_PAGE_09,
|
||||
W25Q32_PAGE_10,
|
||||
W25Q32_PAGE_11,
|
||||
W25Q32_PAGE_12,
|
||||
W25Q32_PAGE_13,
|
||||
W25Q32_PAGE_14,
|
||||
W25Q32_PAGE_15,
|
||||
}w25q32_page_enum;
|
||||
|
||||
//====================================================Ӳ<><D3B2> SPI <20><><EFBFBD><EFBFBD>====================================================
|
||||
#define W25Q32_SPI_SPEED system_clock/8 // Ӳ<><D3B2> SPI <20><><EFBFBD><EFBFBD>
|
||||
#define W25Q32_SPI SPI_3 // Ӳ<><D3B2> SPI <20><>
|
||||
#define W25Q32_SPC_PIN SPI1_MAP1_SCK_B3 // Ӳ<><D3B2> SPI SCK <20><><EFBFBD><EFBFBD>
|
||||
#define W25Q32_SDI_PIN SPI1_MAP1_MISO_B4 // Ӳ<><D3B2> SPI MOSI <20><><EFBFBD><EFBFBD>
|
||||
#define W25Q32_SDO_PIN SPI1_MAP1_MOSI_B5 // Ӳ<><D3B2> SPI MISO <20><><EFBFBD><EFBFBD>
|
||||
//====================================================Ӳ<><D3B2> SPI <20><><EFBFBD><EFBFBD>====================================================
|
||||
#define W25Q32_CS_PIN A15 // CS Ƭѡ<C6AC><D1A1><EFBFBD><EFBFBD>
|
||||
#define W25Q32_CS(x) (x? (gpio_high(W25Q32_CS_PIN)): (gpio_low(W25Q32_CS_PIN)))
|
||||
|
||||
#define W25Q32_TIMEOUT_COUNT 0x00FF
|
||||
|
||||
//================================================<3D><><EFBFBD><EFBFBD> ICM20602 <20>ڲ<EFBFBD><DAB2><EFBFBD>ַ================================================
|
||||
#define W25Q32_WRITE_ENABLE 0x06
|
||||
#define W25Q32_WRITE_DISABLE 0x04
|
||||
|
||||
#define W25Q32_READ_STATUS_REG_1 0x05
|
||||
#define W25Q32_READ_STATUS_REG_2 0x35
|
||||
#define W25Q32_READ_STATUS_REG_3 0x15
|
||||
#define W25Q32_WRITE_STATUS_REG_1 0x01
|
||||
#define W25Q32_WRITE_STATUS_REG_2 0x31
|
||||
#define W25Q32_WRITE_STATUS_REG_3 0x11
|
||||
#define W25Q32_PAGE_PROGRAM 0x02
|
||||
#define W25Q32_READ_DATA 0x03
|
||||
#define W25Q32_FAST_READ 0x0B
|
||||
#define W25Q32_SECTOR_ERASE 0x20
|
||||
#define W25Q32_32KB_BLOCK_ERASE 0x52
|
||||
#define W25Q32_64KB_BLOCK_ERASE 0xD8
|
||||
#define W25Q32_CHIP_ERASE 0xC7
|
||||
#define W25Q32_SUSPEND 0x75
|
||||
#define W25Q32_RESUME 0x7A
|
||||
#define W25Q32_READ_UID 0x4B
|
||||
#define W25Q32_JEDEC_ID 0x9F // W25Q32 <20><><EFBFBD><EFBFBD>0xEF40
|
||||
#define W25Q32_DEVICE_ID 0x90 // W25Q32 <20><><EFBFBD><EFBFBD>0xEF15
|
||||
#define W25Q32_RESET_ENABLE 0x66
|
||||
#define W25Q32_RESET_DEVICE 0x99
|
||||
//================================================<3D><><EFBFBD><EFBFBD> ICM20602 <20>ڲ<EFBFBD><DAB2><EFBFBD>ַ================================================
|
||||
|
||||
|
||||
void w25q32_erase_chip(void);
|
||||
uint8 w25q32_check (w25q32_block_enum block_num, w25q32_section_enum sector_num, w25q32_page_enum page_num);
|
||||
uint8 w25q32_erase_sector (w25q32_block_enum block_num, w25q32_section_enum sector_num);
|
||||
|
||||
void w25q32_read_page (w25q32_block_enum block_num, w25q32_section_enum sector_num, w25q32_page_enum page_num,
|
||||
uint8 *buf, uint16 len);
|
||||
|
||||
void w25q32_write_page (w25q32_block_enum block_num, w25q32_section_enum sector_num, w25q32_page_enum page_num,
|
||||
uint8 *buf, uint16 len);
|
||||
uint8 w25q32_init();
|
||||
|
||||
//SPI_FLASHдʹ<D0B4><CAB9>
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user