久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 5794|回復: 1
打印 上一主題 下一主題
收起左側

完備性保證-IAR在程序鏡像中嵌入校驗碼

[復制鏈接]
跳轉到指定樓層
樓主
          完備性保證-IAR在程序鏡像中嵌入校驗碼,本文是我在公司內部寫的培訓文檔,
講解如何在IAR編譯器環境下自動插入校驗碼,用于程序鏡像的升級校驗。
                                         --2017-11-09 22:50:04  

前言
目前我們的程序升級等存在無完備性保證的問題,代碼升級過程沒有可靠性保證。
也就是升級完后沒辦法確認升級完后程序是不是完全正確的寫入了芯片的FLASH,如果存在某些原因導致的字節錯誤則可能無法發現很可能存在隱患。
目前我們的平臺確認應用是否存在也就是簡單的檢查某地固定地址的魔術字是否存在,對代碼升級的過程沒有回讀校驗沒辦法確認是否升級成功。

本文檔就是介紹在代碼中自動嵌入程序校驗碼,在升級和運行過程中通過校驗該校驗碼來保證可靠性。

本本只講述如何在鏡像中自動生成校驗碼和如何使用代碼去校驗。詳細的應用邏輯參考bootloader詳細設計文檔。
一.原理概述


開發工具IAR可以自動按要求在生成的鏡像中添加校驗信息。校驗信息一般放在鏡像區域的開頭或者結束位置,一般中斷向量表在鏡像開頭位置的校驗信息就放在鏡像結束位置。
應用邏輯中就可以根據這個檢驗信息對整個鏡像區域(不包括校驗檢驗信息)進行校驗用于驗證:
  • 確認應用或者bootloader代碼升級是否確定成功
  • 是否存在有效的應用代碼或者bootloader代碼。
二.方法詳述2.1 使用編譯器預留符號
右鍵資源管理器的工程名->【Options…】->【Linker】->【Extra Optinos】
添加
--keep __checksum
該語句的意思是不管你程序中有沒有使用__checksum都會鏈接__checksum到鏡像中。
設置如下:

2.2     設置校驗碼的存放位置
打開工程的icf文件,添加語句
place at address mem:0xFFFC0000 { ro section .checksum };
該語句的意思是將checksum段鏈接到地址0xFFFC0000處,由于__checksum是放置在段checksum中的,也就是說__checksum放在了地址0xFFFC0000的地方。
0xFFFC0000是應用區域的首地址(因為我們的芯片中斷向量在高地址0xFFFFFFFF所以校驗碼就放在低地址)。實際需要根據芯片存儲的分配設置。

設置如下
2.3 設置校驗碼產生方式
右鍵資源管理器的工程名->【Options…】->【Linker】->【Checksum】
其中1區域設置的是如何填充未使用區域,圖中表示從0xFFFF8004到0xFFFFFFFF區域沒有使用區域填充0xFF。因為0xFFFF8000預留4個字節放置checksum所以這里是0xFFFF8004.
我們的boot的范圍是0xFFFF8004-0xFFFFFFFF。
其中2區域設置的是校驗方式,我們一般使用crc16的校驗方式。
注意一下設置要與代碼中使用的校驗算法一致,我們使用的是CCITT算法,初始值為0.
設置如下圖。


編譯代碼進入仿真模式,我們發現鏡像中已經增加了checksum的值
__checksum表示放置checksum的地址正是我們設置的地址0xFFFF8000
__checksum_begin表示需要計算校驗值區域的開始地址正是我們設置的0xFFFF8004
__checksum_end表示需要計算校驗值區域的結束地址正是我們設置的0xFFFFFFFF
這三個符號是編譯器變量,我們在代碼中可以直接使用
但是要用extern先申明。


如下圖
2.4           校驗代碼
按2.3設置好參數后,我們要有代碼能去計算鏡像的校驗值,用來跟編譯器產生的校驗值去比較。
crc16.c

  1. #include "crc16.h"

  2. /* CRC16 implementation acording to CCITT standards */

  3. static const unsigned short crc16tab[256]= {
  4.     0x0000,0x1021,0x2042,0x3063,0x4084,0x50a5,0x60c6,0x70e7,
  5.     0x8108,0x9129,0xa14a,0xb16b,0xc18c,0xd1ad,0xe1ce,0xf1ef,
  6.     0x1231,0x0210,0x3273,0x2252,0x52b5,0x4294,0x72f7,0x62d6,
  7.     0x9339,0x8318,0xb37b,0xa35a,0xd3bd,0xc39c,0xf3ff,0xe3de,
  8.     0x2462,0x3443,0x0420,0x1401,0x64e6,0x74c7,0x44a4,0x5485,
  9.     0xa56a,0xb54b,0x8528,0x9509,0xe5ee,0xf5cf,0xc5ac,0xd58d,
  10.     0x3653,0x2672,0x1611,0x0630,0x76d7,0x66f6,0x5695,0x46b4,
  11.     0xb75b,0xa77a,0x9719,0x8738,0xf7df,0xe7fe,0xd79d,0xc7bc,
  12.     0x48c4,0x58e5,0x6886,0x78a7,0x0840,0x1861,0x2802,0x3823,
  13.     0xc9cc,0xd9ed,0xe98e,0xf9af,0x8948,0x9969,0xa90a,0xb92b,
  14.     0x5af5,0x4ad4,0x7ab7,0x6a96,0x1a71,0x0a50,0x3a33,0x2a12,
  15.     0xdbfd,0xcbdc,0xfbbf,0xeb9e,0x9b79,0x8b58,0xbb3b,0xab1a,
  16.     0x6ca6,0x7c87,0x4ce4,0x5cc5,0x2c22,0x3c03,0x0c60,0x1c41,
  17.     0xedae,0xfd8f,0xcdec,0xddcd,0xad2a,0xbd0b,0x8d68,0x9d49,
  18.     0x7e97,0x6eb6,0x5ed5,0x4ef4,0x3e13,0x2e32,0x1e51,0x0e70,
  19.     0xff9f,0xefbe,0xdfdd,0xcffc,0xbf1b,0xaf3a,0x9f59,0x8f78,
  20.     0x9188,0x81a9,0xb1ca,0xa1eb,0xd10c,0xc12d,0xf14e,0xe16f,
  21.     0x1080,0x00a1,0x30c2,0x20e3,0x5004,0x4025,0x7046,0x6067,
  22.     0x83b9,0x9398,0xa3fb,0xb3da,0xc33d,0xd31c,0xe37f,0xf35e,
  23.     0x02b1,0x1290,0x22f3,0x32d2,0x4235,0x5214,0x6277,0x7256,
  24.     0xb5ea,0xa5cb,0x95a8,0x8589,0xf56e,0xe54f,0xd52c,0xc50d,
  25.     0x34e2,0x24c3,0x14a0,0x0481,0x7466,0x6447,0x5424,0x4405,
  26.     0xa7db,0xb7fa,0x8799,0x97b8,0xe75f,0xf77e,0xc71d,0xd73c,
  27.     0x26d3,0x36f2,0x0691,0x16b0,0x6657,0x7676,0x4615,0x5634,
  28.     0xd94c,0xc96d,0xf90e,0xe92f,0x99c8,0x89e9,0xb98a,0xa9ab,
  29.     0x5844,0x4865,0x7806,0x6827,0x18c0,0x08e1,0x3882,0x28a3,
  30.     0xcb7d,0xdb5c,0xeb3f,0xfb1e,0x8bf9,0x9bd8,0xabbb,0xbb9a,
  31.     0x4a75,0x5a54,0x6a37,0x7a16,0x0af1,0x1ad0,0x2ab3,0x3a92,
  32.     0xfd2e,0xed0f,0xdd6c,0xcd4d,0xbdaa,0xad8b,0x9de8,0x8dc9,
  33.     0x7c26,0x6c07,0x5c64,0x4c45,0x3ca2,0x2c83,0x1ce0,0x0cc1,
  34.     0xef1f,0xff3e,0xcf5d,0xdf7c,0xaf9b,0xbfba,0x8fd9,0x9ff8,
  35.     0x6e17,0x7e36,0x4e55,0x5e74,0x2e93,0x3eb2,0x0ed1,0x1ef0
  36. };

  37. unsigned short crc16_ccitt(const void *buf, int len)
  38. {
  39.     register int counter;
  40.     register unsigned short crc = 0;
  41.     for( counter = 0; counter < len; counter++)
  42.         crc = (crc<<8) ^ crc16tab[((crc>>8) ^ ((char *)buf)[counter])&0x00FF];
  43.     return crc;
  44. }
復制代碼


codecheck.c

  1. #include "crc16.h"
  2. #include "wsprintf.h"

  3. #define APP_CHECKSUM_ADD       0xFFFC0000
  4. #define APP_CHECKSUM_BEGIN_ADD 0xFFFC0004
  5. #define APP_CHECKSUM_END_ADD   0xFFFF7FFF
  6. #define APP_CHECKSUM_VAL       (*(unsigned short*)0xFFFC0000)

  7. #define BOOT_CHECKSUM_ADD       0xFFFF8000
  8. #define BOOT_CHECKSUM_BEGIN_ADD 0xFFFF8004
  9. #define BOOT_CHECKSUM_END_ADD   0xFFFFFFFF
  10. #define BOOT_CHECKSUM_VAL       (*(unsigned short*)0xFFFF8000)

  11. int checkapp(void)
  12. {
  13. // 校驗值地址
  14. unsigned char* p1 = (unsigned char*)APP_CHECKSUM_BEGIN_ADD;

  15. // 校驗區域長度
  16. unsigned int len2 = ((unsigned char*)APP_CHECKSUM_END_ADD-p1)+1;

  17. // 校驗初始值
  18. unsigned short sum = 0;
  19. if (len2)
  20. {
  21.     sum = crc16_ccitt(p1, len2);
  22. }
  23. //比較值
  24. if (sum == APP_CHECKSUM_VAL)
  25. {
  26.     return 1;
  27. }
  28. wsprintf("boot checksum:%x\r\n",BOOT_CHECKSUM_VAL);
  29. wsprintf("boot calsum:%x\r\n",sum);
  30. return 0;
  31. }

  32. int checkboot(void)
  33. {
  34. // 校驗值地址
  35. unsigned char* p1 = (unsigned char*)BOOT_CHECKSUM_BEGIN_ADD;

  36. // 校驗區域長度
  37. unsigned int len2 = ((unsigned char*)BOOT_CHECKSUM_END_ADD-p1)+1;

  38. // 校驗初始值
  39. unsigned short sum = 0;
  40. if (len2)
  41. {
  42.     sum = crc16_ccitt(p1, len2);
  43. }
  44. //比較值
  45. if (sum == BOOT_CHECKSUM_VAL)
  46. {
  47.     return 1;
  48. }
  49. wsprintf("boot checksum:%x\r\n",BOOT_CHECKSUM_VAL);
  50. wsprintf("boot calsum:%x\r\n",sum);
  51. return 0;
  52. }
復制代碼



三.測試
測試代碼如下
   if(checkboot())
    {
        wsprintf("boot校驗OK\r\n");
    }
    else
    {
        wsprintf("boot校驗失敗\r\n");
}
    if(checkapp())
    {
        wsprintf("應用校驗OK\r\n");
        return 1;
    }
    else
    {
        wsprintf("應用校驗失敗\r\n");
        return 0;
}

輸出結果如下
四.注意
調試過程中如果插入bkp斷點,會改寫鏡像內容,可能會導致checksum不對。
相應的是能的goto main 使能了堆棧監控等功能時都會插入斷點導致校驗不對。

完整的Word格式文檔51黑下載地址:
完備性保證-IAR在程序鏡像中嵌入校驗碼.docx (125.15 KB, 下載次數: 9)



評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:1 發表于 2017-11-9 22:51 | 只看該作者
好資料,51黑有你更精彩!!!
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 5060网一级毛片 | av网站在线免费观看 | 国产免费观看一区 | 欧美精品欧美精品系列 | 欧美成年人 | 亚洲精品一区二区 | 草久视频 | 亚洲在线 | 一区二区三区视频在线观看 | 日韩精品一区二区三区老鸭窝 | 日本理论片好看理论片 | 精品久久一区 | 中文字幕一区二区视频 | 久久精品中文 | 久久亚洲免费 | 亚洲综合在线一区 | 亚洲欧美一区二区三区在线 | 在线视频成人 | 国产欧美一区二区三区另类精品 | 国产一区亚洲 | 美女视频一区二区三区 | 国产在线不卡 | 亚洲精品一区二区 | 看片wwwwwwwwwww | 国产精品视频一区二区三区 | 日韩综合 | 欧美国产精品 | 亚洲精品国产电影 | 亚洲免费在线观看 | 午夜精品一区二区三区在线视频 | 在线免费激情视频 | 亚洲高清在线视频 | 久久精品一区 | 欧美激情亚洲激情 | 国产日韩精品久久 | 狠狠亚洲 | 久久中文字幕电影 | 色综合久 | 911影院 | 一区二区三区亚洲视频 | 久久精品无码一区二区三区 |