STM32 串口烧写 FLASH 外部字库 UCGUI显示 自我学习总结

发布者:温柔的爱情最新更新时间:2017-11-28 来源: eefocus关键字:STM32  串口烧写  FLASH  外部字库  UCGUI显示 手机看文章 扫描二维码
随时随地手机看文章

最近学习TFT显示问题,在多种汉字显示方面有点难,主要是字库太大,几个字库就不得了。开始是使用SD卡向外部FLASH---W25X16写,完全能够完成。后来觉得这样比较麻烦,有时候还没有SD接口,于是打算用串口写一下试一试,网上有很多人说会丢失数据,在后面的试验中暂时没有发现。


我是在我前段时间学习的UCGUI的基础基础上修改的。


主要功能是----启动开发板,首先写入地址指令----必须十六进制----比如---2A 23 00 05 00 03 23 2A-----其中2A,23为验证码,前后都有,第3,4位是地址码,前面就表示将要写入的起始地址是0x05*4096,第5,6位是为了写入数据将要从起始地址连续擦除的扇区个数,前面就表示0x0003个。

--------------主函数-------------------

int main(void)
{
  uint16_t Erase_flag=0,i=0;
  uint32_t Erase_adrr=0;
  bsp_InitLCD();
  bsp_InitTouch();
  SPI_GPIO_Init(4);
  NVIC_Configuration();
  USART1_Config();
  GPIO_Other_Config();
  
  //TIM3_Init(84,1000); //实时检测触摸屏信息
  GUI_Init();
  
  GUI_SetBkColor(GUI_RED); //背景颜色
  GUI_Clear(); //用背景颜色清屏
  GUI_CURSOR_Show(); //显示光标---大小32

  GUI_SetFont(&GUI_Font32B_1);  //设置字体
  GUI_SetColor(GUI_BLACK);  //设置文本颜色
  GUI_DispStringAt("Addr:",10,50);   //指定位置显示指定文本
  GUI_DispStringAt("Sect:",10,85);
  GUI_DispStringAt("Nums:",10,120);
  GUI_DispStringAt("Eras:",10,160);
  GUI_DispStringAt("Test:",10,200);

  while(1)
  {
        CK_flag=0;   //串口接收数据是否是地址的的标识判断位---为0 表示后面接收的是地址
        RS232_RX_CNT=0; //串口接收到地址数据时有作用,每次到这里串口接收缓存数组下表为0,表示后面将接收地址
        addr_i=0;    //串口接收到非地址数据的个数,它的变化实在串口接收中断函数中递增,这里清零表示再次烧写
        Delay_Ms(1000);
        GUI_SetFont(&GUI_Font32B_1);
        GUI_SetColor(GUI_YELLOW);
        GUI_DispStringAtCEOL("Wait Send Addr",50,10);
        GUI_DispStringAt("Waits Addr",100,160);
        GUI_DispHexAt(addr_Stop,200,50,6);//烧录完成后根据真实烧录的字节数计算出终止地址显示出来
//下面这个while循环,其目的是等待串口接收地址指令---指令需要16进制发送---比如2A 23 00 50 00 01 23 2A---为一个完整指令
//2A 23 都为判断标识---第3,4表示起始地址--0x05*4096---第5,6数据表示从起始地址需要擦除多少个扇区来方便后面写数据--0x0002个
        while(!(RS232_RX_BUF[0]==0x2A)||!(RS232_RX_BUF[1]==0x23)||!(RS232_RX_BUF[6]==0x23)||!(RS232_RX_BUF[7]==0x2A));

        addr=RS232_RX_BUF[2]*256+RS232_RX_BUF[3];  //addr为接收到的起始地址所在扇区,也就是说是第几个扇区
        addr_Stop  = addr*4096;//第几个扇区对应的扇区地址
        Erase_adrr = addr;   //起始地址也就是要擦除的扇区是第几个
        Erase_flag=RS232_RX_BUF[4]*256+RS232_RX_BUF[5];//要擦出的连续扇区个数

        GUI_SetFont(&GUI_Font32B_1);
        GUI_SetColor(GUI_CYAN);  
        GUI_DispHexAt(addr*4096,100,50,6);//显示起始地址
        GUI_DispDecAt(Erase_flag,100,85,4); //显示要擦出的扇区个数
        GUI_DispStringAt("Start Erase",100,160);
        for(i=0;i        {
                Erase_adrr=addr+i;//扇区地址自增---这里自己试验的时候不小心把addr写成了Erase_adrr,导致调试好久,最后一步一步添加验证才找到问题,不过在这个过程中加深了自己对FLASH的了解!
                SPI_FLASH_SectorErase(4096*Erase_adrr);  //擦出扇区
 
                GUI_SetColor(GUI_WHITE);
                GUI_DispDecAt(i+1,255,160,4);// 显示实时擦除扇区状态---第几个
                Delay_Ms(50);
        }
        GUI_SetColor(GUI_CYAN); 
        GUI_DispStringAt("Finis Erase",100,160);
        GUI_SetFont(&GUI_FontHZ16);
        GUI_SetColor(GUI_DARKMAGENTA);
        GUI_DispStringAt("啊波次的乐我许与在 #*aA/字库",100,210);//这里是用来测试前面的擦出是否完成---比如前面擦出了ASCII码的字库地址,其中的FLASH就不会显示
        CK_flag=10; //串口接收数据是否是地址的的标识判断位 ---为10 表示后面接收的是数据

        GUI_SetFont(&GUI_Font32B_1);
        GUI_SetColor(GUI_GREEN);
        GUI_DispStringAtCEOL("Wait Send Data",50,10);

        while(GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_1) == 0);   //这里等于是一个开关---用来等待串口传输完成,可以再串口上看到是否传输完成
    
        GUI_SetColor(GUI_WHITE);
        GUI_DispDecAt(addr_i,100,120,7);
        GUI_SetFont(&GUI_FontHZ16);
        GUI_SetColor(GUI_BLUE);
        GUI_DispStringAt("啊波次的乐我许与在 #*aA/字库",100,210);//这里是用来测试前面的烧写是否完成---比如前面擦出了ASCII码的字库地址这里又重新烧录了ASCII码,其中的FLASH就会再次显示
        Delay_Ms(100);

        GUI_TOUCH_Exec();
        GUI_Exec(); 
  }
}


--------------串口中断函数------------

void USART1_IRQHandler(void)
{        
  uint8_t res;
  if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)  //接收到数据  
  {        
        USART_ClearITPendingBit(USART1, USART_IT_RXNE); 
        res=USART_ReceiveData(USART1);  //读取接收到的数据 
        RS232_RX_BUF[RS232_RX_CNT++]=res;  //接收数据,主要保存地址指令
        if(CK_flag==10)  //串口接收数据
        {  
                addr_i++;  //烧写地址自增---主函数中将在烧写完成后显示
                SPI_FLASH_BufferWrite(&res,addr++,1);  //烧写接收到的数据到FLASH
        }
        if( RS232_RX_CNT==12)//无影响
                RS232_RX_CNT=0;  
  }


---------------------实验实物图片----------------------

----标识显示-----


-----指令---擦除0x000000起始的连续64个扇区


----上面擦除的是汉字库的内容---故下面汉字没有显示---


----重新烧录汉字库,一共261696个字节数据---大约64K---


-----烧录完成,汉字又显示了----


----指令----擦除0x050000起始的一个扇区---



-----擦除了ASCII码地址内容,故ASCII码没有显示--



-----重新烧录ASCII码库,一个4096个字节数据,刚好4K---


----烧录完成,ASCII码再次显示----


关键字:STM32  串口烧写  FLASH  外部字库  UCGUI显示 引用地址:STM32 串口烧写 FLASH 外部字库 UCGUI显示 自我学习总结

上一篇:ARM汇编之寄存器
下一篇:STM32 MDK 工程创建 图解步骤 自我学习总结

推荐阅读最新更新时间:2024-03-16 15:47

STM32总结之GPIO编程过程
用寄存器点亮LED的过程 1:通过原理图找到要点亮的LED灯对应的GPIO口 2.通过stm32手册找到要操作的寄存器,找到这个GPIO的基地址, 基地址+地址偏移 = 目标寄存器的地址 3.编码 1.打开对应的GPIO的时钟。 2.通过操作CRL寄存器将对应的GPIO口设置为推挽输出模式,并设置一 个翻转速度 3.通过操作ODR寄存器,将电平置高或置低。 按键操作过程 1.通过原理图找到要操作的按键对应的GPIO 2.通过stm32手册找到要操作的寄存器,找到这个GPIO的基地址 基地址+地址偏移 = 目标寄存器的地址 3.编码 1.打开对应的GPIO的时钟。 2.通过操作CRL寄存器将对应的GP
[单片机]
STM32 USB虚拟串口问题汇总
汇总1:STM32的USB例程修改步骤,来自http://blog.csdn.net/cy757/archive/2010/01/01/5117610.aspx 以下是笔者将ST的Custom_HID例程修改为“自定义USB设备”例程时总结出来的,因为笔者也是刚刚学USB开发不久,某些方面理解错误在所难免,请各位大虾指正。 一、usb_desc.c文件 根据你程序使用的通信方式修改。usb_desc.h文件中定义要根据usb_desc.c文件中的数组的大小;ConfigDescriptor 下添加需要处理的端点;根据需要添加或删除报告描述符(主要用于HID)和CDC接口描述符(主要用于实现USB转串口)等。具体方法可以下载个“
[单片机]
STM32-NVIC中断嵌套优先级管理器
NVIC简介 NVIC(Nested Vectored Interrupt Controller),中断嵌套向量控制器,是 Cortex‐M3 不可分离的一部分,它与 CM3 内核共同完成对中断的响应。在了解NVIC之前最好简单了解一下CM3内核的中断系统,传送。 NVIC 共支持 1 至 240 个外部中断输入(通常外部中断写作 IRQn),每个中断有最高256(最低8)级的优先级,具体的中断数和优先级级数由芯片厂商在设计芯片时决定(STM32F1支持60个外部中断,16级优先级)。此外,NVIC 还支持一个“永垂不朽”的不可屏蔽中断(NMI)输入。NMI 的实际功能亦由芯片制造商决定。在某些情况下,NMI 无法由外部中断源
[单片机]
STM32-NVIC中断嵌套优先级管理器
STM32 移植 STemwin
移植STemwin 平台STM32F429+LTDC+SDRAM 其实不难就是给自己做个记录,年纪大了记性不好。。。 自己先驱动好TFTLCD, LTDC, SDRAM等 Cubemx配置增大堆栈大小,不然容易出错 需要添加以下文件进行配置 挨个文件配置 GUIConf.c里面主要修改ram大小,酌情而定,不宜太大。 #define GUI_NUMBYTES (1024)*50 GUIDRV_Template.c里面修改以下函数TBD by customer部分添加画点,读点,填充函数 static void _SetPixelIndex(GUI_DEVICE * pDevice, int x, i
[单片机]
<font color='red'>STM32</font> 移植 STemwin
STM32的JTAG下载模式
SWJ:串行线JTAG配置 (Serial wire JTAG configuration) SWJ(串行线JTAG)支持JTAG或SWD访问Cortex的调试端口。 系统复位后的默认状态是启用SWJ但没有跟踪功能,这种状态下可以通过JTMS/JTCK脚上的特定信号选择JTAG或SW(串行线)模式。
[单片机]
STM32大小端模式与堆栈及其增长方向
栈增长和大端/小端问题是和CPU相关的两个问题. 1,首先来看:栈(STACK)的问题. 函数的局部变量,都是存放在 栈 里面,栈的英文是:STACK.STACK的大小,我们可以在stm32的启动文件里面设置,以战舰stm32开发板为例,在startup_stm32f10x_hd.s里面,开头就有: Stack_Size EQU 0x00000800 表示栈大小是0X800,也就是2048字节.这样,CPU处理任务的时候,函数局部变量做多可占用的大小就是:2048字节,注意:是所有在处理的函数,包括函数嵌套,递归,等等,都是从这个 栈 里面,来分配的. 所以,如果一个函数的局部变量过多,比如在函数里面定义一个u8 buf
[单片机]
<font color='red'>STM32</font>大小端模式与堆栈及其增长方向
STM32-(30):内部温度传感器
温度传感器 STM32有一个内部的温度传感器,可以用来测量CPU及周围的温度(TA)。 该温度传感器在内部和ADCx_IN16输入通道相连接,此通道把传感器输出的电压转换成数字值。温度传感器模拟输入推荐采样时间是17.1 u s。STM32的内部温度传感器支持的温度范围为: -40~125度。精度比较差,为±1.5°C左右。 注:V25在 25℃时的值为1.43V,斜率为0.0043
[单片机]
STM32-(30):内部温度传感器
学习单片机和STM32的一道坎
刚开始学单片机的你,是不是会因用程序把LED点亮而感到高兴,会因用程序把数码管点亮而感到高兴。这是好事,这也是想继续学习下去的动力。 但是数据相关的实验是学习单片机和STM32的一道坎,此时就需要用好本文要说的串口这个调试工具。串口通信介绍关于串口通信的介绍,也可以点击阅读之前发的一篇文章:STM32串口通信基本原理。串口通信是指外设和计算机间,通过数据信号线 、地线、控制线等,按位进行传输数据的一种通讯方式......这种太过理论了,看似懂了,但又不懂。还是用我笔者自己的话来说吧。串口通信就是可以把程序在单片机或者STM32芯片中运行的结果发送到电脑的一种通信方式。 如何使用串口通讯,你需要知道的几个重要的知识点: 波特
[单片机]
学习单片机和<font color='red'>STM32</font>的一道坎
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
热门活动
换一批
更多
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

更多精选电路图
换一换 更多 相关热搜器件
更多每日新闻
随便看看
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved