代码在韦东山6410的裸机代码上优化所得,做个笔记并注释如下:
void update_program(void)
{
unsigned char *buf = (unsigned char *)0x52000000;
unsigned long len = 0;
int have_begin = 0;//数据开始发送标志
int nodata_time = 0;//数据停止发送标记
char c;
/* 读串口获得数据 */
printf("\n\ruse gtkterm to send file\n\r");
while (1)
{
if (getc_nowait(&buf[len]) == 0)
{
have_begin = 1;
nodata_time = 0;
len++;
}
else
{
if (have_begin)
{
nodata_time++;
}
}
if (nodata_time == 1000000)//注意:原数据是1000,改为1000000后传输稳定性大大提高!
{
break;
}
}
printf("have get %d bytes data\n\r", len);
printf("Press Y to program the flash: \n\r");
c = getc();
if (c == 'y' || c == 'Y')
{
/* 烧写到nand flash block 0 */
nand_erase_block(0);//擦除第一个nandflash的第一个block,数据大小应该小于1block
nand_write(0, buf, len);//写入数据到nandflash
printf("update program successful\n\r");
}
else
{
printf("Cancel program!\n\r");
}
}
检查串口是否有数据:
int getc_nowait(unsigned char *pChar)
{
#ifdef ENABLE_FIFO
if ((UFSTAT0 & (1<<6)) == 0 && (UFSTAT0 & 0x3f) == 0)
#else
if ((UTRSTAT0 & (1<<0)) == 0)
#endif
{
return -1;
}
else
{
*pChar = URXH0;
return 0;
}
}
通过时间检查法检测数据是否发送完毕,如果数据发送完毕。则:getc_nowait 返回 -1,然后nodata_time 自加到1000000跳出,为了提高检测精度我将1000改为了1000000。