В исходниках этой папки:
\STM32F10x_StdPeriph_Lib_V3.1.2\Project\STM32F10x_StdPeriph_Examples\SPI\M25P64_FLASH
SCK, MISO и MOSI - настроены как GPIO_Mode_AF_PP.
...
Не могу связать stm32 с FM25L04. Пациент практически живёт, но что-то не так. В общем статусный регистр нормально читается и пишется (там фактически два бита защиты только). Но вот заставить писать и читать нормально ячейки памяти не могу. Тайминги просматриваю логическим анализатором. При записи ничего криминального нет и всё проходит в соответствии с диаграммами даташита на FM25. А вот чтение работает не верно: на линии MISO просто повторяется DUMMY-байт и при этом чтение SPI_I2S_ReceiveData
возвращает 0.
Настройка MISO на плавающий вход ничего не меняет. CS управляется программно (отрабатывает адекватно).
Вот кусок кода:
CODE
void spi_init(void)
{
SPI_FLASH_CS_HIGH();
SPI_InitTypeDef SPI_InitStructure;
SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;
SPI_InitStructure.SPI_Mode = SPI_Mode_Master;
SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;
SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low;
SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge;
SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;
SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_16;
SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;
SPI_InitStructure.SPI_CRCPolynomial = 7; /* ïî õîäó íå íóæåí */
SPI_Init(SPI_FM25, &SPI_InitStructure);
}
static uint8_t sendByte(uint8_t byte)
{
WAIT_TXE();
SPI_I2S_SendData( SPI_FM25, byte );
WAIT_RXNE();
return SPI_I2S_ReceiveData(SPI_FM25);
}
void spi_readBuf(uint16_t addr, uint8_t* buff, uint16_t buff_size)
{
uint_fast16_t i;
if(
( addr > FM25_MAX_ADDR )
|| ( buff_size > FM25_MAX_ADDR )
|| ( !buff )
) return;
SPI_FLASH_CS_LOW();
{
sendByte(FM25_READ_ADDR_HI( addr ));
sendByte(FM25_READ_ADDR_LO( addr ));
for( i = 0; i < buff_size; i++ )
{
buff[i] = sendByte(FM25_CMD_DUMMY);
}
}
SPI_FLASH_CS_HIGH();
}
void spi_writeBuf(uint16_t addr, uint8_t* buff, uint16_t buff_size)
{
uint_fast16_t i;
if(
( addr > FM25_MAX_ADDR )
|| ( buff_size > FM25_MAX_ADDR )
|| ( !buff )
) return;
SPI_FLASH_WriteEnable();
SPI_FLASH_CS_LOW();
{
sendByte( FM25_WRITE_ADDR_HI( addr ) );
sendByte( FM25_WRITE_ADDR_LO( addr ) );
for( i = 0; i < buff_size; i++ )
{
sendByte(buff[i]);
}
}
SPI_FLASH_CS_HIGH();
}
void spi_test(void)
{
static uint8_t buff[1];
buff[0] = 0x22;
spi_writeBuf(0x0000, buff, 1 );
spi_readBuf(0x0000, buff, 1);
}
Функции FM25_READ_ADDR_HI/LO и FM25_WRITE_ADDR_HI/LO - дают нужный опкод на чтение и запись + нужный адрес. Работают корректно. В функции sendByte пробовал делать предварительную проверку приёмного буффера - ничего не меняет. Уже второй день бьюсь

.