Quectel winbond SPI написать страницу
Возникла проблема при записи данных размером более 256 байт на winbond W25Q32. Я использую Quectel MC60, Eclipse IDE для программирования. Дело в том, что я могу написать одну страницу.
Последовательность следующая:
- Читать читать (page_addr)
- Стереть erase_sector(0) // сектор для стирания
Write write(page_addr,buff) // buff - байты данных для записи
Ql_strcpy(buff3,"EDIT (11-MAR-2014)): возникла проблема с низкоуровневой функцией _read_page, я забыл вытащить CS HIGH, прежде чем тянуть его LOW в начале функции, как и другие функции. Это означает, что если _read_page является первой вызванной вами функцией, CS может быть еще не на высоком уровне, поэтому без действительного /CS 1->0 перехода _read_page не будет работать должным образом при первом вызове. Во второй раз он будет работать нормально, потому что он оставляет / CS как 1. Маленький, но ");
// это буфер
Код выглядит следующим образом:
void proc_main_task(void)
{
s32 ret;
ST_MSG msg;
bool keepGoing = TRUE;
u8 ar[255];
u8 counter=0xf0,temp_counter=0;
char counter_s[6];
Ql_memset(ar,0,sizeof(ar));
// Register & open UART port
Ql_UART_Register(UART_PORT1, CallBack_UART_Hdlr, NULL);
Ql_UART_Open(UART_PORT1, 115200, FC_NONE);
Ql_UART_Register(UART_PORT2, CallBack_UART_Hdlr, NULL);
Ql_UART_Open(UART_PORT2, 115200, FC_NONE);
APP_DEBUG("\r\n<-- OpenCPU: SPI TEST! -->\r\n")
//chnnlNo, //pinClk, //pinMiso, //pinMosi, //pinCs, //spiType
ret = Ql_SPI_Init(USR_SPI_CHANNAL,PINNAME_PCM_IN,PINNAME_PCM_SYNC,PINNAME_PCM_OUT,PINNAME_PCM_CLK,spi_usr_type);
if(ret <0)
{
APP_DEBUG("\r\n<-- Failed!! Ql_SPI_Init fail , ret =%d-->\r\n",ret)
}
else
{
APP_DEBUG("\r\n<-- Ql_SPI_Init ret =%d -->\r\n",ret)
}
ret = Ql_SPI_Config(USR_SPI_CHANNAL,1,0,0,10000); //config sclk about 10MHz;
if(ret <0)
{
APP_DEBUG("\r\n<--Failed!! Ql_SPI_Config fail ret=%d -->\r\n",ret)
}
else
{
APP_DEBUG("\r\n<-- Ql_SPI_Config =%d -->\r\n",ret)
}
//init cs pin
if (!spi_usr_type)
{
Ql_GPIO_Init(PINNAME_PCM_CLK,PINDIRECTION_OUT,PINLEVEL_HIGH,PINPULLSEL_PULLUP); //CS high
}
u8 buff1[255]={0};
u16 addr=0,dev_id=0;
u8 i=0,counter1=0;
u8 buff3[1024];
u8 buff2[255]={0};
Ql_memset(buff3,0,sizeof(buff3));
Ql_strcpy(buff3,"EDIT (11-MAR-2014): There was an issue with the _read_page low-level function, I had forgotten to pull CS HIGH before pulling it LOW at the start of the function, like the other functions. This means if _read_page is the first function you call, CS may not already be high, so without a valid /CS 1->0 transition _read_page will not function properly, the first time it is called. The second time it would work fine because it leaves /CS as 1. Small but");
if (cmd_is_over1())
flash_rd_id(); // for reading JEDEC ID
else
APP_DEBUG("error.\r\n");
dev_id = Ql_atoi(s);
APP_DEBUG("DEVICE ID: %d\r\n",dev_id);
if(!Ql_strcmp(s,"4016"))
APP_DEBUG("Number of pages are 16384.\r\n")
else
APP_DEBUG("Number of pages error.\r\n")
ql_winbond_flash_block_unlock(); // unlock flash block
if (cmd_is_over1())
flash_rd_id2(); // For reading MID /DID
else
APP_DEBUG("error.\r\n")
APP_DEBUG("buff3 %s\r\n",buff3);
// for(counter=0;counter<50;counter++) // for reading
// {
Ql_memset(buff1,0,sizeof(buff1));
if (cmd_is_over1())
{
flash_rd_data1(counter,buff1,255);
cmd_is_over1();
}
else
APP_DEBUG("error.\r\n")
if (cmd_is_over1())
{
flash_rd_data1((counter+1),buff1,255);
cmd_is_over1();
}
else
APP_DEBUG("error.\r\n")
Ql_Sleep(50);
counter1=Ql_atoi(buff1);
APP_DEBUG("counter1 =%d\r\n",counter1);
// counter1=temp_counter; // check
Ql_memset(counter_s,0,sizeof(counter_s));
counter1++;
Ql_sprintf(counter_s,"%d",counter1);
APP_DEBUG("counter_s =%s\r\n",counter_s);
// }
// Ql_Sleep(500);
if (cmd_is_over1())
flash_erase_sector1(0);
else
APP_DEBUG("error.\r\n")
// for(counter=0;counter<50;counter++) // for writing
// {
if (cmd_is_over1())
{
// flash_wr_data(counter,my_itoa(counter,ar,10),sizeof(my_itoa(counter,ar,10)));
/// flash_wr_data(counter,"India is a beautiful country",Ql_strlen("India is a beautiful country"));
flash_wr_data(counter,buff3,Ql_strlen(buff3));
// flash_wr_data(counter,counter_s,Ql_strlen(counter_s));
cmd_is_over1();
}
// flash_wr_data(counter,"India\0",sizeof("India\0"));
else
APP_DEBUG("error.\r\n")
Ql_Sleep(50);
// }
// Ql_memset(buff1,0,sizeof(buff1));
// if (cmd_is_over1())
// flash_rd_data1(addr,buff1,255);
while (keepGoing)
{
Ql_OS_GetMessage(&msg);
switch(msg.message)
{
default:
break;
}
}
}