W25Q32 i2c
时间: 2024-06-21 07:03:19 浏览: 4
W25Q32是一款SPI接口的闪存芯片,而不是I2C接口的。它由Winbond生产,容量为32Mbit,相当于4MB。它可以用于嵌入式系统中的存储应用,例如FPGA、单片机等。如果您需要使用I2C接口的闪存芯片,可以考虑使用AT24C系列芯片,例如AT24C256。 AT24C系列芯片是一种串行EEPROM芯片,使用简单方便,容量从1Kbit到4Mbit不等。
相关问题
stm32 w25q128驱动代码
以下是STM32驱动W25Q128的代码示例,使用SPI接口进行通信:
```c
#include "stm32f10x.h"
#define W25Q128_CS_GPIO GPIOA
#define W25Q128_CS_PIN GPIO_Pin_4
#define W25Q128_WRITE_ENABLE 0x06
#define W25Q128_WRITE_DISABLE 0x04
#define W25Q128_READ_STATUS_REG 0x05
#define W25Q128_WRITE_STATUS_REG 0x01
#define W25Q128_READ_DATA 0x03
#define W25Q128_PAGE_PROGRAM 0x02
#define W25Q128_SECTOR_ERASE 0x20
#define W25Q128_BLOCK_ERASE_32K 0x52
#define W25Q128_BLOCK_ERASE_64K 0xD8
#define W25Q128_CHIP_ERASE 0xC7
#define W25Q128_POWER_DOWN 0xB9
#define W25Q128_READ_DEVICE_ID 0x90
#define W25Q128_READ_MANUFACTURER_ID 0x9F
void W25Q128_Init(void);
void W25Q128_CS_Enable(void);
void W25Q128_CS_Disable(void);
void W25Q128_WriteEnable(void);
void W25Q128_WriteDisable(void);
void W25Q128_ReadStatusReg(uint8_t *status);
void W25Q128_WriteStatusReg(uint8_t status);
void W25Q128_ReadData(uint8_t *data, uint32_t addr, uint16_t size);
void W25Q128_PageProgram(uint8_t *data, uint32_t addr, uint16_t size);
void W25Q128_SectorErase(uint32_t addr);
void W25Q128_BlockErase32K(uint32_t addr);
void W25Q128_BlockErase64K(uint32_t addr);
void W25Q128_ChipErase(void);
void W25Q128_PowerDown(void);
void W25Q128_ReadDeviceID(uint8_t *id);
void W25Q128_ReadManufacturerID(uint8_t *id);
void W25Q128_Init(void)
{
GPIO_InitTypeDef GPIO_InitStruct;
SPI_InitTypeDef SPI_InitStruct;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_SPI1, ENABLE);
GPIO_InitStruct.GPIO_Pin = GPIO_Pin_5 | GPIO_Pin_7;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStruct);
GPIO_InitStruct.GPIO_Pin = GPIO_Pin_6;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &GPIO_InitStruct);
GPIO_InitStruct.GPIO_Pin = W25Q128_CS_PIN;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(W25Q128_CS_GPIO, &GPIO_InitStruct);
SPI_InitStruct.SPI_Direction = SPI_Direction_2Lines_FullDuplex;
SPI_InitStruct.SPI_Mode = SPI_Mode_Master;
SPI_InitStruct.SPI_DataSize = SPI_DataSize_8b;
SPI_InitStruct.SPI_CPOL = SPI_CPOL_Low;
SPI_InitStruct.SPI_CPHA = SPI_CPHA_1Edge;
SPI_InitStruct.SPI_NSS = SPI_NSS_Soft;
SPI_InitStruct.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_2;
SPI_InitStruct.SPI_FirstBit = SPI_FirstBit_MSB;
SPI_InitStruct.SPI_CRCPolynomial = 7;
SPI_Init(SPI1, &SPI_InitStruct);
SPI_Cmd(SPI1, ENABLE);
}
void W25Q128_CS_Enable(void)
{
GPIO_ResetBits(W25Q128_CS_GPIO, W25Q128_CS_PIN);
}
void W25Q128_CS_Disable(void)
{
GPIO_SetBits(W25Q128_CS_GPIO, W25Q128_CS_PIN);
}
void W25Q128_WriteEnable(void)
{
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_WRITE_ENABLE);
W25Q128_CS_Disable();
}
void W25Q128_WriteDisable(void)
{
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_WRITE_DISABLE);
W25Q128_CS_Disable();
}
void W25Q128_ReadStatusReg(uint8_t *status)
{
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_READ_STATUS_REG);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET);
*status = SPI_I2S_ReceiveData(SPI1);
W25Q128_CS_Disable();
}
void W25Q128_WriteStatusReg(uint8_t status)
{
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_WRITE_STATUS_REG);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, status);
W25Q128_CS_Disable();
}
void W25Q128_ReadData(uint8_t *data, uint32_t addr, uint16_t size)
{
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_READ_DATA);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, (addr >> 16) & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, (addr >> 8) & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, addr & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
while (size--) {
SPI_I2S_SendData(SPI1, 0);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET);
*data++ = SPI_I2S_ReceiveData(SPI1);
}
W25Q128_CS_Disable();
}
void W25Q128_PageProgram(uint8_t *data, uint32_t addr, uint16_t size)
{
W25Q128_WriteEnable();
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_PAGE_PROGRAM);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, (addr >> 16) & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, (addr >> 8) & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, addr & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
while (size--) {
SPI_I2S_SendData(SPI1, *data++);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
}
W25Q128_CS_Disable();
}
void W25Q128_SectorErase(uint32_t addr)
{
W25Q128_WriteEnable();
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_SECTOR_ERASE);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, (addr >> 16) & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, (addr >> 8) & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, addr & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
W25Q128_CS_Disable();
}
void W25Q128_BlockErase32K(uint32_t addr)
{
W25Q128_WriteEnable();
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_BLOCK_ERASE_32K);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, (addr >> 16) & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, (addr >> 8) & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, addr & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
W25Q128_CS_Disable();
}
void W25Q128_BlockErase64K(uint32_t addr)
{
W25Q128_WriteEnable();
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_BLOCK_ERASE_64K);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, (addr >> 16) & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, (addr >> 8) & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, addr & 0xFF);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
W25Q128_CS_Disable();
}
void W25Q128_ChipErase(void)
{
W25Q128_WriteEnable();
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_CHIP_ERASE);
W25Q128_CS_Disable();
}
void W25Q128_PowerDown(void)
{
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_POWER_DOWN);
W25Q128_CS_Disable();
}
void W25Q128_ReadDeviceID(uint8_t *id)
{
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_READ_DEVICE_ID);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, 0);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET);
*id++ = SPI_I2S_ReceiveData(SPI1);
SPI_I2S_SendData(SPI1, 0);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET);
*id++ = SPI_I2S_ReceiveData(SPI1);
SPI_I2S_SendData(SPI1, 0);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET);
*id++ = SPI_I2S_ReceiveData(SPI1);
SPI_I2S_SendData(SPI1, 0);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET);
*id++ = SPI_I2S_ReceiveData(SPI1);
W25Q128_CS_Disable();
}
void W25Q128_ReadManufacturerID(uint8_t *id)
{
W25Q128_CS_Enable();
SPI_I2S_SendData(SPI1, W25Q128_READ_MANUFACTURER_ID);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI1, 0);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET);
*id++ = SPI_I2S_ReceiveData(SPI1);
SPI_I2S_SendData(SPI1, 0);
while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET);
*id++ = SPI_I2S_ReceiveData(SPI1);
W25Q128_CS_Disable();
}
```
注意,在使用前需要先初始化SPI接口和CS引脚。
stm32f429 w25q256
stm32f429是一款由意法半导体公司(STMicroelectronics)开发的微控制器。它采用了ARM Cortex-M4内核,具有高性能和低功耗的特点。该芯片具有内置的flash和SRAM,支持多个外设接口,如USB、CAN、SPI、I2C等。具有广泛的应用领域,包括工业控制、汽车电子、智能家居、医疗设备等。
w25q256是一款来自美光公司(Micron)的闪存芯片。它具有256Mb的存储容量,采用了SPI接口,具有高速读写、擦除和寿命长的特点。该芯片常常被用于嵌入式系统中,用作数据存储、程序代码存储等。它也常常被用于智能手表、智能电视、智能家居等产品中。
stm32f429和w25q256可以结合使用,如将w25q256连接到stm32f429的SPI接口上,实现数据的存储和读取。使用w25q256可以扩展stm32f429的存储空间,从而使得应用程序更加灵活。同时,由于w25q256具有高速读写和寿命长的特点,可以保证数据的安全和可靠性。
相关推荐
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)