打印
[应用相关]

stm32f1使用IAP升级后STemwin显示图片速度变慢

[复制链接]
1178|19
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
elephant00|  楼主 | 2022-1-17 16:56 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我使用STM32F103VET6进行IAP升级。
现在将512K的flash划分为以下四个区域:
0x8000000——0x800B400的45K为bootloader区,存放IAP升级程序。
0x800B400——0x8030C00的150K为APP1区,存放第一个app程序。
0x8030C00——0x8056400的150K为APP2区,存放第二个app程序。
0x8056400往后的区域为IAP升级标志区,存放IAP升级标志。

app程序中使用了ucos操作系统和STemwinGUI。
我遇到的问题是,同一个app程序烧录在APP1区和APP2区后,STemwin的图片显示函数:"GUI_DrawBitmap()"显示图片的速度不一样。APP1区的显示速度很快,但APP2区的显示速度就变得很慢,通常刷一张图片要730ms左右。而且经过我的测试,APP2在flash的烧录位置越靠后,这个刷图函数就越慢。
在app程序中除了这个刷图慢的问题外其他功能都正常。
可以确保正常的app程序中配置没问题,应为已经测试过了。两个APP程序的唯一区别就是在main函数开头是用了SCB->VTOR = FLASH_BASE | 0xB400;来偏移中断向量表。
如果不使用IAP升级,把APP程序从0x8000000地址开始烧,APP程序就正常运行STemwin也没有任何问题。

想问一下大家有没有遇到过类似的问题或者能帮我提供一些解决思路,谢谢

以下是IAP的升级函数

void app_updata (uint16_t app_**)        {//传参为APP固件上次烧写标志

        u16 j=0;
        u16 temp;
        uint16_t app_num = 0;
        u32 fwaddr = FLASH_APP1_ADDR;//当前写入的地址
        u16 u;
        int i = 0;
        char pathbuf[30];
      
      
        if (app_** == APP_1)        {        //上次从一区起的,这次烧二区
                fwaddr = FLASH_APP2_ADDR;
                strcpy(pathbuf, APP2_NAME);
        }
        else if (app_** == APP_2)        {        //上次从二区起的,这次烧一区
                fwaddr = FLASH_APP1_ADDR;
                strcpy(pathbuf, APP1_NAME);
        }
      
        mount_flash();
        res_flash = f_open(&fnew, pathbuf, FA_OPEN_EXISTING | FA_READ );//打开外部flash中的固件
        if (res_flash == FR_NO_FILE)        {
               
                if (app_** == APP_1)        {
                        printf("无固件升级包,跳转到APP一区执行\r\n");
                        iap_load_app(FLASH_APP1_ADDR);//执行FLASH APP代码
                }
                else {
                        printf("无固件升级包,跳转到APP二区执行\r\n");
                        iap_load_app(FLASH_APP2_ADDR);//执行FLASH APP代码
                }
        }
        else if (res_flash == FR_OK) {
                recordsize = f_size(&fnew);
                app_num = recordsize / READ_SIZE;
                if (recordsize != 0)        {
                        printf( "打开固件%s成功,字节数为:%ld\r\n", pathbuf, recordsize);
                        printf ("准备开始固件升级!\r\n");
                        for (i = 0; i < app_num; i++)        {                //读固件数据
                                res_flash = f_lseek(&fnew, i * READ_SIZE);
                                memset(app_buf, 0, READ_SIZE);
                                res_flash = f_read(&fnew, app_buf, READ_SIZE, &fnum);                                                      
                                u8 *dfu = app_buf;
                                for(u = 0; u < READ_SIZE; u += 2)
                                {                                                   
                                        temp = (u16)dfu[1] << 8;
                                        temp += (u16)dfu[0];         
                                        dfu += 2;//偏移2个字节
                                        iapbuf[j++] = temp;            
                                        if(j == 1024)
                                        {
                                                j = 0;
                                                STMFLASH_Write(fwaddr, iapbuf, 1024);      
                                                fwaddr += 2048;//偏移2048  16=2*8.所以要乘以2.
                                        }
                                }
                                printf("固件升级中:读到%d字节,还剩%ld字节\r\n", READ_SIZE, (recordsize - (i + 1) * READ_SIZE));
                        }
                        //读剩余的不满1024的字节
                        res_flash = f_lseek(&fnew, app_num * READ_SIZE);
                        memset(app_buf, 0, READ_SIZE);
                        res_flash = f_read(&fnew, app_buf, recordsize % READ_SIZE, &fnum);
                        u8 *dfu = app_buf;
                        for(u = 0; u < recordsize % READ_SIZE; u += 2)
                        {                                                   
                                temp = (u16)dfu[1] << 8;
                                temp += (u16)dfu[0];         
                                dfu += 2;//偏移2个字节
                                iapbuf[j++] = temp;            
                        }
                        STMFLASH_Write(fwaddr, iapbuf, j);
                       
                        printf ("最后读到%ld字节\r\n", recordsize % READ_SIZE);
                        if (app_** == APP_1)                                       
                                f_unlink("0:/iCasa_multimeter_2.bin");        //删除固件包
                        else f_unlink("0:/iCasa_multimeter_1.bin");      
//                                                unmount_flash();
                        f_close(&fnew);
                       
                        beep_en();                //蜂鸣器响一声代表固件升级完成
                        delay_ms(100);
                        beep_dis();
                        if (app_** == APP_1)        {
                                Test_Write(FLASH_BAK_ADDR, APP_2);                //往flash写入标志,表示当前写入的是那个APP区
                                printf("固件升级完成,准备跳转至APP二程序!\r\n");
                                iap_load_app(FLASH_APP2_ADDR);//执行FLASH APP代码
                        }
                        else {
                                Test_Write(FLASH_BAK_ADDR, APP_1);                //往flash写入标志,表示当前写入的是那个APP区
                                printf("固件升级完成,准备跳转至APP一程序!\r\n");
                                iap_load_app(FLASH_APP1_ADDR);//执行FLASH APP代码
                        }
                }
                else {        //打开文件为空
                       
                        if (app_** == APP_1)        {
                                printf("固件包为空,跳转到APP一区执行\r\n");
                                iap_load_app(FLASH_APP1_ADDR);//执行FLASH APP代码
                        }
                        else {
                                printf("固件包为空,跳转到APP二区执行\r\n");
                                iap_load_app(FLASH_APP2_ADDR);//执行FLASH APP代码
                        }
                }
        }        //f_open出错
        else
                printf("打开固件包失败");
}

使用特权

评论回复
沙发
yangxiaor520| | 2022-1-17 20:55 | 只看该作者
是不是没有清楚内存

使用特权

评论回复
板凳
gouguoccc| | 2022-1-18 08:29 | 只看该作者
重新刷下一下固件试试

使用特权

评论回复
地板
小叶三千| | 2022-1-18 10:44 | 只看该作者
时钟看看对不对,之前遇到过跳转到APP后,时钟有改变,重新设置时钟试试

使用特权

评论回复
5
pmp| | 2022-11-19 12:32 | 只看该作者
stm32f1 ucos+stemwin ram够用吗

使用特权

评论回复
6
beacherblack| | 2022-11-19 17:36 | 只看该作者
touchgfx stm32可以免费用吗

使用特权

评论回复
7
chenci2013| | 2022-11-20 14:59 | 只看该作者
专门针对ST的版本,叫STemWin。

使用特权

评论回复
8
pl202| | 2022-11-24 13:29 | 只看该作者
STM芯片是有个stemwin,ST官方的UI界面库

使用特权

评论回复
9
mattlincoln| | 2022-11-24 15:03 | 只看该作者
STM32上的GUI哪个比较好学

使用特权

评论回复
10
sanfuzi| | 2022-11-24 15:53 | 只看该作者
推荐《基于STemWin的STM32开发与实践》

使用特权

评论回复
11
帛灿灿| | 2024-11-4 08:27 | 只看该作者

当电路出现异常过压并达到其击穿电压时

使用特权

评论回复
12
Bblythe| | 2024-11-4 09:30 | 只看该作者

例如下图中在SPI信号线上串联电阻就是为了改善匹配情况

使用特权

评论回复
13
周半梅| | 2024-11-4 11:26 | 只看该作者

即原/副边交错通断。

使用特权

评论回复
14
Pulitzer| | 2024-11-4 12:29 | 只看该作者

般只要关注值、精度、额度功率

使用特权

评论回复
15
童雨竹| | 2024-11-4 14:25 | 只看该作者

然后将其用作在PCB组装过程中放置在另一个板上的独立部件。

使用特权

评论回复
16
Wordsworth| | 2024-11-4 15:28 | 只看该作者

ESD静电保护器基本上都是通过静电进行吸收和耗散

使用特权

评论回复
17
Clyde011| | 2024-11-4 16:31 | 只看该作者

这类型灌封胶一般分为A、B双组份在进行1:1的配比后再进行灌封的操作

使用特权

评论回复
18
万图| | 2024-11-4 18:27 | 只看该作者

同时把异常高压箝制在一个安全水平之内

使用特权

评论回复
19
Uriah| | 2024-11-4 19:30 | 只看该作者

从而抑制电路的振荡。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

988

主题

3111

帖子

7

粉丝